프로젝트

일반

사용자정보

통계
| 브랜치(Branch): | 개정판:

markus / MarkusAutoUpdate / src / NetSparkle.Samples.NetFramework.WPF / MainWindow.xaml.cs @ d3161976

이력 | 보기 | 이력해설 | 다운로드 (12.6 KB)

1
using NetSparkle.TestAppWPF.Common;
2
using NetSparkle.TestAppWPF.ViewModel;
3
using NetSparkleUpdater.Events;
4
using NetSparkleUpdater.SignatureVerifiers;
5
using System;
6
using System.Diagnostics;
7
using System.Drawing;
8
using System.IO;
9
using System.IO.Compression;
10
using System.Linq;
11
using System.Security;
12
using System.Threading.Tasks;
13
using System.Windows;
14

    
15

    
16
namespace NetSparkleUpdater.Samples.NetFramework.WPF
17
{
18
    /// <summary>
19
    /// Interaction logic for MainWindow.xaml
20
    /// </summary>
21
    public partial class MainWindow : Window
22
    {
23
        private SparkleUpdater _sparkle;
24
        private const string InstallPath = @"C:\Program Files\Doftech\MARKUS";
25
        private string KcomPath = @"C:\Program Files\Doftech\MARKUS\KCOM.exe";
26

    
27
        private string downloadFile;
28
        private string tempStoragePath;
29

    
30
        private NetSparkle.TestAppWPF.ViewModels.MainViewModel viewModel;
31

    
32
        public MainWindow()
33
        {
34
            InitializeComponent();
35
            viewModel = new NetSparkle.TestAppWPF.ViewModels.MainViewModel();
36
            this.DataContext = viewModel;
37

    
38
            //remove the netsparkle key from registry z
39
            //try
40
            //{
41
            //    Microsoft.Win32.Registry.CurrentUser.DeleteSubKeyTree("Software\\Microsoft\\NetSparkle.TestAppNetCoreWPF");
42
            //}
43
            //catch (Exception ex)
44
            //{
45
            //    System.Diagnostics.Debug.WriteLine(ex);
46
            //}
47

    
48
            // set icon in project properties!
49
            try
50
            {
51
                string manifestModuleName = System.Reflection.Assembly.GetEntryAssembly().ManifestModule.FullyQualifiedName;
52
                var icon = System.Drawing.Icon.ExtractAssociatedIcon(manifestModuleName);
53

    
54
                tempStoragePath = System.IO.Path.Combine(System.IO.Path.GetTempPath(), "MARKUS", System.IO.Path.GetRandomFileName());
55

    
56
                App.logger.Info($"Temp Strorage Create : {tempStoragePath}");
57

    
58
                if (!Directory.Exists(tempStoragePath))
59
                {
60
                    Directory.CreateDirectory(tempStoragePath);
61
                }
62

    
63
                if (!Directory.Exists(InstallPath))
64
                {
65
                    CheckAdmin();
66
                    Directory.CreateDirectory(InstallPath);
67
                }
68

    
69
                //File.Copy(KcomPath, System.IO.Path.Combine(tempStoragePath, "Kcom.exe"));
70

    
71
                //KcomPath = System.IO.Path.Combine(tempStoragePath, "Kcom.exe");
72

    
73
                if (!File.Exists(KcomPath))
74
                {
75
                    CheckAdmin();
76
                    File.Copy(Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "kcom.exe"), KcomPath);
77
                }
78

    
79
                _sparkle = new SparkleUpdater(App.AppCastUri, new Ed25519Checker(Enums.SecurityMode.Unsafe, null, "NetSparkle_Ed25519.pub"), KcomPath)
80
                {
81
                    UIFactory = new NetSparkleUpdater.UI.WPF.UIFactory(NetSparkleUpdater.UI.WPF.IconUtilities.ToImageSource(icon)),
82
                    ShowsUIOnMainThread = true,
83
                    TmpDownloadFilePath = tempStoragePath,
84
                    UserInteractionMode = Enums.UserInteractionMode.DownloadNoInstall,
85
                    //UseNotificationToast = true
86
                    RelaunchAfterUpdate = true,
87
                    SecurityProtocolType = System.Net.SecurityProtocolType.Tls12
88
            };
89

    
90
                // TLS 1.2 required by GitHub (https://developer.github.com/changes/2018-02-01-weak-crypto-removal-notice/)
91
                _sparkle.DownloadFinished += FullUpdate_DownloadFileIsReady;
92
                _sparkle.UpdateCheckFinished += _sparkle_UpdateCheckFinished;
93
                _sparkle.DownloadHadError += _sparkle_DownloadError;
94
                _sparkle.DownloadMadeProgress += _sparkle_DownloadMadeProgress;
95
                //_sparkle.StartLoop(true, true);
96
                Updater();
97
                App.logger.Info("main Initialize");
98

    
99
                this.Loaded += MainWindow_Loaded;
100
            }
101
            catch (Exception ex)
102
            {
103
                App.logger.Error("main Initialize", ex);
104
            }
105

    
106
        }
107
        private void CheckAdmin()
108
        {
109
            if (!VistaSecurity.IsAdmin())
110
            {
111
                var param = new ExtractParam(App.KcomParam);
112

    
113
                VistaSecurity.RestartElevated($"ADMIN {ObjectToBytesStringConvert.ObjectToBytesString(param)}");
114
            }
115
        }
116

    
117
        private void _sparkle_DownloadMadeProgress(object sender, AppCastItem item, ItemDownloadProgressEventArgs args)
118
        {
119
            viewModel.DownloadProgress = args.ProgressPercentage;
120
        }
121

    
122
        private void _sparkle_DownloadError(AppCastItem item, string path, Exception exception)
123
        {
124
            App.logger.Error($"Download Error", exception);
125
        }
126

    
127
        private async void Updater()
128
        {
129
            App.logger.Info("main Load");
130
            try
131
            {
132
                var _updateInfo = await _sparkle.CheckForUpdatesQuietly();
133

    
134
                if (_updateInfo != null)
135
                {
136
                    App.logger.Info("Update Status : " + _updateInfo.Status);
137

    
138
                    switch (_updateInfo.Status)
139
                    {
140
                        case Enums.UpdateStatus.UpdateAvailable:
141
                            this.Visibility = Visibility.Visible;
142
                            //string a = "There's an update available!";
143
                            var castitem = _updateInfo.Updates.First();
144

    
145
                            viewModel.UpdateVersion = castitem.Version;
146
                            System.Threading.Thread.Sleep(1000);
147
                            
148
                            if (App.IsExternal)
149
                            {
150
                                if (!string.IsNullOrWhiteSpace(castitem.DownloadLink))
151
                                {
152
                                    var uri = UriHelper.ChangeAddress(new Uri(castitem.DownloadLink), App.ExternalAddress);
153
                                    castitem.DownloadLink = uri.ToString();
154
                                }
155

    
156
                                if (!string.IsNullOrWhiteSpace(castitem.ReleaseNotesLink))
157
                                {
158
                                    var uri2 = UriHelper.ChangeAddress(new Uri(castitem.ReleaseNotesLink), App.ExternalAddress);
159
                                    castitem.ReleaseNotesLink = uri2.ToString();
160
                                }
161
                                
162
                            }
163

    
164
                            await _sparkle.InitAndBeginDownload(castitem);
165

    
166
                            App.logger.Info($"Update available Version : {castitem.Version} Link : {castitem.DownloadLink}");
167

    
168
                            break;
169
                        case Enums.UpdateStatus.UpdateNotAvailable:
170
                        case Enums.UpdateStatus.CouldNotDetermine:
171
                            _sparkle.CloseApplication += () =>
172
                            {
173
                                App.logger.Info($"Start Markus : {App.KcomParam}");
174

    
175
                                Process.Start(KcomPath, App.KcomParam);
176
                                Application.Current.Shutdown();
177
                            };
178

    
179
                            App.logger.Info($"Update Not available. Application Exit.");
180
                            await _sparkle.QuitApplication();
181

    
182
                            break;
183
                    }
184
                }
185
                else
186
                {
187
                    if (_updateInfo != null)
188
                    {
189
                        App.logger.Error("Update Is Null");
190
                        Process.Start(KcomPath, App.KcomParam);
191
                    }
192
                }
193
            }
194
            catch (Exception ex)
195
            {
196
                App.logger.Error($"main Load", ex);
197
            }
198

    
199
        }
200

    
201
        private async void MainWindow_Loaded(object sender, RoutedEventArgs e)
202
        {
203

    
204
        }
205

    
206
        private void _sparkle_UpdateCheckFinished(object sender, Enums.UpdateStatus status)
207
        {
208

    
209
        }
210

    
211
        //[PermissionSet(SecurityAction.Demand, Name = "FullTrust")]
212
        private void FullUpdate_DownloadFileIsReady(AppCastItem item, string downloadPath)
213
        {
214
            viewModel.IsWait = true;
215

    
216
            ExtractFiles(InstallPath,tempStoragePath,downloadPath,KcomPath, App.KcomParam);
217
            if (VistaSecurity.IsAdmin())
218
            {
219
                ExtractFiles(InstallPath, tempStoragePath, downloadPath, KcomPath, App.KcomParam);
220
            }
221
            else
222
            {
223
                var param = new ExtractParam(tempStoragePath, downloadPath, App.KcomParam);
224
                VistaSecurity.RestartElevated($"EXT {ObjectToBytesStringConvert.ObjectToBytesString(param)}");
225
            }
226
            //ExtractProcess(item, downloadPath);
227
        }
228

    
229
        [System.Security.Permissions.PermissionSet(System.Security.Permissions.SecurityAction.Demand, Name = "FullTrust")]
230
        private void ExtractFiles(string InstallPath, string tempStoragePath, string downloadFile, string KcomPath, string Param)
231
        {
232
            viewModel.IsWait = true;
233
            try
234
            {
235
                var extractFolder = Path.Combine(tempStoragePath, "Extract");
236

    
237
                ZipFile.ExtractToDirectory(downloadFile, extractFolder);
238

    
239
                foreach (var file in Directory.EnumerateFiles(extractFolder, "*.*", SearchOption.AllDirectories))
240
                {
241
                    var target = System.IO.Path.Combine(InstallPath, file.Replace(extractFolder, "").Substring(1));
242

    
243
                    var dir = Path.GetDirectoryName(target);
244

    
245
                    if (!Directory.Exists(dir))
246
                    {
247
                        Directory.CreateDirectory(dir);
248
                    }
249

    
250
                    File.Copy(file, target, FileExits(target));
251
                    App.logger.Info($"Copy - {target}");
252
                }
253

    
254
                Process.Start(KcomPath, Param);
255
            }
256
            catch (Exception ex)
257
            {
258
                App.logger.Error($"ExtractFile Error", ex);
259

    
260
                if (ex.InnerException != null)
261
                {
262
                    App.logger.Error($"ExtractFile Error InnerException", ex.InnerException);
263
                }
264
            }
265
            finally
266
            {
267
                Application.Current.Shutdown();
268
            }
269
        }
270

    
271
        private static bool FileExits(string fileName)
272
        {
273
            try
274
            {
275
                return File.Exists(fileName);
276
            }
277
            catch (Exception)
278
            {
279
                return false;
280
            }
281
        }
282

    
283
        private void ExtractProcess(AppCastItem item, string downloadPath)
284
        { 
285
            try
286
            {
287
                downloadFile = downloadPath;
288

    
289
                //var args = $"{InstallPath} {tempStoragePath} {downloadFile} {KcomPath} {App.KcomParam}";
290

    
291
                string endpoint = IIpc.Commons.shortGuid();
292

    
293
                var wcfServer = new IIpc.WcfServer(endpoint + "M");
294
                wcfServer.Start();
295

    
296
                wcfServer.ProcessStart += (snd, ect) =>
297
                {
298
                    var ipcClient = new IIpc.WcfClient(endpoint + "E");
299
                    try
300
                    {
301
                        ipcClient.ParamReceived(InstallPath, tempStoragePath, downloadFile, KcomPath, App.KcomParam);
302

    
303
                        //Application.Current.Shutdown();
304
                    }
305
                    catch (Exception ex)
306
                    {
307
                        App.logger.Error($"ParamReceived ", ex);
308
                    }
309
                };
310

    
311
                //MarkusExtract.GetFile();
312

    
313
                var exrtractFile = System.IO.Path.Combine(System.IO.Path.GetDirectoryName(System.Reflection.Assembly.GetExecutingAssembly().Location), "MarkusExtractUpdate", @"MarkusUpdateExtract.exe");
314

    
315
                Process DownloadProcess = new Process();
316

    
317
                ProcessStartInfo startInfo = new ProcessStartInfo
318
                {
319
                    UseShellExecute = false,
320
                    FileName = exrtractFile,
321
                    WindowStyle = ProcessWindowStyle.Hidden,
322
                    CreateNoWindow = true,
323
                    ErrorDialog = false,
324
                    Verb = "runas",
325
                    RedirectStandardInput = false,
326
                    RedirectStandardError = false,
327
                    Arguments = endpoint
328
                };
329

    
330
                //$"{ InstallPath} {tempStoragePath} {downloadFile} {KcomPath} {param}"
331

    
332
                DownloadProcess.StartInfo = startInfo;
333
                DownloadProcess.EnableRaisingEvents = false;
334

    
335
                DownloadProcess.Start();
336
            }
337
            catch (Exception ex)
338
            {
339
                App.logger.Error($"DownloadFileIsReady ", ex);
340
            }
341

    
342
        }
343
    }
344
}
클립보드 이미지 추가 (최대 크기: 500 MB)