-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathOrdersController.cs
More file actions
82 lines (67 loc) · 3.42 KB
/
Copy pathOrdersController.cs
File metadata and controls
82 lines (67 loc) · 3.42 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
namespace Comanda.Orchestrator.WebApi.Controllers;
[ApiController]
[Route("api/v1/orders")]
public sealed class OrdersController(IDispatcher dispatcher) : ControllerBase
{
[HttpGet]
[Authorize(Roles = Permissions.ViewOrders)]
public async Task<IActionResult> GetOrdersAsync([FromQuery] OrdersFetchParameters request, CancellationToken cancellation)
{
var result = await dispatcher.DispatchAsync(request, cancellation);
/* applies pagination navigation links according to RFC 8288 (web linking) */
/* https://datatracker.ietf.org/doc/html/rfc8288 */
if (result.IsSuccess && result.Data is not null)
{
Response.WithPagination(result.Data);
Response.WithWebLinking(result.Data, Request);
}
return result switch
{
{ IsSuccess: true } when result.Data is not null =>
StatusCode(StatusCodes.Status200OK, result.Data.Items),
{ IsFailure: true } when result.Error == CommonErrors.OperationFailed =>
StatusCode(StatusCodes.Status500InternalServerError, result.Error),
{ IsFailure: true } when result.Error == CommonErrors.RateLimitExceeded =>
StatusCode(StatusCodes.Status429TooManyRequests, result.Error),
};
}
[HttpPost]
[Idempotent] // https://developer.mozilla.org/en-US/docs/Glossary/Idempotent
[Authorize(Roles = Permissions.CreateOrder)]
public async Task<IActionResult> CreateOrderAsync([FromBody] OrderCreationScheme request, CancellationToken cancellation)
{
var result = await dispatcher.DispatchAsync(request, cancellation);
/* appends resource location header according to RFC 9110 (HTTP Semantics) */
/* https://www.rfc-editor.org/rfc/rfc9110.html */
if (result.IsSuccess && result.Data is not null)
{
Response.WithResourceLocation(Request, result.Data.Identifier);
}
return result switch
{
{ IsSuccess: true } when result.Data is not null =>
StatusCode(StatusCodes.Status201Created, result.Data),
{ IsFailure: true } when result.Error == CommonErrors.OperationFailed =>
StatusCode(StatusCodes.Status500InternalServerError, result.Error),
{ IsFailure: true } when result.Error == CommonErrors.RateLimitExceeded =>
StatusCode(StatusCodes.Status429TooManyRequests, result.Error),
};
}
[HttpPut("{id}")]
[Authorize(Roles = Permissions.UpdateOrder)]
public async Task<IActionResult> UpdateOrderAsync([FromBody] OrderModificationScheme request, [FromRoute] string id, CancellationToken cancellation)
{
var result = await dispatcher.DispatchAsync(request with { Id = id }, cancellation);
return result switch
{
{ IsSuccess: true } when result.Data is not null =>
StatusCode(StatusCodes.Status200OK, result.Data),
{ IsFailure: true } when result.Error == OrderErrors.OrderDoesNotExist =>
StatusCode(StatusCodes.Status404NotFound, result.Error),
{ IsFailure: true } when result.Error == CommonErrors.OperationFailed =>
StatusCode(StatusCodes.Status500InternalServerError, result.Error),
{ IsFailure: true } when result.Error == CommonErrors.RateLimitExceeded =>
StatusCode(StatusCodes.Status429TooManyRequests, result.Error),
};
}
}