-
Notifications
You must be signed in to change notification settings - Fork 27
Expand file tree
/
Copy pathEndpoint.cs
More file actions
44 lines (37 loc) · 1.38 KB
/
Endpoint.cs
File metadata and controls
44 lines (37 loc) · 1.38 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
using Authorization.Policies.Requirements;
using Feature.FormTemplates.Specifications;
using Microsoft.AspNetCore.Authorization;
using Vote.Monitor.Core.Services.Security;
using Vote.Monitor.Domain.Entities.FormTemplateAggregate;
namespace Feature.FormTemplates.Get;
public class Endpoint(
IReadRepository<FormTemplate> repository,
ICurrentUserRoleProvider userRoleProvider,
IAuthorizationService authorizationService) : Endpoint<Request, Results<Ok<FormTemplateFullModel>, NotFound>>
{
public override void Configure()
{
Get("/api/form-templates/{id}");
Policies(PolicyNames.AdminsOnly);
}
public override async Task<Results<Ok<FormTemplateFullModel>, NotFound>> ExecuteAsync(Request req,
CancellationToken ct)
{
var isNgoAdmin = userRoleProvider.IsNgoAdmin();
if (isNgoAdmin)
{
var result = await authorizationService.AuthorizeAsync(User, new NgoAdminRequirement());
if (!result.Succeeded)
{
return TypedResults.NotFound();
}
}
var formTemplate =
await repository.SingleOrDefaultAsync(new GetFormTemplateSpecification(req.Id, isNgoAdmin), ct);
if (formTemplate is null)
{
return TypedResults.NotFound();
}
return TypedResults.Ok(FormTemplateFullModel.FromEntity(formTemplate));
}
}