root / trunk / Pithos.Client.WPF / App.xaml.cs @ 79f92570
History | View | Annotate | Download (9.9 kB)
1 | 255f5f86 | Panagiotis Kanavos | #region |
---|---|---|---|
2 | 255f5f86 | Panagiotis Kanavos | /* ----------------------------------------------------------------------- |
3 | 255f5f86 | Panagiotis Kanavos | * <copyright file="App.xaml.cs" company="GRNet"> |
4 | 255f5f86 | Panagiotis Kanavos | * |
5 | 255f5f86 | Panagiotis Kanavos | * Copyright 2011-2012 GRNET S.A. All rights reserved. |
6 | 255f5f86 | Panagiotis Kanavos | * |
7 | 255f5f86 | Panagiotis Kanavos | * Redistribution and use in source and binary forms, with or |
8 | 255f5f86 | Panagiotis Kanavos | * without modification, are permitted provided that the following |
9 | 255f5f86 | Panagiotis Kanavos | * conditions are met: |
10 | 255f5f86 | Panagiotis Kanavos | * |
11 | 255f5f86 | Panagiotis Kanavos | * 1. Redistributions of source code must retain the above |
12 | 255f5f86 | Panagiotis Kanavos | * copyright notice, this list of conditions and the following |
13 | 255f5f86 | Panagiotis Kanavos | * disclaimer. |
14 | 255f5f86 | Panagiotis Kanavos | * |
15 | 255f5f86 | Panagiotis Kanavos | * 2. Redistributions in binary form must reproduce the above |
16 | 255f5f86 | Panagiotis Kanavos | * copyright notice, this list of conditions and the following |
17 | 255f5f86 | Panagiotis Kanavos | * disclaimer in the documentation and/or other materials |
18 | 255f5f86 | Panagiotis Kanavos | * provided with the distribution. |
19 | 255f5f86 | Panagiotis Kanavos | * |
20 | 255f5f86 | Panagiotis Kanavos | * |
21 | 255f5f86 | Panagiotis Kanavos | * THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS |
22 | 255f5f86 | Panagiotis Kanavos | * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED |
23 | 255f5f86 | Panagiotis Kanavos | * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
24 | 255f5f86 | Panagiotis Kanavos | * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR |
25 | 255f5f86 | Panagiotis Kanavos | * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
26 | 255f5f86 | Panagiotis Kanavos | * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
27 | 255f5f86 | Panagiotis Kanavos | * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF |
28 | 255f5f86 | Panagiotis Kanavos | * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED |
29 | 255f5f86 | Panagiotis Kanavos | * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT |
30 | 255f5f86 | Panagiotis Kanavos | * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN |
31 | 255f5f86 | Panagiotis Kanavos | * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
32 | 255f5f86 | Panagiotis Kanavos | * POSSIBILITY OF SUCH DAMAGE. |
33 | 255f5f86 | Panagiotis Kanavos | * |
34 | 255f5f86 | Panagiotis Kanavos | * The views and conclusions contained in the software and |
35 | 255f5f86 | Panagiotis Kanavos | * documentation are those of the authors and should not be |
36 | 255f5f86 | Panagiotis Kanavos | * interpreted as representing official policies, either expressed |
37 | 255f5f86 | Panagiotis Kanavos | * or implied, of GRNET S.A. |
38 | 255f5f86 | Panagiotis Kanavos | * </copyright> |
39 | 255f5f86 | Panagiotis Kanavos | * ----------------------------------------------------------------------- |
40 | 255f5f86 | Panagiotis Kanavos | */ |
41 | 255f5f86 | Panagiotis Kanavos | #endregion |
42 | 255f5f86 | Panagiotis Kanavos | using System; |
43 | 9bae55d1 | Panagiotis Kanavos | using System.Collections.Generic; |
44 | db8a9589 | Panagiotis Kanavos | using System.IO; |
45 | 9bae55d1 | Panagiotis Kanavos | using System.Linq; |
46 | 5bcf6d70 | Panagiotis Kanavos | using System.Reflection; |
47 | ff26eb71 | Panagiotis Kanavos | using System.Text; |
48 | 759bd3c4 | Panagiotis Kanavos | using System.Threading; |
49 | ff26eb71 | Panagiotis Kanavos | using System.Threading.Tasks; |
50 | 9bae55d1 | Panagiotis Kanavos | using System.Windows; |
51 | ff26eb71 | Panagiotis Kanavos | using Caliburn.Micro; |
52 | 29a6b387 | Panagiotis Kanavos | using Pithos.Client.WPF.Properties; |
53 | db8a9589 | Panagiotis Kanavos | using log4net.Appender; |
54 | db8a9589 | Panagiotis Kanavos | using log4net.Repository.Hierarchy; |
55 | 20e9a378 | Panagiotis Kanavos | |
56 | 9bae55d1 | Panagiotis Kanavos | |
57 | 9bae55d1 | Panagiotis Kanavos | namespace Pithos.Client.WPF |
58 | 9bae55d1 | Panagiotis Kanavos | { |
59 | 9bae55d1 | Panagiotis Kanavos | /// <summary> |
60 | 9bae55d1 | Panagiotis Kanavos | /// Interaction logic for App.xaml |
61 | 9bae55d1 | Panagiotis Kanavos | /// </summary> |
62 | 9bae55d1 | Panagiotis Kanavos | public partial class App : Application |
63 | 9bae55d1 | Panagiotis Kanavos | { |
64 | db8a9589 | Panagiotis Kanavos | private static readonly log4net.ILog Log = log4net.LogManager.GetLogger( MethodBase.GetCurrentMethod().DeclaringType ); |
65 | f734ab5b | Panagiotis Kanavos | |
66 | 46426dbd | Panagiotis Kanavos | |
67 | 46426dbd | Panagiotis Kanavos | |
68 | 9bae55d1 | Panagiotis Kanavos | public App() |
69 | 9bae55d1 | Panagiotis Kanavos | { |
70 | 46426dbd | Panagiotis Kanavos | |
71 | db8a9589 | Panagiotis Kanavos | InitializeLogging(); |
72 | db8a9589 | Panagiotis Kanavos | |
73 | db8a9589 | Panagiotis Kanavos | |
74 | db8a9589 | Panagiotis Kanavos | DispatcherUnhandledException += OnDispatcherUnhandledException; |
75 | ff26eb71 | Panagiotis Kanavos | AppDomain.CurrentDomain.UnhandledException += OnUnhandledException; |
76 | ff26eb71 | Panagiotis Kanavos | TaskScheduler.UnobservedTaskException += OnUnobservedException; |
77 | 5bcf6d70 | Panagiotis Kanavos | |
78 | 79f92570 | Panagiotis Kanavos | //_sparkle = new Sparkle(Settings.Default.UpdateUrl); |
79 | 79f92570 | Panagiotis Kanavos | //_sparkle.updateDetected += OnUpdateDetected; |
80 | 79f92570 | Panagiotis Kanavos | //_sparkle.ShowDiagnosticWindow = true; |
81 | 46426dbd | Panagiotis Kanavos | |
82 | 79f92570 | Panagiotis Kanavos | //Must delay opening the upgrade window |
83 | 79f92570 | Panagiotis Kanavos | //to avoid Windows Messages sent by the TaskbarIcon |
84 | 79f92570 | Panagiotis Kanavos | //TaskEx.Delay(5000).ContinueWith(_=>_sparkle.StartLoop(true,true),TaskScheduler.FromCurrentSynchronizationContext()); |
85 | 46426dbd | Panagiotis Kanavos | |
86 | 8a84d039 | Panagiotis Kanavos | //Fix incorrect proxy settings by switching to default proxy, if the proxy server settings is empty |
87 | 8a84d039 | Panagiotis Kanavos | if (Settings.Default.UseManualProxy && String.IsNullOrWhiteSpace(Settings.Default.ProxyServer)) |
88 | 8a84d039 | Panagiotis Kanavos | { |
89 | 8a84d039 | Panagiotis Kanavos | Settings.Default.UseManualProxy = false; |
90 | 8a84d039 | Panagiotis Kanavos | Settings.Default.UseDefaultProxy = true; |
91 | 8a84d039 | Panagiotis Kanavos | } |
92 | 8a84d039 | Panagiotis Kanavos | |
93 | 5bcf6d70 | Panagiotis Kanavos | InitializeComponent(); |
94 | 9bae55d1 | Panagiotis Kanavos | } |
95 | ff26eb71 | Panagiotis Kanavos | |
96 | 79f92570 | Panagiotis Kanavos | /* |
97 | 46426dbd | Panagiotis Kanavos | private void OnUpdateDetected(object sender, UpdateDetectedEventArgs e) |
98 | 46426dbd | Panagiotis Kanavos | { |
99 | 46426dbd | Panagiotis Kanavos | Log.InfoFormat("Update Detected {0}",e.LatestVersion.Version); |
100 | 46426dbd | Panagiotis Kanavos | } |
101 | 79f92570 | Panagiotis Kanavos | */ |
102 | 46426dbd | Panagiotis Kanavos | |
103 | db8a9589 | Panagiotis Kanavos | private static void InitializeLogging() |
104 | db8a9589 | Panagiotis Kanavos | { |
105 | db8a9589 | Panagiotis Kanavos | log4net.Config.XmlConfigurator.Configure(); |
106 | db8a9589 | Panagiotis Kanavos | |
107 | db8a9589 | Panagiotis Kanavos | try |
108 | db8a9589 | Panagiotis Kanavos | { |
109 | db8a9589 | Panagiotis Kanavos | var appDataPath = Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData); |
110 | db8a9589 | Panagiotis Kanavos | var pithosDataPath= Path.Combine(appDataPath , "GRNET"); |
111 | db8a9589 | Panagiotis Kanavos | if (!Directory.Exists(pithosDataPath)) |
112 | db8a9589 | Panagiotis Kanavos | Directory.CreateDirectory(pithosDataPath); |
113 | db8a9589 | Panagiotis Kanavos | |
114 | db8a9589 | Panagiotis Kanavos | var loggerRepository = (Hierarchy)log4net.LogManager.GetRepository(); |
115 | db8a9589 | Panagiotis Kanavos | |
116 | db8a9589 | Panagiotis Kanavos | var appenders = loggerRepository.GetAppenders(); |
117 | db8a9589 | Panagiotis Kanavos | var lossyAppender = appenders.OfType<BufferingForwardingAppender>() |
118 | db8a9589 | Panagiotis Kanavos | .First(appender => appender.Name == "LossyFileAppender"); |
119 | db8a9589 | Panagiotis Kanavos | var dumpAppender = lossyAppender.Appenders.OfType<RollingFileAppender>().First(); |
120 | db8a9589 | Panagiotis Kanavos | dumpAppender.File = Path.Combine(pithosDataPath, "errorlog.txt"); |
121 | db8a9589 | Panagiotis Kanavos | dumpAppender.ActivateOptions(); |
122 | db8a9589 | Panagiotis Kanavos | } |
123 | db8a9589 | Panagiotis Kanavos | catch (Exception exc) |
124 | db8a9589 | Panagiotis Kanavos | { |
125 | db8a9589 | Panagiotis Kanavos | Log.Error("Dumpl appender initialization failed",exc); |
126 | db8a9589 | Panagiotis Kanavos | } |
127 | db8a9589 | Panagiotis Kanavos | } |
128 | db8a9589 | Panagiotis Kanavos | |
129 | 29a6b387 | Panagiotis Kanavos | protected override void OnStartup(StartupEventArgs e) |
130 | ca79acb7 | Panagiotis Kanavos | { |
131 | 29a6b387 | Panagiotis Kanavos | if (!Settings.Default.StartOnSystemStartup && e.Args.Contains("startup")) |
132 | 29a6b387 | Panagiotis Kanavos | { |
133 | db8a9589 | Panagiotis Kanavos | Shutdown(); |
134 | ca79acb7 | Panagiotis Kanavos | return; |
135 | 29a6b387 | Panagiotis Kanavos | } |
136 | db8a9589 | Panagiotis Kanavos | |
137 | db8a9589 | Panagiotis Kanavos | //Delay during startup |
138 | 759bd3c4 | Panagiotis Kanavos | if (e.Args.Contains("startup")) |
139 | 759bd3c4 | Panagiotis Kanavos | { |
140 | 759bd3c4 | Panagiotis Kanavos | if (Settings.Default.StartupDelay>TimeSpan.Zero) |
141 | 759bd3c4 | Panagiotis Kanavos | Thread.Sleep(Settings.Default.StartupDelay); |
142 | 759bd3c4 | Panagiotis Kanavos | } |
143 | 759bd3c4 | Panagiotis Kanavos | |
144 | ca79acb7 | Panagiotis Kanavos | var splashScreen = new SplashScreen("images/logo.png"); |
145 | ca79acb7 | Panagiotis Kanavos | splashScreen.Show(true); |
146 | ca79acb7 | Panagiotis Kanavos | |
147 | 29a6b387 | Panagiotis Kanavos | base.OnStartup(e); |
148 | 29a6b387 | Panagiotis Kanavos | } |
149 | 29a6b387 | Panagiotis Kanavos | |
150 | ff26eb71 | Panagiotis Kanavos | private void OnUnobservedException(object sender, UnobservedTaskExceptionEventArgs e) |
151 | ff26eb71 | Panagiotis Kanavos | { |
152 | ff26eb71 | Panagiotis Kanavos | var messages=new List<UserMessage>(); |
153 | ff26eb71 | Panagiotis Kanavos | e.Exception.Handle(exc=>{ |
154 | ff26eb71 | Panagiotis Kanavos | messages.Add(new UserMessage |
155 | ff26eb71 | Panagiotis Kanavos | { |
156 | ff26eb71 | Panagiotis Kanavos | Message = "Unexpected Exception", |
157 | ff26eb71 | Panagiotis Kanavos | Details = exc.ToString(), |
158 | ff26eb71 | Panagiotis Kanavos | Severity = Severity.Error |
159 | ff26eb71 | Panagiotis Kanavos | }); |
160 | ff26eb71 | Panagiotis Kanavos | return true; |
161 | ff26eb71 | Panagiotis Kanavos | }); |
162 | ff26eb71 | Panagiotis Kanavos | |
163 | db8a9589 | Panagiotis Kanavos | Log.Error("Unobserved Task Exception",e.Exception); |
164 | db8a9589 | Panagiotis Kanavos | |
165 | db8a9589 | Panagiotis Kanavos | var message = String.Format(@"{0}\r\n{1}\r\n\r\n{2}", |
166 | db8a9589 | Panagiotis Kanavos | WPF.Properties.Resources.Unexpected_Error, |
167 | db8a9589 | Panagiotis Kanavos | WPF.Properties.Resources.We_Apologize, |
168 | db8a9589 | Panagiotis Kanavos | WPF.Properties.Resources.Please_Submit_Error); |
169 | db8a9589 | Panagiotis Kanavos | ShowMessages("Oops!",message, messages); |
170 | ff26eb71 | Panagiotis Kanavos | e.SetObserved(); |
171 | ff26eb71 | Panagiotis Kanavos | } |
172 | ff26eb71 | Panagiotis Kanavos | |
173 | ff26eb71 | Panagiotis Kanavos | private void OnUnhandledException(object sender, UnhandledExceptionEventArgs e) |
174 | ff26eb71 | Panagiotis Kanavos | { |
175 | db8a9589 | Panagiotis Kanavos | Log.Error("Unhandled exception", (Exception)e.ExceptionObject); |
176 | db8a9589 | Panagiotis Kanavos | |
177 | db8a9589 | Panagiotis Kanavos | var description = e.IsTerminating |
178 | db8a9589 | Panagiotis Kanavos | ? WPF.Properties.Resources.Unexpected_Error_Terminating |
179 | db8a9589 | Panagiotis Kanavos | : WPF.Properties.Resources.Unexpected_Error; |
180 | db8a9589 | Panagiotis Kanavos | var message = String.Format(@"{0}\r\n{1}\r\n\r\n{2}", |
181 | db8a9589 | Panagiotis Kanavos | description, |
182 | db8a9589 | Panagiotis Kanavos | WPF.Properties.Resources.We_Apologize, |
183 | db8a9589 | Panagiotis Kanavos | WPF.Properties.Resources.Please_Submit_Error); |
184 | ff26eb71 | Panagiotis Kanavos | |
185 | ff26eb71 | Panagiotis Kanavos | |
186 | db8a9589 | Panagiotis Kanavos | var exc = ((Exception) e.ExceptionObject); |
187 | ff26eb71 | Panagiotis Kanavos | var messages = new[]{ |
188 | ff26eb71 | Panagiotis Kanavos | new UserMessage |
189 | ff26eb71 | Panagiotis Kanavos | { |
190 | db8a9589 | Panagiotis Kanavos | Message = exc.Message, |
191 | db8a9589 | Panagiotis Kanavos | Details = exc.ToString(), |
192 | ff26eb71 | Panagiotis Kanavos | Severity = Severity.Error |
193 | ff26eb71 | Panagiotis Kanavos | } |
194 | ff26eb71 | Panagiotis Kanavos | }; |
195 | db8a9589 | Panagiotis Kanavos | |
196 | db8a9589 | Panagiotis Kanavos | |
197 | ff26eb71 | Panagiotis Kanavos | ShowMessages("Oops!", message,messages); |
198 | ff26eb71 | Panagiotis Kanavos | } |
199 | ff26eb71 | Panagiotis Kanavos | |
200 | db8a9589 | Panagiotis Kanavos | void OnDispatcherUnhandledException(object sender, System.Windows.Threading.DispatcherUnhandledExceptionEventArgs e) |
201 | db8a9589 | Panagiotis Kanavos | { |
202 | db8a9589 | Panagiotis Kanavos | Log.Error("Unhandled Dispatcher exception", e.Exception); |
203 | db8a9589 | Panagiotis Kanavos | |
204 | ff26eb71 | Panagiotis Kanavos | var messages = new[]{ |
205 | ff26eb71 | Panagiotis Kanavos | new UserMessage |
206 | ff26eb71 | Panagiotis Kanavos | { |
207 | ff26eb71 | Panagiotis Kanavos | Message = e.Exception.Message, |
208 | ff26eb71 | Panagiotis Kanavos | Details = e.Exception.ToString(), |
209 | ff26eb71 | Panagiotis Kanavos | Severity = Severity.Error |
210 | ff26eb71 | Panagiotis Kanavos | } |
211 | ff26eb71 | Panagiotis Kanavos | }; |
212 | db8a9589 | Panagiotis Kanavos | ShowMessages(WPF.Properties.Resources.Error_Title, |
213 | db8a9589 | Panagiotis Kanavos | WPF.Properties.Resources.Unexpected_Error, |
214 | db8a9589 | Panagiotis Kanavos | messages); |
215 | ff26eb71 | Panagiotis Kanavos | e.Handled=true; |
216 | ff26eb71 | Panagiotis Kanavos | } |
217 | ff26eb71 | Panagiotis Kanavos | |
218 | ff26eb71 | Panagiotis Kanavos | void ShowMessages(string title,string message,IEnumerable<UserMessage> messages ) |
219 | ff26eb71 | Panagiotis Kanavos | { |
220 | db8a9589 | Panagiotis Kanavos | var messageList = messages.ToList(); |
221 | db8a9589 | Panagiotis Kanavos | LogMessages(messageList); |
222 | ff26eb71 | Panagiotis Kanavos | Execute.OnUIThread(()=>{ |
223 | db8a9589 | Panagiotis Kanavos | var messageView = new MessageView(messageList) |
224 | db8a9589 | Panagiotis Kanavos | { |
225 | db8a9589 | Panagiotis Kanavos | Title = title, |
226 | db8a9589 | Panagiotis Kanavos | Message = message |
227 | db8a9589 | Panagiotis Kanavos | }; |
228 | db8a9589 | Panagiotis Kanavos | messageView.ShowDialog(); |
229 | ff26eb71 | Panagiotis Kanavos | }); |
230 | ff26eb71 | Panagiotis Kanavos | } |
231 | ff26eb71 | Panagiotis Kanavos | |
232 | ff26eb71 | Panagiotis Kanavos | private void LogMessages(IEnumerable<UserMessage> messages) |
233 | ff26eb71 | Panagiotis Kanavos | { |
234 | ff26eb71 | Panagiotis Kanavos | var logMessage = CreateMessage(messages); |
235 | ff26eb71 | Panagiotis Kanavos | |
236 | db8a9589 | Panagiotis Kanavos | Log.Error(logMessage); |
237 | ff26eb71 | Panagiotis Kanavos | } |
238 | ff26eb71 | Panagiotis Kanavos | |
239 | ff26eb71 | Panagiotis Kanavos | private static string CreateMessage(IEnumerable<UserMessage> messages) |
240 | ff26eb71 | Panagiotis Kanavos | { |
241 | ff26eb71 | Panagiotis Kanavos | var messageBuilder = messages.Aggregate(new StringBuilder("Unexpected Error\r\n"), |
242 | ff26eb71 | Panagiotis Kanavos | (builder, message) => |
243 | ff26eb71 | Panagiotis Kanavos | { |
244 | ff26eb71 | Panagiotis Kanavos | builder.AppendFormat("\r\n[{0}] {1}\r\n{2}\r\n", message.Severity, |
245 | ff26eb71 | Panagiotis Kanavos | message.Message, message.Details); |
246 | ff26eb71 | Panagiotis Kanavos | return builder; |
247 | ff26eb71 | Panagiotis Kanavos | }); |
248 | ff26eb71 | Panagiotis Kanavos | var logMessage = messageBuilder.ToString(); |
249 | ff26eb71 | Panagiotis Kanavos | return logMessage; |
250 | ff26eb71 | Panagiotis Kanavos | } |
251 | 9bae55d1 | Panagiotis Kanavos | } |
252 | 9bae55d1 | Panagiotis Kanavos | |
253 | 9bae55d1 | Panagiotis Kanavos | } |