Creation of ADO Connection
This commit is contained in:
@ -5,7 +5,6 @@ using Adaptation.Shared.Duplicator;
|
||||
using Adaptation.Shared.Methods;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Collections.ObjectModel;
|
||||
using System.IO;
|
||||
using System.Text.Json;
|
||||
|
||||
@ -16,8 +15,6 @@ public class FileRead : Shared.FileRead, IFileRead
|
||||
|
||||
private long? _TickOffset;
|
||||
private readonly string _URL;
|
||||
private readonly ReadOnlyCollection<string> _CSSLines;
|
||||
private readonly ReadOnlyCollection<string> _FrontMatterLines;
|
||||
|
||||
public FileRead(ISMTP smtp, Dictionary<string, string> fileParameter, string cellInstanceName, int? connectionCount, string cellInstanceConnectionName, FileConnectorConfiguration fileConnectorConfiguration, string equipmentTypeName, string parameterizedModelObjectDefinitionType, IList<ModelObjectParameterDefinition> modelObjectParameters, string equipmentDictionaryName, Dictionary<string, List<long>> dummyRuns, Dictionary<long, List<string>> staticRuns, bool useCyclicalForDescription, bool isEAFHosted) :
|
||||
base(new Description(), false, smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null)
|
||||
@ -31,20 +28,8 @@ public class FileRead : Shared.FileRead, IFileRead
|
||||
throw new Exception(cellInstanceConnectionName);
|
||||
if (!_IsDuplicator)
|
||||
throw new Exception(cellInstanceConnectionName);
|
||||
List<string> cssLines = new();
|
||||
string cellInstanceNamed = string.Concat("CellInstance.", _EquipmentType);
|
||||
_URL = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, $"{cellInstanceNamed}.URL");
|
||||
string cssLinesName = string.Concat("CellInstance.", cellInstanceName, '.', cellInstanceConnectionName, ".CSS.Lines");
|
||||
ModelObjectParameterDefinition[] cssLinesDefinitions = GetProperties(cellInstanceConnectionName, modelObjectParameters, cssLinesName);
|
||||
foreach (ModelObjectParameterDefinition modelObjectParameterDefinition in cssLinesDefinitions)
|
||||
cssLines.Add(modelObjectParameterDefinition.Value);
|
||||
_CSSLines = new(cssLines);
|
||||
List<string> FrontMatterLines = new();
|
||||
string FrontMatterLinesName = string.Concat("CellInstance.", cellInstanceName, '.', cellInstanceConnectionName, ".Front.Matter.Lines");
|
||||
ModelObjectParameterDefinition[] FrontMatterLinesDefinitions = GetProperties(cellInstanceConnectionName, modelObjectParameters, FrontMatterLinesName);
|
||||
foreach (ModelObjectParameterDefinition modelObjectParameterDefinition in FrontMatterLinesDefinitions)
|
||||
FrontMatterLines.Add(modelObjectParameterDefinition.Value);
|
||||
_FrontMatterLines = new(FrontMatterLines);
|
||||
if (_IsEAFHosted)
|
||||
NestExistingFiles(_FileConnectorConfiguration);
|
||||
}
|
||||
@ -124,7 +109,7 @@ public class FileRead : Shared.FileRead, IFileRead
|
||||
results.Item4.Add(_Logistics.FileInfo);
|
||||
else
|
||||
{
|
||||
IProcessData iProcessData = new ProcessData(this, _Logistics, _FileConnectorConfiguration.TargetFileLocation, _URL, _CSSLines, _FrontMatterLines, results.Item4);
|
||||
IProcessData iProcessData = new ProcessData(this, _Logistics, _FileConnectorConfiguration.TargetFileLocation, _URL, results.Item4);
|
||||
if (iProcessData.Details.Count == 0)
|
||||
throw new Exception(string.Concat("B) No Data - ", dateTime.Ticks));
|
||||
results = iProcessData.GetResults(this, _Logistics, results.Item4);
|
||||
|
@ -7,7 +7,6 @@ using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Collections.ObjectModel;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using System.Text.Json;
|
||||
using System.Text.Json.Serialization;
|
||||
|
||||
@ -22,14 +21,16 @@ public class ProcessData : IProcessData
|
||||
|
||||
private readonly ILog _Log;
|
||||
|
||||
public ProcessData(IFileRead fileRead, Logistics logistics, string targetFileLocation, string url, ReadOnlyCollection<string> cssLines, ReadOnlyCollection<string> frontMatterLines, List<FileInfo> fileInfoCollection)
|
||||
public ProcessData(IFileRead fileRead, Logistics logistics, string targetFileLocation, string url, List<FileInfo> fileInfoCollection)
|
||||
{
|
||||
if (fileRead.IsEAFHosted)
|
||||
{ }
|
||||
if (url is null)
|
||||
throw new ArgumentNullException(nameof(url));
|
||||
fileInfoCollection.Clear();
|
||||
_Details = new List<object>();
|
||||
_Log = LogManager.GetLogger(typeof(ProcessData));
|
||||
WriteFiles(fileRead, logistics, url, cssLines, frontMatterLines, targetFileLocation, fileInfoCollection);
|
||||
WriteFiles(fileRead, logistics, targetFileLocation, fileInfoCollection);
|
||||
}
|
||||
|
||||
string IProcessData.GetCurrentReactor(IFileRead fileRead, Logistics logistics, Dictionary<string, string> reactors) =>
|
||||
@ -57,147 +58,101 @@ public class ProcessData : IProcessData
|
||||
return results;
|
||||
}
|
||||
|
||||
private void WriteFiles(IFileRead fileRead, Logistics logistics, string url, ReadOnlyCollection<string> cssLines, ReadOnlyCollection<string> frontMatterLines, string destinationDirectory, List<FileInfo> fileInfoCollection)
|
||||
private void WriteFiles(IFileRead fileRead, Logistics logistics, string destinationDirectory, List<FileInfo> fileInfoCollection)
|
||||
{
|
||||
if (!Directory.Exists(destinationDirectory))
|
||||
_ = Directory.CreateDirectory(destinationDirectory);
|
||||
bool keepRelations = true;
|
||||
const string taskWorkItemType = "Task";
|
||||
string json = File.ReadAllText(logistics.ReportFullPath);
|
||||
string fileNameWithoutExtension = Path.GetFileNameWithoutExtension(logistics.ReportFullPath);
|
||||
WorkItem[]? workItems = JsonSerializer.Deserialize<WorkItem[]>(json);
|
||||
if (workItems is null)
|
||||
throw new Exception(nameof(workItems));
|
||||
_Details.Add(workItems);
|
||||
ReadOnlyDictionary<int, Record> keyValuePairs = GetWorkItems(workItems);
|
||||
WriteFileStructure(destinationDirectory, keyValuePairs);
|
||||
WriteFiles(fileRead, destinationDirectory, fileInfoCollection, fileNameWithoutExtension, keyValuePairs);
|
||||
WriteKanbanFiles(fileRead, url, cssLines, frontMatterLines, fileInfoCollection, destinationDirectory, keyValuePairs);
|
||||
if (!Directory.Exists(destinationDirectory))
|
||||
_ = Directory.CreateDirectory(destinationDirectory);
|
||||
ReadOnlyDictionary<int, Record> keyValuePairs = GetWorkItems(workItems, keepRelations);
|
||||
ReadOnlyCollection<string> bugUserStoryTaskWorkItemTypes = new(new string[] { "Bug", "User Story", "Task" });
|
||||
ReadOnlyDictionary<int, string> collection = MoveCurrentAndGetExpectedDirectories(taskWorkItemType, destinationDirectory, bugUserStoryTaskWorkItemTypes, keyValuePairs);
|
||||
WriteFiles(fileRead, fileInfoCollection, taskWorkItemType, destinationDirectory, keyValuePairs, collection);
|
||||
}
|
||||
|
||||
private static ReadOnlyDictionary<int, Record> GetWorkItems(WorkItem[] workItems)
|
||||
private static ReadOnlyDictionary<int, Record> GetWorkItems(WorkItem[] workItems, bool keepRelations)
|
||||
{
|
||||
ReadOnlyDictionary<int, Record> results;
|
||||
Dictionary<int, WorkItem> keyValuePairs = new();
|
||||
foreach (WorkItem workItem in workItems)
|
||||
keyValuePairs.Add(workItem.Id, workItem);
|
||||
results = GetKeyValuePairs(new(keyValuePairs));
|
||||
results = GetKeyValuePairs(new(keyValuePairs), keepRelations);
|
||||
return results;
|
||||
}
|
||||
|
||||
private static void WriteFileStructure(string destinationDirectory, ReadOnlyDictionary<int, Record> keyValuePairs)
|
||||
private static ReadOnlyDictionary<int, string> MoveCurrentAndGetExpectedDirectories(string taskWorkItemType, string destinationDirectory, ReadOnlyCollection<string> bugUserStoryTaskWorkItemTypes, ReadOnlyDictionary<int, Record> keyValuePairs)
|
||||
{
|
||||
ReadOnlyCollection<string> collection = GetDirectories(destinationDirectory, keyValuePairs);
|
||||
foreach (string directory in collection)
|
||||
ReadOnlyDictionary<int, string> results;
|
||||
string? directory;
|
||||
ReadOnlyDictionary<int, string> collection = GetCurrentDirectories(destinationDirectory, bugUserStoryTaskWorkItemTypes);
|
||||
results = GetExpectedDirectories(taskWorkItemType, destinationDirectory, bugUserStoryTaskWorkItemTypes, keyValuePairs);
|
||||
foreach (KeyValuePair<int, string> keyValuePair in collection)
|
||||
{
|
||||
if (directory.Length > 222)
|
||||
continue;
|
||||
if (!Directory.Exists(directory))
|
||||
_ = Directory.CreateDirectory(directory);
|
||||
if (!results.TryGetValue(keyValuePair.Key, out directory))
|
||||
MoveToUnknown(destinationDirectory, keyValuePair.Key, keyValuePair.Value);
|
||||
else
|
||||
{
|
||||
if (keyValuePair.Value == directory)
|
||||
continue;
|
||||
else
|
||||
MoveToNew(destinationDirectory, keyValuePair.Key, keyValuePair.Value, directory);
|
||||
}
|
||||
}
|
||||
return results;
|
||||
}
|
||||
|
||||
private static void WriteFiles(IFileRead fileRead, string destinationDirectory, List<FileInfo> fileInfoCollection, string fileNameWithoutExtension, ReadOnlyDictionary<int, Record> keyValuePairs)
|
||||
private static FileInfo GetFileInfoAndMaybeWriteFile(string directory, WorkItem workItem)
|
||||
{
|
||||
string old;
|
||||
FileInfo result;
|
||||
string json;
|
||||
string checkFile;
|
||||
json = JsonSerializer.Serialize(workItem, WorkItemSourceGenerationContext.Default.WorkItem);
|
||||
string singletonDirectory = Path.Combine(directory, $"{workItem.Id}");
|
||||
if (!Directory.Exists(singletonDirectory))
|
||||
_ = Directory.CreateDirectory(singletonDirectory);
|
||||
result = new(Path.Combine(singletonDirectory, ".json"));
|
||||
string old = result.Exists ? File.ReadAllText(result.FullName) : string.Empty;
|
||||
if (old != json)
|
||||
File.WriteAllText(result.FullName, json);
|
||||
return result;
|
||||
}
|
||||
|
||||
private static void WriteFiles(IFileRead fileRead, List<FileInfo> fileInfoCollection, string taskWorkItemType, string destinationDirectory, ReadOnlyDictionary<int, Record> keyValuePairs, ReadOnlyDictionary<int, string> collection)
|
||||
{
|
||||
string? directory;
|
||||
FileInfo fileInfo;
|
||||
WorkItem workItem;
|
||||
string singletonDirectory;
|
||||
JsonSerializerOptions jsonSerializerOptions = new() { WriteIndented = true };
|
||||
string rootDirectory = Path.Combine(destinationDirectory, fileNameWithoutExtension);
|
||||
if (string.IsNullOrEmpty(rootDirectory))
|
||||
throw new NullReferenceException(nameof(rootDirectory));
|
||||
Record? parent;
|
||||
foreach (KeyValuePair<int, Record> keyValuePair in keyValuePairs)
|
||||
{
|
||||
workItem = keyValuePair.Value.WorkItem;
|
||||
json = JsonSerializer.Serialize(workItem, jsonSerializerOptions);
|
||||
singletonDirectory = Path.Combine(rootDirectory, workItem.WorkItemType.Replace(" ", "-"), $"{workItem.Id}-{workItem.WorkItemType.Replace(" ", "-")}");
|
||||
if (!Directory.Exists(singletonDirectory))
|
||||
_ = Directory.CreateDirectory(singletonDirectory);
|
||||
checkFile = Path.Combine(singletonDirectory, ".json");
|
||||
if (File.Exists(checkFile))
|
||||
if (!collection.TryGetValue(keyValuePair.Key, out directory))
|
||||
{
|
||||
old = File.ReadAllText(checkFile);
|
||||
if (old == json)
|
||||
if (workItem.WorkItemType != taskWorkItemType || workItem.Parent is not null)
|
||||
continue;
|
||||
directory = GetDirectory(destinationDirectory, workItem);
|
||||
}
|
||||
File.WriteAllText(checkFile, json);
|
||||
fileInfo = GetFileInfoAndMaybeWriteFile(directory, workItem);
|
||||
if (!fileRead.IsEAFHosted)
|
||||
fileInfoCollection.Add(new(checkFile));
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private static void WriteKanbanFiles(IFileRead fileRead, string url, ReadOnlyCollection<string> cssLines, ReadOnlyCollection<string> frontMatterLines, List<FileInfo> fileInfoCollection, string destinationDirectory, ReadOnlyDictionary<int, Record> keyValuePairs)
|
||||
{
|
||||
string old;
|
||||
string json;
|
||||
Record record;
|
||||
string markdown;
|
||||
string checkFile;
|
||||
string jsonDirectory;
|
||||
string tasksDirectory;
|
||||
string kanbanDirectory;
|
||||
string vscodeDirectory;
|
||||
string[] iterationPaths;
|
||||
string singletonDirectory;
|
||||
string iterationPathDirectory;
|
||||
JsonSerializerOptions jsonSerializerOptions = new() { WriteIndented = true };
|
||||
foreach (KeyValuePair<int, Record> keyValuePair in keyValuePairs)
|
||||
{
|
||||
record = keyValuePair.Value;
|
||||
iterationPathDirectory = destinationDirectory;
|
||||
iterationPaths = record.WorkItem.IterationPath.Split('\\');
|
||||
json = JsonSerializer.Serialize(record, jsonSerializerOptions);
|
||||
foreach (string iterationPath in iterationPaths)
|
||||
{
|
||||
if (iterationPath.Contains("Sprint"))
|
||||
continue;
|
||||
iterationPathDirectory = Path.Combine(iterationPathDirectory, iterationPath);
|
||||
}
|
||||
singletonDirectory = Path.Combine(iterationPathDirectory, record.WorkItem.WorkItemType.Replace(" ", "-"), $"{record.WorkItem.Id}-{record.WorkItem.WorkItemType.Replace(" ", "-")}");
|
||||
kanbanDirectory = Path.Combine(singletonDirectory, ".kanbn");
|
||||
if (!Directory.Exists(kanbanDirectory))
|
||||
_ = Directory.CreateDirectory(kanbanDirectory);
|
||||
tasksDirectory = Path.Combine(kanbanDirectory, "tasks");
|
||||
if (!Directory.Exists(tasksDirectory))
|
||||
_ = Directory.CreateDirectory(tasksDirectory);
|
||||
vscodeDirectory = Path.Combine(singletonDirectory, ".vscode");
|
||||
if (!Directory.Exists(vscodeDirectory))
|
||||
_ = Directory.CreateDirectory(vscodeDirectory);
|
||||
jsonDirectory = Path.Combine(singletonDirectory, record.WorkItem.Id.ToString());
|
||||
if (!Directory.Exists(jsonDirectory))
|
||||
_ = Directory.CreateDirectory(jsonDirectory);
|
||||
checkFile = Path.Combine(vscodeDirectory, "settings.json");
|
||||
if (!File.Exists(checkFile))
|
||||
File.WriteAllText(checkFile, "{ \"[markdown]\": { \"editor.wordWrap\": \"off\" }, \"cSpell.words\": [ \"kanbn\" ] }");
|
||||
markdown = GetIndexLines(frontMatterLines, record);
|
||||
checkFile = Path.Combine(kanbanDirectory, "board.css");
|
||||
if (!File.Exists(checkFile))
|
||||
File.WriteAllLines(checkFile, cssLines);
|
||||
checkFile = Path.Combine(kanbanDirectory, "index.md");
|
||||
if (!File.Exists(checkFile))
|
||||
File.WriteAllText(checkFile, markdown);
|
||||
checkFile = Path.Combine(jsonDirectory, ".json");
|
||||
old = File.Exists(checkFile) ? File.ReadAllText(checkFile) : string.Empty;
|
||||
if (old != json)
|
||||
File.WriteAllText(checkFile, json);
|
||||
markdown = GetMarkdownLines(url, record, jsonDirectory, iterationPathDirectory);
|
||||
checkFile = Path.Combine(vscodeDirectory, "markdown.md");
|
||||
old = File.Exists(checkFile) ? File.ReadAllText(checkFile) : string.Empty;
|
||||
if (old != markdown)
|
||||
File.WriteAllText(checkFile, markdown);
|
||||
if (!fileRead.IsEAFHosted)
|
||||
fileInfoCollection.Add(new(checkFile));
|
||||
fileInfoCollection.Add(fileInfo);
|
||||
if (workItem.WorkItemType != taskWorkItemType && workItem.Parent is not null && keyValuePairs.TryGetValue(workItem.Parent.Value, out parent))
|
||||
_ = GetFileInfoAndMaybeWriteFile(Path.Combine(directory, ".parent"), parent.WorkItem);
|
||||
}
|
||||
}
|
||||
|
||||
private static ReadOnlyDictionary<int, Record> GetKeyValuePairs(ReadOnlyDictionary<int, WorkItem> keyValuePairs)
|
||||
private static ReadOnlyDictionary<int, Record> GetKeyValuePairs(ReadOnlyDictionary<int, WorkItem> keyValuePairs, bool keepRelations)
|
||||
{
|
||||
Dictionary<int, Record> results = new();
|
||||
Record record;
|
||||
List<bool> nests = new();
|
||||
WorkItem? parentWorkItem;
|
||||
ReadOnlyCollection<Record> records;
|
||||
ReadOnlyCollection<Record> childRecords;
|
||||
ReadOnlyCollection<Record> relatedRecords;
|
||||
ReadOnlyCollection<Record> successorRecords;
|
||||
foreach (KeyValuePair<int, WorkItem> keyValuePair in keyValuePairs)
|
||||
{
|
||||
nests.Clear();
|
||||
@ -207,166 +162,111 @@ public class ProcessData : IProcessData
|
||||
_ = keyValuePairs.TryGetValue(keyValuePair.Value.Parent.Value, out parentWorkItem);
|
||||
try
|
||||
{
|
||||
records = GetKeyValuePairs(keyValuePairs, keyValuePair.Value, nests);
|
||||
record = Record.Get(keyValuePair.Value, parentWorkItem, records);
|
||||
childRecords = Record.GetKeyValuePairs(keyValuePairs, keyValuePair.Value, "Child", nests, keepRelations); // Forward
|
||||
// records = Record.GetKeyValuePairs(keyValuePairs, keyValuePair.Value, "Predecessor", nests, keepRelations); // Reverse
|
||||
relatedRecords = Record.GetKeyValuePairs(keyValuePairs, keyValuePair.Value, "Related", nests, keepRelations); // Related
|
||||
successorRecords = Record.GetKeyValuePairs(keyValuePairs, keyValuePair.Value, "Successor", nests, keepRelations); // Forward
|
||||
record = Record.Get(keyValuePair.Value, parentWorkItem, childRecords, relatedRecords, successorRecords, keepRelations);
|
||||
}
|
||||
catch (Exception)
|
||||
{
|
||||
record = new(keyValuePair.Value, parentWorkItem, Array.Empty<Record>());
|
||||
record = new(keyValuePair.Value, parentWorkItem, Array.Empty<Record>(), Array.Empty<Record>(), Array.Empty<Record>());
|
||||
}
|
||||
results.Add(keyValuePair.Key, record);
|
||||
}
|
||||
return new(results);
|
||||
}
|
||||
|
||||
private static ReadOnlyCollection<string> GetDirectories(string destinationDirectory, ReadOnlyDictionary<int, Record> keyValuePairs)
|
||||
private static ReadOnlyDictionary<int, string> GetCurrentDirectories(string destinationDirectory, ReadOnlyCollection<string> bugUserStoryTaskWorkItemTypes)
|
||||
{
|
||||
List<string> results = new();
|
||||
Record record;
|
||||
Dictionary<int, string> results = new();
|
||||
int id;
|
||||
string idCheck;
|
||||
string? fileName;
|
||||
string[] directories;
|
||||
string[] split = new string[] { "-" };
|
||||
foreach (string w in bugUserStoryTaskWorkItemTypes)
|
||||
{
|
||||
directories = Directory.GetDirectories(destinationDirectory, $"*-{w.Replace(" ", "-")}", SearchOption.AllDirectories);
|
||||
foreach (string directory in directories)
|
||||
{
|
||||
fileName = Path.GetFileName(directory);
|
||||
if (string.IsNullOrEmpty(fileName))
|
||||
continue;
|
||||
idCheck = fileName.Split(split, StringSplitOptions.None)[0];
|
||||
if (!int.TryParse(idCheck, out id))
|
||||
continue;
|
||||
if (!results.ContainsKey(id))
|
||||
results.Add(id, directory);
|
||||
else
|
||||
MoveToDuplicate(destinationDirectory, directory);
|
||||
}
|
||||
}
|
||||
return new(results);
|
||||
}
|
||||
|
||||
private static ReadOnlyDictionary<int, string> GetExpectedDirectories(string taskWorkItemType, string destinationDirectory, ReadOnlyCollection<string> bugUserStoryTaskWorkItemTypes, ReadOnlyDictionary<int, Record> keyValuePairs)
|
||||
{
|
||||
Dictionary<int, string> results = new();
|
||||
string directory;
|
||||
List<bool> nests = new();
|
||||
ReadOnlyCollection<string> childrenDirectories;
|
||||
string dateDirectory = Path.Combine(destinationDirectory, "_", DateTime.Now.ToString("yyyy-MM-dd"));
|
||||
WorkItem workItem;
|
||||
foreach (KeyValuePair<int, Record> keyValuePair in keyValuePairs)
|
||||
{
|
||||
record = keyValuePair.Value;
|
||||
if (record.Parent is not null && (record.WorkItem.Parent is null || record.Parent.Id != record.WorkItem.Parent.Value))
|
||||
workItem = keyValuePair.Value.WorkItem;
|
||||
if (!bugUserStoryTaskWorkItemTypes.Contains(workItem.WorkItemType))
|
||||
continue;
|
||||
if (record.Parent is not null)
|
||||
if (workItem.WorkItemType == taskWorkItemType && workItem.Parent is not null)
|
||||
continue;
|
||||
// if (record.WorkItem.Id == 110730)
|
||||
// continue;
|
||||
// if (record.WorkItem.Id == 110732)
|
||||
// continue;
|
||||
nests.Clear();
|
||||
directory = Path.Combine(dateDirectory, $"{record.WorkItem.WorkItemType.Substring(0, 1)}-{record.WorkItem.Id}-{record.WorkItem.Title.Trim().Substring(0, 1)}");
|
||||
childrenDirectories = GetChildrenDirectories(keyValuePairs, nests, directory, record);
|
||||
results.AddRange(childrenDirectories);
|
||||
}
|
||||
return new(results.Distinct().ToArray());
|
||||
}
|
||||
|
||||
private static string GetIndexLines(ReadOnlyCollection<string> frontMatterLines, Record record)
|
||||
{
|
||||
List<string> results = new();
|
||||
results.Clear();
|
||||
results.AddRange(frontMatterLines);
|
||||
results.Add(string.Empty);
|
||||
results.Add($"# {record.WorkItem.Id}");
|
||||
results.Add(string.Empty);
|
||||
results.Add("## Backlog");
|
||||
results.Add(string.Empty);
|
||||
results.Add("## Todo");
|
||||
results.Add(string.Empty);
|
||||
results.Add("## In Progress");
|
||||
results.Add(string.Empty);
|
||||
results.Add("## Done");
|
||||
results.Add(string.Empty);
|
||||
return string.Join(Environment.NewLine, results);
|
||||
}
|
||||
|
||||
private static string GetMarkdownLines(string url, Record record, string jsonDirectory, string iterationPathDirectory)
|
||||
{
|
||||
List<string> results = new();
|
||||
string link;
|
||||
string target;
|
||||
results.Add($"# {record.WorkItem.Id}");
|
||||
results.Add(string.Empty);
|
||||
results.Add($"## {record.WorkItem.Title}");
|
||||
results.Add(string.Empty);
|
||||
foreach (Record r in record.Children)
|
||||
results.Add($"- [{r.WorkItem.Id}]({url}{r.WorkItem.Id})");
|
||||
results.Add(string.Empty);
|
||||
results.Add("```bash");
|
||||
foreach (Record r in record.Children)
|
||||
{
|
||||
link = Path.Combine(jsonDirectory, $"{r.WorkItem.Id}-{r.WorkItem.WorkItemType}");
|
||||
target = Path.Combine(iterationPathDirectory, r.WorkItem.WorkItemType, $"{r.WorkItem.Id}-{r.WorkItem.WorkItemType}", r.WorkItem.Id.ToString());
|
||||
results.Add($"mklink /J \"{link}\" \"{target}\"");
|
||||
}
|
||||
results.Add("```");
|
||||
results.Add(string.Empty);
|
||||
return string.Join(Environment.NewLine, results);
|
||||
}
|
||||
|
||||
private static ReadOnlyCollection<Record> GetKeyValuePairs(ReadOnlyDictionary<int, WorkItem> keyValuePairs, WorkItem workItem, List<bool> nests)
|
||||
{
|
||||
List<Record> results = new();
|
||||
int? childId;
|
||||
Record record;
|
||||
nests.Add(true);
|
||||
WorkItem? childWorkItem;
|
||||
WorkItem? parentWorkItem;
|
||||
List<WorkItem> collection = new();
|
||||
ReadOnlyCollection<Record> records;
|
||||
if (workItem.Relations is not null && workItem.Relations.Length > 0)
|
||||
{
|
||||
collection.Clear();
|
||||
foreach (Relation relation in workItem.Relations)
|
||||
{
|
||||
childId = GetIdFromUrlIfChild(relation);
|
||||
if (childId is not null && workItem.Parent is not null && relation?.URL is not null && relation.URL.Contains(workItem.Parent.Value.ToString()))
|
||||
continue;
|
||||
if (childId is null || !keyValuePairs.TryGetValue(childId.Value, out childWorkItem))
|
||||
continue;
|
||||
collection.Add(childWorkItem);
|
||||
}
|
||||
collection = (from l in collection orderby l.State != "Closed", l.Id select l).ToList();
|
||||
foreach (WorkItem w in collection)
|
||||
{
|
||||
if (nests.Count > 99)
|
||||
break;
|
||||
if (w.Parent is null)
|
||||
parentWorkItem = null;
|
||||
else
|
||||
_ = keyValuePairs.TryGetValue(w.Parent.Value, out parentWorkItem);
|
||||
records = GetKeyValuePairs(keyValuePairs, w, nests);
|
||||
record = Record.Get(w, parentWorkItem, records);
|
||||
results.Add(record);
|
||||
}
|
||||
directory = GetDirectory(destinationDirectory, workItem);
|
||||
results.Add(workItem.Id, directory);
|
||||
}
|
||||
return new(results);
|
||||
}
|
||||
|
||||
private static ReadOnlyCollection<string> GetChildrenDirectories(ReadOnlyDictionary<int, Record> keyValuePairs, List<bool> nests, string parentDirectory, Record record)
|
||||
private static void MoveToUnknown(string destinationDirectory, int id, string directory)
|
||||
{
|
||||
List<string> results = new();
|
||||
nests.Add(true);
|
||||
string directory;
|
||||
Record? childRecord;
|
||||
ReadOnlyCollection<string> childrenDirectories;
|
||||
foreach (Record r in record.Children)
|
||||
{
|
||||
// if (record.WorkItem.Id == 110730)
|
||||
// continue;
|
||||
// if (record.WorkItem.Id == 110732)
|
||||
// continue;
|
||||
directory = Path.Combine(parentDirectory, $"{r.WorkItem.WorkItemType.Substring(0, 1)}-{r.WorkItem.Id}-{r.WorkItem.Title.Trim().Substring(0, 1)}");
|
||||
results.Add(directory);
|
||||
if (!keyValuePairs.TryGetValue(r.WorkItem.Id, out childRecord))
|
||||
continue;
|
||||
if (nests.Count > 99)
|
||||
break;
|
||||
childrenDirectories = GetChildrenDirectories(keyValuePairs, nests, directory, childRecord);
|
||||
results.AddRange(childrenDirectories);
|
||||
}
|
||||
return new(results);
|
||||
if (string.IsNullOrEmpty(destinationDirectory))
|
||||
throw new ArgumentException($"'{nameof(destinationDirectory)}' {id} cannot be null or empty.", nameof(destinationDirectory));
|
||||
if (string.IsNullOrEmpty(directory))
|
||||
throw new ArgumentException($"'{nameof(directory)}' cannot be null or empty.", nameof(directory));
|
||||
}
|
||||
|
||||
private static int? GetIdFromUrlIfChild(Relation relation)
|
||||
private static void MoveToNew(string destinationDirectory, int id, string oldDirectory, string newDirectory)
|
||||
{
|
||||
int? result;
|
||||
string[] segments = relation?.Attributes is null || relation.Attributes.Name != "Child" ? Array.Empty<string>() : relation.URL.Split('/');
|
||||
if (segments.Length < 2)
|
||||
result = null;
|
||||
if (Directory.Exists(newDirectory))
|
||||
MoveToDuplicate(destinationDirectory, id, oldDirectory);
|
||||
else
|
||||
{
|
||||
if (!int.TryParse(segments[segments.Length - 1], out int id))
|
||||
result = null;
|
||||
else
|
||||
result = id;
|
||||
string directory = Path.GetDirectoryName(newDirectory) ?? throw new NotImplementedException();
|
||||
if (!Directory.Exists(directory))
|
||||
_ = Directory.CreateDirectory(directory);
|
||||
Directory.Move(oldDirectory, newDirectory);
|
||||
}
|
||||
}
|
||||
|
||||
private static string GetDirectory(string destinationDirectory, WorkItem workItem)
|
||||
{
|
||||
string result;
|
||||
string workItemType = workItem.WorkItemType.Replace(" ", "-");
|
||||
string iterationPath = workItem.IterationPath.Replace(" ", "-");
|
||||
result = Path.Combine(destinationDirectory, iterationPath, $"{workItem.Id}-{workItemType}");
|
||||
return result;
|
||||
}
|
||||
|
||||
private static void MoveToDuplicate(string destinationDirectory, string directory)
|
||||
{
|
||||
if (string.IsNullOrEmpty(destinationDirectory))
|
||||
throw new ArgumentException($"'{nameof(destinationDirectory)}' cannot be null or empty.", nameof(destinationDirectory));
|
||||
if (string.IsNullOrEmpty(directory))
|
||||
throw new ArgumentException($"'{nameof(directory)}' cannot be null or empty.", nameof(directory));
|
||||
}
|
||||
|
||||
private static void MoveToDuplicate(string destinationDirectory, int id, string oldDirectory)
|
||||
{
|
||||
if (string.IsNullOrEmpty(destinationDirectory))
|
||||
throw new ArgumentException($"'{nameof(destinationDirectory)}' {id} cannot be null or empty.", nameof(destinationDirectory));
|
||||
if (string.IsNullOrEmpty(oldDirectory))
|
||||
throw new ArgumentException($"'{nameof(oldDirectory)}' cannot be null or empty.", nameof(oldDirectory));
|
||||
}
|
||||
|
||||
}
|
Reference in New Issue
Block a user