Removed gpcl6win64 and LincPDFC just from proj file Removed package.json to clean out publish directory
63 lines
2.6 KiB
C#
63 lines
2.6 KiB
C#
using File_Watcher.Models;
|
|
using Microsoft.AspNetCore.Builder;
|
|
using Microsoft.Extensions.Hosting.WindowsServices;
|
|
|
|
namespace File_Watcher;
|
|
|
|
public class Program
|
|
{
|
|
|
|
internal static async Task Main(string[] args)
|
|
{
|
|
ILogger<Program>? logger = null;
|
|
#pragma warning disable IL3050
|
|
WebApplicationBuilder webApplicationBuilder = WebApplication.CreateBuilder(args);
|
|
#pragma warning restore IL3050
|
|
_ = webApplicationBuilder.Configuration.AddUserSecrets<Program>();
|
|
AppSettings appSettings = AppSettings.Get(webApplicationBuilder.Configuration);
|
|
if (string.IsNullOrEmpty(appSettings.FileWatcherConfiguration.Company))
|
|
throw new Exception("Company name must have a value!");
|
|
try
|
|
{
|
|
List<string> collection =
|
|
[
|
|
$"BuildNumber:{webApplicationBuilder.Configuration.GetValue<string>("BuildNumber")};",
|
|
$"GitCommitSeven:{webApplicationBuilder.Configuration.GetValue<string>("GitCommitSeven")};"
|
|
];
|
|
_ = webApplicationBuilder.Services.AddHttpClient();
|
|
_ = webApplicationBuilder.Services.AddHostedService<Worker>();
|
|
_ = webApplicationBuilder.Services.AddSingleton(collection);
|
|
_ = webApplicationBuilder.Services.AddSingleton(appSettings);
|
|
if (WindowsServiceHelpers.IsWindowsService())
|
|
{
|
|
collection.Add(nameof(WindowsServiceLifetime));
|
|
_ = 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
|
|
});
|
|
}
|
|
using WebApplication webApplication = webApplicationBuilder.Build();
|
|
logger = webApplication.Services.GetRequiredService<ILogger<Program>>();
|
|
if (string.IsNullOrEmpty(appSettings.FileWatcherConfiguration.Company))
|
|
{
|
|
Environment.ExitCode = -1;
|
|
_ = webApplication.StopAsync();
|
|
}
|
|
logger.LogInformation("Starting Web Application");
|
|
logger.LogCritical("{Company}", appSettings.FileWatcherConfiguration.Company);
|
|
await webApplication.RunAsync();
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
try
|
|
{ logger?.LogCritical(ex, "WebApplication terminated unexpectedly"); }
|
|
catch (Exception) { }
|
|
throw;
|
|
}
|
|
}
|
|
|
|
} |