tools/code/publisher/Logger.cs (203 lines of code) (raw):

using Azure.Core.Pipeline; using common; using LanguageExt; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.DependencyInjection.Extensions; using Microsoft.Extensions.Hosting; using Microsoft.Extensions.Logging; using System; using System.Diagnostics; using System.IO; using System.Linq; using System.Threading; using System.Threading.Tasks; namespace publisher; public delegate ValueTask PutLoggers(CancellationToken cancellationToken); public delegate Option<LoggerName> TryParseLoggerName(FileInfo file); public delegate bool IsLoggerNameInSourceControl(LoggerName name); public delegate ValueTask PutLogger(LoggerName name, CancellationToken cancellationToken); public delegate ValueTask<Option<LoggerDto>> FindLoggerDto(LoggerName name, CancellationToken cancellationToken); public delegate ValueTask PutLoggerInApim(LoggerName name, LoggerDto dto, CancellationToken cancellationToken); public delegate ValueTask DeleteLoggers(CancellationToken cancellationToken); public delegate ValueTask DeleteLogger(LoggerName name, CancellationToken cancellationToken); public delegate ValueTask DeleteLoggerFromApim(LoggerName name, CancellationToken cancellationToken); internal static class LoggerModule { public static void ConfigurePutLoggers(IHostApplicationBuilder builder) { CommonModule.ConfigureGetPublisherFiles(builder); ConfigureTryParseLoggerName(builder); ConfigureIsLoggerNameInSourceControl(builder); ConfigurePutLogger(builder); builder.Services.TryAddSingleton(GetPutLoggers); } private static PutLoggers GetPutLoggers(IServiceProvider provider) { var getPublisherFiles = provider.GetRequiredService<GetPublisherFiles>(); var tryParseName = provider.GetRequiredService<TryParseLoggerName>(); var isNameInSourceControl = provider.GetRequiredService<IsLoggerNameInSourceControl>(); var put = provider.GetRequiredService<PutLogger>(); var activitySource = provider.GetRequiredService<ActivitySource>(); var logger = provider.GetRequiredService<ILogger>(); return async cancellationToken => { using var _ = activitySource.StartActivity(nameof(PutLoggers)); logger.LogInformation("Putting loggers..."); await getPublisherFiles() .Choose(tryParseName.Invoke) .Where(isNameInSourceControl.Invoke) .Distinct() .IterParallel(put.Invoke, cancellationToken); }; } private static void ConfigureTryParseLoggerName(IHostApplicationBuilder builder) { AzureModule.ConfigureManagementServiceDirectory(builder); builder.Services.TryAddSingleton(GetTryParseLoggerName); } private static TryParseLoggerName GetTryParseLoggerName(IServiceProvider provider) { var serviceDirectory = provider.GetRequiredService<ManagementServiceDirectory>(); return file => from informationFile in LoggerInformationFile.TryParse(file, serviceDirectory) select informationFile.Parent.Name; } private static void ConfigureIsLoggerNameInSourceControl(IHostApplicationBuilder builder) { CommonModule.ConfigureGetArtifactFiles(builder); AzureModule.ConfigureManagementServiceDirectory(builder); builder.Services.TryAddSingleton(GetIsLoggerNameInSourceControl); } private static IsLoggerNameInSourceControl GetIsLoggerNameInSourceControl(IServiceProvider provider) { var getArtifactFiles = provider.GetRequiredService<GetArtifactFiles>(); var serviceDirectory = provider.GetRequiredService<ManagementServiceDirectory>(); return doesInformationFileExist; bool doesInformationFileExist(LoggerName name) { var artifactFiles = getArtifactFiles(); var informationFile = LoggerInformationFile.From(name, serviceDirectory); return artifactFiles.Contains(informationFile.ToFileInfo()); } } private static void ConfigurePutLogger(IHostApplicationBuilder builder) { ConfigureFindLoggerDto(builder); ConfigurePutLoggerInApim(builder); builder.Services.TryAddSingleton(GetPutLogger); } private static PutLogger GetPutLogger(IServiceProvider provider) { var findDto = provider.GetRequiredService<FindLoggerDto>(); var putInApim = provider.GetRequiredService<PutLoggerInApim>(); var activitySource = provider.GetRequiredService<ActivitySource>(); return async (name, cancellationToken) => { using var _ = activitySource.StartActivity(nameof(PutLogger)) ?.AddTag("logger.name", name); var dtoOption = await findDto(name, cancellationToken); await dtoOption.IterTask(async dto => await putInApim(name, dto, cancellationToken)); }; } private static void ConfigureFindLoggerDto(IHostApplicationBuilder builder) { AzureModule.ConfigureManagementServiceDirectory(builder); CommonModule.ConfigureTryGetFileContents(builder); OverrideDtoModule.ConfigureOverrideDtoFactory(builder); builder.Services.TryAddSingleton(GetFindLoggerDto); } private static FindLoggerDto GetFindLoggerDto(IServiceProvider provider) { var serviceDirectory = provider.GetRequiredService<ManagementServiceDirectory>(); var tryGetFileContents = provider.GetRequiredService<TryGetFileContents>(); var overrideFactory = provider.GetRequiredService<OverrideDtoFactory>(); var overrideDto = overrideFactory.Create<LoggerName, LoggerDto>(); return async (name, cancellationToken) => { var informationFile = LoggerInformationFile.From(name, serviceDirectory); var informationFileInfo = informationFile.ToFileInfo(); var contentsOption = await tryGetFileContents(informationFileInfo, cancellationToken); return from contents in contentsOption let dto = contents.ToObjectFromJson<LoggerDto>() select overrideDto(name, dto); }; } private static void ConfigurePutLoggerInApim(IHostApplicationBuilder builder) { AzureModule.ConfigureManagementServiceUri(builder); AzureModule.ConfigureHttpPipeline(builder); builder.Services.TryAddSingleton(GetPutLoggerInApim); } private static PutLoggerInApim GetPutLoggerInApim(IServiceProvider provider) { var serviceUri = provider.GetRequiredService<ManagementServiceUri>(); var pipeline = provider.GetRequiredService<HttpPipeline>(); var logger = provider.GetRequiredService<ILogger>(); return async (name, dto, cancellationToken) => { logger.LogInformation("Putting logger {LoggerName}...", name); await LoggerUri.From(name, serviceUri) .PutDto(dto, pipeline, cancellationToken); }; } public static void ConfigureDeleteLoggers(IHostApplicationBuilder builder) { CommonModule.ConfigureGetPublisherFiles(builder); ConfigureTryParseLoggerName(builder); ConfigureIsLoggerNameInSourceControl(builder); ConfigureDeleteLogger(builder); builder.Services.TryAddSingleton(GetDeleteLoggers); } private static DeleteLoggers GetDeleteLoggers(IServiceProvider provider) { var getPublisherFiles = provider.GetRequiredService<GetPublisherFiles>(); var tryParseName = provider.GetRequiredService<TryParseLoggerName>(); var isNameInSourceControl = provider.GetRequiredService<IsLoggerNameInSourceControl>(); var delete = provider.GetRequiredService<DeleteLogger>(); var activitySource = provider.GetRequiredService<ActivitySource>(); var logger = provider.GetRequiredService<ILogger>(); return async cancellationToken => { using var _ = activitySource.StartActivity(nameof(DeleteLoggers)); logger.LogInformation("Deleting loggers..."); await getPublisherFiles() .Choose(tryParseName.Invoke) .Where(name => isNameInSourceControl(name) is false) .Distinct() .IterParallel(delete.Invoke, cancellationToken); }; } private static void ConfigureDeleteLogger(IHostApplicationBuilder builder) { ConfigureDeleteLoggerFromApim(builder); builder.Services.TryAddSingleton(GetDeleteLogger); } private static DeleteLogger GetDeleteLogger(IServiceProvider provider) { var deleteFromApim = provider.GetRequiredService<DeleteLoggerFromApim>(); var activitySource = provider.GetRequiredService<ActivitySource>(); return async (name, cancellationToken) => { using var _ = activitySource.StartActivity(nameof(DeleteLogger)) ?.AddTag("logger.name", name); await deleteFromApim(name, cancellationToken); }; } private static void ConfigureDeleteLoggerFromApim(IHostApplicationBuilder builder) { AzureModule.ConfigureManagementServiceUri(builder); AzureModule.ConfigureHttpPipeline(builder); builder.Services.TryAddSingleton(GetDeleteLoggerFromApim); } private static DeleteLoggerFromApim GetDeleteLoggerFromApim(IServiceProvider provider) { var serviceUri = provider.GetRequiredService<ManagementServiceUri>(); var pipeline = provider.GetRequiredService<HttpPipeline>(); var logger = provider.GetRequiredService<ILogger>(); return async (name, cancellationToken) => { logger.LogInformation("Deleting logger {LoggerName}...", name); await LoggerUri.From(name, serviceUri) .Delete(pipeline, cancellationToken); }; } }