OStatus: support @example.com/path/to/profile mentions as well as @profile@example.com (latter requires webfinger, former doesn't)

Plus misc warnings/notices cleanup in the submission path.
This commit is contained in:
Brion Vibber 2010-03-01 16:36:33 -08:00
parent 0512151eab
commit 493b5479c1
5 changed files with 53 additions and 19 deletions

View File

@ -294,6 +294,9 @@ class NewnoticeAction extends Action
if ($profile) { if ($profile) {
$content = '@' . $profile->nickname . ' '; $content = '@' . $profile->nickname . ' ';
} }
} else {
// @fixme most of these bits above aren't being passed on above
$inreplyto = null;
} }
$notice_form = new NoticeForm($this, '', $content, null, $inreplyto); $notice_form = new NoticeForm($this, '', $content, null, $inreplyto);

View File

@ -222,31 +222,62 @@ class OStatusPlugin extends Plugin
} }
/** /**
* * Find any explicit remote mentions. Accepted forms:
* Webfinger: @user@example.com
* Profile link: @example.com/mublog/user
* @param Profile $sender (os user?)
* @param string $text input markup text
* @param array &$mention in/out param: set of found mentions
* @return boolean hook return value
*/ */
function onEndFindMentions($sender, $text, &$mentions) function onEndFindMentions($sender, $text, &$mentions)
{ {
preg_match_all('/(?:^|\s+)@((?:\w+\.)*\w+@(?:\w+\.)*\w+(?:\w+\-\w+)*\.\w+)/', preg_match_all('!(?:^|\s+)
@( # Webfinger:
(?:\w+\.)*\w+ # user
@ # @
(?:\w+\.)*\w+(?:\w+\-\w+)*\.\w+ # domain
| # Profile:
(?:\w+\.)*\w+(?:\w+\-\w+)*\.\w+ # domain
(?:/\w+)+ # /path1(/path2...)
)!x',
$text, $text,
$wmatches, $wmatches,
PREG_OFFSET_CAPTURE); PREG_OFFSET_CAPTURE);
foreach ($wmatches[1] as $wmatch) { foreach ($wmatches[1] as $wmatch) {
$target = $wmatch[0];
$oprofile = null;
$webfinger = $wmatch[0]; if (strpos($target, '/') === false) {
$this->log(LOG_INFO, "Checking Webfinger for address '$target'");
$this->log(LOG_INFO, "Checking Webfinger for address '$webfinger'"); try {
$oprofile = Ostatus_profile::ensureWebfinger($target);
$oprofile = Ostatus_profile::ensureWebfinger($webfinger); } catch (Exception $e) {
$this->log(LOG_ERR, "Webfinger check failed: " . $e->getMessage());
}
} else {
$schemes = array('https', 'http');
foreach ($schemes as $scheme) {
$url = "$scheme://$target";
$this->log(LOG_INFO, "Checking profile address '$url'");
try {
$oprofile = Ostatus_profile::ensureProfile($url);
if ($oprofile) {
continue;
}
} catch (Exception $e) {
$this->log(LOG_ERR, "Profile check failed: " . $e->getMessage());
}
}
}
if (empty($oprofile)) { if (empty($oprofile)) {
$this->log(LOG_INFO, "No Ostatus_profile found for address '$target'");
$this->log(LOG_INFO, "No Ostatus_profile found for address '$webfinger'");
} else { } else {
$this->log(LOG_INFO, "Ostatus_profile found for address '$webfinger'"); $this->log(LOG_INFO, "Ostatus_profile found for address '$target'");
if ($oprofile->isGroup()) { if ($oprofile->isGroup()) {
continue; continue;
@ -261,7 +292,7 @@ class OStatusPlugin extends Plugin
} }
} }
$mentions[] = array('mentioned' => array($profile), $mentions[] = array('mentioned' => array($profile),
'text' => $wmatch[0], 'text' => $target,
'position' => $pos, 'position' => $pos,
'url' => $profile->profileurl); 'url' => $profile->profileurl);
} }

View File

@ -698,7 +698,7 @@ class Ostatus_profile extends Memcached_DataObject
{ {
// Get the canonical feed URI and check it // Get the canonical feed URI and check it
$discover = new FeedDiscovery(); $discover = new FeedDiscovery();
if ($hints['feedurl']) { if (isset($hints['feedurl'])) {
$feeduri = $hints['feedurl']; $feeduri = $hints['feedurl'];
$feeduri = $discover->discoverFromFeedURL($feeduri); $feeduri = $discover->discoverFromFeedURL($feeduri);
} else { } else {

View File

@ -94,7 +94,7 @@ class Discovery
$links = call_user_func(array($class, 'discover'), $uri); $links = call_user_func(array($class, 'discover'), $uri);
if ($link = Discovery::getService($links, Discovery::LRDD_REL)) { if ($link = Discovery::getService($links, Discovery::LRDD_REL)) {
// Load the LRDD XRD // Load the LRDD XRD
if ($link['template']) { if (!empty($link['template'])) {
$xrd_uri = Discovery::applyTemplate($link['template'], $uri); $xrd_uri = Discovery::applyTemplate($link['template'], $uri);
} else { } else {
$xrd_uri = $link['href']; $xrd_uri = $link['href'];

View File

@ -156,20 +156,20 @@ class XRD
function saveLink($doc, $link) function saveLink($doc, $link)
{ {
$link_element = $doc->createElement('Link'); $link_element = $doc->createElement('Link');
if ($link['rel']) { if (!empty($link['rel'])) {
$link_element->setAttribute('rel', $link['rel']); $link_element->setAttribute('rel', $link['rel']);
} }
if ($link['type']) { if (!empty($link['type'])) {
$link_element->setAttribute('type', $link['type']); $link_element->setAttribute('type', $link['type']);
} }
if ($link['href']) { if (!empty($link['href'])) {
$link_element->setAttribute('href', $link['href']); $link_element->setAttribute('href', $link['href']);
} }
if ($link['template']) { if (!empty($link['template'])) {
$link_element->setAttribute('template', $link['template']); $link_element->setAttribute('template', $link['template']);
} }
if (is_array($link['title'])) { if (!empty($link['title']) && is_array($link['title'])) {
foreach($link['title'] as $title) { foreach($link['title'] as $title) {
$title = $doc->createElement('Title', $title); $title = $doc->createElement('Title', $title);
$link_element->appendChild($title); $link_element->appendChild($title);