More sensical profile::getUri()
This commit is contained in:
parent
b2a502b336
commit
2cb243808c
|
@ -722,6 +722,10 @@ StartRobotsTxt: Before outputting the robots.txt page
|
||||||
EndRobotsTxt: After the default robots.txt page (good place for customization)
|
EndRobotsTxt: After the default robots.txt page (good place for customization)
|
||||||
- &$action: RobotstxtAction being shown
|
- &$action: RobotstxtAction being shown
|
||||||
|
|
||||||
GetProfileUri: When determining the canonical URI for a given profile
|
StartGetProfileUri: When determining the canonical URI for a given profile
|
||||||
- &$profile: the current profile
|
- $profile: the current profile
|
||||||
|
- &$uri: the URI
|
||||||
|
|
||||||
|
EndGetProfileUri: After determining the canonical URI for a given profile
|
||||||
|
- $profile: the current profile
|
||||||
|
- &$uri: the URI
|
||||||
|
|
|
@ -769,7 +769,7 @@ class Profile extends Memcached_DataObject
|
||||||
|
|
||||||
$xs->elementStart('author');
|
$xs->elementStart('author');
|
||||||
$xs->element('name', null, $this->nickname);
|
$xs->element('name', null, $this->nickname);
|
||||||
$xs->element('uri', null, $this->profileurl);
|
$xs->element('uri', null, $this->getUri());
|
||||||
$xs->elementEnd('author');
|
$xs->elementEnd('author');
|
||||||
|
|
||||||
return $xs->getString();
|
return $xs->getString();
|
||||||
|
@ -832,21 +832,40 @@ class Profile extends Memcached_DataObject
|
||||||
return $xs->getString();
|
return $xs->getString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the best URI for a profile. Plugins may override.
|
||||||
|
*
|
||||||
|
* @return string $uri
|
||||||
|
*/
|
||||||
function getUri()
|
function getUri()
|
||||||
{
|
{
|
||||||
if (Event::handle('GetProfileUri', array($this))) {
|
$uri = null;
|
||||||
|
|
||||||
|
// check for a local user first
|
||||||
|
$user = User::staticGet('id', $this->id);
|
||||||
|
|
||||||
|
if (!empty($user)) {
|
||||||
|
$uri = common_local_url(
|
||||||
|
'userbyid',
|
||||||
|
array('id' => $user->id)
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
|
||||||
|
// give plugins a chance to set the URI
|
||||||
|
if (Event::handle('StartGetProfileUri', array($this, &$uri))) {
|
||||||
|
|
||||||
|
// return OMB profile if any
|
||||||
$remote = Remote_profile::staticGet('id', $this->id);
|
$remote = Remote_profile::staticGet('id', $this->id);
|
||||||
|
|
||||||
if (!empty($remote)) {
|
if (!empty($remote)) {
|
||||||
return $remote->uri;
|
$uri = $remote->uri;
|
||||||
} else {
|
|
||||||
return common_local_url(
|
|
||||||
'userbyid',
|
|
||||||
array('id' => $this->id)
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Event::handle('EndGetProfileUri', array($this, &$uri));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return $uri;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user