| | | 1 | | using pva.SuperV.Api.Exceptions; |
| | | 2 | | using pva.SuperV.Api.Mappers; |
| | | 3 | | using pva.SuperV.Engine; |
| | | 4 | | using pva.SuperV.Model; |
| | | 5 | | using pva.SuperV.Model.Classes; |
| | | 6 | | using pva.SuperV.Model.Services; |
| | | 7 | | |
| | | 8 | | namespace pva.SuperV.Api.Services.Classes |
| | | 9 | | { |
| | | 10 | | public class ClassService : BaseService, IClassService |
| | | 11 | | { |
| | | 12 | | private readonly ILogger logger; |
| | 12 | 13 | | private readonly Dictionary<string, Comparison<ClassModel>> sortOptions = new() |
| | 12 | 14 | | { |
| | 88 | 15 | | { "name", new Comparison<ClassModel>((a, b) => a.Name.CompareTo(b.Name)) } |
| | 12 | 16 | | }; |
| | | 17 | | |
| | | 18 | | |
| | 12 | 19 | | public ClassService(ILoggerFactory loggerFactory) |
| | 12 | 20 | | { |
| | 12 | 21 | | logger = loggerFactory.CreateLogger(this.GetType()); |
| | 12 | 22 | | } |
| | | 23 | | |
| | | 24 | | public async Task<List<ClassModel>> GetClassesAsync(string projectId) |
| | 12 | 25 | | { |
| | 12 | 26 | | logger.LogDebug("Getting classes for project {ProjectId}", projectId); |
| | 12 | 27 | | Project project = GetProjectEntity(projectId); |
| | 127 | 28 | | return await Task.FromResult(project.Classes.Values.Select(clazz => ClassMapper.ToDto(clazz)).ToList()); |
| | 12 | 29 | | } |
| | | 30 | | |
| | | 31 | | public async Task<PagedSearchResult<ClassModel>> SearchClassesAsync(string projectId, ClassPagedSearchRequest se |
| | 10 | 32 | | { |
| | 10 | 33 | | logger.LogDebug("Searching classes for project {ProjectId} with filter {NameFilter} page number {PageNumber} |
| | 10 | 34 | | projectId, search.NameFilter, search.PageNumber, search.PageSize); |
| | 10 | 35 | | List<ClassModel> allClasses = await GetClassesAsync(projectId); |
| | 10 | 36 | | List<ClassModel> projects = FilterClasses(allClasses, search); |
| | 10 | 37 | | projects = SortResult(projects, search.SortOption, sortOptions); |
| | 9 | 38 | | return CreateResult(search, allClasses, projects); |
| | 9 | 39 | | } |
| | | 40 | | |
| | | 41 | | public Task<ClassModel> GetClassAsync(string projectId, string className) |
| | 2 | 42 | | { |
| | 2 | 43 | | logger.LogDebug("Getting class {ClassName} for project {ProjectId}", |
| | 2 | 44 | | className, projectId); |
| | 2 | 45 | | return Task.FromResult(ClassMapper.ToDto(GetClassEntity(projectId, className))); |
| | 1 | 46 | | } |
| | | 47 | | |
| | | 48 | | public Task<ClassModel> CreateClassAsync(string projectId, ClassModel createRequest) |
| | 4 | 49 | | { |
| | 4 | 50 | | logger.LogDebug("Creating class {ClassName} with base class {BaseClassName} for project {ProjectId}", |
| | 4 | 51 | | createRequest.Name, createRequest.BaseClassName, projectId); |
| | 4 | 52 | | if (GetProjectEntity(projectId) is WipProject wipProject) |
| | 4 | 53 | | { |
| | 4 | 54 | | return Task.FromResult(ClassMapper.ToDto(wipProject.AddClass(createRequest!.Name, createRequest!.BaseCla |
| | | 55 | | } |
| | 0 | 56 | | return Task.FromException<ClassModel>(new NonWipProjectException(projectId)); |
| | 4 | 57 | | } |
| | | 58 | | |
| | | 59 | | public Task<ClassModel> UpdateClassAsync(string projectId, string className, ClassModel updateRequest) |
| | 1 | 60 | | { |
| | 1 | 61 | | logger.LogDebug("Updating class {ClassName} with base class {BaseClassName} for project {ProjectId}", |
| | 1 | 62 | | updateRequest.Name, updateRequest.BaseClassName, projectId); |
| | 1 | 63 | | if (GetProjectEntity(projectId) is WipProject wipProject) |
| | 1 | 64 | | { |
| | 1 | 65 | | if (updateRequest.Name?.Equals(className) != false) |
| | 1 | 66 | | { |
| | 1 | 67 | | return Task.FromResult(ClassMapper.ToDto(wipProject.UpdateClass(className, updateRequest!.BaseClassN |
| | | 68 | | } |
| | 0 | 69 | | return Task.FromException<ClassModel>(new EntityPropertyNotChangeableException("class", "Name")); |
| | | 70 | | } |
| | 0 | 71 | | return Task.FromException<ClassModel>(new NonWipProjectException(projectId)); |
| | 1 | 72 | | } |
| | | 73 | | |
| | | 74 | | public ValueTask DeleteClassAsync(string projectId, string className) |
| | 1 | 75 | | { |
| | 1 | 76 | | logger.LogDebug("Deleting class {ClassName} for project {ProjectId}", |
| | 1 | 77 | | className, projectId); |
| | 1 | 78 | | if (GetProjectEntity(projectId) is WipProject wipProject) |
| | 1 | 79 | | { |
| | 1 | 80 | | wipProject.RemoveClass(className); |
| | 1 | 81 | | return ValueTask.CompletedTask; |
| | | 82 | | } |
| | 0 | 83 | | return ValueTask.FromException(new NonWipProjectException(projectId)); |
| | 1 | 84 | | } |
| | | 85 | | private static List<ClassModel> FilterClasses(List<ClassModel> allClasses, ClassPagedSearchRequest search) |
| | 10 | 86 | | { |
| | 10 | 87 | | List<ClassModel> filteredClasses = allClasses; |
| | 10 | 88 | | if (!String.IsNullOrEmpty(search.NameFilter)) |
| | 3 | 89 | | { |
| | 23 | 90 | | filteredClasses = [.. filteredClasses.Where(clazz => clazz.Name.Contains(search.NameFilter))]; |
| | 3 | 91 | | } |
| | 10 | 92 | | return filteredClasses; |
| | 10 | 93 | | } |
| | | 94 | | } |
| | | 95 | | } |
| | | 96 | | |