aboutsummaryrefslogtreecommitdiffstats
path: root/code/api/src/Endpoints/V1/Entries/CreateEntryRoute.cs
diff options
context:
space:
mode:
Diffstat (limited to 'code/api/src/Endpoints/V1/Entries/CreateEntryRoute.cs')
-rw-r--r--code/api/src/Endpoints/V1/Entries/CreateEntryRoute.cs67
1 files changed, 0 insertions, 67 deletions
diff --git a/code/api/src/Endpoints/V1/Entries/CreateEntryRoute.cs b/code/api/src/Endpoints/V1/Entries/CreateEntryRoute.cs
deleted file mode 100644
index 45d8f32..0000000
--- a/code/api/src/Endpoints/V1/Entries/CreateEntryRoute.cs
+++ /dev/null
@@ -1,67 +0,0 @@
-namespace IOL.GreatOffice.Api.Endpoints.V1.Entries;
-
-public class CreateEntryRoute : RouteBaseSync.WithRequest<TimeEntry.TimeEntryDto>.WithActionResult<TimeEntry.TimeEntryDto>
-{
- private readonly MainAppDatabase _database;
-
- public CreateEntryRoute(MainAppDatabase database) {
- _database = database;
- }
-
- /// <summary>
- /// Create a time entry.
- /// </summary>
- /// <param name="timeEntryTimeEntryDto"></param>
- /// <returns></returns>
- [ApiVersion(ApiSpecV1.VERSION_STRING)]
- [BasicAuthentication(AppConstants.TOKEN_ALLOW_CREATE)]
- [ProducesResponseType(200)]
- [ProducesResponseType(400, Type = typeof(KnownProblemModel))]
- [ProducesResponseType(404, Type = typeof(KnownProblemModel))]
- [HttpPost("~/v{version:apiVersion}/entries/create")]
- public override ActionResult<TimeEntry.TimeEntryDto> Handle(TimeEntry.TimeEntryDto timeEntryTimeEntryDto) {
- if (timeEntryTimeEntryDto.Stop == default) {
- return BadRequest(new KnownProblemModel("Invalid form", "A stop date is required"));
- }
-
- if (timeEntryTimeEntryDto.Start == default) {
- return BadRequest(new KnownProblemModel("Invalid form", "A start date is required"));
- }
-
- if (timeEntryTimeEntryDto.Category == default) {
- return BadRequest(new KnownProblemModel("Invalid form", "A category is required"));
- }
-
- var category = _database.TimeCategories
- .Where(c => c.UserId == LoggedInUser.Id)
- .SingleOrDefault(c => c.Id == timeEntryTimeEntryDto.Category.Id);
-
- if (category == default) {
- return NotFound(new KnownProblemModel("Not found", $"Could not find category {timeEntryTimeEntryDto.Category.Name}"));
- }
-
- var entry = new TimeEntry(LoggedInUser) {
- Category = category,
- Start = timeEntryTimeEntryDto.Start.ToUniversalTime(),
- Stop = timeEntryTimeEntryDto.Stop.ToUniversalTime(),
- Description = timeEntryTimeEntryDto.Description,
- };
- entry.SetOwnerIds(LoggedInUser.Id);
-
- if (timeEntryTimeEntryDto.Labels?.Count > 0) {
- var labels = _database.TimeLabels
- .Where(c => c.UserId == LoggedInUser.Id)
- .Where(c => timeEntryTimeEntryDto.Labels.Select(p => p.Id).Contains(c.Id))
- .ToList();
- if (labels.Count != timeEntryTimeEntryDto.Labels.Count) {
- return NotFound(new KnownProblemModel("Not found", "Could not find all of the specified labels"));
- }
-
- entry.Labels = labels;
- }
-
- _database.TimeEntries.Add(entry);
- _database.SaveChanges();
- return Ok(entry.AsDto);
- }
-} \ No newline at end of file