-
Notifications
You must be signed in to change notification settings - Fork 526
Expand file tree
/
Copy pathCategoryController.cs
More file actions
125 lines (106 loc) · 4.85 KB
/
CategoryController.cs
File metadata and controls
125 lines (106 loc) · 4.85 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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
using Grand.Module.Api.Commands.Models.Catalog;
using Grand.Module.Api.DTOs.Catalog;
using Grand.Module.Api.Queries.Models.Common;
using Grand.Business.Core.Interfaces.Common.Security;
using Grand.Domain.Permissions;
using Grand.Domain.Catalog;
using MediatR;
using Microsoft.AspNetCore.JsonPatch.SystemTextJson;
using Microsoft.AspNetCore.Mvc;
using Grand.Module.Api.Attributes;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Routing;
namespace Grand.Module.Api.Controllers;
public class CategoryController : BaseApiController
{
private readonly IMediator _mediator;
private readonly IPermissionService _permissionService;
public CategoryController(
IMediator mediator,
IPermissionService permissionService)
{
_mediator = mediator;
_permissionService = permissionService;
}
[EndpointDescription("Get entity from Category by key")]
[EndpointName("GetCategoryById")]
[HttpGet("{key}")]
[ProducesResponseType(StatusCodes.Status403Forbidden)]
[ProducesResponseType(StatusCodes.Status200OK, Type = typeof(CategoryDto))]
[ProducesResponseType(StatusCodes.Status404NotFound)]
public async Task<IActionResult> Get([FromRoute] string key)
{
if (!await _permissionService.Authorize(PermissionSystemName.Categories)) return Forbid();
var category = await _mediator.Send(new GetGenericQuery<CategoryDto, Category>(key));
if (!category.Any()) return NotFound();
return Ok(category.FirstOrDefault());
}
[EndpointDescription("Get entities from Category")]
[EndpointName("GetCategories")]
[HttpGet]
[EnableQuery]
[ProducesResponseType(StatusCodes.Status403Forbidden)]
[ProducesResponseType(StatusCodes.Status200OK, Type = typeof(IEnumerable<CategoryDto>))]
public async Task<IActionResult> Get()
{
if (!await _permissionService.Authorize(PermissionSystemName.Categories)) return Forbid();
return Ok(await _mediator.Send(new GetGenericQuery<CategoryDto, Category>()));
}
[EndpointDescription("Add new entity to Category")]
[EndpointName("InsertCategory")]
[HttpPost]
[ProducesResponseType(StatusCodes.Status403Forbidden)]
[ProducesResponseType(StatusCodes.Status200OK, Type = typeof(CategoryDto))]
[ProducesResponseType(StatusCodes.Status400BadRequest)]
public async Task<IActionResult> Post([FromBody] CategoryDto model)
{
if (!await _permissionService.Authorize(PermissionSystemName.Categories)) return Forbid();
model = await _mediator.Send(new AddCategoryCommand { Model = model });
return Ok(model);
}
[EndpointDescription("Update entity in Category")]
[EndpointName("UpdateCategory")]
[HttpPut]
[ProducesResponseType(StatusCodes.Status403Forbidden)]
[ProducesResponseType(StatusCodes.Status200OK, Type = typeof(CategoryDto))]
[ProducesResponseType(StatusCodes.Status400BadRequest)]
public async Task<IActionResult> Put([FromBody] CategoryDto model)
{
if (!await _permissionService.Authorize(PermissionSystemName.Categories)) return Forbid();
model = await _mediator.Send(new UpdateCategoryCommand { Model = model });
return Ok(model);
}
[EndpointDescription("Update entity in Category (delta)")]
[EndpointName("UpdateCategoryPatch")]
[HttpPatch("{key}")]
[ProducesResponseType(StatusCodes.Status403Forbidden)]
[ProducesResponseType(StatusCodes.Status200OK)]
[ProducesResponseType(StatusCodes.Status400BadRequest)]
[ProducesResponseType(StatusCodes.Status404NotFound)]
public async Task<IActionResult> Patch([FromRoute] string key, [FromBody] JsonPatchDocument<CategoryDto> model)
{
if (string.IsNullOrEmpty(key))
return BadRequest("Key is null or empty");
if (!await _permissionService.Authorize(PermissionSystemName.Categories)) return Forbid();
var category = await _mediator.Send(new GetGenericQuery<CategoryDto, Category>(key));
if (!category.Any()) return NotFound();
var cat = category.FirstOrDefault();
model.ApplyTo(cat);
await _mediator.Send(new UpdateCategoryCommand { Model = cat });
return Ok();
}
[EndpointDescription("Delete entity from Category")]
[EndpointName("DeleteCategory")]
[HttpDelete("{key}")]
[ProducesResponseType(StatusCodes.Status403Forbidden)]
[ProducesResponseType(StatusCodes.Status200OK)]
[ProducesResponseType(StatusCodes.Status404NotFound)]
public async Task<IActionResult> Delete([FromRoute] string key)
{
if (!await _permissionService.Authorize(PermissionSystemName.Categories)) return Forbid();
var category = await _mediator.Send(new GetGenericQuery<CategoryDto, Category>(key));
if (!category.Any()) return NotFound();
await _mediator.Send(new DeleteCategoryCommand { Model = category.FirstOrDefault() });
return Ok();
}
}