tools/code/extractor/Logger.cs (99 lines of code) (raw):

using Azure.Core.Pipeline; using common; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.DependencyInjection.Extensions; using Microsoft.Extensions.Hosting; using Microsoft.Extensions.Logging; using System; using System.Collections.Generic; using System.Diagnostics; using System.Linq; using System.Threading; using System.Threading.Tasks; namespace extractor; public delegate ValueTask ExtractLoggers(CancellationToken cancellationToken); public delegate IAsyncEnumerable<(LoggerName Name, LoggerDto Dto)> ListLoggers(CancellationToken cancellationToken); public delegate ValueTask WriteLoggerArtifacts(LoggerName name, LoggerDto dto, CancellationToken cancellationToken); public delegate ValueTask WriteLoggerInformationFile(LoggerName name, LoggerDto dto, CancellationToken cancellationToken); internal static class LoggerModule { public static void ConfigureExtractLoggers(IHostApplicationBuilder builder) { ConfigureListLoggers(builder); ConfigureWriteLoggerArtifacts(builder); builder.Services.TryAddSingleton(GetExtractLoggers); } private static ExtractLoggers GetExtractLoggers(IServiceProvider provider) { var list = provider.GetRequiredService<ListLoggers>(); var writeArtifacts = provider.GetRequiredService<WriteLoggerArtifacts>(); var activitySource = provider.GetRequiredService<ActivitySource>(); var logger = provider.GetRequiredService<ILogger>(); return async cancellationToken => { using var _ = activitySource.StartActivity(nameof(ExtractLoggers)); logger.LogInformation("Extracting loggers..."); await list(cancellationToken) .IterParallel(async resource => await writeArtifacts(resource.Name, resource.Dto, cancellationToken), cancellationToken); }; } private static void ConfigureListLoggers(IHostApplicationBuilder builder) { ConfigurationModule.ConfigureFindConfigurationNamesFactory(builder); AzureModule.ConfigureManagementServiceUri(builder); AzureModule.ConfigureHttpPipeline(builder); builder.Services.TryAddSingleton(GetListLoggers); } private static ListLoggers GetListLoggers(IServiceProvider provider) { var findConfigurationNamesFactory = provider.GetRequiredService<FindConfigurationNamesFactory>(); var serviceUri = provider.GetRequiredService<ManagementServiceUri>(); var pipeline = provider.GetRequiredService<HttpPipeline>(); var findConfigurationNames = findConfigurationNamesFactory.Create<LoggerName>(); return cancellationToken => findConfigurationNames() .Map(names => listFromSet(names, cancellationToken)) .IfNone(() => listAll(cancellationToken)); IAsyncEnumerable<(LoggerName, LoggerDto)> listFromSet(IEnumerable<LoggerName> names, CancellationToken cancellationToken) => names.Select(name => LoggerUri.From(name, serviceUri)) .ToAsyncEnumerable() .Choose(async uri => { var dtoOption = await uri.TryGetDto(pipeline, cancellationToken); return dtoOption.Map(dto => (uri.Name, dto)); }); IAsyncEnumerable<(LoggerName, LoggerDto)> listAll(CancellationToken cancellationToken) { var loggersUri = LoggersUri.From(serviceUri); return loggersUri.List(pipeline, cancellationToken); } } private static void ConfigureWriteLoggerArtifacts(IHostApplicationBuilder builder) { ConfigureWriteLoggerInformationFile(builder); builder.Services.TryAddSingleton(GetWriteLoggerArtifacts); } private static WriteLoggerArtifacts GetWriteLoggerArtifacts(IServiceProvider provider) { var writeInformationFile = provider.GetRequiredService<WriteLoggerInformationFile>(); return async (name, dto, cancellationToken) => await writeInformationFile(name, dto, cancellationToken); } private static void ConfigureWriteLoggerInformationFile(IHostApplicationBuilder builder) { AzureModule.ConfigureManagementServiceDirectory(builder); builder.Services.TryAddSingleton(GetWriteLoggerInformationFile); } private static WriteLoggerInformationFile GetWriteLoggerInformationFile(IServiceProvider provider) { var serviceDirectory = provider.GetRequiredService<ManagementServiceDirectory>(); var logger = provider.GetRequiredService<ILogger>(); return async (name, dto, cancellationToken) => { var informationFile = LoggerInformationFile.From(name, serviceDirectory); logger.LogInformation("Writing logger information file {LoggerInformationFile}...", informationFile); await informationFile.WriteDto(dto, cancellationToken); }; } }