using System; using System.Threading.Tasks; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Hosting; using Microsoft.Extensions.Logging; using Microsoft.Extensions.Configuration; using Microsoft.EntityFrameworkCore; using NLog.Extensions.Logging; using Selector.Model; using Selector.Cache; using IF.Lastfm.Core.Api; using StackExchange.Redis; namespace Selector.CLI { class Program { public static async Task Main(string[] args) { var host = CreateHostBuilder(args); await host.RunConsoleAsync(); } static IHostBuilder CreateHostBuilder(string[] args) => Host.CreateDefaultBuilder(args) .ConfigureServices((context, services) => { Console.WriteLine("~~~ Selector CLI ~~~"); Console.WriteLine(); Console.WriteLine("> Configuring..."); // CONFIG services.Configure(options => { OptionsHelper.ConfigureOptions(options, context.Configuration); }); var config = OptionsHelper.ConfigureOptions(context.Configuration); Console.WriteLine("> Adding Services..."); // SERVICES services.AddSingleton(); services.AddSingleton(); services.AddSingleton(); // For generating spotify clients //services.AddSingleton(); services.AddSingleton(); if(config.LastfmClient is not null) { Console.WriteLine("> Adding Last.fm credentials..."); var lastAuth = new LastAuth(config.LastfmClient, config.LastfmSecret); services.AddSingleton(lastAuth); } else { Console.WriteLine("> No Last.fm credentials, skipping init..."); } // DB if (config.DatabaseOptions.Enabled) { Console.WriteLine("> Adding Databse Context..."); services.AddDbContext(options => options.UseNpgsql(config.DatabaseOptions.ConnectionString) ); } // REDIS if (config.RedisOptions.Enabled) { Console.WriteLine("> Configuring Redis..."); if(string.IsNullOrWhiteSpace(config.RedisOptions.ConnectionString)) { Console.WriteLine("> No Redis configuration string provided, exiting..."); Environment.Exit(1); } var connMulti = ConnectionMultiplexer.Connect(config.RedisOptions.ConnectionString); services.AddSingleton(connMulti); services.AddTransient(services => services.GetService().GetDatabase()); services.AddTransient(services => services.GetService().GetSubscriber()); } // EQUAL switch (config.Equality) { case EqualityChecker.Uri: Console.WriteLine("> Using Uri Equality"); services.AddTransient(); break; case EqualityChecker.String: Console.WriteLine("> Using String Equality"); services.AddTransient(); break; } // HOSTED SERVICES if (config.WatcherOptions.Enabled) { Console.WriteLine("> Adding Watcher Service"); services.AddHostedService(); } }) .ConfigureLogging((context, builder) => { builder.ClearProviders(); builder.SetMinimumLevel(LogLevel.Trace); builder.AddNLog(context.Configuration); }); } }