| | | 1 | | using Chronicis.Api.Infrastructure; |
| | | 2 | | using Chronicis.Api.Services; |
| | | 3 | | using Chronicis.Shared.DTOs; |
| | | 4 | | using Chronicis.Shared.Extensions; |
| | | 5 | | using Microsoft.AspNetCore.Authorization; |
| | | 6 | | using Microsoft.AspNetCore.Mvc; |
| | | 7 | | |
| | | 8 | | namespace Chronicis.Api.Controllers; |
| | | 9 | | |
| | | 10 | | /// <summary> |
| | | 11 | | /// Controller for managing resource providers and their world associations. |
| | | 12 | | /// </summary> |
| | | 13 | | [ApiController] |
| | | 14 | | [Route("api/worlds/{worldId}/resource-providers")] |
| | | 15 | | [Authorize] |
| | | 16 | | public class ResourceProvidersController : ControllerBase |
| | | 17 | | { |
| | | 18 | | private readonly IResourceProviderService _service; |
| | | 19 | | private readonly ICurrentUserService _currentUserService; |
| | | 20 | | private readonly ILogger<ResourceProvidersController> _logger; |
| | | 21 | | |
| | 0 | 22 | | public ResourceProvidersController( |
| | 0 | 23 | | IResourceProviderService service, |
| | 0 | 24 | | ICurrentUserService currentUserService, |
| | 0 | 25 | | ILogger<ResourceProvidersController> logger) |
| | | 26 | | { |
| | 0 | 27 | | _service = service; |
| | 0 | 28 | | _currentUserService = currentUserService; |
| | 0 | 29 | | _logger = logger; |
| | 0 | 30 | | } |
| | | 31 | | |
| | | 32 | | /// <summary> |
| | | 33 | | /// Gets all resource providers with their enabled status for a world. |
| | | 34 | | /// </summary> |
| | | 35 | | /// <param name="worldId">The world ID</param> |
| | | 36 | | /// <returns>List of providers with enabled status</returns> |
| | | 37 | | [HttpGet] |
| | | 38 | | [ProducesResponseType(typeof(List<WorldResourceProviderDto>), StatusCodes.Status200OK)] |
| | | 39 | | [ProducesResponseType(StatusCodes.Status401Unauthorized)] |
| | | 40 | | [ProducesResponseType(StatusCodes.Status403Forbidden)] |
| | | 41 | | [ProducesResponseType(StatusCodes.Status404NotFound)] |
| | | 42 | | public async Task<IActionResult> GetWorldProviders(Guid worldId) |
| | | 43 | | { |
| | | 44 | | try |
| | | 45 | | { |
| | 0 | 46 | | var user = await _currentUserService.GetRequiredUserAsync(); |
| | 0 | 47 | | var providers = await _service.GetWorldProvidersAsync(worldId, user.Id); |
| | | 48 | | |
| | 0 | 49 | | var dtos = providers.Select(p => new WorldResourceProviderDto |
| | 0 | 50 | | { |
| | 0 | 51 | | Provider = new ResourceProviderDto |
| | 0 | 52 | | { |
| | 0 | 53 | | Code = p.Provider.Code, |
| | 0 | 54 | | Name = p.Provider.Name, |
| | 0 | 55 | | Description = p.Provider.Description, |
| | 0 | 56 | | DocumentationLink = p.Provider.DocumentationLink, |
| | 0 | 57 | | License = p.Provider.License |
| | 0 | 58 | | }, |
| | 0 | 59 | | IsEnabled = p.IsEnabled |
| | 0 | 60 | | }).ToList(); |
| | | 61 | | |
| | 0 | 62 | | return Ok(dtos); |
| | | 63 | | } |
| | 0 | 64 | | catch (KeyNotFoundException ex) |
| | | 65 | | { |
| | 0 | 66 | | _logger.LogWarning(ex, "World {WorldId} not found", worldId); |
| | 0 | 67 | | return NotFound(new { message = ex.Message }); |
| | | 68 | | } |
| | 0 | 69 | | catch (UnauthorizedAccessException ex) |
| | | 70 | | { |
| | 0 | 71 | | _logger.LogWarning(ex, "Unauthorized access to world {WorldId}", worldId); |
| | 0 | 72 | | return Forbid(); |
| | | 73 | | } |
| | 0 | 74 | | } |
| | | 75 | | |
| | | 76 | | /// <summary> |
| | | 77 | | /// Enables or disables a resource provider for a world. |
| | | 78 | | /// Only the world owner can modify provider settings. |
| | | 79 | | /// </summary> |
| | | 80 | | /// <param name="worldId">The world ID</param> |
| | | 81 | | /// <param name="providerCode">The provider code</param> |
| | | 82 | | /// <param name="request">Toggle request</param> |
| | | 83 | | /// <returns>Success result</returns> |
| | | 84 | | [HttpPost("{providerCode}/toggle")] |
| | | 85 | | [ProducesResponseType(StatusCodes.Status200OK)] |
| | | 86 | | [ProducesResponseType(StatusCodes.Status401Unauthorized)] |
| | | 87 | | [ProducesResponseType(StatusCodes.Status403Forbidden)] |
| | | 88 | | [ProducesResponseType(StatusCodes.Status404NotFound)] |
| | | 89 | | public async Task<IActionResult> ToggleProvider( |
| | | 90 | | Guid worldId, |
| | | 91 | | string providerCode, |
| | | 92 | | [FromBody] ToggleResourceProviderRequestDto request) |
| | | 93 | | { |
| | | 94 | | try |
| | | 95 | | { |
| | 0 | 96 | | var user = await _currentUserService.GetRequiredUserAsync(); |
| | 0 | 97 | | await _service.SetProviderEnabledAsync(worldId, providerCode, request.Enabled, user.Id); |
| | | 98 | | |
| | 0 | 99 | | return Ok(new { message = $"Provider {providerCode} {(request.Enabled ? "enabled" : "disabled")} successfull |
| | | 100 | | } |
| | 0 | 101 | | catch (KeyNotFoundException ex) |
| | | 102 | | { |
| | 0 | 103 | | _logger.LogErrorSanitized(ex, "World {WorldId} or provider {ProviderCode} not found", worldId, providerCode) |
| | 0 | 104 | | return NotFound(new { message = ex.Message }); |
| | | 105 | | } |
| | 0 | 106 | | catch (UnauthorizedAccessException ex) |
| | | 107 | | { |
| | 0 | 108 | | _logger.LogWarning(ex, "Unauthorized attempt to modify world {WorldId}", worldId); |
| | 0 | 109 | | return Forbid(); |
| | | 110 | | } |
| | 0 | 111 | | } |
| | | 112 | | } |