tools/code/extractor/WorkspaceLogger.cs (83 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.Threading;
using System.Threading.Tasks;
namespace extractor;
public delegate ValueTask ExtractWorkspaceLoggers(WorkspaceName workspaceName, CancellationToken cancellationToken);
public delegate IAsyncEnumerable<(LoggerName Name, WorkspaceLoggerDto Dto)> ListWorkspaceLoggers(WorkspaceName workspaceName, CancellationToken cancellationToken);
public delegate ValueTask WriteWorkspaceLoggerArtifacts(LoggerName name, WorkspaceLoggerDto dto, WorkspaceName workspaceName, CancellationToken cancellationToken);
public delegate ValueTask WriteWorkspaceLoggerInformationFile(LoggerName name, WorkspaceLoggerDto dto, WorkspaceName workspaceName, CancellationToken cancellationToken);
internal static class WorkspaceLoggerModule
{
public static void ConfigureExtractWorkspaceLoggers(IHostApplicationBuilder builder)
{
ConfigureListWorkspaceLoggers(builder);
ConfigureWriteWorkspaceLoggerArtifacts(builder);
builder.Services.TryAddSingleton(GetExtractWorkspaceLoggers);
}
private static ExtractWorkspaceLoggers GetExtractWorkspaceLoggers(IServiceProvider provider)
{
var list = provider.GetRequiredService<ListWorkspaceLoggers>();
var writeArtifacts = provider.GetRequiredService<WriteWorkspaceLoggerArtifacts>();
var activitySource = provider.GetRequiredService<ActivitySource>();
var logger = provider.GetRequiredService<ILogger>();
return async (workspaceName, cancellationToken) =>
{
using var _ = activitySource.StartActivity(nameof(ExtractWorkspaceLoggers));
logger.LogInformation("Extracting loggers for workspace {WorkspaceName}...", workspaceName);
await list(workspaceName, cancellationToken)
.IterParallel(async logger => await writeArtifacts(logger.Name, logger.Dto, workspaceName, cancellationToken),
cancellationToken);
};
}
private static void ConfigureListWorkspaceLoggers(IHostApplicationBuilder builder)
{
AzureModule.ConfigureManagementServiceUri(builder);
AzureModule.ConfigureHttpPipeline(builder);
builder.Services.TryAddSingleton(GetListWorkspaceLoggers);
}
private static ListWorkspaceLoggers GetListWorkspaceLoggers(IServiceProvider provider)
{
var serviceUri = provider.GetRequiredService<ManagementServiceUri>();
var pipeline = provider.GetRequiredService<HttpPipeline>();
return (workspaceName, cancellationToken) =>
WorkspaceLoggersUri.From(workspaceName, serviceUri)
.List(pipeline, cancellationToken);
}
private static void ConfigureWriteWorkspaceLoggerArtifacts(IHostApplicationBuilder builder)
{
ConfigureWriteWorkspaceLoggerInformationFile(builder);
builder.Services.TryAddSingleton(GetWriteWorkspaceLoggerArtifacts);
}
private static WriteWorkspaceLoggerArtifacts GetWriteWorkspaceLoggerArtifacts(IServiceProvider provider)
{
var writeInformationFile = provider.GetRequiredService<WriteWorkspaceLoggerInformationFile>();
return async (name, dto, workspaceName, cancellationToken) =>
{
await writeInformationFile(name, dto, workspaceName, cancellationToken);
};
}
private static void ConfigureWriteWorkspaceLoggerInformationFile(IHostApplicationBuilder builder)
{
AzureModule.ConfigureManagementServiceDirectory(builder);
builder.Services.TryAddSingleton(GetWriteWorkspaceLoggerInformationFile);
}
private static WriteWorkspaceLoggerInformationFile GetWriteWorkspaceLoggerInformationFile(IServiceProvider provider)
{
var serviceDirectory = provider.GetRequiredService<ManagementServiceDirectory>();
var logger = provider.GetRequiredService<ILogger>();
return async (name, dto, workspaceName, cancellationToken) =>
{
var informationFile = WorkspaceLoggerInformationFile.From(name, workspaceName, serviceDirectory);
logger.LogInformation("Writing workspace logger information file {WorkspaceLoggerInformationFile}...", informationFile);
await informationFile.WriteDto(dto, cancellationToken);
};
}
}