X-Git-Url: https://scripts.mit.edu/gitweb/autoinstallsdev/mediawiki.git/blobdiff_plain/19e297c21b10b1b8a3acad5e73fc71dcb35db44a..6932310fd58ebef145fa01eb76edf7150284d8ea:/maintenance/protect.php diff --git a/maintenance/protect.php b/maintenance/protect.php index baef45fb..f6bb2532 100644 --- a/maintenance/protect.php +++ b/maintenance/protect.php @@ -1,5 +1,7 @@ mDescription = "Protect or unprotect an article from the command line."; + $this->addDescription( 'Protect or unprotect a page from the command line.' ); $this->addOption( 'unprotect', 'Removes protection' ); $this->addOption( 'semiprotect', 'Adds semi-protection' ); - $this->addOption( 'u', 'Username to protect with', false, true ); - $this->addOption( 'r', 'Reason for un/protection', false, true ); + $this->addOption( 'cascade', 'Add cascading protection' ); + $this->addOption( 'user', 'Username to protect with', false, true, 'u' ); + $this->addOption( 'reason', 'Reason for un/protection', false, true, 'r' ); $this->addArg( 'title', 'Title to protect', true ); } public function execute() { - global $wgUser; + $userName = $this->getOption( 'user', false ); + $reason = $this->getOption( 'reason', '' ); - $userName = $this->getOption( 'u', 'Maintenance script' ); - $reason = $this->getOption( 'r', '' ); + $cascade = $this->hasOption( 'cascade' ); $protection = "sysop"; if ( $this->hasOption( 'semiprotect' ) ) { @@ -44,20 +53,35 @@ class Protect extends Maintenance { $protection = ""; } - $wgUser = User::newFromName( $userName ); - $restrictions = array( 'edit' => $protection, 'move' => $protection ); + if ( $userName === false ) { + $user = User::newSystemUser( 'Maintenance script', [ 'steal' => true ] ); + } else { + $user = User::newFromName( $userName ); + } + if ( !$user ) { + $this->error( "Invalid username", true ); + } + + // @todo FIXME: This is reset 7 lines down. + $restrictions = [ 'edit' => $protection, 'move' => $protection ]; $t = Title::newFromText( $this->getArg() ); if ( !$t ) { $this->error( "Invalid title", true ); } - $article = new Article( $t ); + $restrictions = []; + foreach ( $t->getRestrictionTypes() as $type ) { + $restrictions[$type] = $protection; + } # un/protect the article $this->output( "Updating protection status... " ); - $success = $article->updateRestrictions( $restrictions, $reason ); - if ( $success ) { + + $page = WikiPage::factory( $t ); + $status = $page->doUpdateRestrictions( $restrictions, [], $cascade, $reason, $user ); + + if ( $status->isOK() ) { $this->output( "done\n" ); } else { $this->output( "failed\n" ); @@ -66,4 +90,4 @@ class Protect extends Maintenance { } $maintClass = "Protect"; -require_once( RUN_MAINTENANCE_IF_MAIN ); +require_once RUN_MAINTENANCE_IF_MAIN;