using Application.Classes; using Application.DataTransferObjects.MarshalGuard; using Application.Errors; using Application.Interfaces; using AutoMapper; using AutoMapper.QueryableExtensions; using Database; using Database.Entities; using Microsoft.EntityFrameworkCore; using Microsoft.Extensions.Logging; namespace Application.Repositories; public class MarshalGuardRepository(ApplicationContext context, IMapper mapper, ILogger logger) : IMarshalGuardRepository { public async Task> GetMarshalGuardAsync(Guid marshalGuardId, CancellationToken cancellationToken) { var marshalGuardById = await context.MarshalGuards .ProjectTo(mapper.ConfigurationProvider) .AsNoTracking() .FirstOrDefaultAsync(marshalGuard => marshalGuard.Id == marshalGuardId, cancellationToken); return marshalGuardById is null ? Result.Failure(MarshalGuardErrors.NotFound) : Result.Success(marshalGuardById); } public async Task> GetMarshalGuardDetailAsync(Guid marshalGuardId, CancellationToken cancellationToken) { var detailMarshalGuard = await context.MarshalGuards .ProjectTo(mapper.ConfigurationProvider) .AsNoTracking() .FirstOrDefaultAsync(marshalGuard => marshalGuard.Id == marshalGuardId, cancellationToken); return detailMarshalGuard is null ? Result.Failure(MarshalGuardErrors.NotFound) : Result.Success(detailMarshalGuard); } public async Task>> GetAllianceMarshalGuardsAsync(Guid allianceId, int take, CancellationToken cancellationToken) { var allianceMarshalGuards = await context.MarshalGuards .Where(marshalGuard => marshalGuard.AllianceId == allianceId) .OrderByDescending(marshalGuard => marshalGuard.EventDate) .ProjectTo(mapper.ConfigurationProvider) .AsNoTracking() .Take(take) .ToListAsync(cancellationToken); return Result.Success(allianceMarshalGuards); } public async Task> CreateMarshalGuardsAsync(CreateMarshalGuardDto createMarshalGuardDto, string createdBy, CancellationToken cancellationToken) { var newMarshalGuard = mapper.Map(createMarshalGuardDto); newMarshalGuard.CreatedBy = createdBy; await context.MarshalGuards.AddAsync(newMarshalGuard, cancellationToken); try { await context.SaveChangesAsync(cancellationToken); return Result.Success(mapper.Map(newMarshalGuard)); } catch (Exception e) { logger.LogError(e, e.Message); return Result.Failure(GeneralErrors.DatabaseError); } } public async Task> UpdateMarshalGuardAsync(UpdateMarshalGuardDto updateMarshalGuardDto, string modifiedBy, CancellationToken cancellationToken) { var marshalGuardToUpdate = await context.MarshalGuards .FirstOrDefaultAsync(marshalGuard => marshalGuard.Id == updateMarshalGuardDto.Id, cancellationToken); if (marshalGuardToUpdate is null) return Result.Failure(MarshalGuardErrors.NotFound); mapper.Map(updateMarshalGuardDto, marshalGuardToUpdate); marshalGuardToUpdate.ModifiedBy = modifiedBy; try { await context.SaveChangesAsync(cancellationToken); return Result.Success(mapper.Map(marshalGuardToUpdate)); } catch (Exception e) { logger.LogError(e, e.Message); return Result.Failure(GeneralErrors.DatabaseError); } } public async Task> DeleteMarshalGuardAsync(Guid marshalGuardId, CancellationToken cancellationToken) { var marshalGuardToDelete = await context.MarshalGuards .FirstOrDefaultAsync(marshalGuard => marshalGuard.Id == marshalGuardId, cancellationToken); if (marshalGuardToDelete is null) return Result.Failure(MarshalGuardErrors.NotFound); context.MarshalGuards.Remove(marshalGuardToDelete); try { await context.SaveChangesAsync(cancellationToken); return Result.Success(true); } catch (Exception e) { logger.LogError(e, e.Message); return Result.Failure(GeneralErrors.DatabaseError); } } }