| | | 1 | | using Microsoft.Extensions.Options; |
| | | 2 | | using ProjectTemplate.Infrastructure.Data.Options; |
| | | 3 | | |
| | | 4 | | namespace ProjectTemplate.Infrastructure.Data.Services; |
| | | 5 | | |
| | 128 | 6 | | internal sealed partial class DataAccessStartupLogger( |
| | 128 | 7 | | ILogger<DataAccessStartupLogger> logger, |
| | 128 | 8 | | IOptions<DataAccessOptions> options) : IHostedService |
| | | 9 | | { |
| | | 10 | | public Task StartAsync(CancellationToken cancellationToken) |
| | | 11 | | { |
| | 126 | 12 | | if (DataAccessOptions.IsDisabledProvider(options.Value.Provider)) |
| | | 13 | | { |
| | 0 | 14 | | LogDataAccessDisabled( |
| | 0 | 15 | | logger, |
| | 0 | 16 | | options.Value.Provider); |
| | | 17 | | |
| | 0 | 18 | | return Task.CompletedTask; |
| | | 19 | | } |
| | | 20 | | |
| | 126 | 21 | | LogDataAccessConfiguration( |
| | 126 | 22 | | logger, |
| | 126 | 23 | | options.Value.Provider, |
| | 126 | 24 | | options.Value.ConnectionStringName, |
| | 126 | 25 | | options.Value.Auditing.Enabled ? "enabled" : "disabled"); |
| | | 26 | | |
| | 126 | 27 | | return Task.CompletedTask; |
| | | 28 | | } |
| | | 29 | | |
| | | 30 | | public Task StopAsync(CancellationToken cancellationToken) |
| | | 31 | | { |
| | 252 | 32 | | return Task.CompletedTask; |
| | | 33 | | } |
| | | 34 | | |
| | | 35 | | [LoggerMessage( |
| | | 36 | | EventId = 19100, |
| | | 37 | | Level = LogLevel.Information, |
| | | 38 | | Message = "Data access configured. Provider: {Provider}; ConnectionStringName: {ConnectionStringName}; EF Core a |
| | | 39 | | private static partial void LogDataAccessConfiguration( |
| | | 40 | | ILogger logger, |
| | | 41 | | string provider, |
| | | 42 | | string connectionStringName, |
| | | 43 | | string auditingStatus); |
| | | 44 | | |
| | | 45 | | [LoggerMessage( |
| | | 46 | | EventId = 19101, |
| | | 47 | | Level = LogLevel.Information, |
| | | 48 | | Message = "Application data access disabled. Provider: {Provider}; EF Core services were not registered.")] |
| | | 49 | | private static partial void LogDataAccessDisabled( |
| | | 50 | | ILogger logger, |
| | | 51 | | string provider); |
| | | 52 | | } |