From cba9c246b20c9b2d33546a48ac5878dc46e87f55 Mon Sep 17 00:00:00 2001 From: ivarlovlie Date: Thu, 17 Nov 2022 13:52:37 +0700 Subject: refactor: Use explicit req/res classes instead of common dto --- .../src/Endpoints/V1/ApiTokens/CreateTokenRoute.cs | 13 +++++++++++-- .../src/Endpoints/V1/ApiTokens/GetTokensRoute.cs | 22 +++++++++++++++++++--- 2 files changed, 30 insertions(+), 5 deletions(-) (limited to 'code/api/src/Endpoints') diff --git a/code/api/src/Endpoints/V1/ApiTokens/CreateTokenRoute.cs b/code/api/src/Endpoints/V1/ApiTokens/CreateTokenRoute.cs index c4f2ee5..163ddb6 100644 --- a/code/api/src/Endpoints/V1/ApiTokens/CreateTokenRoute.cs +++ b/code/api/src/Endpoints/V1/ApiTokens/CreateTokenRoute.cs @@ -2,7 +2,7 @@ using System.Text; namespace IOL.GreatOffice.Api.Endpoints.V1.ApiTokens; -public class CreateTokenRoute : RouteBaseSync.WithRequest.WithActionResult +public class CreateTokenRoute : RouteBaseSync.WithRequest.WithActionResult { private readonly MainAppDatabase _database; private readonly AppConfiguration _configuration; @@ -14,6 +14,15 @@ public class CreateTokenRoute : RouteBaseSync.WithRequest /// Create a new api token with the provided claims. /// @@ -21,7 +30,7 @@ public class CreateTokenRoute : RouteBaseSync.WithRequest [ApiVersion(ApiSpecV1.VERSION_STRING)] [HttpPost("~/v{version:apiVersion}/api-tokens/create")] - public override ActionResult Handle(ApiAccessToken.ApiAccessTokenDto request) { + public override ActionResult Handle(Payload request) { var user = _database.Users.SingleOrDefault(c => c.Id == LoggedInUser.Id); if (user == default) { return NotFound(new KnownProblemModel("User does not exist")); diff --git a/code/api/src/Endpoints/V1/ApiTokens/GetTokensRoute.cs b/code/api/src/Endpoints/V1/ApiTokens/GetTokensRoute.cs index 90f4d71..ee46b34 100644 --- a/code/api/src/Endpoints/V1/ApiTokens/GetTokensRoute.cs +++ b/code/api/src/Endpoints/V1/ApiTokens/GetTokensRoute.cs @@ -1,6 +1,6 @@ namespace IOL.GreatOffice.Api.Endpoints.V1.ApiTokens; -public class GetTokensRoute : RouteBaseSync.WithoutRequest.WithResult>> +public class GetTokensRoute : RouteBaseSync.WithoutRequest.WithResult>> { private readonly MainAppDatabase _database; @@ -8,13 +8,29 @@ public class GetTokensRoute : RouteBaseSync.WithoutRequest.WithResult ExpiryDate < AppDateTime.UtcNow; + } + /// /// Get all tokens, both active and inactive. /// /// A list of tokens [ApiVersion(ApiSpecV1.VERSION_STRING)] [HttpGet("~/v{version:apiVersion}/api-tokens")] - public override ActionResult> Handle() { - return Ok(_database.AccessTokens.Where(c => c.User.Id == LoggedInUser.Id).Select(c => c.AsDto)); + public override ActionResult> Handle() { + return Ok(_database.AccessTokens.Where(c => c.User.Id == LoggedInUser.Id).Select(c => new ResponseModel() { + AllowCreate = c.AllowCreate, + AllowRead = c.AllowRead, + AllowDelete = c.AllowDelete, + AllowUpdate = c.AllowUpdate, + ExpiryDate = c.ExpiryDate + })); } } \ No newline at end of file -- cgit v1.3