diff options
Diffstat (limited to 'maintenance/importSiteScripts.php')
-rw-r--r-- | maintenance/importSiteScripts.php | 53 |
1 files changed, 37 insertions, 16 deletions
diff --git a/maintenance/importSiteScripts.php b/maintenance/importSiteScripts.php index 0dc200ec..e369cb15 100644 --- a/maintenance/importSiteScripts.php +++ b/maintenance/importSiteScripts.php @@ -1,13 +1,34 @@ <?php /** - * Maintenance script to import all scripts in the MediaWiki namespace from a - * local site. + * Import all scripts in the MediaWiki namespace from a local site. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along + * with this program; if not, write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + * http://www.gnu.org/copyleft/gpl.html + * * @file * @ingroup Maintenance */ -require_once( dirname( __FILE__ ) . '/Maintenance.php' ); +require_once( __DIR__ . '/Maintenance.php' ); +/** + * Maintenance script to import all scripts in the MediaWiki namespace from a + * local site. + * + * @ingroup Maintenance + */ class ImportSiteScripts extends Maintenance { public function __construct() { parent::__construct(); @@ -16,17 +37,17 @@ class ImportSiteScripts extends Maintenance { $this->addArg( 'index', 'index.php base url' ); $this->addOption( 'username', 'User name of the script importer' ); } - + public function execute() { global $wgUser; $user = User::newFromName( $this->getOption( 'username', 'ScriptImporter' ) ); $wgUser = $user; - + $baseUrl = $this->getArg( 1 ); $pageList = $this->fetchScriptList(); $this->output( 'Importing ' . count( $pageList ) . " pages\n" ); - + foreach ( $pageList as $page ) { $title = Title::makeTitleSafe( NS_MEDIAWIKI, $page ); if ( !$title ) { @@ -35,34 +56,34 @@ class ImportSiteScripts extends Maintenance { } $this->output( "Importing $page\n" ); - $url = wfAppendQuery( $baseUrl, array( - 'action' => 'raw', + $url = wfAppendQuery( $baseUrl, array( + 'action' => 'raw', 'title' => "MediaWiki:{$page}" ) ); $text = Http::get( $url ); $wikiPage = WikiPage::factory( $title ); $wikiPage->doEdit( $text, "Importing from $url", 0, false, $user ); } - + } - + protected function fetchScriptList() { - $data = array( + $data = array( 'action' => 'query', 'format' => 'php',//'json', 'list' => 'allpages', 'apnamespace' => '8', - 'aplimit' => '500', + 'aplimit' => '500', ); $baseUrl = $this->getArg( 0 ); $pages = array(); - + do { $url = wfAppendQuery( $baseUrl, $data ); $strResult = Http::get( $url ); //$result = FormatJson::decode( $strResult ); // Still broken $result = unserialize( $strResult ); - + if ( !empty( $result['query']['allpages'] ) ) { foreach ( $result['query']['allpages'] as $page ) { if ( substr( $page['title'], -3 ) === '.js' ) { @@ -76,9 +97,9 @@ class ImportSiteScripts extends Maintenance { $this->output( "Fetching new batch from {$data['apfrom']}\n" ); } } while ( isset( $result['query-continue'] ) ); - + return $pages; - + } } |