aboutsummaryrefslogtreecommitdiffstats
path: root/code/api/src/Endpoints/V1/Entries/CreateEntryRoute.cs
diff options
context:
space:
mode:
authorivarlovlie <git@ivarlovlie.no>2022-10-30 16:40:03 +0100
committerivarlovlie <git@ivarlovlie.no>2022-10-30 16:40:03 +0100
commit0725e4f7cf4c6f723264b6d461b91c660d144cb7 (patch)
treeaae5876b5760c80679161d918c34d753ec0e2582 /code/api/src/Endpoints/V1/Entries/CreateEntryRoute.cs
parentd76c180c9631df015d37138045c79a46cca350e8 (diff)
downloadgreatoffice-0725e4f7cf4c6f723264b6d461b91c660d144cb7.tar.xz
greatoffice-0725e4f7cf4c6f723264b6d461b91c660d144cb7.zip
feat: Apiwork
Diffstat (limited to 'code/api/src/Endpoints/V1/Entries/CreateEntryRoute.cs')
-rw-r--r--code/api/src/Endpoints/V1/Entries/CreateEntryRoute.cs107
1 files changed, 54 insertions, 53 deletions
diff --git a/code/api/src/Endpoints/V1/Entries/CreateEntryRoute.cs b/code/api/src/Endpoints/V1/Entries/CreateEntryRoute.cs
index 854ff59..45d8f32 100644
--- a/code/api/src/Endpoints/V1/Entries/CreateEntryRoute.cs
+++ b/code/api/src/Endpoints/V1/Entries/CreateEntryRoute.cs
@@ -2,65 +2,66 @@ namespace IOL.GreatOffice.Api.Endpoints.V1.Entries;
public class CreateEntryRoute : RouteBaseSync.WithRequest<TimeEntry.TimeEntryDto>.WithActionResult<TimeEntry.TimeEntryDto>
{
- private readonly AppDbContext _context;
+ private readonly MainAppDatabase _database;
- public CreateEntryRoute(AppDbContext context) {
- _context = context;
- }
+ 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"));
- }
+ /// <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.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"));
- }
+ if (timeEntryTimeEntryDto.Category == default) {
+ return BadRequest(new KnownProblemModel("Invalid form", "A category is required"));
+ }
- var category = _context.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 category = _database.TimeCategories
+ .Where(c => c.UserId == LoggedInUser.Id)
+ .SingleOrDefault(c => c.Id == timeEntryTimeEntryDto.Category.Id);
- var entry = new TimeEntry(LoggedInUser.Id) {
- Category = category,
- Start = timeEntryTimeEntryDto.Start.ToUniversalTime(),
- Stop = timeEntryTimeEntryDto.Stop.ToUniversalTime(),
- Description = timeEntryTimeEntryDto.Description,
- };
+ if (category == default) {
+ return NotFound(new KnownProblemModel("Not found", $"Could not find category {timeEntryTimeEntryDto.Category.Name}"));
+ }
- if (timeEntryTimeEntryDto.Labels?.Count > 0) {
- var labels = _context.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"));
- }
+ var entry = new TimeEntry(LoggedInUser) {
+ Category = category,
+ Start = timeEntryTimeEntryDto.Start.ToUniversalTime(),
+ Stop = timeEntryTimeEntryDto.Stop.ToUniversalTime(),
+ Description = timeEntryTimeEntryDto.Description,
+ };
+ entry.SetOwnerIds(LoggedInUser.Id);
- entry.Labels = labels;
- }
+ 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"));
+ }
- _context.TimeEntries.Add(entry);
- _context.SaveChanges();
- return Ok(entry.AsDto);
- }
-}
+ entry.Labels = labels;
+ }
+
+ _database.TimeEntries.Add(entry);
+ _database.SaveChanges();
+ return Ok(entry.AsDto);
+ }
+} \ No newline at end of file