83 lines
3.2 KiB
C#
83 lines
3.2 KiB
C#
using StructureHelperCommon.Infrastructures.Interfaces;
|
|
using StructureHelperCommon.Models;
|
|
using StructureHelperCommon.Models.Analyses;
|
|
using StructureHelperCommon.Models.Loggers;
|
|
using StructureHelperCommon.Models.Projects;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using System.Threading.Tasks;
|
|
|
|
namespace DataAccess.DTOs
|
|
{
|
|
public class ProjectFromDTOConvertStrategy : IConvertStrategy<Project, ProjectDTO>
|
|
{
|
|
private IUpdateStrategy<IProject> updateStrategy;
|
|
private IConvertStrategy<IVisualAnalysis, IVisualAnalysis> visualAnalysisConvertStrategy = new VisualAnaysisFromDTOConvertStrategy();
|
|
|
|
public ProjectFromDTOConvertStrategy(IUpdateStrategy<IProject> updateStrategy)
|
|
{
|
|
this.updateStrategy = updateStrategy;
|
|
}
|
|
|
|
public ProjectFromDTOConvertStrategy() : this (new ProjectUpdateStrategy())
|
|
{
|
|
|
|
}
|
|
|
|
public Dictionary<(Guid id, Type type), ISaveable> ReferenceDictionary { get; set; }
|
|
public IShiftTraceLogger TraceLogger { get; set; }
|
|
|
|
public Project Convert(ProjectDTO source)
|
|
{
|
|
Check();
|
|
TraceLogger?.AddMessage("Converting project is started", TraceLogStatuses.Info);
|
|
try
|
|
{
|
|
Project newItem = GetProject(source);
|
|
return newItem;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
TraceLogger?.AddMessage(LoggerStrings.LogicType(this), TraceLogStatuses.Error);
|
|
TraceLogger?.AddMessage(ex.Message, TraceLogStatuses.Error);
|
|
throw;
|
|
}
|
|
}
|
|
|
|
private Project GetProject(ProjectDTO source)
|
|
{
|
|
TraceLogger?.AddMessage("Converting of project is started", TraceLogStatuses.Service);
|
|
Project newItem = new();
|
|
updateStrategy.Update(newItem, source);
|
|
visualAnalysisConvertStrategy.ReferenceDictionary = ReferenceDictionary;
|
|
visualAnalysisConvertStrategy.TraceLogger = TraceLogger;
|
|
var convertLogic = new DictionaryConvertStrategy<IVisualAnalysis, IVisualAnalysis>(this, visualAnalysisConvertStrategy);
|
|
newItem.VisualAnalyses.Clear();
|
|
TraceLogger?.AddMessage($"Source project has {source.VisualAnalyses.Count()} analyses", TraceLogStatuses.Service);
|
|
foreach (var item in source.VisualAnalyses)
|
|
{
|
|
var visualAnalysis = convertLogic.Convert(item);
|
|
newItem.VisualAnalyses.Add(visualAnalysis);
|
|
}
|
|
if (newItem.VisualAnalyses.Any())
|
|
{
|
|
TraceLogger?.AddMessage($"Totaly {newItem.VisualAnalyses.Count()} were(was) obtained", TraceLogStatuses.Service);
|
|
}
|
|
else
|
|
{
|
|
TraceLogger?.AddMessage($"Project does not have any analyses", TraceLogStatuses.Warning);
|
|
}
|
|
TraceLogger?.AddMessage("Converting of project has completed succesfully", TraceLogStatuses.Service);
|
|
return newItem;
|
|
}
|
|
|
|
private void Check()
|
|
{
|
|
var checkLogic = new CheckConvertLogic<Project, ProjectDTO>(this);
|
|
checkLogic.Check();
|
|
}
|
|
}
|
|
}
|