| | | 1 | | using System.Collections.Generic; |
| | | 2 | | using System.Linq; |
| | | 3 | | using System.Threading.Tasks; |
| | | 4 | | using Microsoft.EntityFrameworkCore; |
| | | 5 | | using Microsoft.Extensions.Logging; |
| | | 6 | | using WinSolutions.Sveta.Server.Data.DataModel.Contexts; |
| | | 7 | | using WinSolutions.Sveta.Server.Data.DataModel.Entities; |
| | | 8 | | using WinSolutions.Sveta.Server.Data.DataModel.Kinds; |
| | | 9 | | using WinSolutions.Sveta.Server.Domain; |
| | | 10 | | using WinSolutions.Sveta.Server.Services.Interfaces; |
| | | 11 | | using WinSolutions.Sveta.Common; |
| | | 12 | | using System; |
| | | 13 | | using Org.BouncyCastle.Math.EC.Rfc7748; |
| | | 14 | | |
| | | 15 | | namespace WinSolutions.Sveta.Server.Services.Implements |
| | | 16 | | { |
| | | 17 | | public class ConfigurationService : SvetaServiceBase, IConfigurationService |
| | | 18 | | { |
| | | 19 | | private readonly SvetaDbContext _db; |
| | | 20 | | private readonly ILogger<ConfigurationService> _logger; |
| | | 21 | | |
| | | 22 | | public ConfigurationService(SvetaDbContext db, ILogger<ConfigurationService> logger, IAuthenticationService auth |
| | 2 | 23 | | : base(authenticationService) |
| | 2 | 24 | | { |
| | 2 | 25 | | _db = db; |
| | 2 | 26 | | _logger = logger; |
| | 2 | 27 | | } |
| | | 28 | | |
| | | 29 | | /// <summary> |
| | | 30 | | /// предварительная выборка конфигураций |
| | | 31 | | /// </summary> |
| | | 32 | | /// <returns></returns> |
| | 11 | 33 | | private IQueryable<Configuration> PrepareConfigurations() => _db.sysConfigurations |
| | 11 | 34 | | .Include(x=>x.ValueType) |
| | 11 | 35 | | .Where(x => !x.IsDeleted).AsQueryable(); |
| | | 36 | | |
| | | 37 | | /// <summary> |
| | | 38 | | /// получить конфигурацию по id |
| | | 39 | | /// </summary> |
| | | 40 | | /// <param name="confId">id конфигурации</param> |
| | | 41 | | /// <returns></returns> |
| | 3 | 42 | | public async Task<Configuration> GetConfiguration(long confId) => await PrepareConfigurations().FirstOrDefaultAs |
| | | 43 | | |
| | | 44 | | /// <summary> |
| | | 45 | | /// получить конфигурацию по названию секции и ключа |
| | | 46 | | /// </summary> |
| | | 47 | | /// <param name="section">название секции</param> |
| | | 48 | | /// <param name="key">название ключа</param> |
| | | 49 | | /// <returns></returns> |
| | 2 | 50 | | public async Task<Configuration> GetConfiguration(string section, string key) => await PrepareConfigurations() |
| | 2 | 51 | | .FirstOrDefaultAsync(x=>x.Section == section && x.Key == key); |
| | | 52 | | |
| | | 53 | | /// <summary> |
| | | 54 | | /// получить конфигурации с пагинацией |
| | | 55 | | /// </summary> |
| | | 56 | | /// <param name="page">номер страницы</param> |
| | | 57 | | /// <param name="limit">размер страницы</param> |
| | | 58 | | /// <param name="filter">фильтр (секция, ключ, тип значения, значение)</param> |
| | | 59 | | /// <param name="sort">сортировка</param> |
| | | 60 | | /// <param name="encrypted">выводить только зашифрованные записи</param> |
| | | 61 | | /// <returns></returns> |
| | | 62 | | public async Task<PaginatedData<List<Configuration>>> GetConfigurations(int page, int limit, string filter, stri |
| | 3 | 63 | | { |
| | 3 | 64 | | var confs = PrepareConfigurations().AsNoTracking(); |
| | 3 | 65 | | int total = await confs?.CountAsync(); |
| | 3 | 66 | | confs = confs.Where(x=> !encrypted || x.Encrypted) |
| | 3 | 67 | | .Where(x => string.IsNullOrWhiteSpace(filter) || x.Section.ToUpper().Contains(filter.ToUpper()) || x.Key |
| | 3 | 68 | | || x.ValueType.Name.ToUpper().Contains(filter.ToUpper()) || x.Value.ToUpper().Contains(filter.ToUpper()) |
| | 3 | 69 | | int totalFiltered = await confs?.CountAsync(); |
| | 3 | 70 | | confs = Sort(confs, sort?.ToLower()); |
| | 3 | 71 | | return new PaginatedData<List<Configuration>> |
| | 3 | 72 | | { |
| | 3 | 73 | | Result = await confs.Skip(page * limit).Take(limit).ToListAsync(), |
| | 3 | 74 | | TotalCount = total, |
| | 3 | 75 | | TotalFilteredCount = totalFiltered |
| | 3 | 76 | | }; |
| | 3 | 77 | | } |
| | | 78 | | |
| | | 79 | | /// <summary> |
| | | 80 | | /// создать конфигурацию |
| | | 81 | | /// </summary> |
| | | 82 | | /// <param name="data">конф-ция</param> |
| | | 83 | | /// <returns></returns> |
| | | 84 | | public async Task CreateConfiguration(Configuration data) |
| | 7 | 85 | | { |
| | 7 | 86 | | await _db.sysConfigurations.AddAsync(data); |
| | 7 | 87 | | await _db.SaveChangesAsync(CurrentUserId); |
| | 7 | 88 | | } |
| | | 89 | | |
| | | 90 | | /// <summary> |
| | | 91 | | /// обновить конфигурацию |
| | | 92 | | /// </summary> |
| | | 93 | | /// <param name="data">конф-ция</param> |
| | | 94 | | /// <returns></returns> |
| | | 95 | | public async Task UpdateConfiguration(Configuration data) |
| | 1 | 96 | | { |
| | 1 | 97 | | if (!(await ConfigurationExists(data.Id))) |
| | 0 | 98 | | { |
| | 0 | 99 | | throw new ArgumentException($"Конфигурация с id={data.Id} не найдена"); |
| | | 100 | | } |
| | 1 | 101 | | _db.sysConfigurations.Update(data); |
| | 1 | 102 | | await _db.SaveChangesAsync(CurrentUserId); |
| | 1 | 103 | | } |
| | | 104 | | |
| | | 105 | | /// <summary> |
| | | 106 | | /// удалить конфигурацию |
| | | 107 | | /// </summary> |
| | | 108 | | /// <param name="data">конф-ция</param> |
| | | 109 | | /// <returns></returns> |
| | | 110 | | public async Task DeleteConfiguration(long id) |
| | 1 | 111 | | { |
| | 1 | 112 | | Configuration rec = await _db.sysConfigurations.FindAsync(id); |
| | 1 | 113 | | if (rec == null) |
| | 0 | 114 | | throw new KeyNotFoundException($"Конфигурация с id={id} не найдена"); |
| | 1 | 115 | | rec.IsDeleted = true; |
| | 1 | 116 | | await _db.SaveChangesAsync(CurrentUserId); |
| | 1 | 117 | | } |
| | | 118 | | |
| | | 119 | | /// <summary> |
| | | 120 | | /// проверяет существование конф-ции |
| | | 121 | | /// </summary> |
| | | 122 | | /// <param name="confId">id конф-ции</param> |
| | | 123 | | /// <returns></returns> |
| | 3 | 124 | | public async Task<bool> ConfigurationExists(long confId) => await PrepareConfigurations().AsNoTracking().AnyAsyn |
| | | 125 | | |
| | | 126 | | /// <summary> |
| | | 127 | | /// сортировка |
| | | 128 | | /// </summary> |
| | | 129 | | /// <param name="items">конф-ции</param> |
| | | 130 | | /// <param name="sort">тип сортировки</param> |
| | | 131 | | /// <returns></returns> |
| | 3 | 132 | | private IQueryable<Configuration> Sort(IQueryable<Configuration> items, string sort = default) => (sort ?? "").T |
| | 3 | 133 | | { |
| | 3 | 134 | | "key|desc" => items.OrderByDescending(d => d.Key), |
| | 3 | 135 | | "section" => items.OrderBy(d => d.Section), |
| | 3 | 136 | | "section|desc" => items.OrderByDescending(d => d.Section), |
| | 3 | 137 | | "valuetype" => items.OrderBy(d => d.ValueType.Name), |
| | 3 | 138 | | "valuetype|desc" => items.OrderByDescending(d => d.ValueType.Name), |
| | 3 | 139 | | _ => items.OrderBy(d => d.Key) |
| | 3 | 140 | | }; |
| | | 141 | | |
| | | 142 | | /// <summary> |
| | | 143 | | /// получает типы значений |
| | | 144 | | /// </summary> |
| | | 145 | | /// <param name="typeId">id типа.0 если все выводить</param> |
| | | 146 | | /// <param name="filter">фильтр по названию</param> |
| | | 147 | | /// <returns></returns> |
| | | 148 | | public async Task<List<ConfigurationsDataType>> GetDataTypes(long typeId, string filter = null) |
| | 2 | 149 | | { |
| | 2 | 150 | | var data = _db.ConfigurationsDataTypes |
| | 2 | 151 | | .AsNoTracking() |
| | 2 | 152 | | .Where(x => typeId == 0 || x.Id == typeId) |
| | 2 | 153 | | .Where(x => string.IsNullOrWhiteSpace(filter) || x.Name.ToLower().Contains(filter.ToLower())) |
| | 2 | 154 | | .Where(d => !d.IsDeleted); |
| | 2 | 155 | | return await data.ToListAsync(); |
| | 2 | 156 | | } |
| | | 157 | | |
| | | 158 | | /// <summary> |
| | | 159 | | /// получить тип значения |
| | | 160 | | /// </summary> |
| | | 161 | | /// <param name="id">id значения</param> |
| | | 162 | | /// <returns></returns> |
| | 1 | 163 | | public async Task<ConfigurationsDataType> GetDataType(long id) => await _db.ConfigurationsDataTypes |
| | 1 | 164 | | .Where(d => !d.IsDeleted && d.Id == id).FirstOrDefaultAsync(); |
| | | 165 | | |
| | | 166 | | /// <summary> |
| | | 167 | | /// получить кол-во конфигураций |
| | | 168 | | /// </summary> |
| | | 169 | | /// <returns></returns> |
| | 1 | 170 | | public async Task<int> GetCountConfTypes() => await _db.ConfigurationsDataTypes.CountAsync(); |
| | | 171 | | } |
| | | 172 | | } |