121 lines
3.3 KiB
C#
121 lines
3.3 KiB
C#
using Microsoft.Extensions.Logging;
|
|
using Umbraco.Cms.Core;
|
|
using Umbraco.Cms.Core.Cache;
|
|
using Umbraco.Cms.Infrastructure.Examine;
|
|
|
|
namespace Umbraco.Cms.Infrastructure;
|
|
|
|
public static class Suspendable
|
|
{
|
|
public static class PageCacheRefresher
|
|
{
|
|
private static bool _tried;
|
|
private static bool _suspended;
|
|
|
|
public static bool CanRefreshDocumentCacheFromDatabase
|
|
{
|
|
get
|
|
{
|
|
// trying a full refresh
|
|
if (_suspended == false)
|
|
{
|
|
return true;
|
|
}
|
|
|
|
_tried = true; // remember we tried
|
|
return false;
|
|
}
|
|
}
|
|
|
|
// trying a partial update
|
|
// ok if not suspended, or if we haven't done a full already
|
|
public static bool CanUpdateDocumentCache => _suspended == false || _tried == false;
|
|
|
|
public static void SuspendDocumentCache()
|
|
{
|
|
StaticApplicationLogging.Logger.LogInformation("Suspend document cache.");
|
|
_suspended = true;
|
|
}
|
|
|
|
public static void ResumeDocumentCache(CacheRefresherCollection cacheRefresherCollection)
|
|
{
|
|
_suspended = false;
|
|
|
|
StaticApplicationLogging.Logger.LogInformation("Resume document cache (reload:{Tried}).", _tried);
|
|
|
|
if (_tried == false)
|
|
{
|
|
return;
|
|
}
|
|
|
|
_tried = false;
|
|
|
|
ICacheRefresher? pageRefresher = cacheRefresherCollection[ContentCacheRefresher.UniqueId];
|
|
pageRefresher?.RefreshAll();
|
|
}
|
|
}
|
|
|
|
// This is really needed at all since the only place this is used is in ExamineComponent and that already maintains a flag of whether it suspsended or not
|
|
// AHH... but Deploy probably uses this?
|
|
public static class ExamineEvents
|
|
{
|
|
private static bool _tried;
|
|
private static bool _suspended;
|
|
|
|
public static bool CanIndex
|
|
{
|
|
get
|
|
{
|
|
if (_suspended == false)
|
|
{
|
|
return true;
|
|
}
|
|
|
|
_tried = true; // remember we tried
|
|
return false;
|
|
}
|
|
}
|
|
|
|
public static void SuspendIndexers(ILogger logger)
|
|
{
|
|
logger.LogInformation("Suspend indexers.");
|
|
_suspended = true;
|
|
}
|
|
|
|
public static void ResumeIndexers(IIndexRebuilder backgroundIndexRebuilder)
|
|
{
|
|
_suspended = false;
|
|
|
|
StaticApplicationLogging.Logger.LogInformation("Resume indexers (rebuild:{Tried}).", _tried);
|
|
|
|
if (_tried == false)
|
|
{
|
|
return;
|
|
}
|
|
|
|
_tried = false;
|
|
|
|
backgroundIndexRebuilder.RebuildIndexes(false);
|
|
}
|
|
}
|
|
|
|
public static class ScheduledPublishing
|
|
{
|
|
private static bool _suspended;
|
|
|
|
public static bool CanRun => _suspended == false;
|
|
|
|
public static void Suspend()
|
|
{
|
|
StaticApplicationLogging.Logger.LogInformation("Suspend scheduled publishing.");
|
|
_suspended = true;
|
|
}
|
|
|
|
public static void Resume()
|
|
{
|
|
StaticApplicationLogging.Logger.LogInformation("Resume scheduled publishing.");
|
|
_suspended = false;
|
|
}
|
|
}
|
|
}
|