aboutsummaryrefslogtreecommitdiffstats
path: root/code/api/src/Endpoints/V1/Labels
diff options
context:
space:
mode:
Diffstat (limited to 'code/api/src/Endpoints/V1/Labels')
-rw-r--r--code/api/src/Endpoints/V1/Labels/CreateLabelRoute.cs44
-rw-r--r--code/api/src/Endpoints/V1/Labels/DeleteLabelRoute.cs32
-rw-r--r--code/api/src/Endpoints/V1/Labels/GetLabelRoute.cs31
-rw-r--r--code/api/src/Endpoints/V1/Labels/UpdateLabelRoute.cs36
4 files changed, 0 insertions, 143 deletions
diff --git a/code/api/src/Endpoints/V1/Labels/CreateLabelRoute.cs b/code/api/src/Endpoints/V1/Labels/CreateLabelRoute.cs
deleted file mode 100644
index d6106aa..0000000
--- a/code/api/src/Endpoints/V1/Labels/CreateLabelRoute.cs
+++ /dev/null
@@ -1,44 +0,0 @@
-namespace IOL.GreatOffice.Api.Endpoints.V1.Labels;
-
-public class CreateLabelRoute : RouteBaseSync.WithRequest<TimeLabel.TimeLabelDto>.WithActionResult<TimeLabel.TimeLabelDto>
-{
- private readonly MainAppDatabase _database;
-
- public CreateLabelRoute(MainAppDatabase database) {
- _database = database;
- }
-
- /// <summary>
- /// Create a time entry label.
- /// </summary>
- /// <param name="labelTimeLabelDto"></param>
- /// <returns></returns>
- [ApiVersion(ApiSpecV1.VERSION_STRING)]
- [BasicAuthentication(AppConstants.TOKEN_ALLOW_CREATE)]
- [HttpPost("~/v{version:apiVersion}/labels/create")]
- public override ActionResult<TimeLabel.TimeLabelDto> Handle(TimeLabel.TimeLabelDto labelTimeLabelDto) {
- var duplicate = _database.TimeLabels
- .Where(c => c.UserId == LoggedInUser.Id)
- .Any(c => c.Name.Trim() == labelTimeLabelDto.Name.Trim());
- if (duplicate) {
- var label = _database.TimeLabels
- .Where(c => c.UserId == LoggedInUser.Id)
- .SingleOrDefault(c => c.Name.Trim() == labelTimeLabelDto.Name.Trim());
-
- if (label != default) {
- return Ok(label.AsDto);
- }
- }
-
- var newLabel = new TimeLabel(LoggedInUser) {
- Name = labelTimeLabelDto.Name.Trim(),
- Color = labelTimeLabelDto.Color
- };
- newLabel.SetOwnerIds(LoggedInUser.Id);
-
- _database.TimeLabels.Add(newLabel);
- _database.SaveChanges();
- labelTimeLabelDto.Id = newLabel.Id;
- return Ok(labelTimeLabelDto);
- }
-} \ No newline at end of file
diff --git a/code/api/src/Endpoints/V1/Labels/DeleteLabelRoute.cs b/code/api/src/Endpoints/V1/Labels/DeleteLabelRoute.cs
deleted file mode 100644
index 1baf4ef..0000000
--- a/code/api/src/Endpoints/V1/Labels/DeleteLabelRoute.cs
+++ /dev/null
@@ -1,32 +0,0 @@
-namespace IOL.GreatOffice.Api.Endpoints.V1.Labels;
-
-public class DeleteLabelEndpoint : RouteBaseSync.WithRequest<Guid>.WithActionResult
-{
- private readonly MainAppDatabase _database;
-
- public DeleteLabelEndpoint(MainAppDatabase database) {
- _database = database;
- }
-
- /// <summary>
- /// Delete a time entry label.
- /// </summary>
- /// <param name="id"></param>
- /// <returns></returns>
- [ApiVersion(ApiSpecV1.VERSION_STRING)]
- [BasicAuthentication(AppConstants.TOKEN_ALLOW_DELETE)]
- [HttpDelete("~/v{version:apiVersion}/labels/{id:guid}/delete")]
- public override ActionResult Handle(Guid id) {
- var label = _database.TimeLabels
- .Where(c => c.UserId == LoggedInUser.Id)
- .SingleOrDefault(c => c.Id == id);
-
- if (label == default) {
- return NotFound();
- }
-
- _database.TimeLabels.Remove(label);
- _database.SaveChanges();
- return Ok();
- }
-} \ No newline at end of file
diff --git a/code/api/src/Endpoints/V1/Labels/GetLabelRoute.cs b/code/api/src/Endpoints/V1/Labels/GetLabelRoute.cs
deleted file mode 100644
index 09d453b..0000000
--- a/code/api/src/Endpoints/V1/Labels/GetLabelRoute.cs
+++ /dev/null
@@ -1,31 +0,0 @@
-namespace IOL.GreatOffice.Api.Endpoints.V1.Labels;
-
-public class GetEndpoint : RouteBaseSync.WithoutRequest.WithActionResult<List<TimeLabel.TimeLabelDto>>
-{
- private readonly MainAppDatabase _database;
-
- public GetEndpoint(MainAppDatabase database) {
- _database = database;
- }
-
- /// <summary>
- /// Get a minimal list of time entry labels.
- /// </summary>
- /// <returns></returns>
- [ApiVersion(ApiSpecV1.VERSION_STRING)]
- [BasicAuthentication(AppConstants.TOKEN_ALLOW_READ)]
- [HttpGet("~/v{version:apiVersion}/labels")]
- public override ActionResult<List<TimeLabel.TimeLabelDto>> Handle() {
- var labels = _database.TimeLabels
- .Where(c => c.UserId == LoggedInUser.Id)
- .OrderByDescending(c => c.CreatedAt)
- .Select(c => c.AsDto)
- .ToList();
-
- if (labels.Count == 0) {
- return NoContent();
- }
-
- return Ok(labels);
- }
-} \ No newline at end of file
diff --git a/code/api/src/Endpoints/V1/Labels/UpdateLabelRoute.cs b/code/api/src/Endpoints/V1/Labels/UpdateLabelRoute.cs
deleted file mode 100644
index 9857b7d..0000000
--- a/code/api/src/Endpoints/V1/Labels/UpdateLabelRoute.cs
+++ /dev/null
@@ -1,36 +0,0 @@
-namespace IOL.GreatOffice.Api.Endpoints.V1.Labels;
-
-public class UpdateLabelEndpoint : RouteBaseSync.WithRequest<TimeLabel.TimeLabelDto>.WithActionResult
-{
- private readonly MainAppDatabase _database;
-
- public UpdateLabelEndpoint(MainAppDatabase database) {
- _database = database;
- }
-
- /// <summary>
- /// Update a time entry label.
- /// </summary>
- /// <param name="labelTimeLabelDto"></param>
- /// <returns></returns>
- [ApiVersion(ApiSpecV1.VERSION_STRING)]
- [BasicAuthentication(AppConstants.TOKEN_ALLOW_UPDATE)]
- [HttpPost("~/v{version:apiVersion}/labels/update")]
- public override ActionResult Handle(TimeLabel.TimeLabelDto labelTimeLabelDto) {
- var label = _database.TimeLabels
- .Where(c => c.UserId == LoggedInUser.Id)
- .SingleOrDefault(c => c.Id == labelTimeLabelDto.Id);
- if (label == default) {
- return NotFound();
- }
-
- if (LoggedInUser.Id != label.UserId) {
- return Forbid();
- }
-
- label.Name = labelTimeLabelDto.Name;
- label.Color = labelTimeLabelDto.Color;
- _database.SaveChanges();
- return Ok();
- }
-} \ No newline at end of file