root / trunk / Pithos.Client.WPF / App.xaml.cs @ 049333d2
History | View | Annotate | Download (9.4 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 | 46426dbd | Panagiotis Kanavos | |
79 | 8a84d039 | Panagiotis Kanavos | //Fix incorrect proxy settings by switching to default proxy, if the proxy server settings is empty |
80 | 8a84d039 | Panagiotis Kanavos | if (Settings.Default.UseManualProxy && String.IsNullOrWhiteSpace(Settings.Default.ProxyServer)) |
81 | 8a84d039 | Panagiotis Kanavos | { |
82 | 8a84d039 | Panagiotis Kanavos | Settings.Default.UseManualProxy = false; |
83 | 8a84d039 | Panagiotis Kanavos | Settings.Default.UseDefaultProxy = true; |
84 | 8a84d039 | Panagiotis Kanavos | } |
85 | 8a84d039 | Panagiotis Kanavos | |
86 | 5bcf6d70 | Panagiotis Kanavos | InitializeComponent(); |
87 | 9bae55d1 | Panagiotis Kanavos | } |
88 | ff26eb71 | Panagiotis Kanavos | |
89 | 79f92570 | Panagiotis Kanavos | /* |
90 | 46426dbd | Panagiotis Kanavos | private void OnUpdateDetected(object sender, UpdateDetectedEventArgs e) |
91 | 46426dbd | Panagiotis Kanavos | { |
92 | 46426dbd | Panagiotis Kanavos | Log.InfoFormat("Update Detected {0}",e.LatestVersion.Version); |
93 | 46426dbd | Panagiotis Kanavos | } |
94 | 79f92570 | Panagiotis Kanavos | */ |
95 | 46426dbd | Panagiotis Kanavos | |
96 | db8a9589 | Panagiotis Kanavos | private static void InitializeLogging() |
97 | db8a9589 | Panagiotis Kanavos | { |
98 | db8a9589 | Panagiotis Kanavos | log4net.Config.XmlConfigurator.Configure(); |
99 | db8a9589 | Panagiotis Kanavos | |
100 | db8a9589 | Panagiotis Kanavos | try |
101 | db8a9589 | Panagiotis Kanavos | { |
102 | db8a9589 | Panagiotis Kanavos | var appDataPath = Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData); |
103 | db8a9589 | Panagiotis Kanavos | var pithosDataPath= Path.Combine(appDataPath , "GRNET"); |
104 | db8a9589 | Panagiotis Kanavos | if (!Directory.Exists(pithosDataPath)) |
105 | db8a9589 | Panagiotis Kanavos | Directory.CreateDirectory(pithosDataPath); |
106 | db8a9589 | Panagiotis Kanavos | |
107 | db8a9589 | Panagiotis Kanavos | var loggerRepository = (Hierarchy)log4net.LogManager.GetRepository(); |
108 | db8a9589 | Panagiotis Kanavos | |
109 | db8a9589 | Panagiotis Kanavos | var appenders = loggerRepository.GetAppenders(); |
110 | db8a9589 | Panagiotis Kanavos | var lossyAppender = appenders.OfType<BufferingForwardingAppender>() |
111 | db8a9589 | Panagiotis Kanavos | .First(appender => appender.Name == "LossyFileAppender"); |
112 | db8a9589 | Panagiotis Kanavos | var dumpAppender = lossyAppender.Appenders.OfType<RollingFileAppender>().First(); |
113 | db8a9589 | Panagiotis Kanavos | dumpAppender.File = Path.Combine(pithosDataPath, "errorlog.txt"); |
114 | db8a9589 | Panagiotis Kanavos | dumpAppender.ActivateOptions(); |
115 | db8a9589 | Panagiotis Kanavos | } |
116 | db8a9589 | Panagiotis Kanavos | catch (Exception exc) |
117 | db8a9589 | Panagiotis Kanavos | { |
118 | db8a9589 | Panagiotis Kanavos | Log.Error("Dumpl appender initialization failed",exc); |
119 | db8a9589 | Panagiotis Kanavos | } |
120 | db8a9589 | Panagiotis Kanavos | } |
121 | db8a9589 | Panagiotis Kanavos | |
122 | 29a6b387 | Panagiotis Kanavos | protected override void OnStartup(StartupEventArgs e) |
123 | ca79acb7 | Panagiotis Kanavos | { |
124 | 29a6b387 | Panagiotis Kanavos | if (!Settings.Default.StartOnSystemStartup && e.Args.Contains("startup")) |
125 | 29a6b387 | Panagiotis Kanavos | { |
126 | db8a9589 | Panagiotis Kanavos | Shutdown(); |
127 | ca79acb7 | Panagiotis Kanavos | return; |
128 | 29a6b387 | Panagiotis Kanavos | } |
129 | db8a9589 | Panagiotis Kanavos | |
130 | db8a9589 | Panagiotis Kanavos | //Delay during startup |
131 | 759bd3c4 | Panagiotis Kanavos | if (e.Args.Contains("startup")) |
132 | 759bd3c4 | Panagiotis Kanavos | { |
133 | 759bd3c4 | Panagiotis Kanavos | if (Settings.Default.StartupDelay>TimeSpan.Zero) |
134 | 759bd3c4 | Panagiotis Kanavos | Thread.Sleep(Settings.Default.StartupDelay); |
135 | 759bd3c4 | Panagiotis Kanavos | } |
136 | 759bd3c4 | Panagiotis Kanavos | |
137 | ca79acb7 | Panagiotis Kanavos | var splashScreen = new SplashScreen("images/logo.png"); |
138 | ca79acb7 | Panagiotis Kanavos | splashScreen.Show(true); |
139 | ca79acb7 | Panagiotis Kanavos | |
140 | 29a6b387 | Panagiotis Kanavos | base.OnStartup(e); |
141 | 29a6b387 | Panagiotis Kanavos | } |
142 | 29a6b387 | Panagiotis Kanavos | |
143 | ff26eb71 | Panagiotis Kanavos | private void OnUnobservedException(object sender, UnobservedTaskExceptionEventArgs e) |
144 | ff26eb71 | Panagiotis Kanavos | { |
145 | ff26eb71 | Panagiotis Kanavos | var messages=new List<UserMessage>(); |
146 | ff26eb71 | Panagiotis Kanavos | e.Exception.Handle(exc=>{ |
147 | ff26eb71 | Panagiotis Kanavos | messages.Add(new UserMessage |
148 | ff26eb71 | Panagiotis Kanavos | { |
149 | ff26eb71 | Panagiotis Kanavos | Message = "Unexpected Exception", |
150 | ff26eb71 | Panagiotis Kanavos | Details = exc.ToString(), |
151 | ff26eb71 | Panagiotis Kanavos | Severity = Severity.Error |
152 | ff26eb71 | Panagiotis Kanavos | }); |
153 | ff26eb71 | Panagiotis Kanavos | return true; |
154 | ff26eb71 | Panagiotis Kanavos | }); |
155 | ff26eb71 | Panagiotis Kanavos | |
156 | db8a9589 | Panagiotis Kanavos | Log.Error("Unobserved Task Exception",e.Exception); |
157 | db8a9589 | Panagiotis Kanavos | |
158 | db8a9589 | Panagiotis Kanavos | var message = String.Format(@"{0}\r\n{1}\r\n\r\n{2}", |
159 | db8a9589 | Panagiotis Kanavos | WPF.Properties.Resources.Unexpected_Error, |
160 | db8a9589 | Panagiotis Kanavos | WPF.Properties.Resources.We_Apologize, |
161 | db8a9589 | Panagiotis Kanavos | WPF.Properties.Resources.Please_Submit_Error); |
162 | db8a9589 | Panagiotis Kanavos | ShowMessages("Oops!",message, messages); |
163 | ff26eb71 | Panagiotis Kanavos | e.SetObserved(); |
164 | ff26eb71 | Panagiotis Kanavos | } |
165 | ff26eb71 | Panagiotis Kanavos | |
166 | ff26eb71 | Panagiotis Kanavos | private void OnUnhandledException(object sender, UnhandledExceptionEventArgs e) |
167 | ff26eb71 | Panagiotis Kanavos | { |
168 | db8a9589 | Panagiotis Kanavos | Log.Error("Unhandled exception", (Exception)e.ExceptionObject); |
169 | db8a9589 | Panagiotis Kanavos | |
170 | db8a9589 | Panagiotis Kanavos | var description = e.IsTerminating |
171 | db8a9589 | Panagiotis Kanavos | ? WPF.Properties.Resources.Unexpected_Error_Terminating |
172 | db8a9589 | Panagiotis Kanavos | : WPF.Properties.Resources.Unexpected_Error; |
173 | db8a9589 | Panagiotis Kanavos | var message = String.Format(@"{0}\r\n{1}\r\n\r\n{2}", |
174 | db8a9589 | Panagiotis Kanavos | description, |
175 | db8a9589 | Panagiotis Kanavos | WPF.Properties.Resources.We_Apologize, |
176 | db8a9589 | Panagiotis Kanavos | WPF.Properties.Resources.Please_Submit_Error); |
177 | ff26eb71 | Panagiotis Kanavos | |
178 | ff26eb71 | Panagiotis Kanavos | |
179 | db8a9589 | Panagiotis Kanavos | var exc = ((Exception) e.ExceptionObject); |
180 | ff26eb71 | Panagiotis Kanavos | var messages = new[]{ |
181 | ff26eb71 | Panagiotis Kanavos | new UserMessage |
182 | ff26eb71 | Panagiotis Kanavos | { |
183 | db8a9589 | Panagiotis Kanavos | Message = exc.Message, |
184 | db8a9589 | Panagiotis Kanavos | Details = exc.ToString(), |
185 | ff26eb71 | Panagiotis Kanavos | Severity = Severity.Error |
186 | ff26eb71 | Panagiotis Kanavos | } |
187 | ff26eb71 | Panagiotis Kanavos | }; |
188 | db8a9589 | Panagiotis Kanavos | |
189 | db8a9589 | Panagiotis Kanavos | |
190 | ff26eb71 | Panagiotis Kanavos | ShowMessages("Oops!", message,messages); |
191 | ff26eb71 | Panagiotis Kanavos | } |
192 | ff26eb71 | Panagiotis Kanavos | |
193 | db8a9589 | Panagiotis Kanavos | void OnDispatcherUnhandledException(object sender, System.Windows.Threading.DispatcherUnhandledExceptionEventArgs e) |
194 | db8a9589 | Panagiotis Kanavos | { |
195 | db8a9589 | Panagiotis Kanavos | Log.Error("Unhandled Dispatcher exception", e.Exception); |
196 | db8a9589 | Panagiotis Kanavos | |
197 | ff26eb71 | Panagiotis Kanavos | var messages = new[]{ |
198 | ff26eb71 | Panagiotis Kanavos | new UserMessage |
199 | ff26eb71 | Panagiotis Kanavos | { |
200 | ff26eb71 | Panagiotis Kanavos | Message = e.Exception.Message, |
201 | ff26eb71 | Panagiotis Kanavos | Details = e.Exception.ToString(), |
202 | ff26eb71 | Panagiotis Kanavos | Severity = Severity.Error |
203 | ff26eb71 | Panagiotis Kanavos | } |
204 | ff26eb71 | Panagiotis Kanavos | }; |
205 | db8a9589 | Panagiotis Kanavos | ShowMessages(WPF.Properties.Resources.Error_Title, |
206 | db8a9589 | Panagiotis Kanavos | WPF.Properties.Resources.Unexpected_Error, |
207 | db8a9589 | Panagiotis Kanavos | messages); |
208 | ff26eb71 | Panagiotis Kanavos | e.Handled=true; |
209 | ff26eb71 | Panagiotis Kanavos | } |
210 | ff26eb71 | Panagiotis Kanavos | |
211 | ff26eb71 | Panagiotis Kanavos | void ShowMessages(string title,string message,IEnumerable<UserMessage> messages ) |
212 | ff26eb71 | Panagiotis Kanavos | { |
213 | db8a9589 | Panagiotis Kanavos | var messageList = messages.ToList(); |
214 | db8a9589 | Panagiotis Kanavos | LogMessages(messageList); |
215 | ff26eb71 | Panagiotis Kanavos | Execute.OnUIThread(()=>{ |
216 | db8a9589 | Panagiotis Kanavos | var messageView = new MessageView(messageList) |
217 | db8a9589 | Panagiotis Kanavos | { |
218 | db8a9589 | Panagiotis Kanavos | Title = title, |
219 | db8a9589 | Panagiotis Kanavos | Message = message |
220 | db8a9589 | Panagiotis Kanavos | }; |
221 | db8a9589 | Panagiotis Kanavos | messageView.ShowDialog(); |
222 | ff26eb71 | Panagiotis Kanavos | }); |
223 | ff26eb71 | Panagiotis Kanavos | } |
224 | ff26eb71 | Panagiotis Kanavos | |
225 | ff26eb71 | Panagiotis Kanavos | private void LogMessages(IEnumerable<UserMessage> messages) |
226 | ff26eb71 | Panagiotis Kanavos | { |
227 | ff26eb71 | Panagiotis Kanavos | var logMessage = CreateMessage(messages); |
228 | ff26eb71 | Panagiotis Kanavos | |
229 | db8a9589 | Panagiotis Kanavos | Log.Error(logMessage); |
230 | ff26eb71 | Panagiotis Kanavos | } |
231 | ff26eb71 | Panagiotis Kanavos | |
232 | ff26eb71 | Panagiotis Kanavos | private static string CreateMessage(IEnumerable<UserMessage> messages) |
233 | ff26eb71 | Panagiotis Kanavos | { |
234 | ff26eb71 | Panagiotis Kanavos | var messageBuilder = messages.Aggregate(new StringBuilder("Unexpected Error\r\n"), |
235 | ff26eb71 | Panagiotis Kanavos | (builder, message) => |
236 | ff26eb71 | Panagiotis Kanavos | { |
237 | ff26eb71 | Panagiotis Kanavos | builder.AppendFormat("\r\n[{0}] {1}\r\n{2}\r\n", message.Severity, |
238 | ff26eb71 | Panagiotis Kanavos | message.Message, message.Details); |
239 | ff26eb71 | Panagiotis Kanavos | return builder; |
240 | ff26eb71 | Panagiotis Kanavos | }); |
241 | ff26eb71 | Panagiotis Kanavos | var logMessage = messageBuilder.ToString(); |
242 | ff26eb71 | Panagiotis Kanavos | return logMessage; |
243 | ff26eb71 | Panagiotis Kanavos | } |
244 | 9bae55d1 | Panagiotis Kanavos | } |
245 | 9bae55d1 | Panagiotis Kanavos | |
246 | 9bae55d1 | Panagiotis Kanavos | } |