// See https://aka.ms/new-console-template for more information using log4net; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Hosting; using Microsoft.Extensions.Logging; using QRBee.Api.Services; using QRBee.Droid.Services; using QRBee.Load.Generator; using Microsoft.Extensions.Configuration; Console.WriteLine("=== QRBee artificaial load generator ==="); var builder = Host.CreateDefaultBuilder(); builder.ConfigureServices((context, services) => { services.AddLogging(logging => { logging.ClearProviders(); GlobalContext.Properties["LOGS_ROOT"] = Environment.GetEnvironmentVariable("LOGS_ROOT") ?? ""; System.Text.Encoding.RegisterProvider(System.Text.CodePagesEncodingProvider.Instance); logging.AddLog4Net("log4net.config"); }); services .AddHttpClient(httpClient => new QRBee.Core.Client.Client("https://localhost:7000/", httpClient)) .ConfigurePrimaryHttpMessageHandler(() => new HttpClientHandler() { ServerCertificateCustomValidationCallback = HttpClientHandler.DangerousAcceptAnyServerCertificateValidator }); ; services .Configure(context.Configuration.GetSection("GeneratorSettings")) .AddSingleton() .AddSingleton() .AddSingleton(x => no => new PrivateKeyHandler(x.GetRequiredService>(), x.GetRequiredService(), no)) .AddSingleton(x => no => new AndroidSecurityService(x.GetRequiredService()(no))) .AddHostedService() ; }); var host = builder.Build(); host.Run();