diff options
author | Zach Copley <zach@status.net> | 2010-02-02 08:47:14 +0000 |
---|---|---|
committer | Zach Copley <zach@status.net> | 2010-02-02 08:47:14 +0000 |
commit | 5e90f744a6fb58c43f8f5332ef868ba38e82b3d1 (patch) | |
tree | 30d17875812abd0040fbfa26ebea41de6ded6e50 | |
parent | c03883fc88c678e62e02d201cb74b862b108188a (diff) |
Linkify notice source when posting from registered OAuth apps
-rw-r--r-- | lib/api.php | 19 | ||||
-rw-r--r-- | lib/noticelist.php | 20 |
2 files changed, 36 insertions, 3 deletions
diff --git a/lib/api.php b/lib/api.php index 987f2cc1b..7d94eaee4 100644 --- a/lib/api.php +++ b/lib/api.php @@ -1250,10 +1250,27 @@ class ApiAction extends Action case 'api': break; default: + + $name = null; + $url = null; + $ns = Notice_source::staticGet($source); + if ($ns) { - $source_name = '<a href="' . $ns->url . '">' . $ns->name . '</a>'; + $name = $ns->name; + $url = $ns->url; + } else { + $app = Oauth_application::staticGet('name', $source); + if ($app) { + $name = $app->name; + $url = $app->source_url; + } + } + + if (!empty($name) && !empty($url)) { + $source_name = '<a href="' . $url . '">' . $name . '</a>'; } + break; } return $source_name; diff --git a/lib/noticelist.php b/lib/noticelist.php index 85c169716..a4a0f2651 100644 --- a/lib/noticelist.php +++ b/lib/noticelist.php @@ -486,12 +486,28 @@ class NoticeListItem extends Widget $this->out->element('span', 'device', $source_name); break; default: + + $name = null; + $url = null; + $ns = Notice_source::staticGet($this->notice->source); + if ($ns) { + $name = $ns->name; + $url = $ns->url; + } else { + $app = Oauth_application::staticGet('name', $this->notice->source); + if ($app) { + $name = $app->name; + $url = $app->source_url; + } + } + + if (!empty($name) && !empty($url)) { $this->out->elementStart('span', 'device'); - $this->out->element('a', array('href' => $ns->url, + $this->out->element('a', array('href' => $url, 'rel' => 'external'), - $ns->name); + $name); $this->out->elementEnd('span'); } else { $this->out->element('span', 'device', $source_name); |