- Update endpoint now returns CatalogReadDto or NotFound - Replace UpdateWithStoredProcedure with Upsert endpoint (PUT /upsert) - Rename AddAsync to InsertAsync; UpdateAsync returns DTO or null - Introduce UpsertAsync for combined insert/update logic - Remove stored procedure-specific update/delete methods - Use DTOs consistently in controller/service responses - Repository methods now return entities instead of booleans
81 lines
2.8 KiB
C#
81 lines
2.8 KiB
C#
using AutoMapper;
|
|
using DbFirst.Domain.Repositories;
|
|
using DbFirst.Domain.Entities;
|
|
|
|
namespace DbFirst.Application.Catalogs;
|
|
|
|
public class CatalogService : ICatalogService
|
|
{
|
|
private readonly ICatalogRepository _repository;
|
|
private readonly IMapper _mapper;
|
|
|
|
public CatalogService(ICatalogRepository repository, IMapper mapper)
|
|
{
|
|
_repository = repository;
|
|
_mapper = mapper;
|
|
}
|
|
|
|
public async Task<List<CatalogReadDto>> GetAllAsync(CancellationToken cancellationToken = default)
|
|
{
|
|
var items = await _repository.GetAllAsync(cancellationToken);
|
|
return _mapper.Map<List<CatalogReadDto>>(items);
|
|
}
|
|
|
|
public async Task<CatalogReadDto?> GetByIdAsync(int id, CancellationToken cancellationToken = default)
|
|
{
|
|
var item = await _repository.GetByIdAsync(id, cancellationToken);
|
|
return item == null ? null : _mapper.Map<CatalogReadDto>(item);
|
|
}
|
|
|
|
public async Task<CatalogReadDto> CreateAsync(CatalogWriteDto dto, CancellationToken cancellationToken = default)
|
|
{
|
|
var entity = _mapper.Map<VwmyCatalog>(dto);
|
|
entity.AddedWho = "system";
|
|
entity.AddedWhen = DateTime.UtcNow;
|
|
entity.ChangedWho = "system";
|
|
entity.ChangedWhen = DateTime.UtcNow;
|
|
|
|
var created = await _repository.InsertAsync(entity, cancellationToken);
|
|
return _mapper.Map<CatalogReadDto>(created);
|
|
}
|
|
|
|
public async Task<CatalogReadDto?> UpdateAsync(int id, CatalogWriteDto dto, CancellationToken cancellationToken = default)
|
|
{
|
|
var existing = await _repository.GetByIdAsync(id, cancellationToken);
|
|
if (existing == null)
|
|
{
|
|
return null;
|
|
}
|
|
|
|
var entity = _mapper.Map<VwmyCatalog>(dto);
|
|
entity.Guid = id;
|
|
entity.AddedWho = existing.AddedWho;
|
|
entity.AddedWhen = existing.AddedWhen;
|
|
entity.ChangedWho = "system";
|
|
entity.ChangedWhen = DateTime.UtcNow;
|
|
|
|
var updated = await _repository.UpdateAsync(id, entity, cancellationToken);
|
|
return updated == null ? null : _mapper.Map<CatalogReadDto>(updated);
|
|
}
|
|
|
|
public async Task<CatalogReadDto?> UpsertAsync(CatalogWriteDto dto, CancellationToken cancellationToken = default)
|
|
{
|
|
var entity = _mapper.Map<VwmyCatalog>(dto);
|
|
if (entity.Guid == 0)
|
|
{
|
|
entity.AddedWho = "system";
|
|
entity.AddedWhen = DateTime.UtcNow;
|
|
}
|
|
entity.ChangedWho = "system";
|
|
entity.ChangedWhen = DateTime.UtcNow;
|
|
|
|
var upserted = await _repository.UpsertAsync(entity, cancellationToken);
|
|
return upserted == null ? null : _mapper.Map<CatalogReadDto>(upserted);
|
|
}
|
|
|
|
public async Task<bool> DeleteAsync(int id, CancellationToken cancellationToken = default)
|
|
{
|
|
return await _repository.DeleteAsync(id, cancellationToken);
|
|
}
|
|
}
|