using System; using System.Collections.Generic; using System.Configuration; using System.Data; using System.Diagnostics; using System.Linq; using System.Threading; using System.Threading.Tasks; using System.Windows; using Tango.Core.Helpers; using Tango.BL.Entities; using Tango.Logging; using Tango.MachineStudio.UI.Windows; using Tango.Settings; using Tango.MachineStudio.Common.EventLogging; using Tango.BL.Enumerations; using Tango.Core.DI; using Tango.MachineStudio.UI.TFS; using Tango.TFS; using Tango.MachineStudio.Common.Notifications; using Tango.MachineStudio.UI.ViewModels; using Tango.MachineStudio.UI.Views; using Tango.MachineStudio.Common; using Tango.Core; using Tango.BL; namespace Tango.MachineStudio.UI { /// /// Interaction logic for App.xaml /// public partial class App : Application { private WpfGlobalExceptionTrapper exceptionTrapper; private LogManager LogManager = LogManager.Default; public static String[] StartupArgs { get; set; } protected override void OnStartup(StartupEventArgs e) { StartupArgs = e.Args; #if DEBUG CoreSettings.DefaultDataSource = new DataSource() { Address = "localhost\\SQLEXPRESS", Catalog = "Tango", IntegratedSecurity = true, }; #else CoreSettings.DefaultDataSource = new DataSource() { Address = "twine01\\SQLTWINE", Catalog = "Tango", IntegratedSecurity = true, }; #endif #if DEBUG LogManager.RegisterLogger(new VSOutputLogger()); #endif LogManager.RegisterLogger(new FileLogger()); LogManager.Log("Application Started..."); LogManager.LogReferencedAssemblies(); var settings = SettingsManager.Default.GetOrCreate(); //add current theme MachineStudioTheme wTheme = settings.Theme; base.OnStartup(e); LogManager.Categories.Clear(); if (settings.LoggingCategories.Count == 0) { settings.LoggingCategories.Add(LogCategory.Critical); settings.LoggingCategories.Add(LogCategory.Error); settings.LoggingCategories.Add(LogCategory.Info); settings.LoggingCategories.Add(LogCategory.Warning); } LogManager.Categories.AddRange(settings.LoggingCategories); exceptionTrapper = new WpfGlobalExceptionTrapper(); exceptionTrapper.Initialize(this); exceptionTrapper.ApplicationCrashed += ExceptionTrapper_ApplicationCrashed; //Apply Caching if (settings.CachingMode != ObservablesContextInMemoryCachingMode.None) { LogManager.Log("EF Caching is enabled."); LogManager.Log($"EF Caching mode is: {settings.CachingMode}."); LogManager.Log($"EF Caching timeout: {settings.MaximumCacheTime.ToString()}"); try { ObservablesContext.EnableInMemoryCache(settings.MaximumCacheTime, settings.CachingMode); } catch (Exception ex) { LogManager.Log(ex, "Error while trying to activate EF caching."); } } else { LogManager.Log("EF Caching is disabled"); } } #region Global Exception Trapping /// /// Handles the ApplicationCrashed event of the ExceptionTrapper. /// /// The source of the event. /// The instance containing the event data. private void ExceptionTrapper_ApplicationCrashed(object sender, ApplicationCrashedEventArgs e) { try { try { if (Application.Current == null) { new Application { ShutdownMode = ShutdownMode.OnExplicitShutdown }; } } catch { } try { var eventLogger = TangoIOC.Default.GetInstance(); if (eventLogger != null) { eventLogger.Log(e.Exception, "Application Crashed!"); } } catch { } Application.Current.Dispatcher.Invoke(() => { WorkItem bug = null; TeamFoundationServiceExtendedClient tfsClient = null; INotificationProvider notification = null; try { tfsClient = TangoIOC.Default.GetInstance(); notification = TangoIOC.Default.GetInstance(); if (tfsClient != null && tfsClient.IsInitialized) { bug = tfsClient.CreateBug(); } } catch (Exception ex) { Debug.WriteLine(ex.ToString()); } ExceptionWindow exWin = new ExceptionWindow(e.Exception, bug != null); exWin.ShowDialog(); switch (exWin.Resolution) { case ExceptionResolutions.Ignore: e.TryRecover = true; break; case ExceptionResolutions.Restart: e.TryRecover = false; LogManager.Log("User selection was to restart the application. Restarting..."); Process.Start(Application.ResourceAssembly.Location); Environment.Exit(0); break; case ExceptionResolutions.Shutdown: e.TryRecover = false; LogManager.Log("User selection was to shutdown the application. Restarting..."); Environment.Exit(0); break; case ExceptionResolutions.Report: e.TryRecover = true; LogManager.Log("User selection was to report the issue."); if (bug != null) { notification.ShowModalDialog(new ReportIssueViewVM(tfsClient.Project, bug), async (vm) => { using (notification.PushTaskItem("Uploading bug report...")) { try { tfsClient.FinalizeBug(vm.WorkItem); await tfsClient.UploadWorkItem(vm.WorkItem); } catch (Exception ex) { notification.ShowError("An error occurred while trying to create the issue." + Environment.NewLine + ex.Message); } } }, null); } break; } }); } catch (Exception ex) { LogManager.Log(ex, "Error in global exception trapper!"); MessageBox.Show(ex.ToStringSafe()); } } #endregion } }