From d9094ca712cce5003857efbb3356b246c5acaf49 Mon Sep 17 00:00:00 2001 From: Ash Davies <3853061+DrizzlyOwl@users.noreply.github.com> Date: Thu, 5 Dec 2024 14:55:07 +0000 Subject: [PATCH] Add DbContextChecks to Health Checks This will ensure that the /healthcheck endpoint correctly reports the status of the service if a database connection faults --- .../Dfe.Academies.Infrastructure.csproj | 1 + ...frastructureServiceCollectionExtensions.cs | 11 +++- PersonsApi/PersonsApi.csproj | 2 +- PersonsApi/Program.cs | 2 + PersonsApi/Startup.cs | 5 +- .../Controllers/HealthCheckController.cs | 62 ------------------- TramsDataApi/Program.cs | 2 + TramsDataApi/Setup/HealthCheckSetup.cs | 17 +++++ TramsDataApi/Startup.cs | 4 ++ TramsDataApi/TramsDataApi.csproj | 1 + 10 files changed, 40 insertions(+), 67 deletions(-) delete mode 100644 TramsDataApi/Controllers/HealthCheckController.cs create mode 100644 TramsDataApi/Setup/HealthCheckSetup.cs diff --git a/Dfe.Academies.Api.Infrastructure/Dfe.Academies.Infrastructure.csproj b/Dfe.Academies.Api.Infrastructure/Dfe.Academies.Infrastructure.csproj index 2dfff1496..9d3970641 100644 --- a/Dfe.Academies.Api.Infrastructure/Dfe.Academies.Infrastructure.csproj +++ b/Dfe.Academies.Api.Infrastructure/Dfe.Academies.Infrastructure.csproj @@ -17,6 +17,7 @@ + diff --git a/Dfe.Academies.Api.Infrastructure/InfrastructureServiceCollectionExtensions.cs b/Dfe.Academies.Api.Infrastructure/InfrastructureServiceCollectionExtensions.cs index 44ff4a9be..3c3c5cbe7 100644 --- a/Dfe.Academies.Api.Infrastructure/InfrastructureServiceCollectionExtensions.cs +++ b/Dfe.Academies.Api.Infrastructure/InfrastructureServiceCollectionExtensions.cs @@ -31,6 +31,8 @@ public static IServiceCollection AddInfrastructureDependencyGroup( services.AddDbContext(options => options.UseSqlServer(connectionString)); + AddInfrastructureHealthChecks(services); + return services; } @@ -58,10 +60,17 @@ public static IServiceCollection AddPersonsApiInfrastructureDependencyGroup( services.AddDbContext(options => options.UseSqlServer(connectionString)); + AddInfrastructureHealthChecks(services); + // Authentication services.AddCustomAuthorization(config); return services; } + + public static void AddInfrastructureHealthChecks(this IServiceCollection services) { + services.AddHealthChecks() + .AddDbContextCheck("Academies Database"); + } } -} \ No newline at end of file +} diff --git a/PersonsApi/PersonsApi.csproj b/PersonsApi/PersonsApi.csproj index 461f8beca..a2d366656 100644 --- a/PersonsApi/PersonsApi.csproj +++ b/PersonsApi/PersonsApi.csproj @@ -62,5 +62,5 @@ - + diff --git a/PersonsApi/Program.cs b/PersonsApi/Program.cs index cfd31fa8b..4a1eeccb9 100644 --- a/PersonsApi/Program.cs +++ b/PersonsApi/Program.cs @@ -30,4 +30,6 @@ logger.LogInformation("Logger is working..."); +app.MapHealthChecks("/HealthCheck").AllowAnonymous(); + app.Run(); diff --git a/PersonsApi/Startup.cs b/PersonsApi/Startup.cs index 2c222d88d..a57fd492f 100644 --- a/PersonsApi/Startup.cs +++ b/PersonsApi/Startup.cs @@ -99,7 +99,6 @@ public void ConfigureServices(IServiceCollection services) { configure.Title = "PersonsApi"; }); - } // This method gets called by the runtime. Use this method to configure the HTTP request pipeline. @@ -175,10 +174,10 @@ public void Configure(IApplicationBuilder app, IWebHostEnvironment env, IApiVers app.UseHttpsRedirection(); app.UseRouting(); - app.UseAuthentication(); + app.UseAuthentication(); app.UseAuthorization(); app.UseEndpoints(endpoints => { endpoints.MapControllers(); }); } } -} \ No newline at end of file +} diff --git a/TramsDataApi/Controllers/HealthCheckController.cs b/TramsDataApi/Controllers/HealthCheckController.cs deleted file mode 100644 index 917017e8b..000000000 --- a/TramsDataApi/Controllers/HealthCheckController.cs +++ /dev/null @@ -1,62 +0,0 @@ -using System.IO; -using Microsoft.AspNetCore.Mvc; -using Microsoft.Data.SqlClient; -using Microsoft.Extensions.Logging; -using TramsDataApi.DatabaseModels; -using Swashbuckle.AspNetCore.Annotations; - -namespace TramsDataApi.Controllers -{ - /// - /// Provides endpoints for checking the health of the API and database. - /// - [ApiController] - [Route("[controller]")] - [ApiVersion("1.0")] - [SwaggerTag("Health Check Endpoints")] - public class HealthCheckController : ControllerBase - { - private readonly LegacyTramsDbContext _dbContext; - private readonly ILogger _logger; - - /// - /// Constructor that initializes database and logger. - /// - /// Database context. - /// Logging service. - public HealthCheckController(LegacyTramsDbContext context, ILogger logger) - { - _dbContext = context; - _logger = logger; - } - - /// - /// Provides a basic health check for the API. - /// - /// String message indicating health status. - [HttpGet] - [HttpHead] - [SwaggerOperation(Summary = "Performs a basic health check", Description = "Checks if the API is operational.")] - [SwaggerResponse(200, "API is healthy.")] - public string Get() - { - _logger.LogInformation("Returning OK Health Check"); - return "Health check ok"; - } - - /// - /// Checks the database connectivity. - /// - /// Boolean indicating whether the database can be connected to. - [HttpGet] - [HttpHead] - [Route("/check_db")] - [SwaggerOperation(Summary = "Performs a database health check", Description = "Checks if the database is reachable.")] - [SwaggerResponse(200, "Database is healthy.")] - public bool CheckDbConnection() - { - _logger.LogInformation("Returning Database Health Check"); - return _dbContext.Database.CanConnect(); - } - } -} diff --git a/TramsDataApi/Program.cs b/TramsDataApi/Program.cs index 5e898a1b6..d8184ca03 100644 --- a/TramsDataApi/Program.cs +++ b/TramsDataApi/Program.cs @@ -37,4 +37,6 @@ logger.LogInformation("Logger is working..."); +app.MapHealthChecks("/HealthCheck").AllowAnonymous(); + app.Run(); diff --git a/TramsDataApi/Setup/HealthCheckSetup.cs b/TramsDataApi/Setup/HealthCheckSetup.cs new file mode 100644 index 000000000..558c42dfb --- /dev/null +++ b/TramsDataApi/Setup/HealthCheckSetup.cs @@ -0,0 +1,17 @@ +using Microsoft.Extensions.DependencyInjection; +using TramsDataApi.DatabaseModels; + +namespace TramsDataApi.Setup; + +public static class HealthCheckSetup +{ + public static void AddHealthChecks(IServiceCollection services) { + services.AddHealthChecks(); + AddDbHealthChecks(services); + } + + public static void AddDbHealthChecks(IServiceCollection services) { + services.AddHealthChecks() + .AddDbContextCheck("Academies Database"); + } +} diff --git a/TramsDataApi/Startup.cs b/TramsDataApi/Startup.cs index 31a3ae130..bd72e1d82 100644 --- a/TramsDataApi/Startup.cs +++ b/TramsDataApi/Startup.cs @@ -28,6 +28,7 @@ namespace TramsDataApi using TramsDataApi.ResponseModels; using TramsDataApi.SerilogCustomEnrichers; using TramsDataApi.Services; + using TramsDataApi.Setup; using TramsDataApi.Swagger; using UseCases; @@ -53,6 +54,9 @@ public void ConfigureServices(IServiceCollection services) services.AddDbContext(options => options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection"))); + // Register Health Checks + HealthCheckSetup.AddHealthChecks(services); + // Add connnection to MFSP services.AddHttpClient("MfspApiClient", (_, client) => { diff --git a/TramsDataApi/TramsDataApi.csproj b/TramsDataApi/TramsDataApi.csproj index 6210734e0..6801dcbf1 100644 --- a/TramsDataApi/TramsDataApi.csproj +++ b/TramsDataApi/TramsDataApi.csproj @@ -32,6 +32,7 @@ runtime; build; native; contentfiles; analyzers; buildtransitive +