assertRequiredOptions( self::CONSTRUCTOR_OPTIONS ); $this->options = $options; list( $this->target, $this->targetType ) = $blockUtils->parseBlockTarget( $target ); $this->performer = $performer; } /** * Check base permission that apply to either block or unblock * * @since 1.36 * @param bool $checkHideuser * @return bool|string */ public function checkBasePermissions( $checkHideuser = false ) { if ( !$this->performer->isAllowed( 'block' ) ) { return 'badaccess-group0'; } if ( $checkHideuser && !$this->performer->isAllowed( 'hideuser' ) ) { return 'unblock-hideuser'; } return true; } /** * Checks block-related permissions (doesn't check any other permissions) * * T17810: Sitewide blocked admins should not be able to block/unblock * others with one exception; they can block the user who blocked them, * to reduce advantage of a malicious account blocking all admins (T150826). * * T208965: Partially blocked admins can block and unblock others as normal. * * @return bool|string True when checks passed, message code for failures */ public function checkBlockPermissions() { $block = $this->performer->getBlock(); // TODO: pass disposition parameter if ( !$block ) { // User is not blocked, process as normal return true; } if ( !$block->isSitewide() ) { // T208965: Partially blocked admins should have full access return true; } $performerIdentity = $this->performer->getUser(); if ( $this->target instanceof UserIdentity && $this->target->getId() === $performerIdentity->getId() ) { // Blocked admin is trying to alter their own block // Self-blocked admins can always remove or alter their block if ( $block->getBlocker() && $performerIdentity->equals( $block->getBlocker() ) ) { return true; } // Users with 'unblockself' right can unblock themselves or alter their own block if ( $this->performer->isAllowed( 'unblockself' ) ) { return true; } else { return 'ipbnounblockself'; } } if ( $this->target instanceof UserIdentity && $block->getBlocker() && $this->target->equals( $block->getBlocker() ) ) { // T150826: Blocked admins can always block the admin who blocked them return true; } // User is blocked and no exception took effect return 'ipbblocked'; } /** * Check permission to block emailing * * @since 1.36 * @return bool */ public function checkEmailPermissions() { return $this->options->get( 'EnableUserEmail' ) && $this->performer->isAllowed( 'blockemail' ); } }