Refactored Setting
This commit is contained in:
@@ -2,10 +2,13 @@
|
|||||||
using PyroFetes.DTO.SettingDTO.Request;
|
using PyroFetes.DTO.SettingDTO.Request;
|
||||||
using PyroFetes.DTO.SettingDTO.Response;
|
using PyroFetes.DTO.SettingDTO.Response;
|
||||||
using PyroFetes.Models;
|
using PyroFetes.Models;
|
||||||
|
using PyroFetes.Repositories;
|
||||||
|
|
||||||
namespace PyroFetes.Endpoints.Settings;
|
namespace PyroFetes.Endpoints.Settings;
|
||||||
|
|
||||||
public class CreateSettingEndpoint(PyroFetesDbContext database) : Endpoint<CreateSettingDto, GetSettingDto>
|
public class CreateSettingEndpoint(
|
||||||
|
SettingsRepository settingsRepository,
|
||||||
|
AutoMapper.IMapper mapper) : Endpoint<CreateSettingDto, GetSettingDto>
|
||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
@@ -21,15 +24,8 @@ public class CreateSettingEndpoint(PyroFetesDbContext database) : Endpoint<Creat
|
|||||||
Logo = req.Logo
|
Logo = req.Logo
|
||||||
};
|
};
|
||||||
|
|
||||||
database.Settings.Add(setting);
|
await settingsRepository.AddAsync(setting, ct);
|
||||||
await database.SaveChangesAsync(ct);
|
|
||||||
|
|
||||||
GetSettingDto responseDto = new()
|
await Send.OkAsync(mapper.Map<GetSettingDto>(setting), ct);
|
||||||
{
|
|
||||||
Id = setting.Id,
|
|
||||||
ElectronicSignature = setting.ElectronicSignature,
|
|
||||||
Logo = setting.Logo
|
|
||||||
};
|
|
||||||
await Send.OkAsync(responseDto, ct);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1,6 +1,8 @@
|
|||||||
using FastEndpoints;
|
using FastEndpoints;
|
||||||
using Microsoft.EntityFrameworkCore;
|
using Microsoft.EntityFrameworkCore;
|
||||||
using PyroFetes.Models;
|
using PyroFetes.Models;
|
||||||
|
using PyroFetes.Repositories;
|
||||||
|
using PyroFetes.Specifications.Settings;
|
||||||
|
|
||||||
namespace PyroFetes.Endpoints.Settings;
|
namespace PyroFetes.Endpoints.Settings;
|
||||||
|
|
||||||
@@ -9,7 +11,7 @@ public class DeleteSettingRequest
|
|||||||
public int Id { get; set; }
|
public int Id { get; set; }
|
||||||
}
|
}
|
||||||
|
|
||||||
public class DeleteSettingEndpoint(PyroFetesDbContext database) : Endpoint<DeleteSettingRequest>
|
public class DeleteSettingEndpoint(SettingsRepository settingsRepository) : Endpoint<DeleteSettingRequest>
|
||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
@@ -19,7 +21,7 @@ public class DeleteSettingEndpoint(PyroFetesDbContext database) : Endpoint<Delet
|
|||||||
|
|
||||||
public override async Task HandleAsync(DeleteSettingRequest req, CancellationToken ct)
|
public override async Task HandleAsync(DeleteSettingRequest req, CancellationToken ct)
|
||||||
{
|
{
|
||||||
Setting? setting = await database.Settings.SingleOrDefaultAsync(x => x.Id == req.Id, ct);
|
Setting? setting = await settingsRepository.FirstOrDefaultAsync(new GetSettingByIdSpec(req.Id), ct);
|
||||||
|
|
||||||
if (setting == null)
|
if (setting == null)
|
||||||
{
|
{
|
||||||
@@ -27,8 +29,7 @@ public class DeleteSettingEndpoint(PyroFetesDbContext database) : Endpoint<Delet
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
database.Settings.Remove(setting);
|
await settingsRepository.DeleteAsync(setting, ct);
|
||||||
await database.SaveChangesAsync(ct);
|
|
||||||
|
|
||||||
await Send.NoContentAsync(ct);
|
await Send.NoContentAsync(ct);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,6 +2,8 @@
|
|||||||
using Microsoft.EntityFrameworkCore;
|
using Microsoft.EntityFrameworkCore;
|
||||||
using PyroFetes.DTO.SettingDTO.Response;
|
using PyroFetes.DTO.SettingDTO.Response;
|
||||||
using PyroFetes.Models;
|
using PyroFetes.Models;
|
||||||
|
using PyroFetes.Repositories;
|
||||||
|
using PyroFetes.Specifications.Settings;
|
||||||
|
|
||||||
namespace PyroFetes.Endpoints.Settings;
|
namespace PyroFetes.Endpoints.Settings;
|
||||||
|
|
||||||
@@ -10,7 +12,9 @@ public class GetSettingRequest
|
|||||||
public int Id { get; set; }
|
public int Id { get; set; }
|
||||||
}
|
}
|
||||||
|
|
||||||
public class GetSettingEndpoint(PyroFetesDbContext database) : Endpoint<GetSettingRequest, GetSettingDto>
|
public class GetSettingEndpoint(
|
||||||
|
SettingsRepository settingsRepository,
|
||||||
|
AutoMapper.IMapper mapper) : Endpoint<GetSettingRequest, GetSettingDto>
|
||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
@@ -20,8 +24,7 @@ public class GetSettingEndpoint(PyroFetesDbContext database) : Endpoint<GetSetti
|
|||||||
|
|
||||||
public override async Task HandleAsync(GetSettingRequest req, CancellationToken ct)
|
public override async Task HandleAsync(GetSettingRequest req, CancellationToken ct)
|
||||||
{
|
{
|
||||||
Setting? setting = await database.Settings
|
Setting? setting = await settingsRepository.FirstOrDefaultAsync(new GetSettingByIdSpec(req.Id), ct);
|
||||||
.SingleOrDefaultAsync(x => x.Id == req.Id, ct);
|
|
||||||
|
|
||||||
if (setting == null)
|
if (setting == null)
|
||||||
{
|
{
|
||||||
@@ -29,12 +32,6 @@ public class GetSettingEndpoint(PyroFetesDbContext database) : Endpoint<GetSetti
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
GetSettingDto responseDto = new()
|
await Send.OkAsync(mapper.Map<GetSettingDto>(setting), ct);
|
||||||
{
|
|
||||||
Id = setting.Id,
|
|
||||||
ElectronicSignature = setting.ElectronicSignature,
|
|
||||||
Logo = setting.Logo
|
|
||||||
};
|
|
||||||
await Send.OkAsync(responseDto, ct);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -3,10 +3,14 @@ using Microsoft.EntityFrameworkCore;
|
|||||||
using PyroFetes.DTO.SettingDTO.Request;
|
using PyroFetes.DTO.SettingDTO.Request;
|
||||||
using PyroFetes.DTO.SettingDTO.Response;
|
using PyroFetes.DTO.SettingDTO.Response;
|
||||||
using PyroFetes.Models;
|
using PyroFetes.Models;
|
||||||
|
using PyroFetes.Repositories;
|
||||||
|
using PyroFetes.Specifications.Settings;
|
||||||
|
|
||||||
namespace PyroFetes.Endpoints.Settings;
|
namespace PyroFetes.Endpoints.Settings;
|
||||||
|
|
||||||
public class PatchSettingElectronicSignatureEndpoint(PyroFetesDbContext database) : Endpoint<PatchSettingElectronicSignatureDto, GetSettingDto>
|
public class PatchSettingElectronicSignatureEndpoint(
|
||||||
|
SettingsRepository settingsRepository,
|
||||||
|
AutoMapper.IMapper mapper) : Endpoint<PatchSettingElectronicSignatureDto, GetSettingDto>
|
||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
@@ -16,8 +20,8 @@ public class PatchSettingElectronicSignatureEndpoint(PyroFetesDbContext database
|
|||||||
|
|
||||||
public override async Task HandleAsync(PatchSettingElectronicSignatureDto req, CancellationToken ct)
|
public override async Task HandleAsync(PatchSettingElectronicSignatureDto req, CancellationToken ct)
|
||||||
{
|
{
|
||||||
Setting? setting = await database.Settings.SingleOrDefaultAsync(x => x.Id == req.Id, ct);
|
Setting? setting = await settingsRepository.FirstOrDefaultAsync(new GetSettingByIdSpec(req.Id), ct);
|
||||||
|
|
||||||
if (setting == null)
|
if (setting == null)
|
||||||
{
|
{
|
||||||
await Send.NotFoundAsync(ct);
|
await Send.NotFoundAsync(ct);
|
||||||
@@ -25,15 +29,8 @@ public class PatchSettingElectronicSignatureEndpoint(PyroFetesDbContext database
|
|||||||
}
|
}
|
||||||
|
|
||||||
setting.ElectronicSignature = req.ElectronicSignature;
|
setting.ElectronicSignature = req.ElectronicSignature;
|
||||||
await database.SaveChangesAsync(ct);
|
await settingsRepository.UpdateAsync(setting, ct);
|
||||||
|
|
||||||
GetSettingDto responseDto = new()
|
await Send.OkAsync(mapper.Map<GetSettingDto>(setting), ct);
|
||||||
{
|
|
||||||
Id = setting.Id,
|
|
||||||
ElectronicSignature = setting.ElectronicSignature,
|
|
||||||
Logo = setting.Logo
|
|
||||||
};
|
|
||||||
|
|
||||||
await Send.OkAsync(responseDto, ct);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -3,10 +3,14 @@ using Microsoft.EntityFrameworkCore;
|
|||||||
using PyroFetes.DTO.SettingDTO.Request;
|
using PyroFetes.DTO.SettingDTO.Request;
|
||||||
using PyroFetes.DTO.SettingDTO.Response;
|
using PyroFetes.DTO.SettingDTO.Response;
|
||||||
using PyroFetes.Models;
|
using PyroFetes.Models;
|
||||||
|
using PyroFetes.Repositories;
|
||||||
|
using PyroFetes.Specifications.Settings;
|
||||||
|
|
||||||
namespace PyroFetes.Endpoints.Settings;
|
namespace PyroFetes.Endpoints.Settings;
|
||||||
|
|
||||||
public class PatchSettingLogoEndpoint(PyroFetesDbContext database) : Endpoint<PatchSettingLogoDto, GetSettingDto>
|
public class PatchSettingLogoEndpoint(
|
||||||
|
SettingsRepository settingsRepository,
|
||||||
|
AutoMapper.IMapper mapper) : Endpoint<PatchSettingLogoDto, GetSettingDto>
|
||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
@@ -16,7 +20,7 @@ public class PatchSettingLogoEndpoint(PyroFetesDbContext database) : Endpoint<Pa
|
|||||||
|
|
||||||
public override async Task HandleAsync(PatchSettingLogoDto req, CancellationToken ct)
|
public override async Task HandleAsync(PatchSettingLogoDto req, CancellationToken ct)
|
||||||
{
|
{
|
||||||
Setting? setting = await database.Settings.SingleOrDefaultAsync(x => x.Id == req.Id, ct);
|
Setting? setting = await settingsRepository.FirstOrDefaultAsync(new GetSettingByIdSpec(req.Id), ct);
|
||||||
|
|
||||||
if (setting == null)
|
if (setting == null)
|
||||||
{
|
{
|
||||||
@@ -25,15 +29,8 @@ public class PatchSettingLogoEndpoint(PyroFetesDbContext database) : Endpoint<Pa
|
|||||||
}
|
}
|
||||||
|
|
||||||
setting.Logo = req.Logo;
|
setting.Logo = req.Logo;
|
||||||
await database.SaveChangesAsync(ct);
|
await settingsRepository.UpdateAsync(setting, ct);
|
||||||
|
|
||||||
GetSettingDto responseDto = new()
|
|
||||||
{
|
|
||||||
Id = setting.Id,
|
|
||||||
ElectronicSignature = setting.ElectronicSignature,
|
|
||||||
Logo = setting.Logo
|
|
||||||
};
|
|
||||||
|
|
||||||
await Send.OkAsync(responseDto, ct);
|
await Send.OkAsync(mapper.Map<GetSettingDto>(setting), ct);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
5
PyroFetes/Repositories/SettingsRepository.cs
Normal file
5
PyroFetes/Repositories/SettingsRepository.cs
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
using PyroFetes.Models;
|
||||||
|
|
||||||
|
namespace PyroFetes.Repositories;
|
||||||
|
|
||||||
|
public class SettingsRepository(PyroFetesDbContext pyrofetesContext, AutoMapper.IMapper mapper) : PyrofetesRepository<Setting>(pyrofetesContext, mapper);
|
||||||
13
PyroFetes/Specifications/Settings/GetSettingByIdSpec.cs
Normal file
13
PyroFetes/Specifications/Settings/GetSettingByIdSpec.cs
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
using Ardalis.Specification;
|
||||||
|
using PyroFetes.Models;
|
||||||
|
|
||||||
|
namespace PyroFetes.Specifications.Settings;
|
||||||
|
|
||||||
|
public sealed class GetSettingByIdSpec : Specification<Setting>
|
||||||
|
{
|
||||||
|
public GetSettingByIdSpec(int settingId)
|
||||||
|
{
|
||||||
|
Query
|
||||||
|
.Where(setting => setting.Id == settingId);
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user