aboutsummaryrefslogtreecommitdiffstats
path: root/code/api/src/Endpoints/V1/Entries/UpdateEntryRoute.cs
diff options
context:
space:
mode:
authorivarlovlie <git@ivarlovlie.no>2022-11-14 04:37:56 +0100
committerivarlovlie <git@ivarlovlie.no>2022-11-14 04:37:56 +0100
commit11be5df857a74fa8ee1c9dcb661a293ed9f09536 (patch)
treee32055c5e2770234193ef7d4e82306746c31f78e /code/api/src/Endpoints/V1/Entries/UpdateEntryRoute.cs
parent47004bfcf8ef72556d8227bbce7dd5c06dc73040 (diff)
downloadgreatoffice-11be5df857a74fa8ee1c9dcb661a293ed9f09536.tar.xz
greatoffice-11be5df857a74fa8ee1c9dcb661a293ed9f09536.zip
feat: Remove old time tracker models, routes and entities
Diffstat (limited to 'code/api/src/Endpoints/V1/Entries/UpdateEntryRoute.cs')
-rw-r--r--code/api/src/Endpoints/V1/Entries/UpdateEntryRoute.cs66
1 files changed, 0 insertions, 66 deletions
diff --git a/code/api/src/Endpoints/V1/Entries/UpdateEntryRoute.cs b/code/api/src/Endpoints/V1/Entries/UpdateEntryRoute.cs
deleted file mode 100644
index 2254214..0000000
--- a/code/api/src/Endpoints/V1/Entries/UpdateEntryRoute.cs
+++ /dev/null
@@ -1,66 +0,0 @@
-namespace IOL.GreatOffice.Api.Endpoints.V1.Entries;
-
-public class UpdateEntryRoute : RouteBaseSync.WithRequest<TimeEntry.TimeEntryDto>.WithActionResult<TimeEntry.TimeEntryDto>
-{
- private readonly MainAppDatabase _database;
-
- public UpdateEntryRoute(MainAppDatabase database) {
- _database = database;
- }
-
- /// <summary>
- /// Update a time entry.
- /// </summary>
- /// <param name="timeEntryTimeEntryDto"></param>
- /// <returns></returns>
- [ApiVersion(ApiSpecV1.VERSION_STRING)]
- [BasicAuthentication(AppConstants.TOKEN_ALLOW_UPDATE)]
- [HttpPost("~/v{version:apiVersion}/entries/update")]
- [ProducesResponseType(404, Type = typeof(KnownProblemModel))]
- [ProducesResponseType(200, Type = typeof(TimeEntry.TimeEntryDto))]
- public override ActionResult<TimeEntry.TimeEntryDto> Handle(TimeEntry.TimeEntryDto timeEntryTimeEntryDto) {
- var entry = _database.TimeEntries
- .Where(c => c.UserId == LoggedInUser.Id)
- .Include(c => c.Labels)
- .SingleOrDefault(c => c.Id == timeEntryTimeEntryDto.Id);
-
- if (entry == default) {
- return NotFound();
- }
-
- 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}"));
- }
-
- entry.Start = timeEntryTimeEntryDto.Start.ToUniversalTime();
- entry.Stop = timeEntryTimeEntryDto.Stop.ToUniversalTime();
- entry.Description = timeEntryTimeEntryDto.Description;
- entry.Category = category;
-
- if (timeEntryTimeEntryDto.Labels?.Count > 0) {
- var labels = new List<TimeLabel>();
-
- foreach (var labelDto in timeEntryTimeEntryDto.Labels) {
- var label = _database.TimeLabels
- .Where(c => c.UserId == LoggedInUser.Id)
- .SingleOrDefault(c => c.Id == labelDto.Id);
-
- if (label == default) {
- continue;
- }
-
- labels.Add(label);
- }
-
- entry.Labels = labels;
- } else {
- entry.Labels = default;
- }
-
- _database.SaveChanges();
- return Ok(entry.AsDto);
- }
-} \ No newline at end of file