public function testToReturnFalseOnMwNamespaceEditPermissionCheckForInappropriatePermision() { $title = Title::newFromText('Smw_allows_pattern', NS_MEDIAWIKI); $user = $this->getMockBuilder('\\User')->disableOriginalConstructor()->getMock(); $user->expects($this->once())->method('isAllowed')->with($this->equalTo('smw-patternedit'))->will($this->returnValue(false)); $result = ''; $instance = new PermissionPthValidator(); $this->assertFalse($instance->checkUserCanPermissionFor($title, $user, 'edit', $result)); $this->assertFalse($result); }
private function addCallbackHandlers($basePath, $globalVars) { $applicationFactory = ApplicationFactory::getInstance(); $httpRequestFactory = new HttpRequestFactory(); $deferredRequestDispatchManager = new DeferredRequestDispatchManager($httpRequestFactory->newSocketRequest()); $deferredRequestDispatchManager->isEnabledHttpDeferredRequest($applicationFactory->getSettings()->get('smwgEnabledHttpDeferredJobRequest')); // SQLite has no lock manager making table lock contention very common // hence use the JobQueue to enqueue any change request and avoid // a rollback due to canceled DB transactions $deferredRequestDispatchManager->isPreferredWithJobQueue($GLOBALS['wgDBtype'] === 'sqlite'); $permissionPthValidator = new PermissionPthValidator(); /** * Hook: ParserAfterTidy to add some final processing to the fully-rendered page output * * @see https://www.mediawiki.org/wiki/Manual:Hooks/ParserAfterTidy */ $this->handlers['ParserAfterTidy'] = function (&$parser, &$text) { $parserAfterTidy = new ParserAfterTidy($parser, $text); return $parserAfterTidy->process(); }; /** * Hook: Called by BaseTemplate when building the toolbox array and * returning it for the skin to output. * * @see https://www.mediawiki.org/wiki/Manual:Hooks/BaseTemplateToolbox */ $this->handlers['BaseTemplateToolbox'] = function ($skinTemplate, &$toolbox) { $baseTemplateToolbox = new BaseTemplateToolbox($skinTemplate, $toolbox); return $baseTemplateToolbox->process(); }; /** * Hook: Allows extensions to add text after the page content and article * metadata. * * @see https://www.mediawiki.org/wiki/Manual:Hooks/SkinAfterContent */ $this->handlers['SkinAfterContent'] = function (&$data, $skin = null) { $skinAfterContent = new SkinAfterContent($skin); return $skinAfterContent->performUpdate($data); }; /** * Hook: Called after parse, before the HTML is added to the output * * @see https://www.mediawiki.org/wiki/Manual:Hooks/OutputPageParserOutput */ $this->handlers['OutputPageParserOutput'] = function (&$outputPage, $parserOutput) { $outputPageParserOutput = new OutputPageParserOutput($outputPage, $parserOutput); return $outputPageParserOutput->process(); }; /** * Hook: Add changes to the output page, e.g. adding of CSS or JavaScript * * @see https://www.mediawiki.org/wiki/Manual:Hooks/BeforePageDisplay */ $this->handlers['BeforePageDisplay'] = function (&$outputPage, &$skin) { $beforePageDisplay = new BeforePageDisplay($outputPage, $skin); return $beforePageDisplay->process(); }; /** * Hook: InternalParseBeforeLinks is used to process the expanded wiki * code after <nowiki>, HTML-comments, and templates have been treated. * * @see https://www.mediawiki.org/wiki/Manual:Hooks/InternalParseBeforeLinks */ $this->handlers['InternalParseBeforeLinks'] = function (&$parser, &$text) { $internalParseBeforeLinks = new InternalParseBeforeLinks($parser, $text); return $internalParseBeforeLinks->process(); }; /** * Hook: NewRevisionFromEditComplete called when a revision was inserted * due to an edit * * @see https://www.mediawiki.org/wiki/Manual:Hooks/NewRevisionFromEditComplete */ $this->handlers['NewRevisionFromEditComplete'] = function ($wikiPage, $revision, $baseId, $user) { $newRevisionFromEditComplete = new NewRevisionFromEditComplete($wikiPage, $revision, $baseId, $user); return $newRevisionFromEditComplete->process(); }; /** * Hook: TitleMoveComplete occurs whenever a request to move an article * is completed * * @see https://www.mediawiki.org/wiki/Manual:Hooks/TitleMoveComplete */ $this->handlers['TitleMoveComplete'] = function ($oldTitle, $newTitle, $user, $oldId, $newId) { $titleMoveComplete = new TitleMoveComplete($oldTitle, $newTitle, $user, $oldId, $newId); return $titleMoveComplete->process(); }; /** * Hook: ArticlePurge executes before running "&action=purge" * * @see https://www.mediawiki.org/wiki/Manual:Hooks/ArticlePurge */ $this->handlers['ArticlePurge'] = function (&$wikiPage) { $articlePurge = new ArticlePurge(); return $articlePurge->process($wikiPage); }; /** * Hook: ArticleDelete occurs whenever the software receives a request * to delete an article * * @see https://www.mediawiki.org/wiki/Manual:Hooks/ArticleDelete */ $this->handlers['ArticleDelete'] = function (&$wikiPage, &$user, &$reason, &$error) { $articleDelete = new ArticleDelete($wikiPage, $user, $reason, $error); return $articleDelete->process(); }; /** * Hook: LinksUpdateConstructed called at the end of LinksUpdate() construction * * @see https://www.mediawiki.org/wiki/Manual:Hooks/LinksUpdateConstructed */ $this->handlers['LinksUpdateConstructed'] = function ($linksUpdate) { $linksUpdateConstructed = new LinksUpdateConstructed($linksUpdate); return $linksUpdateConstructed->process(); }; /** * Hook: Add extra statistic at the end of Special:Statistics * * @see https://www.mediawiki.org/wiki/Manual:Hooks/SpecialStatsAddExtra */ $this->handlers['SpecialStatsAddExtra'] = function (&$extraStats) use($globalVars) { $specialStatsAddExtra = new SpecialStatsAddExtra($extraStats, $globalVars['wgVersion'], $globalVars['wgLang']); return $specialStatsAddExtra->process(); }; /** * @see https://www.mediawiki.org/wiki/Manual:Hooks/FileUpload * * @since 1.9.1 */ $this->handlers['FileUpload'] = function ($file, $reupload) { $fileUpload = new FileUpload($file, $reupload); return $fileUpload->process(); }; /** * @see https://www.mediawiki.org/wiki/Manual:Hooks/ResourceLoaderGetConfigVars */ $this->handlers['ResourceLoaderGetConfigVars'] = function (&$vars) { $resourceLoaderGetConfigVars = new ResourceLoaderGetConfigVars($vars); return $resourceLoaderGetConfigVars->process(); }; /** * @see https://www.mediawiki.org/wiki/Manual:Hooks/GetPreferences */ $this->handlers['GetPreferences'] = function ($user, &$preferences) { $getPreferences = new GetPreferences($user, $preferences); return $getPreferences->process(); }; /** * @see https://www.mediawiki.org/wiki/Manual:Hooks/SkinTemplateNavigation */ $this->handlers['SkinTemplateNavigation'] = function (&$skinTemplate, &$links) { $skinTemplateNavigation = new SkinTemplateNavigation($skinTemplate, $links); return $skinTemplateNavigation->process(); }; /** * @see https://www.mediawiki.org/wiki/Manual:Hooks/LoadExtensionSchemaUpdates */ $this->handlers['LoadExtensionSchemaUpdates'] = function ($databaseUpdater) { $extensionSchemaUpdates = new ExtensionSchemaUpdates($databaseUpdater); return $extensionSchemaUpdates->process(); }; /** * @see https://www.mediawiki.org/wiki/Manual:Hooks/ResourceLoaderTestModules */ $this->handlers['ResourceLoaderTestModules'] = function (&$testModules, &$resourceLoader) use($basePath, $globalVars) { $resourceLoaderTestModules = new ResourceLoaderTestModules($resourceLoader, $testModules, $basePath, $globalVars['IP']); return $resourceLoaderTestModules->process(); }; /** * @see https://www.mediawiki.org/wiki/Manual:Hooks/ExtensionTypes */ $this->handlers['ExtensionTypes'] = function (&$extTypes) { $extensionTypes = new ExtensionTypes($extTypes); return $extensionTypes->process(); }; /** * @see https://www.mediawiki.org/wiki/Manual:Hooks/TitleIsAlwaysKnown */ $this->handlers['TitleIsAlwaysKnown'] = function ($title, &$result) { $titleIsAlwaysKnown = new TitleIsAlwaysKnown($title, $result); return $titleIsAlwaysKnown->process(); }; /** * @see https://www.mediawiki.org/wiki/Manual:Hooks/BeforeDisplayNoArticleText */ $this->handlers['BeforeDisplayNoArticleText'] = function ($article) { $beforeDisplayNoArticleText = new BeforeDisplayNoArticleText($article); return $beforeDisplayNoArticleText->process(); }; /** * @see https://www.mediawiki.org/wiki/Manual:Hooks/ArticleFromTitle */ $this->handlers['ArticleFromTitle'] = function (&$title, &$article) { $articleFromTitle = new ArticleFromTitle($title, $article); return $articleFromTitle->process(); }; /** * @see https://www.mediawiki.org/wiki/Manual:Hooks/TitleIsMovable */ $this->handlers['TitleIsMovable'] = function ($title, &$isMovable) { $titleIsMovable = new TitleIsMovable($title, $isMovable); return $titleIsMovable->process(); }; /** * @see https://www.mediawiki.org/wiki/Manual:Hooks/EditPage::showEditForm:initial */ $this->handlers['EditPage::showEditForm:initial'] = function ($editPage, $output = null) use($applicationFactory) { // 1.19 hook interface is missing the output object if (!$output instanceof \OutputPage) { $output = $GLOBALS['wgOut']; } $htmlFormRenderer = $applicationFactory->newMwCollaboratorFactory()->newHtmlFormRenderer($editPage->getTitle(), $output->getLanguage()); $editPageForm = new EditPageForm($editPage, $htmlFormRenderer); return $editPageForm->process(); }; /** * @see https://www.mediawiki.org/wiki/Manual:Hooks/userCan */ $this->handlers['userCan'] = function (&$title, &$user, $action, &$result) use($permissionPthValidator) { return $permissionPthValidator->checkUserCanPermissionFor($title, $user, $action, $result); }; $this->registerHooksForInternalUse($applicationFactory, $deferredRequestDispatchManager); $this->registerParserFunctionHooks($applicationFactory); }