68 lines
2.8 KiB
C#
68 lines
2.8 KiB
C#
using Microsoft.Extensions.Configuration;
|
|
using Phares.Shared;
|
|
using Serilog;
|
|
using System.Diagnostics;
|
|
using System.Reflection;
|
|
using View_by_Distance.PrepareForOld.Models;
|
|
using View_by_Distance.Shared.Models.Stateless.Methods;
|
|
|
|
namespace View_by_Distance.PrepareForOld;
|
|
|
|
public class Program
|
|
{
|
|
|
|
public static void Secondary(List<string> args)
|
|
{
|
|
LoggerConfiguration loggerConfiguration = new();
|
|
Assembly assembly = Assembly.GetExecutingAssembly();
|
|
bool debuggerWasAttachedAtLineZero = Debugger.IsAttached || assembly.Location.Contains(@"\bin\Debug");
|
|
IsEnvironment isEnvironment = new(processesCount: null, nullASPNetCoreEnvironmentIsDevelopment: debuggerWasAttachedAtLineZero, nullASPNetCoreEnvironmentIsProduction: !debuggerWasAttachedAtLineZero);
|
|
IConfigurationBuilder configurationBuilder = new ConfigurationBuilder()
|
|
.AddEnvironmentVariables()
|
|
.AddJsonFile("appsettings.json", optional: false, reloadOnChange: true)
|
|
.AddJsonFile(isEnvironment.AppSettingsFileName, optional: false, reloadOnChange: true);
|
|
IConfigurationRoot configurationRoot = configurationBuilder.Build();
|
|
AppSettings appSettings = Models.Binder.AppSettings.Get(configurationRoot);
|
|
if (appSettings.MaxDegreeOfParallelism > Environment.ProcessorCount)
|
|
throw new Exception("MaxDegreeOfParallelism must be =< Environment.ProcessorCount!");
|
|
if (string.IsNullOrEmpty(appSettings.WorkingDirectoryName))
|
|
throw new Exception("Working directory name must have a value!");
|
|
string workingDirectory = IWorkingDirectory.GetWorkingDirectory(assembly.GetName().Name, appSettings.WorkingDirectoryName);
|
|
Environment.SetEnvironmentVariable(nameof(workingDirectory), workingDirectory);
|
|
_ = ConfigurationLoggerConfigurationExtensions.Configuration(loggerConfiguration.ReadFrom, configurationRoot);
|
|
Log.Logger = loggerConfiguration.CreateLogger();
|
|
ILogger log = Log.ForContext<Program>();
|
|
int silentIndex = args.IndexOf("s");
|
|
if (silentIndex > -1)
|
|
args.RemoveAt(silentIndex);
|
|
try
|
|
{
|
|
if (args is null)
|
|
throw new Exception("args is null!");
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
log.Fatal(string.Concat(ex.Message, Environment.NewLine, ex.StackTrace));
|
|
}
|
|
finally
|
|
{
|
|
Log.CloseAndFlush();
|
|
}
|
|
if (silentIndex > -1)
|
|
log.Debug("Done. Bye");
|
|
else
|
|
{
|
|
log.Debug("Done. Press 'Enter' to end");
|
|
_ = Console.ReadLine();
|
|
}
|
|
}
|
|
|
|
public static void Main(string[] args)
|
|
{
|
|
if (args is not null)
|
|
Secondary(args.ToList());
|
|
else
|
|
Secondary(new List<string>());
|
|
}
|
|
|
|
} |