2015-07-18 22:40:42 +00:00
|
|
|
<?php
|
|
|
|
|
2022-02-06 18:54:47 +00:00
|
|
|
namespace MediaWiki\Extension\Gadgets;
|
|
|
|
|
|
|
|
use InvalidArgumentException;
|
2017-11-07 19:36:44 +00:00
|
|
|
use MediaWiki\Linker\LinkTarget;
|
2022-02-06 18:54:47 +00:00
|
|
|
use Title;
|
2017-11-07 19:36:44 +00:00
|
|
|
|
2015-07-18 22:40:42 +00:00
|
|
|
abstract class GadgetRepo {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var GadgetRepo|null
|
|
|
|
*/
|
|
|
|
private static $instance;
|
|
|
|
|
2021-10-17 13:05:15 +00:00
|
|
|
/**
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $titlePrefix;
|
|
|
|
|
2015-07-18 22:40:42 +00:00
|
|
|
/**
|
|
|
|
* Get the ids of the gadgets provided by this repository
|
|
|
|
*
|
2015-08-03 06:37:32 +00:00
|
|
|
* It's possible this could be out of sync with what
|
|
|
|
* getGadget() will return due to caching
|
|
|
|
*
|
2015-07-18 22:40:42 +00:00
|
|
|
* @return string[]
|
|
|
|
*/
|
|
|
|
abstract public function getGadgetIds();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the Gadget object for a given gadget id
|
|
|
|
*
|
|
|
|
* @param string $id
|
|
|
|
* @throws InvalidArgumentException
|
|
|
|
* @return Gadget
|
|
|
|
*/
|
|
|
|
abstract public function getGadget( $id );
|
|
|
|
|
2017-11-07 19:36:44 +00:00
|
|
|
/**
|
|
|
|
* Given that the provided page was updated, invalidate
|
|
|
|
* caches if necessary
|
|
|
|
*
|
|
|
|
* @param LinkTarget $target
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function handlePageUpdate( LinkTarget $target ) {
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Given that the provided page was created, invalidate
|
|
|
|
* caches if necessary
|
|
|
|
*
|
|
|
|
* @param LinkTarget $target
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function handlePageCreation( LinkTarget $target ) {
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Given that the provided page was updated, invalidate
|
|
|
|
* caches if necessary
|
|
|
|
*
|
|
|
|
* @param LinkTarget $target
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function handlePageDeletion( LinkTarget $target ) {
|
|
|
|
}
|
|
|
|
|
2021-12-26 21:23:06 +00:00
|
|
|
/**
|
|
|
|
* Given a gadget ID, return the title of the page where the gadget is
|
|
|
|
* defined (or null if the given repo does not have per-gadget definition
|
|
|
|
* pages).
|
|
|
|
*
|
|
|
|
* @param string $id
|
|
|
|
* @return Title|null
|
|
|
|
*/
|
|
|
|
public function getGadgetDefinitionTitle( string $id ): ?Title {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2015-07-18 22:40:42 +00:00
|
|
|
/**
|
|
|
|
* Get a list of gadgets sorted by category
|
|
|
|
*
|
2016-12-28 10:25:47 +00:00
|
|
|
* @return array [ 'category' => [ 'name' => $gadget ] ]
|
2015-07-18 22:40:42 +00:00
|
|
|
*/
|
|
|
|
public function getStructuredList() {
|
2016-12-28 10:25:47 +00:00
|
|
|
$list = [];
|
2015-07-18 22:40:42 +00:00
|
|
|
foreach ( $this->getGadgetIds() as $id ) {
|
2015-08-03 06:37:32 +00:00
|
|
|
try {
|
|
|
|
$gadget = $this->getGadget( $id );
|
|
|
|
} catch ( InvalidArgumentException $e ) {
|
|
|
|
continue;
|
|
|
|
}
|
2015-07-18 22:40:42 +00:00
|
|
|
$list[$gadget->getCategory()][$gadget->getName()] = $gadget;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $list;
|
|
|
|
}
|
|
|
|
|
2021-10-17 13:05:15 +00:00
|
|
|
/**
|
|
|
|
* Get the script file name without the "MediaWiki:Gadget-" or "Gadget:" prefix.
|
|
|
|
* This name is used by the client-side require() so that require("Data.json") resolves
|
|
|
|
* to either "MediaWiki:Gadget-Data.json" or "Gadget:Data.json" depending on the
|
|
|
|
* $wgGadgetsRepoClass configuration, enabling easy migration between the configuration modes.
|
|
|
|
*
|
|
|
|
* @param string $titleText
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function titleWithoutPrefix( string $titleText ): string {
|
|
|
|
$numReplaces = 1; // there will only one occurrence of the prefix
|
|
|
|
return str_replace( $this->titlePrefix, '', $titleText, $numReplaces );
|
|
|
|
}
|
|
|
|
|
2015-07-18 22:40:42 +00:00
|
|
|
/**
|
2015-08-03 06:37:32 +00:00
|
|
|
* Get the configured default GadgetRepo.
|
2015-07-18 22:40:42 +00:00
|
|
|
*
|
|
|
|
* @return GadgetRepo
|
|
|
|
*/
|
|
|
|
public static function singleton() {
|
|
|
|
if ( self::$instance === null ) {
|
2021-10-09 00:34:45 +00:00
|
|
|
// @todo use Config here
|
|
|
|
global $wgGadgetsRepoClass;
|
2022-02-06 18:54:47 +00:00
|
|
|
// @phan-suppress-next-line PhanPossiblyUndeclaredVariable
|
2015-08-03 06:37:32 +00:00
|
|
|
self::$instance = new $wgGadgetsRepoClass();
|
2015-07-18 22:40:42 +00:00
|
|
|
}
|
|
|
|
return self::$instance;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Should only be used by unit tests
|
|
|
|
*
|
|
|
|
* @param GadgetRepo|null $repo
|
|
|
|
*/
|
|
|
|
public static function setSingleton( $repo = null ) {
|
|
|
|
self::$instance = $repo;
|
|
|
|
}
|
|
|
|
}
|