Files
Umbraco-CMS/src/Umbraco.Infrastructure/Suspendable.cs
2024-11-13 11:19:37 +01:00

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