-
-
Notifications
You must be signed in to change notification settings - Fork 4
Expand file tree
/
Copy pathProgram.cs
More file actions
113 lines (102 loc) · 4.33 KB
/
Program.cs
File metadata and controls
113 lines (102 loc) · 4.33 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
using System.Reflection;
using Avalonia;
using DryIoc;
using DryIoc.Microsoft.DependencyInjection;
using JetBrains.Annotations;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using OpenSSH_GUI.Core;
using OpenSSH_GUI.Core.Enums;
using OpenSSH_GUI.Core.Extensions;
using OpenSSH_GUI.Extensions;
using OpenSSH_GUI.SshConfig.Extensions;
using ReactiveUI.Avalonia;
using Serilog;
using Serilog.Core;
namespace OpenSSH_GUI;
[UsedImplicitly]
internal sealed class Program
{
public const SshConfigFiles ConfigFile = SshConfigFiles.Config;
public const SshConfigFiles SshdConfig = SshConfigFiles.Sshd_Config;
public const string AppName = "OpenSSH GUI";
public const string VersionEnvVar = "RUNNING_VERSION";
public const string IconServiceKey = "AppIcon";
private static string GetHostVersion()
{
return Assembly.GetEntryAssembly()
?.GetCustomAttribute<AssemblyInformationalVersionAttribute>()
?.InformationalVersion
?? Assembly.GetEntryAssembly()?.GetName().Version?.ToString()
?? "0.0.0";
}
private static Logger? CreateLogger(IContainer container)
{
var logConfiguration = Core.Configuration.LoggerConfiguration.Default;
if (!Directory.Exists(logConfiguration.LogFilePath))
Directory.CreateDirectory(logConfiguration.LogFilePath);
return new LoggerConfiguration()
.Enrich.FromLogContext()
.Enrich.WithCaller()
.MinimumLevel.ControlledBy(container.Resolve<LoggingLevelSwitch>())
#if DEBUG
.WriteTo.ColoredConsole(outputTemplate: logConfiguration.LogOutputTemplate)
#endif
.WriteTo.File(
logConfiguration.LogFileFullPath,
outputTemplate: logConfiguration.LogOutputTemplate,
rollingInterval: RollingInterval.Day)
.CreateLogger();
}
#pragma warning disable CA1416
[STAThread]
public static async Task Main(string[] args)
{
using var container = new Container(rules =>
{
var newRules = rules;
if (!rules.HasMicrosoftDependencyInjectionRules())
newRules = rules.WithMicrosoftDependencyInjectionRules();
return newRules.WithDefaultReuse(Reuse.Singleton)
.WithTrackingDisposableTransients()
.WithoutThrowOnRegisteringDisposableTransient()
.WithDefaultIfAlreadyRegistered(IfAlreadyRegistered.Replace);
});
container.ConfigureServicesInternal();
var factory = new DryIocServiceProviderFactory(container);
using var mainCancellationTokenSource = new CancellationTokenSource();
var host = Host.CreateDefaultBuilder(args)
.UseServiceProviderFactory(factory)
.ConfigureServices(services => services.RegisterOpenSshGuiServices())
.UseSerilog(logger: CreateLogger(container), dispose: true)
.ConfigureAppConfiguration(ConfigureAppConfiguration)
.Build();
var appBuilder = AppBuilder.Configure(() => host.Services.GetRequiredService<App>())
.UsePlatformDetect()
.WithInterFont()
.UseReactiveUI(configure =>
{
configure.WithPlatformServices();
configure.WithAvalonia();
configure.WithExceptionHandler(host.Services.GetRequiredService<ExceptionHandler>());
});
await host.StartAsync(mainCancellationTokenSource.Token);
appBuilder.StartWithClassicDesktopLifetime(args);
await host.StopAsync(mainCancellationTokenSource.Token);
}
#pragma warning restore CA1416
private static void ConfigureAppConfiguration(HostBuilderContext builderContext,
IConfigurationBuilder configurationBuilder)
{
configurationBuilder.AddSshConfig(ConfigFile.GetPathOfFile(), true, true, LoggingAction);
configurationBuilder.AddSshConfig(SshdConfig.GetPathOfFile(), true, true, LoggingAction);
configurationBuilder.AddInMemoryCollection([
new KeyValuePair<string, string?>(VersionEnvVar, GetHostVersion())
]);
}
private static void LoggingAction(string arg1, Exception arg2)
{
Log.Logger.Error(arg2, "Failed to load SSH config file: {Path}", arg1);
}
}