gadgetRepo = $gadgetRepo; } public function execute() { $params = $this->extractRequestParams(); $this->props = array_flip( $params['prop'] ); $this->categories = isset( $params['categories'] ) ? array_flip( $params['categories'] ) : false; $this->neededIds = isset( $params['ids'] ) ? array_flip( $params['ids'] ) : false; $this->listAllowed = isset( $params['allowedonly'] ) && $params['allowedonly']; $this->listEnabled = isset( $params['enabledonly'] ) && $params['enabledonly']; $this->getMain()->setCacheMode( $this->listAllowed || $this->listEnabled ? 'anon-public-user-private' : 'public' ); $this->applyList( $this->getList() ); } /** * @return array */ private function getList() { $gadgets = $this->gadgetRepo->getStructuredList(); if ( !$gadgets ) { return []; } $result = []; foreach ( $gadgets as $category => $list ) { if ( $this->categories && !isset( $this->categories[$category] ) ) { continue; } foreach ( $list as $g ) { if ( $this->isNeeded( $g ) ) { $result[] = $g; } } } return $result; } /** * @param array $gadgets */ private function applyList( $gadgets ) { $data = []; $result = $this->getResult(); /** * @var $g Gadget */ foreach ( $gadgets as $g ) { $row = []; if ( isset( $this->props['id'] ) ) { $row['id'] = $g->getName(); } if ( isset( $this->props['metadata'] ) ) { $row['metadata'] = $this->fakeMetadata( $g ); $this->setIndexedTagNameForMetadata( $row['metadata'] ); } if ( isset( $this->props['desc'] ) ) { $row['desc'] = $g->getDescription(); } $data[] = $row; } ApiResult::setIndexedTagName( $data, 'gadget' ); $result->addValue( 'query', $this->getModuleName(), $data ); } /** * @param Gadget $gadget * * @return bool */ private function isNeeded( Gadget $gadget ) { $user = $this->getUser(); return ( $this->neededIds === false || isset( $this->neededIds[$gadget->getName()] ) ) && ( !$this->listAllowed || $gadget->isAllowed( $user ) ) && ( !$this->listEnabled || $gadget->isEnabled( $user ) ); } /** * @param Gadget $g * @return array */ private function fakeMetadata( Gadget $g ) { return [ 'settings' => [ 'rights' => $g->getRequiredRights(), 'skins' => $g->getRequiredSkins(), 'actions' => $g->getRequiredActions(), 'namespaces' => $g->getRequiredNamespaces(), 'contentModels' => $g->getRequiredContentModels(), 'default' => $g->isOnByDefault(), 'hidden' => $g->isHidden(), 'package' => $g->isPackaged(), 'shared' => false, 'category' => $g->getCategory(), 'legacyscripts' => (bool)$g->getLegacyScripts(), 'requiresES6' => $g->requiresES6(), 'supportsUrlLoad' => $g->supportsUrlLoad(), ], 'module' => [ 'scripts' => $g->getScripts(), 'styles' => $g->getStyles(), 'datas' => $g->getJSONs(), 'dependencies' => $g->getDependencies(), 'peers' => $g->getPeers(), 'messages' => $g->getMessages(), ] ]; } /** * @param array[] &$metadata */ private function setIndexedTagNameForMetadata( &$metadata ) { static $tagNames = [ 'rights' => 'right', 'skins' => 'skin', 'actions' => 'action', 'namespaces' => 'namespace', 'contentModels' => 'contentModel', 'scripts' => 'script', 'styles' => 'style', 'datas' => 'data', 'dependencies' => 'dependency', 'peers' => 'peer', 'messages' => 'message', ]; foreach ( $metadata as $data ) { foreach ( $data as $key => $value ) { if ( is_array( $value ) ) { $tag = $tagNames[$key] ?? $key; ApiResult::setIndexedTagName( $value, $tag ); } } } } public function getAllowedParams() { return [ 'prop' => [ ParamValidator::PARAM_DEFAULT => 'id|metadata', ParamValidator::PARAM_ISMULTI => true, ParamValidator::PARAM_TYPE => [ 'id', 'metadata', 'desc', ], ApiBase::PARAM_HELP_MSG_PER_VALUE => [], ], 'categories' => [ ParamValidator::PARAM_ISMULTI => true, ParamValidator::PARAM_TYPE => 'string', ], 'ids' => [ ParamValidator::PARAM_TYPE => 'string', ParamValidator::PARAM_ISMULTI => true, ], 'allowedonly' => false, 'enabledonly' => false, ]; } /** * @see ApiBase::getExamplesMessages() * @return array */ protected function getExamplesMessages() { $params = $this->getAllowedParams(); $allProps = implode( '|', $params['prop'][ParamValidator::PARAM_TYPE] ); return [ 'action=query&list=gadgets&gaprop=id|desc' => 'apihelp-query+gadgets-example-1', "action=query&list=gadgets&gaprop=$allProps" => 'apihelp-query+gadgets-example-2', 'action=query&list=gadgets&gacategories=foo' => 'apihelp-query+gadgets-example-3', 'action=query&list=gadgets&gaids=foo|bar&gaprop=id|desc|metadata' => 'apihelp-query+gadgets-example-4', 'action=query&list=gadgets&gaenabledonly' => 'apihelp-query+gadgets-example-5', ]; } }