Class CurrenciesController
- Namespace
- KadicErp.WebApi.Controllers.ReferenceData
- Assembly
- KadicErp.WebApi.dll
[Route("api/[controller]")]
[Authorize]
public class CurrenciesController : GenericCrudControllerBase<CurrencyDto, CreateCurrencyCommand, UpdateCurrencyCommand, GetCurrencyByIdQuery, GetAllCurrenciesQuery>
- Inheritance
-
objectControllerBaseGenericCrudControllerBase<CurrencyDto, CreateCurrencyCommand, UpdateCurrencyCommand, GetCurrencyByIdQuery, GetAllCurrenciesQuery>CurrenciesController
- Inherited Members
-
GenericCrudControllerBase<CurrencyDto, CreateCurrencyCommand, UpdateCurrencyCommand, GetCurrencyByIdQuery, GetAllCurrenciesQuery>.SenderGenericCrudControllerBase<CurrencyDto, CreateCurrencyCommand, UpdateCurrencyCommand, GetCurrencyByIdQuery, GetAllCurrenciesQuery>.CreateGetByIdQuery(Guid)GenericCrudControllerBase<CurrencyDto, CreateCurrencyCommand, UpdateCurrencyCommand, GetCurrencyByIdQuery, GetAllCurrenciesQuery>.CreateGetAllQuery(PaginatorRequestDto, bool?)GenericCrudControllerBase<CurrencyDto, CreateCurrencyCommand, UpdateCurrencyCommand, GetCurrencyByIdQuery, GetAllCurrenciesQuery>.SetCommandId(UpdateCurrencyCommand, Guid)GenericCrudControllerBase<CurrencyDto, CreateCurrencyCommand, UpdateCurrencyCommand, GetCurrencyByIdQuery, GetAllCurrenciesQuery>.HandleCommandResult(Result)GenericCrudControllerBase<CurrencyDto, CreateCurrencyCommand, UpdateCurrencyCommand, GetCurrencyByIdQuery, GetAllCurrenciesQuery>.HandleCommandResult<T>(Result<T>, string)GenericCrudControllerBase<CurrencyDto, CreateCurrencyCommand, UpdateCurrencyCommand, GetCurrencyByIdQuery, GetAllCurrenciesQuery>.Create(CreateCurrencyCommand)GenericCrudControllerBase<CurrencyDto, CreateCurrencyCommand, UpdateCurrencyCommand, GetCurrencyByIdQuery, GetAllCurrenciesQuery>.Update(Guid, UpdateCurrencyCommand)GenericCrudControllerBase<CurrencyDto, CreateCurrencyCommand, UpdateCurrencyCommand, GetCurrencyByIdQuery, GetAllCurrenciesQuery>.GetById(Guid)GenericCrudControllerBase<CurrencyDto, CreateCurrencyCommand, UpdateCurrencyCommand, GetCurrencyByIdQuery, GetAllCurrenciesQuery>.GetAll(PaginatorRequestDto, bool?)
Constructors
CurrenciesController(ISender, IStringLocalizer<GeneralMessages>)
public CurrenciesController(ISender sender, IStringLocalizer<GeneralMessages> localizer)
Parameters
senderISenderlocalizerIStringLocalizer<GeneralMessages>
Methods
Activate(Guid)
[HttpPatch("{id}/activate")]
[Authorize(Policy = "REFERENCE_DATA_CURRENCIES_ACTIVATE")]
public Task<IActionResult> Activate(Guid id)
Parameters
idGuid
Returns
- Task<IActionResult>
Create(CreateCurrencyCommand)
POST endpoint for creating a new entity. Returns 201 Created with Location header on success.
IMPORTANT: Override in derived class to add [HttpPost] and [Authorize(Policy = ...)]
[HttpPost]
[Authorize(Policy = "REFERENCE_DATA_CURRENCIES_CREATE")]
[ProducesResponseType(typeof(Result<Guid>), 201)]
[ProducesResponseType(typeof(Result), 400)]
[ProducesResponseType(typeof(Result), 409)]
public override Task<IActionResult> Create(CreateCurrencyCommand command)
Parameters
commandCreateCurrencyCommand
Returns
- Task<IActionResult>
Deactivate(Guid)
[HttpPatch("{id}/deactivate")]
[Authorize(Policy = "REFERENCE_DATA_CURRENCIES_DEACTIVATE")]
public Task<IActionResult> Deactivate(Guid id)
Parameters
idGuid
Returns
- Task<IActionResult>
GetAll(PaginatorRequestDto, bool?)
GET endpoint for retrieving paginated list of entities. Supports optional isActive filter.
IMPORTANT: Override in derived class to add [HttpGet] and [Authorize(Policy = ...)] Override CreateGetAllQuery if you need additional filters. Note: ProducesResponseType attributes cannot be added here due to generic type parameters. Add them in derived class if needed for Swagger documentation.
[HttpGet]
[Authorize(Policy = "REFERENCE_DATA_CURRENCIES_VIEW")]
[ProducesResponseType(typeof(PaginatorResponseDto<CurrencyDto>), 200)]
[ProducesResponseType(typeof(Error), 400)]
public override Task<IActionResult> GetAll(PaginatorRequestDto paginator, bool? isActive = null)
Parameters
paginatorPaginatorRequestDtoisActivebool?
Returns
- Task<IActionResult>
GetByCode(string)
[HttpGet("{code}")]
[Authorize(Policy = "REFERENCE_DATA_CURRENCIES_VIEW")]
[ProducesResponseType(typeof(CurrencyDto), 200)]
[ProducesResponseType(typeof(Error), 404)]
public Task<IActionResult> GetByCode(string code)
Parameters
codestring
Returns
- Task<IActionResult>
GetById(Guid)
GET endpoint for retrieving a single entity by ID. Returns 404 Not Found if entity doesn't exist.
IMPORTANT: Override in derived class to add [HttpGet("{id}")] and [Authorize(Policy = ...)] Note: ProducesResponseType attributes cannot be added here due to generic type parameters. Add them in derived class if needed for Swagger documentation.
[HttpGet("{id:guid}")]
[Authorize(Policy = "REFERENCE_DATA_CURRENCIES_VIEW")]
[ProducesResponseType(typeof(CurrencyDto), 200)]
[ProducesResponseType(typeof(Error), 404)]
public override Task<IActionResult> GetById(Guid id)
Parameters
idGuid
Returns
- Task<IActionResult>
SetCommandId(UpdateCurrencyCommand, Guid)
Updates the command with the ID from route. This method must be overridden in derived classes to properly set the Id.
For record types with 'with' expression, use:
protected override UpdateXCommand SetCommandId(UpdateXCommand command, Guid id)
=> command with { Id = id };
protected override UpdateCurrencyCommand SetCommandId(UpdateCurrencyCommand command, Guid id)
Parameters
commandUpdateCurrencyCommandidGuid
Returns
- UpdateCurrencyCommand
Update(Guid, UpdateCurrencyCommand)
PUT endpoint for updating an existing entity. Returns 200 OK on success.
IMPORTANT: Override in derived class to add [HttpPut("{id}")] and [Authorize(Policy = ...)]
[HttpPut("{id}")]
[Authorize(Policy = "REFERENCE_DATA_CURRENCIES_UPDATE")]
[ProducesResponseType(typeof(Result), 200)]
[ProducesResponseType(typeof(Result), 400)]
[ProducesResponseType(typeof(Result), 404)]
[ProducesResponseType(typeof(Result), 409)]
public override Task<IActionResult> Update(Guid id, UpdateCurrencyCommand command)
Parameters
idGuidcommandUpdateCurrencyCommand
Returns
- Task<IActionResult>