Output proper remote info on WebFinger notice resources

This commit is contained in:
Mikael Nordfeldth 2016-03-27 14:56:27 +02:00
parent 7be4641040
commit 2d0153195e
2 changed files with 29 additions and 6 deletions

View File

@ -1307,10 +1307,23 @@ class OStatusPlugin extends Plugin
function onEndWebFingerNoticeLinks(XML_XRD $xrd, Notice $target) function onEndWebFingerNoticeLinks(XML_XRD $xrd, Notice $target)
{ {
$author = $target->getProfile(); $salmon_url = null;
$profiletype = $this->profileTypeString($author); $actor = $target->getProfile();
$salmon_url = common_local_url("{$profiletype}salmon", array('id' => $author->id)); if ($actor->isLocal()) {
$xrd->links[] = new XML_XRD_Element_Link(Salmon::REL_SALMON, $salmon_url); $profiletype = $this->profileTypeString($actor);
$salmon_url = common_local_url("{$profiletype}salmon", array('id' => $actor->getID()));
} else {
try {
$oprofile = Ostatus_profile::fromProfile($actor);
$salmon_url = $oprofile->salmonuri;
} catch (Exception $e) {
// Even though it's not a local user, we couldn't get an Ostatus_profile?!
}
}
// Ostatus_profile salmon URL may be empty
if (!empty($salmon_url)) {
$xrd->links[] = new XML_XRD_Element_Link(Salmon::REL_SALMON, $salmon_url);
}
return true; return true;
} }

View File

@ -20,17 +20,27 @@ class WebFingerResource_Notice extends WebFingerResource
public function updateXRD(XML_XRD $xrd) public function updateXRD(XML_XRD $xrd)
{ {
if (Event::handle('StartWebFingerNoticeLinks', array($xrd, $this->object))) { if (Event::handle('StartWebFingerNoticeLinks', array($xrd, $this->object))) {
$xrd->links[] = new XML_XRD_Element_Link('alternate', if ($this->object->isLocal()) {
$xrd->links[] = new XML_XRD_Element_Link('alternate',
common_local_url('ApiStatusesShow', common_local_url('ApiStatusesShow',
array('id'=>$this->object->id, array('id'=>$this->object->id,
'format'=>'atom')), 'format'=>'atom')),
'application/atom+xml'); 'application/atom+xml');
$xrd->links[] = new XML_XRD_Element_Link('alternate', $xrd->links[] = new XML_XRD_Element_Link('alternate',
common_local_url('ApiStatusesShow', common_local_url('ApiStatusesShow',
array('id'=>$this->object->id, array('id'=>$this->object->id,
'format'=>'json')), 'format'=>'json')),
'application/json'); 'application/json');
} else {
try {
$xrd->links[] = new XML_XRD_Element_Link('alternate',
$this->object->getUrl(),
'text/html');
} catch (InvalidUrlException $e) {
// don't do a fallback in webfinger
}
}
Event::handle('EndWebFingerNoticeLinks', array($xrd, $this->object)); Event::handle('EndWebFingerNoticeLinks', array($xrd, $this->object));
} }
} }