Compare commits
3 Commits
3a09bfc8ad
...
master
| Author | SHA1 | Date | |
|---|---|---|---|
| 71b7a53e59 | |||
| b3612f5bec | |||
| 6c1330e570 |
@@ -7,4 +7,5 @@ public class CreateShowDto
|
|||||||
public string? Description { get; set; }
|
public string? Description { get; set; }
|
||||||
public string? PyrotechnicImplementationPlan { get; set; }
|
public string? PyrotechnicImplementationPlan { get; set; }
|
||||||
public DateTime? Date { get; set; }
|
public DateTime? Date { get; set; }
|
||||||
|
public int? CityId { get; set; }
|
||||||
}
|
}
|
||||||
@@ -8,4 +8,5 @@ public class UpdateShowDto
|
|||||||
public string? Description { get; set; }
|
public string? Description { get; set; }
|
||||||
public string? PyrotechnicImplementationPlan { get; set; }
|
public string? PyrotechnicImplementationPlan { get; set; }
|
||||||
public DateTime? Date { get; set; }
|
public DateTime? Date { get; set; }
|
||||||
|
public int? CityId { get; set; }
|
||||||
}
|
}
|
||||||
@@ -8,4 +8,5 @@ public class ReadShowDto
|
|||||||
public string? Description { get; set; }
|
public string? Description { get; set; }
|
||||||
public string? PyrotechnicImplementationPlan { get; set; }
|
public string? PyrotechnicImplementationPlan { get; set; }
|
||||||
public DateTime? Date { get; set; }
|
public DateTime? Date { get; set; }
|
||||||
|
public int? CityId { get; set; }
|
||||||
}
|
}
|
||||||
@@ -6,4 +6,6 @@ public class CreateStaffDto
|
|||||||
public string? LastName { get; set; }
|
public string? LastName { get; set; }
|
||||||
public string? Profession { get; set; }
|
public string? Profession { get; set; }
|
||||||
public string? Email { get; set; }
|
public string? Email { get; set; }
|
||||||
|
public string? F4T2NumberApproval { get; set; }
|
||||||
|
public DateOnly F4T2ExpirationDate { get; set; }
|
||||||
}
|
}
|
||||||
@@ -7,4 +7,6 @@ public class UpdateStaffDto
|
|||||||
public string? LastName { get; set; }
|
public string? LastName { get; set; }
|
||||||
public string? Profession { get; set; }
|
public string? Profession { get; set; }
|
||||||
public string? Email { get; set; }
|
public string? Email { get; set; }
|
||||||
|
public string? F4T2NumberApproval { get; set; }
|
||||||
|
public DateOnly? F4T2ExpirationDate { get; set; }
|
||||||
}
|
}
|
||||||
@@ -7,4 +7,6 @@ public class ReadStaffDto
|
|||||||
public string? LastName { get; set; }
|
public string? LastName { get; set; }
|
||||||
public string? Profession { get; set; }
|
public string? Profession { get; set; }
|
||||||
public string? Email { get; set; }
|
public string? Email { get; set; }
|
||||||
|
public string? F4T2NumberApproval { get; set; }
|
||||||
|
public DateOnly F4T2ExpirationDate { get; set; }
|
||||||
}
|
}
|
||||||
@@ -8,7 +8,7 @@ public class CreateShowEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoin
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Post("/api/shows");
|
Post("/shows");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -16,11 +16,12 @@ public class CreateShowEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoin
|
|||||||
{
|
{
|
||||||
var show = new PyroFetes.Models.Show
|
var show = new PyroFetes.Models.Show
|
||||||
{
|
{
|
||||||
Name = req.Name,
|
Name = req.Name ?? string.Empty,
|
||||||
Place = req.Place,
|
Place = req.Place ?? string.Empty,
|
||||||
Description = req.Description,
|
Description = req.Description,
|
||||||
PyrotechnicImplementationPlan = req.PyrotechnicImplementationPlan,
|
PyrotechnicImplementationPlan = req.PyrotechnicImplementationPlan ?? string.Empty,
|
||||||
Date = req.Date.HasValue ? DateOnly.FromDateTime(req.Date.Value) : null
|
Date = req.Date,
|
||||||
|
CityId = req.CityId
|
||||||
};
|
};
|
||||||
|
|
||||||
pyroFetesDbContext.Shows.Add(show);
|
pyroFetesDbContext.Shows.Add(show);
|
||||||
@@ -33,7 +34,8 @@ public class CreateShowEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoin
|
|||||||
Place = show.Place,
|
Place = show.Place,
|
||||||
Description = show.Description,
|
Description = show.Description,
|
||||||
PyrotechnicImplementationPlan = show.PyrotechnicImplementationPlan,
|
PyrotechnicImplementationPlan = show.PyrotechnicImplementationPlan,
|
||||||
Date = show.Date.HasValue ? show.Date.Value.ToDateTime(TimeOnly.MinValue) : null
|
Date = show.Date,
|
||||||
|
CityId = show.CityId
|
||||||
};
|
};
|
||||||
|
|
||||||
await Send.OkAsync(result, ct);
|
await Send.OkAsync(result, ct);
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ public class DeleteShowEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoin
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Delete("/api/shows/{Id}");
|
Delete("/shows/{Id}");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -21,12 +21,6 @@ public class DeleteShowEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoin
|
|||||||
}
|
}
|
||||||
|
|
||||||
var show = await pyroFetesDbContext.Shows
|
var show = await pyroFetesDbContext.Shows
|
||||||
.Include(s => s.ShowTrucks)
|
|
||||||
.Include(s => s.ShowStaffs)
|
|
||||||
.Include(s => s.SoundTimecodes)
|
|
||||||
.Include(s => s.ProductTimecodes)
|
|
||||||
.Include(s => s.Contracts)
|
|
||||||
.Include(s => s.ShowMaterials)
|
|
||||||
.FirstOrDefaultAsync(s => s.Id == req.Id.Value, ct);
|
.FirstOrDefaultAsync(s => s.Id == req.Id.Value, ct);
|
||||||
|
|
||||||
if (show is null)
|
if (show is null)
|
||||||
@@ -35,16 +29,6 @@ public class DeleteShowEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoin
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Supprimer les relations associées
|
|
||||||
if (show.ShowTrucks != null && show.ShowTrucks.Any())
|
|
||||||
{
|
|
||||||
pyroFetesDbContext.ShowTrucks.RemoveRange(show.ShowTrucks);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Note: Les autres relations (ShowStaffs, SoundTimecodes, etc.) devront aussi être gérées
|
|
||||||
// en fonction de votre modèle de données et de vos règles métier
|
|
||||||
// Pour l'instant, je laisse juste ShowTrucks comme exemple
|
|
||||||
|
|
||||||
pyroFetesDbContext.Shows.Remove(show);
|
pyroFetesDbContext.Shows.Remove(show);
|
||||||
await pyroFetesDbContext.SaveChangesAsync(ct);
|
await pyroFetesDbContext.SaveChangesAsync(ct);
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ public class GetAllShowsEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoi
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Get("/api/shows");
|
Get("/shows");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -22,7 +22,8 @@ public class GetAllShowsEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoi
|
|||||||
Place = s.Place,
|
Place = s.Place,
|
||||||
Description = s.Description,
|
Description = s.Description,
|
||||||
PyrotechnicImplementationPlan = s.PyrotechnicImplementationPlan,
|
PyrotechnicImplementationPlan = s.PyrotechnicImplementationPlan,
|
||||||
Date = s.Date.HasValue ? s.Date.Value.ToDateTime(TimeOnly.MinValue) : null
|
Date = s.Date,
|
||||||
|
CityId = s.CityId
|
||||||
})
|
})
|
||||||
.ToListAsync(ct);
|
.ToListAsync(ct);
|
||||||
|
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ public class GetShowEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoint<I
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Get("/api/shows/{Id}");
|
Get("/shows/{Id}");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -30,7 +30,8 @@ public class GetShowEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoint<I
|
|||||||
Place = s.Place,
|
Place = s.Place,
|
||||||
Description = s.Description,
|
Description = s.Description,
|
||||||
PyrotechnicImplementationPlan = s.PyrotechnicImplementationPlan,
|
PyrotechnicImplementationPlan = s.PyrotechnicImplementationPlan,
|
||||||
Date = s.Date.HasValue ? s.Date.Value.ToDateTime(TimeOnly.MinValue) : null
|
Date = s.Date,
|
||||||
|
CityId = s.CityId
|
||||||
})
|
})
|
||||||
.FirstOrDefaultAsync(ct);
|
.FirstOrDefaultAsync(ct);
|
||||||
|
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ public class UpdateShowEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoin
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Put("/api/shows/{Id}");
|
Put("/shows/{Id}");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -34,11 +34,8 @@ public class UpdateShowEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoin
|
|||||||
show.Place = req.Place ?? show.Place;
|
show.Place = req.Place ?? show.Place;
|
||||||
show.Description = req.Description ?? show.Description;
|
show.Description = req.Description ?? show.Description;
|
||||||
show.PyrotechnicImplementationPlan = req.PyrotechnicImplementationPlan ?? show.PyrotechnicImplementationPlan;
|
show.PyrotechnicImplementationPlan = req.PyrotechnicImplementationPlan ?? show.PyrotechnicImplementationPlan;
|
||||||
|
if (req.CityId.HasValue) show.CityId = req.CityId.Value;
|
||||||
if (req.Date.HasValue)
|
if (req.Date.HasValue) show.Date = req.Date.Value;
|
||||||
{
|
|
||||||
show.Date = DateOnly.FromDateTime(req.Date.Value);
|
|
||||||
}
|
|
||||||
|
|
||||||
await pyroFetesDbContext.SaveChangesAsync(ct);
|
await pyroFetesDbContext.SaveChangesAsync(ct);
|
||||||
|
|
||||||
@@ -49,7 +46,8 @@ public class UpdateShowEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoin
|
|||||||
Place = show.Place,
|
Place = show.Place,
|
||||||
Description = show.Description,
|
Description = show.Description,
|
||||||
PyrotechnicImplementationPlan = show.PyrotechnicImplementationPlan,
|
PyrotechnicImplementationPlan = show.PyrotechnicImplementationPlan,
|
||||||
Date = show.Date.HasValue ? show.Date.Value.ToDateTime(TimeOnly.MinValue) : null
|
Date = show.Date,
|
||||||
|
CityId = show.CityId
|
||||||
};
|
};
|
||||||
|
|
||||||
await Send.OkAsync(result, ct);
|
await Send.OkAsync(result, ct);
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ public class CreateSoundEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoi
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Post("/api/sounds");
|
Post("/sounds");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ public class DeleteSoundEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoi
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Delete("/api/sounds/{Id}");
|
Delete("/sounds/{Id}");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ public class GetAllSoundsEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpo
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Get("/api/sounds");
|
Get("/sounds");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ public class GetSoundEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoint<
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Get("/api/sounds/{Id}");
|
Get("/sounds/{Id}");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ public class UpdateSoundEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoi
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Put("/api/sounds/{Id}");
|
Put("/sounds/{Id}");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ public class CreateSoundCategoryEndpoint(PyroFetesDbContext pyroFetesDbContext)
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Post("/api/soundcategorys");
|
Post("/soundcategorys");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ public class DeleteSoundCategoryEndpoint(PyroFetesDbContext pf3DbContext) : Endp
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Delete("/api/soundcategorys/{Id}");
|
Delete("/soundcategorys/{Id}");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ public class GetAllSoundCategorysEndpoint(PyroFetesDbContext pf3DbContext) : End
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Get("/api/soundcategorys");
|
Get("/soundcategorys");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ public class GetSoundCategoryEndpoint(PyroFetesDbContext pf3DbContext) : Endpoin
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Get("/api/soundcategorys/{Id}");
|
Get("/soundcategorys/{Id}");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ public class UpdateSoundCategoryEndpoint(PyroFetesDbContext pf3DbContext) : Endp
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Patch("/api/soundcategorys/{Id}/name");
|
Patch("/soundcategorys/{Id}/name");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ public class CreateSoundTimecodeEndpoint(PyroFetesDbContext pyroFetesDbContext)
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Post("/api/soundtimecodes");
|
Post("/soundtimecodes");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ public class DeleteSoundTimecodeEndpoint(PyroFetesDbContext pyroFetesDbContext)
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Delete("/api/soundtimecodes/{ShowId}/{SoundId}");
|
Delete("/soundtimecodes/{ShowId}/{SoundId}");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ public class GetAllSoundTimecodesEndpoint(PyroFetesDbContext pyroFetesDbContext)
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Get("/api/soundtimecodes");
|
Get("/soundtimecodes");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -15,7 +15,7 @@ public class GetSoundTimecodeEndpoint(PyroFetesDbContext pyroFetesDbContext) : E
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Get("/api/soundtimecodes/{ShowId}/{SoundId}");
|
Get("/soundtimecodes/{ShowId}/{SoundId}");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -18,7 +18,7 @@ public class UpdateSoundTimecodeEndpoint(PyroFetesDbContext pyroFetesDbContext)
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Put("/api/soundtimecodes/{ShowId}/{SoundId}");
|
Put("/soundtimecodes/{ShowId}/{SoundId}");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ public class CreateStaffEndpoint(PyroFetesDbContext pf3DbContext):Endpoint<Creat
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Post("/api/staff");
|
Post("/staff");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -19,19 +19,23 @@ public class CreateStaffEndpoint(PyroFetesDbContext pf3DbContext):Endpoint<Creat
|
|||||||
FirstName = req.FirstName,
|
FirstName = req.FirstName,
|
||||||
LastName = req.LastName,
|
LastName = req.LastName,
|
||||||
Profession = req.Profession,
|
Profession = req.Profession,
|
||||||
Email = req.Email
|
Email = req.Email,
|
||||||
|
F4T2NumberApproval = req.F4T2NumberApproval,
|
||||||
|
F4T2ExpirationDate = req.F4T2ExpirationDate
|
||||||
};
|
};
|
||||||
|
|
||||||
pf3DbContext.Staffs.Add(staff);
|
pf3DbContext.Staffs.Add(staff);
|
||||||
await pf3DbContext.SaveChangesAsync(ct);
|
await pf3DbContext.SaveChangesAsync(ct);
|
||||||
|
|
||||||
var result = new ReadStaffDto()
|
var result = new ReadStaffDto()
|
||||||
{
|
{
|
||||||
Id = staff.Id,
|
Id = staff.Id,
|
||||||
FirstName = req.FirstName,
|
FirstName = staff.FirstName,
|
||||||
LastName = req.LastName,
|
LastName = staff.LastName,
|
||||||
Profession = req.Profession,
|
Profession = staff.Profession,
|
||||||
Email = req.Email
|
Email = staff.Email,
|
||||||
|
F4T2NumberApproval = staff.F4T2NumberApproval,
|
||||||
|
F4T2ExpirationDate = staff.F4T2ExpirationDate
|
||||||
};
|
};
|
||||||
|
|
||||||
await Send.OkAsync(result, ct);
|
await Send.OkAsync(result, ct);
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ public class DeleteStaffEndpoint(PyroFetesDbContext pf3DbContext) : Endpoint<IdS
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Delete("/api/staff/{Id}");
|
Delete("/staff/{Id}");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ public class GetAllStaffEndpoint(PyroFetesDbContext pf3DbContext) : EndpointWith
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Get("/api/staff");
|
Get("/staff");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -22,7 +22,9 @@ public class GetAllStaffEndpoint(PyroFetesDbContext pf3DbContext) : EndpointWith
|
|||||||
FirstName = s.FirstName,
|
FirstName = s.FirstName,
|
||||||
LastName = s.LastName,
|
LastName = s.LastName,
|
||||||
Profession = s.Profession,
|
Profession = s.Profession,
|
||||||
Email = s.Email
|
Email = s.Email,
|
||||||
|
F4T2NumberApproval = s.F4T2NumberApproval,
|
||||||
|
F4T2ExpirationDate = s.F4T2ExpirationDate
|
||||||
}).ToList();
|
}).ToList();
|
||||||
|
|
||||||
await Send.OkAsync(result, ct);
|
await Send.OkAsync(result, ct);
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ public class GetStaffEndpoint(PyroFetesDbContext pf3DbContext) : Endpoint<IdStaf
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Get("/api/staff/{Id}");
|
Get("/staff/{Id}");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -23,7 +23,9 @@ public class GetStaffEndpoint(PyroFetesDbContext pf3DbContext) : Endpoint<IdStaf
|
|||||||
FirstName = s.FirstName,
|
FirstName = s.FirstName,
|
||||||
LastName = s.LastName,
|
LastName = s.LastName,
|
||||||
Profession = s.Profession,
|
Profession = s.Profession,
|
||||||
Email = s.Email
|
Email = s.Email,
|
||||||
|
F4T2NumberApproval = s.F4T2NumberApproval,
|
||||||
|
F4T2ExpirationDate = s.F4T2ExpirationDate
|
||||||
})
|
})
|
||||||
.FirstOrDefaultAsync(ct);
|
.FirstOrDefaultAsync(ct);
|
||||||
|
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ public class UpdateStaffEndpoint(PyroFetesDbContext pf3DbContext) : Endpoint<Upd
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Put("/api/staff/{Id}");
|
Put("/staff/{Id}");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -22,10 +22,13 @@ public class UpdateStaffEndpoint(PyroFetesDbContext pf3DbContext) : Endpoint<Upd
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
staff.FirstName = req.FirstName;
|
staff.FirstName = req.FirstName ?? staff.FirstName;
|
||||||
staff.LastName = req.LastName;
|
staff.LastName = req.LastName ?? staff.LastName;
|
||||||
staff.Profession = req.Profession;
|
staff.Profession = req.Profession ?? staff.Profession;
|
||||||
staff.Email = req.Email;
|
staff.Email = req.Email ?? staff.Email;
|
||||||
|
staff.F4T2NumberApproval = req.F4T2NumberApproval ?? staff.F4T2NumberApproval;
|
||||||
|
if (req.F4T2ExpirationDate.HasValue)
|
||||||
|
staff.F4T2ExpirationDate = req.F4T2ExpirationDate.Value;
|
||||||
|
|
||||||
await pf3DbContext.SaveChangesAsync(ct);
|
await pf3DbContext.SaveChangesAsync(ct);
|
||||||
|
|
||||||
@@ -35,7 +38,9 @@ public class UpdateStaffEndpoint(PyroFetesDbContext pf3DbContext) : Endpoint<Upd
|
|||||||
FirstName = staff.FirstName,
|
FirstName = staff.FirstName,
|
||||||
LastName = staff.LastName,
|
LastName = staff.LastName,
|
||||||
Profession = staff.Profession,
|
Profession = staff.Profession,
|
||||||
Email = staff.Email
|
Email = staff.Email,
|
||||||
|
F4T2NumberApproval = staff.F4T2NumberApproval,
|
||||||
|
F4T2ExpirationDate = staff.F4T2ExpirationDate
|
||||||
};
|
};
|
||||||
|
|
||||||
await Send.OkAsync(result, ct);
|
await Send.OkAsync(result, ct);
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ public class CreateTruckEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoi
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Post("/api/trucks");
|
Post("/trucks");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ public class DeleteTruckEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoi
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Delete("/api/trucks/{Id}");
|
Delete("/trucks/{Id}");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ public class GetAllTrucksEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpo
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Get("/api/trucks");
|
Get("/trucks");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ public class GetTruckEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoint<
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Get("/api/trucks/{Id}");
|
Get("/trucks/{Id}");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ public class UpdateTruckEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoi
|
|||||||
{
|
{
|
||||||
public override void Configure()
|
public override void Configure()
|
||||||
{
|
{
|
||||||
Put("/api/trucks/{Id}");
|
Put("/trucks/{Id}");
|
||||||
AllowAnonymous();
|
AllowAnonymous();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,59 @@
|
|||||||
|
using Microsoft.EntityFrameworkCore.Migrations;
|
||||||
|
|
||||||
|
#nullable disable
|
||||||
|
|
||||||
|
namespace PyroFetes.Migrations
|
||||||
|
{
|
||||||
|
/// <inheritdoc />
|
||||||
|
public partial class MakeCityIdNullable : Migration
|
||||||
|
{
|
||||||
|
/// <inheritdoc />
|
||||||
|
protected override void Up(MigrationBuilder migrationBuilder)
|
||||||
|
{
|
||||||
|
migrationBuilder.DropForeignKey(
|
||||||
|
name: "FK_Shows_Cities_CityId",
|
||||||
|
table: "Shows");
|
||||||
|
|
||||||
|
migrationBuilder.AlterColumn<int>(
|
||||||
|
name: "CityId",
|
||||||
|
table: "Shows",
|
||||||
|
type: "int",
|
||||||
|
nullable: true,
|
||||||
|
oldClrType: typeof(int),
|
||||||
|
oldType: "int");
|
||||||
|
|
||||||
|
migrationBuilder.AddForeignKey(
|
||||||
|
name: "FK_Shows_Cities_CityId",
|
||||||
|
table: "Shows",
|
||||||
|
column: "CityId",
|
||||||
|
principalTable: "Cities",
|
||||||
|
principalColumn: "Id");
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <inheritdoc />
|
||||||
|
protected override void Down(MigrationBuilder migrationBuilder)
|
||||||
|
{
|
||||||
|
migrationBuilder.DropForeignKey(
|
||||||
|
name: "FK_Shows_Cities_CityId",
|
||||||
|
table: "Shows");
|
||||||
|
|
||||||
|
migrationBuilder.AlterColumn<int>(
|
||||||
|
name: "CityId",
|
||||||
|
table: "Shows",
|
||||||
|
type: "int",
|
||||||
|
nullable: false,
|
||||||
|
defaultValue: 0,
|
||||||
|
oldClrType: typeof(int),
|
||||||
|
oldType: "int",
|
||||||
|
oldNullable: true);
|
||||||
|
|
||||||
|
migrationBuilder.AddForeignKey(
|
||||||
|
name: "FK_Shows_Cities_CityId",
|
||||||
|
table: "Shows",
|
||||||
|
column: "CityId",
|
||||||
|
principalTable: "Cities",
|
||||||
|
principalColumn: "Id",
|
||||||
|
onDelete: ReferentialAction.Cascade);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,37 @@
|
|||||||
|
using System;
|
||||||
|
using Microsoft.EntityFrameworkCore.Migrations;
|
||||||
|
|
||||||
|
#nullable disable
|
||||||
|
|
||||||
|
namespace PyroFetes.Migrations
|
||||||
|
{
|
||||||
|
/// <inheritdoc />
|
||||||
|
public partial class DateTimeForShow : Migration
|
||||||
|
{
|
||||||
|
/// <inheritdoc />
|
||||||
|
protected override void Up(MigrationBuilder migrationBuilder)
|
||||||
|
{
|
||||||
|
migrationBuilder.AlterColumn<DateTime>(
|
||||||
|
name: "Date",
|
||||||
|
table: "Shows",
|
||||||
|
type: "datetime2",
|
||||||
|
nullable: true,
|
||||||
|
oldClrType: typeof(DateOnly),
|
||||||
|
oldType: "date",
|
||||||
|
oldNullable: true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <inheritdoc />
|
||||||
|
protected override void Down(MigrationBuilder migrationBuilder)
|
||||||
|
{
|
||||||
|
migrationBuilder.AlterColumn<DateOnly>(
|
||||||
|
name: "Date",
|
||||||
|
table: "Shows",
|
||||||
|
type: "date",
|
||||||
|
nullable: true,
|
||||||
|
oldClrType: typeof(DateTime),
|
||||||
|
oldType: "datetime2",
|
||||||
|
oldNullable: true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -813,11 +813,11 @@ namespace PyroFetes.Migrations
|
|||||||
|
|
||||||
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
|
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
|
||||||
|
|
||||||
b.Property<int>("CityId")
|
b.Property<int?>("CityId")
|
||||||
.HasColumnType("int");
|
.HasColumnType("int");
|
||||||
|
|
||||||
b.Property<DateOnly?>("Date")
|
b.Property<DateTime?>("Date")
|
||||||
.HasColumnType("date");
|
.HasColumnType("datetime2");
|
||||||
|
|
||||||
b.Property<string>("Description")
|
b.Property<string>("Description")
|
||||||
.HasMaxLength(500)
|
.HasMaxLength(500)
|
||||||
@@ -887,7 +887,7 @@ namespace PyroFetes.Migrations
|
|||||||
|
|
||||||
b.HasIndex("TruckId");
|
b.HasIndex("TruckId");
|
||||||
|
|
||||||
b.ToTable("ShowTruck");
|
b.ToTable("ShowTrucks");
|
||||||
});
|
});
|
||||||
|
|
||||||
modelBuilder.Entity("PyroFetes.Models.Sound", b =>
|
modelBuilder.Entity("PyroFetes.Models.Sound", b =>
|
||||||
@@ -1593,9 +1593,7 @@ namespace PyroFetes.Migrations
|
|||||||
{
|
{
|
||||||
b.HasOne("PyroFetes.Models.City", "City")
|
b.HasOne("PyroFetes.Models.City", "City")
|
||||||
.WithMany("Shows")
|
.WithMany("Shows")
|
||||||
.HasForeignKey("CityId")
|
.HasForeignKey("CityId");
|
||||||
.OnDelete(DeleteBehavior.Cascade)
|
|
||||||
.IsRequired();
|
|
||||||
|
|
||||||
b.Navigation("City");
|
b.Navigation("City");
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -8,12 +8,12 @@ public class Show
|
|||||||
[Required, MaxLength(100)] public string? Name { get; set; }
|
[Required, MaxLength(100)] public string? Name { get; set; }
|
||||||
[Required, MaxLength(120)] public string? Place { get; set; }
|
[Required, MaxLength(120)] public string? Place { get; set; }
|
||||||
[MaxLength(500)] public string? Description { get; set; }
|
[MaxLength(500)] public string? Description { get; set; }
|
||||||
public DateOnly? Date { get; set; }
|
public DateTime? Date { get; set; }
|
||||||
|
|
||||||
// Link (path/URL/file name) to the pyrotechnic implementation plan
|
// Link (path/URL/file name) to the pyrotechnic implementation plan
|
||||||
[Required, MaxLength(500)] public string? PyrotechnicImplementationPlan { get; set; }
|
[Required, MaxLength(500)] public string? PyrotechnicImplementationPlan { get; set; }
|
||||||
|
|
||||||
[Required] public int CityId { get; set; }
|
public int? CityId { get; set; }
|
||||||
public City? City { get; set; }
|
public City? City { get; set; }
|
||||||
|
|
||||||
public List<ShowStaff>? ShowStaffs { get; set; }
|
public List<ShowStaff>? ShowStaffs { get; set; }
|
||||||
|
|||||||
+31
-8
@@ -1,19 +1,42 @@
|
|||||||
|
using FastEndpoints;
|
||||||
|
using FastEndpoints.Swagger;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using PyroFetes;
|
||||||
|
|
||||||
var builder = WebApplication.CreateBuilder(args);
|
var builder = WebApplication.CreateBuilder(args);
|
||||||
|
|
||||||
// Add services to the container.
|
builder.Services.AddDbContext<PyroFetesDbContext>(options =>
|
||||||
// Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
|
options.UseSqlServer(builder.Configuration.GetConnectionString("DefaultConnection")));
|
||||||
builder.Services.AddEndpointsApiExplorer();
|
|
||||||
builder.Services.AddSwaggerGen();
|
builder.Services.AddFastEndpoints();
|
||||||
|
builder.Services.SwaggerDocument();
|
||||||
|
|
||||||
var app = builder.Build();
|
var app = builder.Build();
|
||||||
|
|
||||||
// Configure the HTTP request pipeline.
|
using (var scope = app.Services.CreateScope())
|
||||||
|
{
|
||||||
|
var db = scope.ServiceProvider.GetRequiredService<PyroFetesDbContext>();
|
||||||
|
db.Database.ExecuteSqlRaw("""
|
||||||
|
IF EXISTS (
|
||||||
|
SELECT 1 FROM sys.foreign_keys
|
||||||
|
WHERE name = 'FK_Shows_Cities_CityId' AND parent_object_id = OBJECT_ID('Shows')
|
||||||
|
)
|
||||||
|
ALTER TABLE Shows DROP CONSTRAINT FK_Shows_Cities_CityId
|
||||||
|
""");
|
||||||
|
db.Database.ExecuteSqlRaw("""
|
||||||
|
IF COL_LENGTH('Shows', 'CityId') IS NOT NULL
|
||||||
|
AND COLUMNPROPERTY(OBJECT_ID('Shows'), 'CityId', 'AllowsNull') = 0
|
||||||
|
ALTER TABLE Shows ALTER COLUMN CityId INT NULL
|
||||||
|
""");
|
||||||
|
}
|
||||||
|
|
||||||
if (app.Environment.IsDevelopment())
|
if (app.Environment.IsDevelopment())
|
||||||
{
|
{
|
||||||
app.UseSwagger();
|
app.UseSwaggerGen();
|
||||||
app.UseSwaggerUI();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
app.UseHttpsRedirection();
|
app.UseHttpsRedirection();
|
||||||
|
app.UseFastEndpoints();
|
||||||
|
|
||||||
app.Run();
|
app.Run();
|
||||||
|
|
||||||
@@ -4,7 +4,7 @@ using ServiceProvider = PyroFetes.Models.ServiceProvider;
|
|||||||
|
|
||||||
namespace PyroFetes;
|
namespace PyroFetes;
|
||||||
|
|
||||||
public class PyroFetesDbContext : DbContext
|
public class PyroFetesDbContext(DbContextOptions<PyroFetesDbContext> options) : DbContext(options)
|
||||||
{
|
{
|
||||||
// Entities
|
// Entities
|
||||||
public DbSet<Availability> Availabilities { get; set; }
|
public DbSet<Availability> Availabilities { get; set; }
|
||||||
|
|||||||
@@ -5,5 +5,8 @@
|
|||||||
"Microsoft.AspNetCore": "Warning"
|
"Microsoft.AspNetCore": "Warning"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"AllowedHosts": "*"
|
"AllowedHosts": "*",
|
||||||
|
"ConnectionStrings": {
|
||||||
|
"DefaultConnection": "Server=romaric-thibault.fr;Database=PyroFetes;Trusted_Connection=True;TrustServerCertificate=True;"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user