Go to the documentation of this file.
25 $this->wanCache = MediaWikiServices::getInstance()->getMainWANObjectCache();
37 return $this->wanCache->getWithSetCallback(
40 function ( $oldValue, &$ttl, array &$setOpts ) use ( $fname ) {
42 $setOpts += Database::getCacheSetOptions(
$dbr );
44 return $dbr->selectFieldValues(
47 [
'page_namespace' => NS_GADGET_DEFINITION ],
52 'checkKeys' => [ $key ],
63 if ( $target->
inNamespace( NS_GADGET_DEFINITION ) ) {
72 if ( $target->
inNamespace( NS_GADGET_DEFINITION ) ) {
81 if ( $target->
inNamespace( NS_GADGET_DEFINITION ) ) {
101 $gadget = $this->wanCache->getWithSetCallback(
104 function ( $old, &$ttl, array &$setOpts ) use ( $id ) {
108 $ttl = WANObjectCache::TTL_UNCACHEABLE;
114 $ttl = WANObjectCache::TTL_UNCACHEABLE;
121 $ttl = WANObjectCache::TTL_UNCACHEABLE;
128 'checkKeys' => [ $key ],
134 if ( $gadget ===
null ) {
135 throw new InvalidArgumentException(
"No gadget registered for '$id'" );
154 return $this->wanCache->makeKey(
'gadgets',
'namespace',
'ids' );
162 return $this->wanCache->makeKey(
const CACHE_TTL
How long in seconds the list of gadget ids and individual gadgets should be cached for (1 day)
handlePageDeletion(LinkTarget $target)
Given that the provided page was updated, invalidate caches if necessary.void
static newFromDefinitionContent( $id, GadgetDefinitionContent $content)
Create a object based on the metadata in a GadgetDefinitionContent object.
static newFromTitle(LinkTarget $linkTarget, $id=0, $flags=0)
Load either the current, or a specified, revision that's attached to a given link target.
purgeGadgetIdsList()
Purge the list of gadget ids when a page is deleted or if a new page is created.
wfGetDB( $db, $groups=[], $wiki=false)
Get a Database object.
getGadgetIds()
Get a list of gadget ids from cache/database.
static makeTitleSafe( $ns, $title, $fragment='', $interwiki='')
Create a new Title from a namespace index and a DB key.
GadgetRepo implementation where each gadget has a page in the Gadget definition namespace,...
Multi-datacenter aware caching interface.
handlePageUpdate(LinkTarget $target)
Given that the provided page was updated, invalidate caches if necessary.void
purgeGadgetEntry( $id)
Update the cache for a specific Gadget whenever it is updated.
const GADGET_CLASS_VERSION
Increment this when changing class structure.
handlePageCreation(LinkTarget $target)
Given that the provided page was created, invalidate caches if necessary.void