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; using System.Net; using Microsoft.Extensions.Options; 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,x) => { var settings = x.GetRequiredService>(); var url = settings.Value.QRBeeURL; return new QRBee.Core.Client.Client(url, httpClient); }) .ConfigurePrimaryHttpMessageHandler(() => new HttpClientHandler() { ServerCertificateCustomValidationCallback = HttpClientHandler.DangerousAcceptAnyServerCertificateValidator }); ; services .Configure(context.Configuration.GetSection("GeneratorSettings")) .AddSingleton() .AddSingleton() .AddSingleton() .AddSingleton() .AddSingleton() .AddSingleton() .AddSingleton() .AddSingleton(x => no => new PrivateKeyHandler(x.GetRequiredService>(), x.GetRequiredService(), no)) .AddSingleton(x => no => new AndroidSecurityService(x.GetRequiredService()(no))) .AddHostedService() ; }); // ServicePointManager.DefaultConnectionLimit = 500; ServicePointManager.ReusePort = true; ServicePointManager.CheckCertificateRevocationList = false; var host = builder.Build(); host.Run();