MediaWiki
master
|
Abstraction for ResourceLoader modules which pull from wiki pages. More...
Public Member Functions | |
__construct (array $options=null) | |
enableModuleContentVersion () | |
Disable module content versioning. More... | |
getDefinitionSummary (ResourceLoaderContext $context) | |
getGroup () | |
Get group name. More... | |
getPosition () | |
getScript (ResourceLoaderContext $context) | |
getStyles (ResourceLoaderContext $context) | |
getType () | |
isKnownEmpty (ResourceLoaderContext $context) | |
Public Member Functions inherited from ResourceLoaderModule | |
enableModuleContentVersion () | |
Whether to generate version hash based on module content. More... | |
getConfig () | |
getDefinitionMtime (ResourceLoaderContext $context) | |
Back-compat dummy for old subclass implementations of getModifiedTime(). More... | |
getDefinitionSummary (ResourceLoaderContext $context) | |
Get the definition summary for this module. More... | |
getDependencies (ResourceLoaderContext $context=null) | |
Get a list of modules this module depends on. More... | |
getFlip ($context) | |
getGroup () | |
Get the group this module is in. More... | |
getHashMtime (ResourceLoaderContext $context) | |
Back-compat dummy for old subclass implementations of getModifiedTime(). More... | |
getMessages () | |
Get the messages needed for this module. More... | |
getModifiedHash (ResourceLoaderContext $context) | |
Helper method for providing a version hash to getVersionHash(). More... | |
getModifiedTime (ResourceLoaderContext $context) | |
Get this module's last modification timestamp for a given context. More... | |
getModuleContent (ResourceLoaderContext $context) | |
Get an array of this module's resources. More... | |
getName () | |
Get this module's name. More... | |
getOrigin () | |
Get this module's origin. More... | |
getPosition () | |
Where on the HTML page should this module's JS be loaded? More... | |
getScript (ResourceLoaderContext $context) | |
Get all JS for this module for a given language and skin. More... | |
getScriptURLsForDebug (ResourceLoaderContext $context) | |
Get the URL or URLs to load for this module's JS in debug mode. More... | |
getSkipFunction () | |
Get the skip function. More... | |
getSource () | |
Get the origin of this module. More... | |
getStyles (ResourceLoaderContext $context) | |
Get all CSS for this module for a given skin. More... | |
getStyleURLsForDebug (ResourceLoaderContext $context) | |
Get the URL or URLs to load for this module's CSS in debug mode. More... | |
getTargets () | |
Get target(s) for the module, eg ['desktop'] or ['desktop', 'mobile']. More... | |
getTemplates () | |
Takes named templates by the module and returns an array mapping. More... | |
getType () | |
Get the module's load type. More... | |
getVersionHash (ResourceLoaderContext $context) | |
Get a string identifying the current version of this module in a given context. More... | |
isKnownEmpty (ResourceLoaderContext $context) | |
Check whether this module is known to be empty. More... | |
isRaw () | |
Whether this module's JS expects to work without the client-side ResourceLoader module. More... | |
setConfig (Config $config) | |
setFileDependencies (ResourceLoaderContext $context, $files) | |
Set in-object cache for file dependencies. More... | |
setLogger (LoggerInterface $logger) | |
setMessageBlob ($blob, $lang) | |
Set in-object cache for message blobs. More... | |
setName ($name) | |
Set this module's name. More... | |
supportsURLLoading () | |
Whether this module supports URL loading. More... | |
Protected Member Functions | |
getContent ($titleText) | |
getDB () | |
Get the Database object used in getTitleInfo(). More... | |
getPages (ResourceLoaderContext $context) | |
Subclasses should return an associative array of resources in the module. More... | |
getTitleInfo (ResourceLoaderContext $context) | |
Get the information about the wiki pages for a given context. More... | |
Protected Member Functions inherited from ResourceLoaderModule | |
buildContent (ResourceLoaderContext $context) | |
Bundle all resources attached to this module into an array. More... | |
getFileDependencies (ResourceLoaderContext $context) | |
Get the files this module depends on indirectly for a given skin. More... | |
getLessVars (ResourceLoaderContext $context) | |
Get module-specific LESS variables, if any. More... | |
getLogger () | |
getMessageBlob (ResourceLoaderContext $context) | |
Get the hash of the message blob. More... | |
saveFileDependencies (ResourceLoaderContext $context, $localFileRefs) | |
Set the files this module depends on indirectly for a given skin. More... | |
validateScriptFile ($fileName, $contents) | |
Validate a given script file; if valid returns the original source. More... | |
Protected Attributes | |
$group | |
$origin = self::ORIGIN_USER_SITEWIDE | |
string | $position = 'bottom' |
Position on the page to load this module at. More... | |
$scripts = [] | |
$styles = [] | |
$titleInfo = [] | |
Protected Attributes inherited from ResourceLoaderModule | |
Config | $config |
$contents = [] | |
$fileDeps = [] | |
LoggerInterface | $logger |
$msgBlobs = [] | |
$name = null | |
$origin = self::ORIGIN_CORE_SITEWIDE | |
$targets = [ 'desktop' ] | |
$versionHash = [] | |
Additional Inherited Members | |
Static Public Member Functions inherited from ResourceLoaderModule | |
static | expandRelativePaths (array $filePaths) |
Expand directories relative to $IP. More... | |
static | getRelativePaths (array $filePaths) |
Make file paths relative to MediaWiki directory. More... | |
Public Attributes inherited from ResourceLoaderModule | |
const | LOAD_GENERAL = 'general' |
const | LOAD_STYLES = 'styles' |
const | ORIGIN_ALL = 10 |
const | ORIGIN_CORE_INDIVIDUAL = 2 |
const | ORIGIN_CORE_SITEWIDE = 1 |
const | ORIGIN_USER_INDIVIDUAL = 4 |
const | ORIGIN_USER_SITEWIDE = 3 |
const | TYPE_COMBINED = 'combined' |
const | TYPE_SCRIPTS = 'scripts' |
const | TYPE_STYLES = 'styles' |
Static Protected Member Functions inherited from ResourceLoaderModule | |
static | javaScriptParser () |
static | safeFileHash ($filePath) |
Compute a non-cryptographic string hash of a file's contents. More... | |
static | safeFilemtime ($filePath) |
Safe version of filemtime(), which doesn't throw a PHP warning if the file doesn't exist. More... | |
Abstraction for ResourceLoader modules which pull from wiki pages.
This can only be used for wiki pages in the MediaWiki and User namespaces, because of its dependence on the functionality of Title::isCssJsSubpage.
This module supports being used as a placeholder for a module on a remote wiki. To do so, getDB() must be overloaded to return a foreign database object that allows local wikis to query page metadata.
Safe for calls on local wikis are:
Definition at line 45 of file ResourceLoaderWikiModule.php.
ResourceLoaderWikiModule::__construct | ( | array | $options = null | ) |
array | $options | For back-compat, this can be omitted in favour of overwriting getPages. |
Definition at line 67 of file ResourceLoaderWikiModule.php.
ResourceLoaderWikiModule::enableModuleContentVersion | ( | ) |
Disable module content versioning.
This class does not support generating content outside of a module request due to foreign database support.
See getDefinitionSummary() for meta-data versioning.
Definition at line 237 of file ResourceLoaderWikiModule.php.
|
protected |
string | $title |
Definition at line 149 of file ResourceLoaderWikiModule.php.
References $content, $handler, $title, CONTENT_FORMAT_CSS, CONTENT_FORMAT_JAVASCRIPT, Title\newFromText(), Revision\newFromTitle(), Revision\RAW, IDBAccessObject\READ_NORMAL, and wfDebugLog().
Referenced by getScript(), and getStyles().
|
protected |
Get the Database object used in getTitleInfo().
Defaults to the local slave DB. Subclasses may want to override this to return a foreign database object, or null if getTitleInfo() shouldn't access the database.
NOTE: This ONLY works for getTitleInfo() and isKnownEmpty(), NOT FOR ANYTHING ELSE. In particular, it doesn't work for getContent() or getScript() etc.
Definition at line 141 of file ResourceLoaderWikiModule.php.
References DB_SLAVE, and wfGetDB().
Referenced by getTitleInfo().
ResourceLoaderWikiModule::getDefinitionSummary | ( | ResourceLoaderContext | $context | ) |
ResourceLoaderContext | $context |
Definition at line 245 of file ResourceLoaderWikiModule.php.
References $summary, getPages(), and getTitleInfo().
ResourceLoaderWikiModule::getGroup | ( | ) |
Get group name.
Definition at line 126 of file ResourceLoaderWikiModule.php.
References $group.
Referenced by isKnownEmpty().
|
protected |
Subclasses should return an associative array of resources in the module.
Keys should be the title of a page in the MediaWiki or User namespace.
Values should be a nested array of options. The supported keys are 'type' and (CSS only) 'media'.
For scripts, 'type' should be 'script'.
For stylesheets, 'type' should be 'style'. There is an optional media key, the value of which can be the medium ('screen', 'print', etc.) of the stylesheet.
ResourceLoaderContext | $context |
Definition at line 101 of file ResourceLoaderWikiModule.php.
References ResourceLoaderModule\$config, as, Config\get(), ResourceLoaderModule\getConfig(), and scripts.
Referenced by getDefinitionSummary(), getScript(), getStyles(), and getTitleInfo().
ResourceLoaderWikiModule::getPosition | ( | ) |
ResourceLoaderWikiModule::getScript | ( | ResourceLoaderContext | $context | ) |
ResourceLoaderContext | $context |
Definition at line 183 of file ResourceLoaderWikiModule.php.
References $options, $scripts, as, getContent(), getPages(), ResourceLoader\makeComment(), and ResourceLoaderModule\validateScriptFile().
ResourceLoaderWikiModule::getStyles | ( | ResourceLoaderContext | $context | ) |
ResourceLoaderContext | $context |
Definition at line 202 of file ResourceLoaderWikiModule.php.
References $options, $styles, as, MemoizedCallable\call(), ResourceLoaderModule\getConfig(), getContent(), ResourceLoaderModule\getFlip(), getPages(), and ResourceLoader\makeComment().
|
protected |
Get the information about the wiki pages for a given context.
ResourceLoaderContext | $context |
Definition at line 284 of file ResourceLoaderWikiModule.php.
References $batch, $dbr, $options, $res, $title, as, getDB(), getPages(), Title\makeTitle(), and Title\newFromText().
Referenced by getDefinitionSummary(), and isKnownEmpty().
ResourceLoaderWikiModule::getType | ( | ) |
Definition at line 335 of file ResourceLoaderWikiModule.php.
References scripts.
ResourceLoaderWikiModule::isKnownEmpty | ( | ResourceLoaderContext | $context | ) |
ResourceLoaderContext | $context |
Definition at line 259 of file ResourceLoaderWikiModule.php.
References as, getGroup(), and getTitleInfo().
|
protected |
Definition at line 62 of file ResourceLoaderWikiModule.php.
Referenced by getGroup(), and ResourceLoaderUserModule\getPages().
|
protected |
Definition at line 50 of file ResourceLoaderWikiModule.php.
|
protected |
Position on the page to load this module at.
Definition at line 47 of file ResourceLoaderWikiModule.php.
Referenced by getPosition().
|
protected |
Definition at line 59 of file ResourceLoaderWikiModule.php.
Referenced by getScript().
|
protected |
Definition at line 56 of file ResourceLoaderWikiModule.php.
Referenced by getStyles().
|
protected |
Definition at line 53 of file ResourceLoaderWikiModule.php.