Merge remote-tracking branch 'origin/develop' into develop
This commit is contained in:
34
PyroFetes/Endpoints/Deliverers/CreateDelivererEndpoint.cs
Normal file
34
PyroFetes/Endpoints/Deliverers/CreateDelivererEndpoint.cs
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
using FastEndpoints;
|
||||||
|
using PyroFetes.DTO.Deliverer.Request;
|
||||||
|
using PyroFetes.DTO.Deliverer.Response;
|
||||||
|
using PyroFetes.Models;
|
||||||
|
|
||||||
|
namespace PyroFetes.Endpoints.Deliverers;
|
||||||
|
|
||||||
|
public class CreateDelivererEndpoint(PyroFetesDbContext database) : Endpoint<CreateDelivererDto, GetDelivererDto>
|
||||||
|
{
|
||||||
|
public override void Configure()
|
||||||
|
{
|
||||||
|
Post("api/deliverers");
|
||||||
|
AllowAnonymous();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public override async Task HandleAsync(CreateDelivererDto req, CancellationToken ct)
|
||||||
|
{
|
||||||
|
Deliverer newDeliverer = new Deliverer()
|
||||||
|
{
|
||||||
|
Transporter = req.Transporter,
|
||||||
|
};
|
||||||
|
|
||||||
|
database.Deliverers.Add(newDeliverer);
|
||||||
|
|
||||||
|
await database.SaveChangesAsync(ct);
|
||||||
|
|
||||||
|
await Send.OkAsync(new GetDelivererDto()
|
||||||
|
{
|
||||||
|
Id = newDeliverer.Id,
|
||||||
|
Transporter = req.Transporter,
|
||||||
|
},ct);
|
||||||
|
}
|
||||||
|
}
|
||||||
37
PyroFetes/Endpoints/Deliverers/DeleteDelivererEndpoint.cs
Normal file
37
PyroFetes/Endpoints/Deliverers/DeleteDelivererEndpoint.cs
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
using FastEndpoints;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using PyroFetes.Models;
|
||||||
|
|
||||||
|
namespace PyroFetes.Endpoints.Deliverers;
|
||||||
|
|
||||||
|
public class DeleteDelivererRequest
|
||||||
|
{
|
||||||
|
public int DelivererId { get; set; }
|
||||||
|
}
|
||||||
|
public class DeleteDelivererEndpoint(PyroFetesDbContext database) : Endpoint<DeleteDelivererRequest>
|
||||||
|
{
|
||||||
|
public override void Configure()
|
||||||
|
{
|
||||||
|
Delete("api/deliverers/{@id}", x=>new {x.DelivererId});
|
||||||
|
AllowAnonymous();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public override async Task HandleAsync(DeleteDelivererRequest req, CancellationToken ct)
|
||||||
|
{
|
||||||
|
Deliverer? deliverer = await database.Deliverers.SingleOrDefaultAsync(x=>x.Id == req.DelivererId, ct);
|
||||||
|
|
||||||
|
if (deliverer == null)
|
||||||
|
{
|
||||||
|
await Send.NotFoundAsync(ct);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
database.Remove(deliverer);
|
||||||
|
|
||||||
|
await database.SaveChangesAsync(ct);
|
||||||
|
|
||||||
|
await Send.OkAsync(ct);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
29
PyroFetes/Endpoints/Deliverers/GetAllDelivererEndpoint.cs
Normal file
29
PyroFetes/Endpoints/Deliverers/GetAllDelivererEndpoint.cs
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
using FastEndpoints;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using Microsoft.EntityFrameworkCore.Scaffolding.Metadata;
|
||||||
|
using PyroFetes.DTO.Deliverer.Response;
|
||||||
|
using PyroFetes.Models;
|
||||||
|
|
||||||
|
namespace PyroFetes.Endpoints.Deliverers;
|
||||||
|
|
||||||
|
public class GetAllDelivererEndpoint(PyroFetesDbContext database) : EndpointWithoutRequest<List<GetDelivererDto>>
|
||||||
|
{
|
||||||
|
public override void Configure()
|
||||||
|
{
|
||||||
|
Get("api/deliverers");
|
||||||
|
AllowAnonymous();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public override async Task HandleAsync(CancellationToken ct)
|
||||||
|
{
|
||||||
|
List<GetDelivererDto> deliverers = await database.Deliverers.Select(x => new GetDelivererDto()
|
||||||
|
{
|
||||||
|
Id = x.Id,
|
||||||
|
Transporter = x.Transporter,
|
||||||
|
}).ToListAsync(ct);
|
||||||
|
|
||||||
|
await Send.OkAsync(deliverers, ct);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
39
PyroFetes/Endpoints/Deliverers/GetDelivererEndpoint.cs
Normal file
39
PyroFetes/Endpoints/Deliverers/GetDelivererEndpoint.cs
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
using FastEndpoints;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using PyroFetes.DTO.Deliverer.Response;
|
||||||
|
using PyroFetes.Models;
|
||||||
|
|
||||||
|
namespace PyroFetes.Endpoints.Deliverers;
|
||||||
|
|
||||||
|
public class GetDelivererRequest
|
||||||
|
{
|
||||||
|
public int DelivererId { get; set; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public class GetDelivererEndpoint(PyroFetesDbContext database) : Endpoint<GetDelivererRequest, GetDelivererDto>
|
||||||
|
{
|
||||||
|
public override void Configure()
|
||||||
|
{
|
||||||
|
Get("api/deliverers/{@id}", x=>new {x.DelivererId});
|
||||||
|
AllowAnonymous();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public override async Task HandleAsync(GetDelivererRequest req, CancellationToken ct)
|
||||||
|
{
|
||||||
|
Deliverer? deliverer = await database.Deliverers.SingleOrDefaultAsync(x=>x.Id == req.DelivererId, ct);
|
||||||
|
|
||||||
|
if (deliverer == null)
|
||||||
|
{
|
||||||
|
await Send.NotFoundAsync(ct);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
await Send.OkAsync(new GetDelivererDto()
|
||||||
|
{
|
||||||
|
Id = deliverer.Id,
|
||||||
|
Transporter = deliverer.Transporter,
|
||||||
|
}, ct);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
39
PyroFetes/Endpoints/Deliverers/UpdateDelivererEndpoint.cs
Normal file
39
PyroFetes/Endpoints/Deliverers/UpdateDelivererEndpoint.cs
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
using FastEndpoints;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using PyroFetes.DTO.Deliverer.Request;
|
||||||
|
using PyroFetes.DTO.Deliverer.Response;
|
||||||
|
using PyroFetes.Models;
|
||||||
|
|
||||||
|
namespace PyroFetes.Endpoints.Deliverers;
|
||||||
|
|
||||||
|
public class UpdateDelivererEndpoint(PyroFetesDbContext database) : Endpoint<UpdateDelivererDto, GetDelivererDto>
|
||||||
|
{
|
||||||
|
public override void Configure()
|
||||||
|
{
|
||||||
|
Put("api/deliverers/{@id}", x=>new {x.Id});
|
||||||
|
AllowAnonymous();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public override async Task HandleAsync(UpdateDelivererDto req, CancellationToken ct)
|
||||||
|
{
|
||||||
|
Deliverer? deliverer = await database.Deliverers.SingleOrDefaultAsync(x=>x.Id == req.Id, ct);
|
||||||
|
|
||||||
|
if (deliverer == null)
|
||||||
|
{
|
||||||
|
await Send.NotFoundAsync(ct);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
deliverer.Transporter = req.Transporter;
|
||||||
|
|
||||||
|
await database.SaveChangesAsync(ct);
|
||||||
|
|
||||||
|
await Send.OkAsync(new GetDelivererDto()
|
||||||
|
{
|
||||||
|
Id = deliverer.Id,
|
||||||
|
Transporter = deliverer.Transporter,
|
||||||
|
}, ct);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -7,6 +7,7 @@
|
|||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
<PackageReference Include="AutoMapper" Version="15.1.0" />
|
||||||
<PackageReference Include="BCrypt.Net-Next" Version="4.0.3" />
|
<PackageReference Include="BCrypt.Net-Next" Version="4.0.3" />
|
||||||
<PackageReference Include="FastEndpoints" Version="7.0.1" />
|
<PackageReference Include="FastEndpoints" Version="7.0.1" />
|
||||||
<PackageReference Include="FastEndpoints.Security" Version="7.0.1" />
|
<PackageReference Include="FastEndpoints.Security" Version="7.0.1" />
|
||||||
|
|||||||
Reference in New Issue
Block a user