using AutoMapper; using MediatR; using Microsoft.EntityFrameworkCore; using Microsoft.Extensions.Logging; using System; using System.Threading; using System.Threading.Tasks; using UserManagement.Common.UnitOfWork; using UserManagement.Data; using UserManagement.Data.Dto; using UserManagement.Domain; using UserManagement.Helper; using UserManagement.MediatR.Commands; using UserManagement.Repository; namespace UserManagement.MediatR.Handlers { public class AddAppSettingCommandHandler( IAppSettingRepository appSettingRepository, IMapper mapper, IUnitOfWork uow, UserInfoToken userInfoToken, ILogger logger ) : IRequestHandler> { public async Task> Handle(AddAppSettingCommand request, CancellationToken cancellationToken) { var entityExist = await appSettingRepository.FindBy(c => c.Key == request.Key).FirstOrDefaultAsync(cancellationToken); if (entityExist != null) { logger.LogError("AppSetting already exist."); return ServiceResponse.Return409("App Setting already exist."); } var entity = mapper.Map(request); entity.Id = Guid.NewGuid(); entity.CreatedBy = Guid.Parse(userInfoToken.Id); entity.CreatedDate = DateTime.Now.ToLocalTime(); entity.ModifiedBy = Guid.Parse(userInfoToken.Id); appSettingRepository.Add(entity); if (await uow.SaveAsync(cancellationToken) <= 0) { return ServiceResponse.Return500(); } var entityDto = mapper.Map(entity); return ServiceResponse.ReturnResultWith200(entityDto); } } }