$end = $db->selectField( 'page', 'MAX(page_id)', false, __FUNCTION__ );
$blockStart = $start;
$blockEnd = $start + BATCH_SIZE - 1;
- $encodedExpiry = Block::decodeExpiry('');
+ $encodedExpiry = 'infinity';
while ( $blockEnd <= $end ) {
- $cond = "page_id BETWEEN $blockStart AND $blockEnd AND page_restrictions !=''";
+ $cond = "page_id BETWEEN $blockStart AND $blockEnd AND page_restrictions !='' AND page_restrictions !='edit=:move='";
$res = $db->select( 'page', array('page_id', 'page_restrictions'), $cond, __FUNCTION__ );
$batch = array();
while ( $row = $db->fetchObject( $res ) ) {
$temp = explode( '=', trim( $restrict ) );
if(count($temp) == 1) {
// old old format should be treated as edit/move restriction
- $oldRestrictions["edit"] = explode( ',', trim( $temp[0] ) );
- $oldRestrictions["move"] = explode( ',', trim( $temp[0] ) );
+ $oldRestrictions["edit"] = trim( $temp[0] );
+ $oldRestrictions["move"] = trim( $temp[0] );
} else {
- $oldRestrictions[$temp[0]] = explode( ',', trim( $temp[1] ) );
+ $oldRestrictions[$temp[0]] = trim( $temp[1] );
}
}
# Update restrictions table
# We use insert() and not replace() as Article.php replaces
# page_restrictions with '' when protected in the restrictions table
if ( count( $batch ) ) {
- $db->insert( 'page_restrictions', $batch, __FUNCTION__ );
+ $db->insert( 'page_restrictions', $batch, __FUNCTION__, array( 'IGNORE' ) );
}
$blockStart += BATCH_SIZE;
$blockEnd += BATCH_SIZE;
}
}
-?>
+