146 lines
7.7 KiB
C#
146 lines
7.7 KiB
C#
using Microsoft.AspNetCore.Mvc;
|
|
using Microsoft.Extensions.Hosting.WindowsServices;
|
|
using OI.Metrology.Server.Models;
|
|
using OI.Metrology.Server.Repositories;
|
|
using OI.Metrology.Server.Repository;
|
|
using OI.Metrology.Server.Services;
|
|
using OI.Metrology.Shared.Models;
|
|
using OI.Metrology.Shared.Models.Stateless;
|
|
using OI.Metrology.Shared.Repositories;
|
|
using OI.Metrology.Shared.Services;
|
|
using Serilog;
|
|
using System.Reflection;
|
|
|
|
namespace OI.Metrology.Server;
|
|
|
|
public class Program
|
|
{
|
|
|
|
private static (string, WebApplicationOptions) Get(string[] args)
|
|
{
|
|
string webRootPath;
|
|
Assembly assembly = Assembly.GetExecutingAssembly();
|
|
string? assemblyName = assembly.GetName()?.Name;
|
|
if (string.IsNullOrEmpty(assemblyName))
|
|
throw new Exception();
|
|
string baseAssemblyName = assemblyName.Split('.')[0];
|
|
if (WindowsServiceHelpers.IsWindowsService())
|
|
webRootPath = Path.Combine(AppContext.BaseDirectory, "wwwroot");
|
|
else
|
|
webRootPath = Path.Combine(AppContext.BaseDirectory.Split(baseAssemblyName)[0], baseAssemblyName, "wwwroot");
|
|
if (!Directory.Exists(webRootPath))
|
|
webRootPath = string.Empty;
|
|
WebApplicationOptions webApplicationOptions = new()
|
|
{
|
|
Args = args,
|
|
ContentRootPath = AppContext.BaseDirectory,
|
|
WebRootPath = webRootPath
|
|
};
|
|
return new(assemblyName, webApplicationOptions);
|
|
}
|
|
|
|
public static int Main(string[] args)
|
|
{
|
|
LoggerConfiguration loggerConfiguration = new();
|
|
(string assemblyName, WebApplicationOptions _) = Get(args);
|
|
WebApplicationBuilder webApplicationBuilder = WebApplication.CreateBuilder(args);
|
|
_ = webApplicationBuilder.Configuration.AddUserSecrets<Program>();
|
|
AppSettings appSettings = Models.Binder.AppSettings.Get(webApplicationBuilder.Configuration);
|
|
if (string.IsNullOrEmpty(appSettings.WorkingDirectoryName))
|
|
throw new Exception("Working directory name must have a value!");
|
|
string workingDirectory = IWorkingDirectory.GetWorkingDirectory(assemblyName, appSettings.WorkingDirectoryName);
|
|
Environment.SetEnvironmentVariable(nameof(workingDirectory), workingDirectory);
|
|
_ = ConfigurationLoggerConfigurationExtensions.Configuration(loggerConfiguration.ReadFrom, webApplicationBuilder.Configuration);
|
|
_ = SerilogHostBuilderExtensions.UseSerilog(webApplicationBuilder.Host);
|
|
Log.Logger = loggerConfiguration.CreateLogger();
|
|
Serilog.ILogger log = Log.ForContext<Program>();
|
|
try
|
|
{
|
|
_ = webApplicationBuilder.Services.AddMemoryCache();
|
|
_ = webApplicationBuilder.Services.Configure<ApiBehaviorOptions>(options => options.SuppressModelStateInvalidFilter = true);
|
|
_ = webApplicationBuilder.Services.AddControllersWithViews();
|
|
_ = webApplicationBuilder.Services.AddDistributedMemoryCache();
|
|
|
|
AppSettingsRepository appSettingsRepository = new(appSettings);
|
|
SQLDbConnectionFactory sqlDbConnectionFactory = new(appSettings);
|
|
ClientSettingsRepository clientSettingsRepository = new(appSettings);
|
|
|
|
_ = webApplicationBuilder.Services.AddSingleton(_ => appSettings);
|
|
_ = webApplicationBuilder.Services.AddSingleton<IInboundRepository, InboundRepository>();
|
|
_ = webApplicationBuilder.Services.AddSingleton<IReactorsRepository, ReactorsRepository>();
|
|
_ = webApplicationBuilder.Services.AddSingleton<IClientSettingsRepository>(_ => clientSettingsRepository);
|
|
_ = webApplicationBuilder.Services.AddSingleton<IServiceShopOrderRepository, ServiceShopOrderRepository>();
|
|
_ = webApplicationBuilder.Services.AddSingleton<IPinRepository, PinRepository>(_ => new(appSettings.MockRoot));
|
|
_ = webApplicationBuilder.Services.AddSingleton<IDbConnectionFactory, SQLDbConnectionFactory>(_ => sqlDbConnectionFactory);
|
|
_ = webApplicationBuilder.Services.AddSingleton<IToolTypesRepository, ToolTypesRepository>(_ => new(appSettings.MockRoot));
|
|
_ = webApplicationBuilder.Services.AddSingleton<IAppSettingsRepository<Models.Binder.AppSettings>>(_ => appSettingsRepository);
|
|
_ = webApplicationBuilder.Services.AddSingleton<IInfinityQSRepository, InfinityQSRepository>(_ => new(appSettings.MockRoot, sqlDbConnectionFactory));
|
|
_ = webApplicationBuilder.Services.AddSingleton<IInfinityQSV2Repository, InfinityQSV2Repository>(_ => new(appSettings.MockRoot, sqlDbConnectionFactory));
|
|
_ = webApplicationBuilder.Services.AddSingleton<IWorkMaterialRepository, WorkMaterialRepository>(_ => new(appSettings.MockRoot, sqlDbConnectionFactory));
|
|
|
|
_ = webApplicationBuilder.Services.AddScoped<IExportRepository, ExportRepository>();
|
|
_ = webApplicationBuilder.Services.AddScoped<IAttachmentsService, AttachmentsService>();
|
|
_ = webApplicationBuilder.Services.AddScoped<IInboundDataService, InboundDataService>();
|
|
_ = webApplicationBuilder.Services.AddScoped<IMetrologyRepository, MetrologyRepository>();
|
|
|
|
_ = webApplicationBuilder.Services.AddSwaggerGen();
|
|
_ = webApplicationBuilder.Services.AddSession(sessionOptions =>
|
|
{
|
|
sessionOptions.IdleTimeout = TimeSpan.FromSeconds(2000);
|
|
sessionOptions.Cookie.HttpOnly = true;
|
|
sessionOptions.Cookie.IsEssential = true;
|
|
}
|
|
);
|
|
if (WindowsServiceHelpers.IsWindowsService())
|
|
{
|
|
_ = webApplicationBuilder.Services.AddSingleton<IHostLifetime, WindowsServiceLifetime>();
|
|
_ = webApplicationBuilder.Logging.AddEventLog(settings =>
|
|
{
|
|
#pragma warning disable CA1416
|
|
if (string.IsNullOrEmpty(settings.SourceName))
|
|
settings.SourceName = webApplicationBuilder.Environment.ApplicationName;
|
|
#pragma warning restore
|
|
});
|
|
}
|
|
WebApplication webApplication = webApplicationBuilder.Build();
|
|
_ = webApplication.UseCors(corsPolicyBuilder => corsPolicyBuilder.AllowAnyOrigin().AllowAnyHeader().AllowAnyMethod());
|
|
if (!webApplicationBuilder.Environment.IsDevelopment())
|
|
{
|
|
_ = webApplication.UseExceptionHandler("/Error");
|
|
_ = webApplication.UseHttpsRedirection();
|
|
_ = webApplication.UseHsts();
|
|
}
|
|
else
|
|
{
|
|
if (string.IsNullOrEmpty(appSettings.URLs))
|
|
{
|
|
Environment.ExitCode = -1;
|
|
webApplication.Lifetime.StopApplication();
|
|
}
|
|
_ = webApplication.UseSwagger();
|
|
_ = webApplication.UseSwaggerUI(c => c.SwaggerEndpoint("/swagger/v1/swagger.json", "Server V1"));
|
|
}
|
|
_ = webApplication.Lifetime.ApplicationStopped.Register(Log.CloseAndFlush);
|
|
_ = ApplicationBuilderSerilogClientExtensions.UseSerilogIngestion(webApplication);
|
|
_ = SerilogApplicationBuilderExtensions.UseSerilogRequestLogging(webApplication);
|
|
_ = webApplication.UseFileServer(enableDirectoryBrowsing: true);
|
|
_ = webApplication.UseStaticFiles();
|
|
_ = webApplication.UseSession();
|
|
_ = webApplication.UseMiddleware<ApiLoggingMiddleware>();
|
|
_ = webApplication.MapControllers();
|
|
log.Information("Starting Web Application");
|
|
webApplication.Run();
|
|
return 0;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
log.Fatal(ex, "Host terminated unexpectedly");
|
|
return 1;
|
|
}
|
|
finally
|
|
{
|
|
Log.CloseAndFlush();
|
|
}
|
|
}
|
|
|
|
} |