From d31837b4fbecc872ba2212730581ce8f259a19e5 Mon Sep 17 00:00:00 2001 From: Sam Warren Date: Mon, 30 Dec 2024 11:20:37 -0800 Subject: [PATCH] Add try/catch to GRPC configuration call --- .../Controllers/ConfigurationController.cs | 39 +++++++++++++++---- 1 file changed, 32 insertions(+), 7 deletions(-) diff --git a/responders/src/API/EMBC.Responders.API/Controllers/ConfigurationController.cs b/responders/src/API/EMBC.Responders.API/Controllers/ConfigurationController.cs index b499181b2..1eabaf236 100644 --- a/responders/src/API/EMBC.Responders.API/Controllers/ConfigurationController.cs +++ b/responders/src/API/EMBC.Responders.API/Controllers/ConfigurationController.cs @@ -14,6 +14,7 @@ using Microsoft.AspNetCore.Http; using Microsoft.AspNetCore.Mvc; using Microsoft.Extensions.Configuration; +using Microsoft.Extensions.Logging; namespace EMBC.Responders.API.Controllers { @@ -27,13 +28,15 @@ namespace EMBC.Responders.API.Controllers public class ConfigurationController : ControllerBase { private readonly IConfiguration configuration; + private readonly ILogger logger; private readonly IMessagingClient client; private readonly IMapper mapper; private readonly ICache cache; private const int cacheDuration = 60 * 1; //1 minute - public ConfigurationController(IConfiguration configuration, IMessagingClient client, IMapper mapper, ICache cache) + public ConfigurationController(IConfiguration configuration, ILogger logger, IMessagingClient client, IMapper mapper, ICache cache) { + this.logger = logger; this.configuration = configuration; this.client = client; this.mapper = mapper; @@ -154,15 +157,37 @@ public async Task> GetSecurityQuestions() } [HttpGet("outage-info")] - [ProducesResponseType(StatusCodes.Status500InternalServerError)] [ProducesResponseType(StatusCodes.Status200OK)] + [ProducesResponseType(StatusCodes.Status500InternalServerError)] public async Task> GetOutageInfo() { - var outageInfo = await cache.GetOrSet( - "outageInfo", - async () => (await client.Send(new OutageQuery { PortalType = PortalType.Responders })).OutageInfo, - TimeSpan.FromSeconds(30)); - return Ok(mapper.Map(outageInfo)); + try + { + var outageInfo = await cache.GetOrSet( + "outageInfo", + async () => + { + try + { + var result = await client.Send(new OutageQuery { PortalType = PortalType.Responders }); + return result.OutageInfo; + } + catch (Exception ex) + { + logger.LogInformation(ex, "Failed to get outage information via gRPC"); + return new ESS.Shared.Contracts.Metadata.OutageInformation(); + } + }, + TimeSpan.FromSeconds(30) + ); + + return Ok(mapper.Map(outageInfo)); + } + catch (Exception ex) + { + logger.LogInformation(ex, "Unexpected error fetching outage information"); + return Ok(new OutageInformation()); + } } [HttpGet("access-reasons")]