Added fix to maintenance page so it is shown before the content cache is created. (#13767)
This commit is contained in:
@@ -5,6 +5,7 @@ using Umbraco.Cms.Infrastructure.Persistence.DatabaseModelDefinitions;
|
||||
|
||||
namespace Umbraco.Cms.Infrastructure.Persistence.Dtos;
|
||||
|
||||
|
||||
[TableName(Constants.DatabaseSchema.Tables.KeyValue)]
|
||||
[PrimaryKey("key", AutoIncrement = false)]
|
||||
[ExplicitColumns]
|
||||
@@ -22,4 +23,6 @@ internal class KeyValueDto
|
||||
[Column("updated")]
|
||||
[Constraint(Default = SystemMethods.CurrentDateTime)]
|
||||
public DateTime UpdateDate { get; set; }
|
||||
|
||||
//NOTE that changes to this file needs to be backward compatible. Otherwise our upgrader cannot work, as it uses this to read from the db
|
||||
}
|
||||
|
||||
@@ -10,9 +10,8 @@ namespace Umbraco.Cms.Web.Common.Controllers;
|
||||
|
||||
internal sealed class MaintenanceModeActionFilterAttribute : TypeFilterAttribute
|
||||
{
|
||||
public MaintenanceModeActionFilterAttribute() : base(typeof(MaintenanceModeActionFilter))
|
||||
{
|
||||
}
|
||||
|
||||
public MaintenanceModeActionFilterAttribute() : base(typeof(MaintenanceModeActionFilter)) => Order = int.MinValue; // Ensures this run as the first filter.
|
||||
|
||||
private sealed class MaintenanceModeActionFilter : IActionFilter
|
||||
{
|
||||
|
||||
@@ -15,6 +15,12 @@ internal class PublishedRequestFilterAttribute : ResultFilterAttribute
|
||||
/// </summary>
|
||||
public override void OnResultExecuting(ResultExecutingContext context)
|
||||
{
|
||||
if (context.Result is not null)
|
||||
{
|
||||
// If the result is already set, we just skip the execution
|
||||
return;
|
||||
}
|
||||
|
||||
UmbracoRouteValues routeVals = GetUmbracoRouteValues(context);
|
||||
IPublishedRequest pcr = routeVals.PublishedRequest;
|
||||
|
||||
|
||||
@@ -5,6 +5,7 @@ using Microsoft.Extensions.DependencyInjection;
|
||||
using Microsoft.Extensions.DependencyInjection.Extensions;
|
||||
using Microsoft.Extensions.Logging;
|
||||
using Microsoft.Extensions.Options;
|
||||
using Umbraco.Cms.Core.Configuration.Models;
|
||||
using Umbraco.Cms.Core.DependencyInjection;
|
||||
using Umbraco.Cms.Core.Routing;
|
||||
using Umbraco.Cms.Core.Services;
|
||||
@@ -55,7 +56,8 @@ public static partial class UmbracoBuilderExtensions
|
||||
x.GetRequiredService<IDataProtectionProvider>(),
|
||||
x.GetRequiredService<IControllerActionSearcher>(),
|
||||
x.GetRequiredService<IPublicAccessRequestHandler>(),
|
||||
x.GetRequiredService<IUmbracoVirtualPageRoute>()
|
||||
x.GetRequiredService<IUmbracoVirtualPageRoute>(),
|
||||
x.GetRequiredService<IOptionsMonitor<GlobalSettings>>()
|
||||
));
|
||||
builder.Services.AddSingleton<IControllerActionSearcher, ControllerActionSearcher>();
|
||||
builder.Services.TryAddEnumerable(Singleton<MatcherPolicy, NotFoundSelectorPolicy>());
|
||||
|
||||
@@ -14,6 +14,7 @@ using Umbraco.Cms.Core.Hosting;
|
||||
using Umbraco.Cms.Core.Routing;
|
||||
using Umbraco.Cms.Core.Services;
|
||||
using Umbraco.Cms.Core.Web;
|
||||
using Umbraco.Cms.Web.Common.Controllers;
|
||||
using Umbraco.Cms.Web.Common.DependencyInjection;
|
||||
using Umbraco.Cms.Web.Common.Routing;
|
||||
using Umbraco.Cms.Web.Common.Security;
|
||||
@@ -49,6 +50,7 @@ public class UmbracoRouteValueTransformer : DynamicRouteValueTransformer
|
||||
private readonly IRuntimeState _runtime;
|
||||
private readonly IUmbracoContextAccessor _umbracoContextAccessor;
|
||||
private readonly IUmbracoVirtualPageRoute _umbracoVirtualPageRoute;
|
||||
private GlobalSettings _globalSettings;
|
||||
|
||||
[Obsolete("Please use constructor that is not obsolete, instead of this. This will be removed in Umbraco 13.")]
|
||||
public UmbracoRouteValueTransformer(
|
||||
@@ -64,7 +66,7 @@ public class UmbracoRouteValueTransformer : DynamicRouteValueTransformer
|
||||
IControllerActionSearcher controllerActionSearcher,
|
||||
IEventAggregator eventAggregator,
|
||||
IPublicAccessRequestHandler publicAccessRequestHandler)
|
||||
: this(logger, umbracoContextAccessor, publishedRouter, runtime, routeValuesFactory, routableDocumentFilter, dataProtectionProvider, controllerActionSearcher, publicAccessRequestHandler, StaticServiceProvider.Instance.GetRequiredService<IUmbracoVirtualPageRoute>())
|
||||
: this(logger, umbracoContextAccessor, publishedRouter, runtime, routeValuesFactory, routableDocumentFilter, dataProtectionProvider, controllerActionSearcher, publicAccessRequestHandler, StaticServiceProvider.Instance.GetRequiredService<IUmbracoVirtualPageRoute>(), StaticServiceProvider.Instance.GetRequiredService<IOptionsMonitor<GlobalSettings>>())
|
||||
{
|
||||
}
|
||||
|
||||
@@ -79,10 +81,26 @@ public class UmbracoRouteValueTransformer : DynamicRouteValueTransformer
|
||||
IDataProtectionProvider dataProtectionProvider,
|
||||
IControllerActionSearcher controllerActionSearcher,
|
||||
IPublicAccessRequestHandler publicAccessRequestHandler)
|
||||
: this(logger, umbracoContextAccessor, publishedRouter, runtime, routeValuesFactory, routableDocumentFilter, dataProtectionProvider, controllerActionSearcher, publicAccessRequestHandler, StaticServiceProvider.Instance.GetRequiredService<IUmbracoVirtualPageRoute>())
|
||||
: this(logger, umbracoContextAccessor, publishedRouter, runtime, routeValuesFactory, routableDocumentFilter, dataProtectionProvider, controllerActionSearcher, publicAccessRequestHandler, StaticServiceProvider.Instance.GetRequiredService<IUmbracoVirtualPageRoute>(), StaticServiceProvider.Instance.GetRequiredService<IOptionsMonitor<GlobalSettings>>())
|
||||
{
|
||||
}
|
||||
|
||||
[Obsolete("Please use constructor that is not obsolete, instead of this. This will be removed in Umbraco 13.")]
|
||||
public UmbracoRouteValueTransformer(
|
||||
ILogger<UmbracoRouteValueTransformer> logger,
|
||||
IUmbracoContextAccessor umbracoContextAccessor,
|
||||
IPublishedRouter publishedRouter,
|
||||
IRuntimeState runtime,
|
||||
IUmbracoRouteValuesFactory routeValuesFactory,
|
||||
IRoutableDocumentFilter routableDocumentFilter,
|
||||
IDataProtectionProvider dataProtectionProvider,
|
||||
IControllerActionSearcher controllerActionSearcher,
|
||||
IPublicAccessRequestHandler publicAccessRequestHandler,
|
||||
IUmbracoVirtualPageRoute umbracoVirtualPageRoute)
|
||||
: this(logger, umbracoContextAccessor, publishedRouter, runtime, routeValuesFactory, routableDocumentFilter, dataProtectionProvider, controllerActionSearcher, publicAccessRequestHandler, StaticServiceProvider.Instance.GetRequiredService<IUmbracoVirtualPageRoute>(), StaticServiceProvider.Instance.GetRequiredService<IOptionsMonitor<GlobalSettings>>())
|
||||
|
||||
{
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Initializes a new instance of the <see cref="UmbracoRouteValueTransformer" /> class.
|
||||
@@ -97,7 +115,8 @@ public class UmbracoRouteValueTransformer : DynamicRouteValueTransformer
|
||||
IDataProtectionProvider dataProtectionProvider,
|
||||
IControllerActionSearcher controllerActionSearcher,
|
||||
IPublicAccessRequestHandler publicAccessRequestHandler,
|
||||
IUmbracoVirtualPageRoute umbracoVirtualPageRoute)
|
||||
IUmbracoVirtualPageRoute umbracoVirtualPageRoute,
|
||||
IOptionsMonitor<GlobalSettings> globalSettings)
|
||||
{
|
||||
_logger = logger ?? throw new ArgumentNullException(nameof(logger));
|
||||
_umbracoContextAccessor =
|
||||
@@ -111,6 +130,8 @@ public class UmbracoRouteValueTransformer : DynamicRouteValueTransformer
|
||||
_controllerActionSearcher = controllerActionSearcher;
|
||||
_publicAccessRequestHandler = publicAccessRequestHandler;
|
||||
_umbracoVirtualPageRoute = umbracoVirtualPageRoute;
|
||||
_globalSettings = globalSettings.CurrentValue;
|
||||
globalSettings.OnChange(x => _globalSettings = x);
|
||||
}
|
||||
|
||||
/// <inheritdoc />
|
||||
@@ -154,6 +175,17 @@ public class UmbracoRouteValueTransformer : DynamicRouteValueTransformer
|
||||
return null!;
|
||||
}
|
||||
|
||||
// Check if the maintenance page should be shown
|
||||
if (_runtime.Level == RuntimeLevel.Upgrade && _globalSettings.ShowMaintenancePageWhenInUpgradeState)
|
||||
{
|
||||
return new RouteValueDictionary
|
||||
{
|
||||
// Redirects to the RenderController who handles maintenance page in a filter, instead of having a dedicated controller
|
||||
[ControllerToken] = ControllerExtensions.GetControllerName<RenderController>(),
|
||||
[ActionToken] = nameof(RenderController.Index),
|
||||
};
|
||||
}
|
||||
|
||||
// Check if there is no existing content and return the no content controller
|
||||
if (!umbracoContext.Content?.HasContent() ?? false)
|
||||
{
|
||||
|
||||
@@ -67,7 +67,8 @@ public class UmbracoRouteValueTransformerTests
|
||||
Mock.Of<IDataProtectionProvider>(),
|
||||
Mock.Of<IControllerActionSearcher>(),
|
||||
publicAccessRequestHandler.Object,
|
||||
Mock.Of<IUmbracoVirtualPageRoute>()
|
||||
Mock.Of<IUmbracoVirtualPageRoute>(),
|
||||
Mock.Of<IOptionsMonitor<GlobalSettings>>()
|
||||
);
|
||||
return transformer;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user