Finalisation endpoints
This commit is contained in:
@@ -0,0 +1,51 @@
|
||||
using FastEndpoints;
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
using PyroFetes.DTO.SoundTimecode.Request;
|
||||
using PyroFetes.DTO.SoundTimecode.Response;
|
||||
|
||||
namespace PyroFetes.Endpoints.SoundTimecode;
|
||||
|
||||
// DTO pour la route avec clé composite
|
||||
public class UpdateSoundTimecodeRequest
|
||||
{
|
||||
public int ShowId { get; set; }
|
||||
public int SoundId { get; set; }
|
||||
public int Start { get; set; }
|
||||
public int End { get; set; }
|
||||
}
|
||||
|
||||
public class UpdateSoundTimecodeEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoint<UpdateSoundTimecodeRequest, ReadSoundTimecodeDto>
|
||||
{
|
||||
public override void Configure()
|
||||
{
|
||||
Put("/api/soundtimecodes/{ShowId}/{SoundId}");
|
||||
AllowAnonymous();
|
||||
}
|
||||
|
||||
public override async Task HandleAsync(UpdateSoundTimecodeRequest req, CancellationToken ct)
|
||||
{
|
||||
var soundTimecode = await pyroFetesDbContext.SoundTimecodes
|
||||
.FirstOrDefaultAsync(st => st.ShowId == req.ShowId && st.SoundId == req.SoundId, ct);
|
||||
|
||||
if (soundTimecode is null)
|
||||
{
|
||||
await Send.NotFoundAsync(ct);
|
||||
return;
|
||||
}
|
||||
|
||||
soundTimecode.Start = req.Start;
|
||||
soundTimecode.End = req.End;
|
||||
|
||||
await pyroFetesDbContext.SaveChangesAsync(ct);
|
||||
|
||||
var result = new ReadSoundTimecodeDto
|
||||
{
|
||||
ShowId = soundTimecode.ShowId,
|
||||
SoundId = soundTimecode.SoundId,
|
||||
Start = (int)soundTimecode.Start,
|
||||
End = (int)soundTimecode.End
|
||||
};
|
||||
|
||||
await Send.OkAsync(result, ct);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user