Merge branch 7.2.7 into dev-v7
Conflicts: build/UmbracoVersion.txt src/SolutionInfo.cs src/Umbraco.Core/ApplicationContext.cs src/Umbraco.Core/AsyncLock.cs src/Umbraco.Core/Cache/DictionaryCacheProviderBase.cs src/Umbraco.Core/Cache/ObjectCacheRuntimeCacheProvider.cs src/Umbraco.Core/CoreBootManager.cs src/Umbraco.Core/Logging/LogHelper.cs src/Umbraco.Core/PluginManager.cs src/Umbraco.Core/Sync/ServerEnvironmentHelper.cs src/Umbraco.Core/TypeFinder.cs src/Umbraco.Core/Umbraco.Core.csproj src/Umbraco.Tests/Scheduling/BackgroundTaskRunnerTests.cs src/Umbraco.Tests/ServerEnvironmentHelperTests.cs src/Umbraco.Web.UI.Client/bower.json src/Umbraco.Web.UI.Client/gruntFile.js src/Umbraco.Web.UI.Client/src/less/grid.less src/Umbraco.Web.UI.Client/src/less/panel.less src/Umbraco.Web.UI.Client/src/less/property-editors.less src/Umbraco.Web.UI.Client/src/loader.js src/Umbraco.Web.UI.Client/src/views/propertyeditors/datepicker/datepicker.controller.js src/Umbraco.Web.UI/Umbraco.Web.UI.csproj src/Umbraco.Web.UI/config/ClientDependency.config src/Umbraco.Web/PublishedCache/XmlPublishedCache/XmlCacheFilePersister.cs src/Umbraco.Web/Scheduling/BackgroundTaskRunner.cs src/Umbraco.Web/Scheduling/KeepAlive.cs src/Umbraco.Web/Scheduling/LatchedBackgroundTaskBase.cs src/Umbraco.Web/Scheduling/LogScrubber.cs src/Umbraco.Web/Scheduling/RecurringTaskBase.cs src/Umbraco.Web/Scheduling/ScheduledPublishing.cs src/Umbraco.Web/Scheduling/ScheduledTasks.cs src/Umbraco.Web/Scheduling/Scheduler.cs src/Umbraco.Web/UI/JavaScript/JsInitialize.js src/Umbraco.Web/Umbraco.Web.csproj src/Umbraco.Web/umbraco.presentation/content.cs src/umbraco.cms/Actions/Action.cs
This commit is contained in:
@@ -45,6 +45,19 @@ namespace Umbraco.Core
|
||||
Logger.Error(typeof(UmbracoApplicationBase), msg, exception);
|
||||
};
|
||||
|
||||
//take care of unhandled exceptions - there is nothing we can do to
|
||||
// prevent the entire w3wp process to go down but at least we can try
|
||||
// and log the exception
|
||||
AppDomain.CurrentDomain.UnhandledException += (_, args) =>
|
||||
{
|
||||
var exception = (Exception) args.ExceptionObject;
|
||||
var isTerminating = args.IsTerminating; // always true?
|
||||
|
||||
var msg = "Unhandled exception in AppDomain";
|
||||
if (isTerminating) msg += " (terminating)";
|
||||
LogHelper.Error<UmbracoApplicationBase>(msg, exception);
|
||||
};
|
||||
|
||||
//boot up the application
|
||||
GetBootManager()
|
||||
.Initialize()
|
||||
@@ -82,7 +95,18 @@ namespace Umbraco.Core
|
||||
protected virtual void OnApplicationStarting(object sender, EventArgs e)
|
||||
{
|
||||
if (ApplicationStarting != null)
|
||||
ApplicationStarting(sender, e);
|
||||
{
|
||||
try
|
||||
{
|
||||
ApplicationStarting(sender, e);
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
LogHelper.Error<UmbracoApplicationBase>("An error occurred in an ApplicationStarting event handler", ex);
|
||||
throw;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@@ -93,7 +117,17 @@ namespace Umbraco.Core
|
||||
protected virtual void OnApplicationStarted(object sender, EventArgs e)
|
||||
{
|
||||
if (ApplicationStarted != null)
|
||||
ApplicationStarted(sender, e);
|
||||
{
|
||||
try
|
||||
{
|
||||
ApplicationStarted(sender, e);
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
LogHelper.Error<UmbracoApplicationBase>("An error occurred in an ApplicationStarted event handler", ex);
|
||||
throw;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@@ -104,7 +138,17 @@ namespace Umbraco.Core
|
||||
private void OnApplicationInit(object sender, EventArgs e)
|
||||
{
|
||||
if (ApplicationInit != null)
|
||||
ApplicationInit(sender, e);
|
||||
{
|
||||
try
|
||||
{
|
||||
ApplicationInit(sender, e);
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
LogHelper.Error<UmbracoApplicationBase>("An error occurred in an ApplicationInit event handler", ex);
|
||||
throw;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
||||
Reference in New Issue
Block a user