using System; using System.Net.Http; using System.Threading.Tasks; using FarmmapsApi.HttpMessageHandlers; using FarmmapsApi.Models; using FarmmapsApi.Services; using IdentityModel.Client; using Microsoft.Extensions.Configuration; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Logging; using Serilog; using Serilog.Events; using Serilog.Filters; namespace FarmmapsApi { public abstract class FarmmapsProgram where T : class, IApplication { public async Task Start(string[] args) { IConfiguration config = new ConfigurationBuilder() .AddJsonFile("appsettings.json", false, true) .Build(); var configuration = config.Get(); var serviceCollection = new ServiceCollection() .AddSingleton(configuration) .AddSingleton(sp => { var httpFactory = sp.GetRequiredService(); return new DiscoveryCache(configuration.DiscoveryEndpointUrl, () => httpFactory.CreateClient()); }) .AddSingleton() .AddSingleton() .AddSingleton() .AddTransient() .AddTransient() .AddTransient() .AddHttpClient() .AddHttpMessageHandler() .Services; Configure(serviceCollection); var serviceProvider = serviceCollection.BuildServiceProvider(); ConfigureLogger(serviceProvider); await serviceProvider.GetService().AuthenticateAsync(); // await serviceProvider.GetService().StartEventHub(); await serviceProvider.GetRequiredService().RunAsync(); } protected abstract void Configure(IServiceCollection serviceCollection); private static void ConfigureLogger(IServiceProvider serviceProvider) { var isService = Matching.FromSource("Microsoft"); Log.Logger = new LoggerConfiguration() .MinimumLevel.Information() .WriteTo.Logger(l => l.Filter.ByIncludingOnly(isService) .WriteTo.Console(LogEventLevel.Warning)) .WriteTo.File(path: "Logs/log.log", rollingInterval: RollingInterval.Day) .CreateLogger(); var loggerFactory = serviceProvider.GetRequiredService(); loggerFactory.AddSerilog(); } } }