Index: branches/wmf-deployment-work/includes/User.php |
— | — | @@ -1066,7 +1066,7 @@ |
1067 | 1067 | * done against master. |
1068 | 1068 | */ |
1069 | 1069 | function getBlockedStatus( $bFromSlave = true ) { |
1070 | | - global $wgEnableSorbs, $wgProxyWhitelist; |
| 1070 | + global $wgEnableSorbs, $wgProxyWhitelist, $wgUser; |
1071 | 1071 | |
1072 | 1072 | if ( -1 != $this->mBlockedby ) { |
1073 | 1073 | wfDebug( "User::getBlockedStatus: already loaded.\n" ); |
— | — | @@ -1086,9 +1086,25 @@ |
1087 | 1087 | $this->mBlockedby = 0; |
1088 | 1088 | $this->mHideName = 0; |
1089 | 1089 | $this->mAllowUsertalk = 0; |
1090 | | - $ip = wfGetIP(); |
1091 | 1090 | |
1092 | | - if ($this->isAllowed( 'ipblock-exempt' ) ) { |
| 1091 | + # Check if we are looking at an IP or a logged-in user |
| 1092 | + if ( $this->isIP( $this->getName() ) ) { |
| 1093 | + $ip = $this->getName(); |
| 1094 | + } |
| 1095 | + else { |
| 1096 | + # Check if we are looking at the current user |
| 1097 | + # If we don't, and the user is logged in, we don't know about |
| 1098 | + # his IP / autoblock status, so ignore autoblock of current user's IP |
| 1099 | + if ( $this->getID() != $wgUser->getID() ) { |
| 1100 | + $ip = ''; |
| 1101 | + } |
| 1102 | + else { |
| 1103 | + # Get IP of current user |
| 1104 | + $ip = wfGetIP(); |
| 1105 | + } |
| 1106 | + } |
| 1107 | + |
| 1108 | + if ( $this->isAllowed( 'ipblock-exempt' ) ) { |
1093 | 1109 | # Exempt from all types of IP-block |
1094 | 1110 | $ip = ''; |
1095 | 1111 | } |
Index: branches/wmf-deployment-work/RELEASE-NOTES |
— | — | @@ -470,6 +470,8 @@ |
471 | 471 | empty portlets are now present but hidden, adding an element to a portlet unhides it |
472 | 472 | * (bug 19531) addPortletLink() now wraps inserted labels in a <span> element to be |
473 | 473 | compatible with the CSS for the Vector skin |
| 474 | +* User::getBlockedStatus() works for all kinds of user objects and doesn't |
| 475 | + assume the user object is equal to the current-user object ($wgUser) |
474 | 476 | |
475 | 477 | == API changes in 1.16 == |
476 | 478 | |