Added fix to maintenance page so it is shown before the content cache is created. (#13767)

This commit is contained in:
Bjarke Berg
2023-02-05 16:47:09 +01:00
committed by GitHub
parent c90a0ecfdc
commit 884793f729
6 changed files with 51 additions and 8 deletions

View File

@@ -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
}

View File

@@ -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
{

View File

@@ -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;

View File

@@ -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>());

View File

@@ -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)
{

View File

@@ -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;
}