-
Notifications
You must be signed in to change notification settings - Fork 42
/
Copy pathProgram.cs
107 lines (92 loc) · 4.84 KB
/
Program.cs
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
/*
Copyright 2009-2022 Intel Corporation
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
using System;
using System.Collections.Specialized;
using System.IO;
using System.Text;
using System.Web;
using System.Windows.Forms;
namespace MeshCentralRouter
{
static class Program
{
public static string LockToHostname = null;
public static string LockToServerId = null;
/// <summary>
/// The main entry point for the application.
/// </summary>
[STAThread]
static void Main(string[] args)
{
// If this application is signed, get the URL of the signature, this will be used to lock this application to a server.
Uri signedUrl = WinCrypt.GetSignatureUrl(System.Reflection.Assembly.GetEntryAssembly().Location);
if (signedUrl != null)
{
NameValueCollection urlArguments = HttpUtility.ParseQueryString(signedUrl.Query);
if (urlArguments["serverid"] != null)
{
LockToServerId = urlArguments["serverid"];
LockToHostname = signedUrl.Host;
}
}
Uri authLoginUrl = null;
// Setup settings & visual style
Application.EnableVisualStyles();
Application.SetCompatibleTextRenderingDefault(false);
Properties.Settings.Default.Upgrade();
Application.ThreadException += new System.Threading.ThreadExceptionEventHandler(ExceptionSink);
AppDomain.CurrentDomain.UnhandledException += new UnhandledExceptionEventHandler(UnhandledExceptionEventSink);
Application.SetUnhandledExceptionMode(UnhandledExceptionMode.CatchException, true);
foreach (string arg in args)
{
if (arg.Length > 3 && string.Compare(arg.Substring(0, 3), "-l:", true) == 0) {
try { System.Threading.Thread.CurrentThread.CurrentUICulture = new System.Globalization.CultureInfo(arg.Substring(3)); } catch (ArgumentException) { }
}
if ((arg.Length == 5) && (string.Compare(arg.Substring(0, 5), "-info", true) == 0))
{
string dialogText = string.Format(Properties.Resources.Version, System.Reflection.Assembly.GetExecutingAssembly().ImageRuntimeVersion);
if (LockToHostname != null) { dialogText += "\r\n" + string.Format(Properties.Resources.LockedToHost, LockToHostname); }
if (LockToServerId != null) { dialogText += "\r\n" + string.Format(Properties.Resources.LockedToServerId, LockToServerId); }
MessageBox.Show(dialogText, Properties.Resources.MeshCentralRouter);
return;
}
if (arg.Length > 11 && arg.Substring(0, 11).ToLower() == "mcrouter://") { authLoginUrl = new Uri(arg); }
}
// Setup single instance pipe client
if (authLoginUrl != null)
{
string urlstring = "wss://" + authLoginUrl.Host + ":" + ((authLoginUrl.Port > 0) ? authLoginUrl.Port : 443) + authLoginUrl.LocalPath;
LocalPipeClient localPipeClient = new LocalPipeClient(Convert.ToBase64String(UTF8Encoding.UTF8.GetBytes(urlstring))); // + "" + meshcentral.certHash
if (localPipeClient.TrySendingArguments(authLoginUrl.ToString()) == true) { Application.Exit(); return; }
}
MainForm main;
System.Globalization.CultureInfo currentCulture;
do
{
currentCulture = System.Threading.Thread.CurrentThread.CurrentUICulture;
main = new MainForm(args);
if (main.forceExit == false) { Application.Run(main); }
}
while (currentCulture.Equals(System.Threading.Thread.CurrentThread.CurrentUICulture) == false);
}
public static void Debug(string msg) { try { File.AppendAllText("debug.log", msg + "\r\n"); } catch (Exception) { } }
public static void ExceptionSink(object sender, System.Threading.ThreadExceptionEventArgs args)
{
Debug("ExceptionSink: " + args.Exception.ToString());
}
public static void UnhandledExceptionEventSink(object sender, UnhandledExceptionEventArgs args)
{
Debug("UnhandledExceptionEventSink: " + ((Exception)args.ExceptionObject).ToString());
}
}
}