using System; using Microsoft.AspNetCore.Http; using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.Authorization; using Microsoft.Extensions.Logging; using AyaNova.Api.ControllerHelpers; using AyaNova.Biz; using AyaNova.Models; using System.ComponentModel.DataAnnotations; namespace AyaNova.Api.Controllers { /// /// Server state controller /// [ApiVersion("8.0")] [Route("api/v{version:apiVersion}/[controller]")] [Produces("application/json")] public class ServerStateController : Controller { private readonly AyContext ct; private readonly ILogger log; private readonly ApiServerState serverState; /// /// ctor /// /// /// /// public ServerStateController(ILogger logger, ApiServerState apiServerState, AyContext dbcontext) { ct = dbcontext; log = logger; serverState = apiServerState; } /// /// Get server state /// /// Required roles: /// [NONE / authentication not required] /// /// Current server state (Closed, OpsOnly, Open) [HttpGet] public ActionResult Get() { return Ok(new ApiOkResponse(new ServerStateModel() { ServerState = serverState.GetState().ToString(), Reason = serverState.Reason })); } /// /// Set server state /// /// Required roles: /// [OpsFull, BizAdminFull] /// /// Valid parameters: /// One of "Closed", "OpsOnly" or "Open" /// /// /// {"NewState":"Closed"} /// NoContent 204 [HttpPost] [Authorize] public ActionResult PostServerState([FromBody] ServerStateModel state) { if (!Authorized.IsAuthorizedToModify(HttpContext.Items, AyaType.ServerState)) { return StatusCode(403, new ApiNotAuthorizedResponse()); } if (serverState.IsSystemLocked)//no state change allowed when system locked, must correct the problem first { return StatusCode(503, new ApiErrorResponse(ApiErrorCode.API_CLOSED, null, serverState.Reason)); } if (!ModelState.IsValid) { return BadRequest(new ApiErrorResponse(ModelState)); } ApiServerState.ServerState desiredState; if (!Enum.TryParse(state.ServerState, true, out desiredState)) { return BadRequest(new ApiErrorResponse(ApiErrorCode.VALIDATION_INVALID_VALUE, null, "Invalid state - must be one of \"Closing\", \"Closed\", \"OpsOnly\" or \"Open\"")); } log.LogInformation($"ServerState change request by user {UserNameFromContext.Name(HttpContext.Items)} from current state of \"{serverState.GetState().ToString()}\" to \"{desiredState.ToString()}\""); serverState.SetState(desiredState, state.Reason); //Log EventLogProcessor.LogEventToDatabase(new Event(UserIdFromContext.Id(HttpContext.Items), 0, AyaType.ServerState, AyaEvent.ServerStateChange, $"{state.ServerState}-{state.Reason}"), ct); return NoContent(); } /// /// Parameter object /// public class ServerStateModel { /// /// One of "Closed", "OpsOnly" or "Open" /// /// [Required] public string ServerState { get; set; } /// /// Reason for server state /// /// public string Reason { get; set; } } //------------ } }