Twitter-compatible API - rss and atom feeds for direct messages

darcs-hash:20080926012015-7b5ce-da94465ff9c027183e0e674b6152902c302d0131.gz
This commit is contained in:
Zach Copley 2008-09-25 21:20:15 -04:00
parent d687f16525
commit 10f4ee7abb
3 changed files with 112 additions and 30 deletions

View File

@ -63,18 +63,24 @@ class Twitapidirect_messagesAction extends TwitterapiAction {
$message->find(); $message->find();
$title = 'Direct messages to ' . $user->nickname;
$subtitle = 'All the direct messages sent to ' . $user->nickname;
$server = common_root_url();
$link = $server . $user->nickname . '/inbox';
switch($apidata['content-type']) { switch($apidata['content-type']) {
case 'xml': case 'xml':
$this->show_xml_direct_messages($message); $this->show_xml_dmsgs($message);
break; break;
case 'rss': case 'rss':
//$this->show_rss_timeline($notice, $title, $id, $link, $subtitle); $this->show_rss_dmsgs($message, $title, $link, $subtitle);
break; break;
case 'atom': case 'atom':
//$this->show_atom_timeline($notice, $title, $id, $link, $subtitle); $this->show_atom_dmsgs($message, $title, $link, $subtitle);
break; break;
case 'json': case 'json':
$this->show_json_direct_messages($message); $this->show_json_dmsgs($message);
break; break;
default: default:
common_user_error(_('API method not found!'), $code = 404); common_user_error(_('API method not found!'), $code = 404);
@ -102,7 +108,7 @@ class Twitapidirect_messagesAction extends TwitterapiAction {
exit(); exit();
} }
function show_xml_direct_messages($message) { function show_xml_dmsgs($message) {
$this->init_document('xml'); $this->init_document('xml');
common_element_start('direct-messages', array('type' => 'array')); common_element_start('direct-messages', array('type' => 'array'));
@ -123,7 +129,7 @@ class Twitapidirect_messagesAction extends TwitterapiAction {
$this->end_document('xml'); $this->end_document('xml');
} }
function show_json_direct_messages($message) { function show_json_dmsgs($message) {
$this->init_document('json'); $this->init_document('json');
@ -146,6 +152,59 @@ class Twitapidirect_messagesAction extends TwitterapiAction {
$this->end_document('json'); $this->end_document('json');
} }
function show_rss_dmsgs($message, $title, $link, $subtitle) {
$this->init_document('rss');
common_element_start('channel');
common_element('title', NULL, $title);
common_element('link', NULL, $link);
common_element('description', NULL, $subtitle);
common_element('language', NULL, 'en-us');
common_element('ttl', NULL, '40');
if (is_array($message)) {
foreach ($message as $m) {
$entry = $this->twitter_rss_dmsg_array($m);
$this->show_twitter_rss_item($entry);
}
} else {
while ($message->fetch()) {
$entry = $this->twitter_rss_dmsg_array($message);
$this->show_twitter_rss_item($entry);
}
}
common_element_end('channel');
$this->end_twitter_rss();
}
function show_atom_dmsgs($message, $title, $link, $subtitle) {
$this->init_document('atom');
common_element('title', NULL, $title);
$siteserver = common_config('site', 'server');
common_element('id', NULL, "tag:$siteserver,2008:DirectMessage");
common_element('link', array('href' => $link, 'rel' => 'alternate', 'type' => 'text/html'), NULL);
common_element('updated', NULL, common_date_iso8601(strftime('%c')));
common_element('subtitle', NULL, $subtitle);
if (is_array($message)) {
foreach ($message as $m) {
$entry = $this->twitter_rss_dmsg_array($m);
$this->show_twitter_atom_entry($entry);
}
} else {
while ($message->fetch()) {
$entry = $this->twitter_rss_dmsg_array($message);
$this->show_twitter_atom_entry($entry);
}
}
$this->end_document('atom');
}
} }

View File

@ -66,7 +66,7 @@ class TwitapistatusesAction extends TwitterapiAction {
$this->show_xml_timeline($notice); $this->show_xml_timeline($notice);
break; break;
case 'rss': case 'rss':
$this->show_rss_timeline($notice, $title, $id, $link, $subtitle); $this->show_rss_timeline($notice, $title, $link, $subtitle);
break; break;
case 'atom': case 'atom':
$this->show_atom_timeline($notice, $title, $id, $link, $subtitle); $this->show_atom_timeline($notice, $title, $id, $link, $subtitle);
@ -107,7 +107,7 @@ class TwitapistatusesAction extends TwitterapiAction {
$this->end_document('xml'); $this->end_document('xml');
} }
function show_rss_timeline($notice, $title, $id, $link, $subtitle) { function show_rss_timeline($notice, $title, $link, $subtitle) {
$this->init_document('rss'); $this->init_document('rss');

View File

@ -85,9 +85,9 @@ class TwitterapiAction extends Action {
$entry['content'] = $profile->nickname . ': ' . $notice->content; $entry['content'] = $profile->nickname . ': ' . $notice->content;
$entry['title'] = $entry['content']; $entry['title'] = $entry['content'];
$entry['link'] = common_local_url('shownotice', array('notice' => $notice->id));; $entry['link'] = common_local_url('shownotice', array('notice' => $notice->id));
$entry['published'] = common_date_iso8601($notice->created); $entry['published'] = common_date_iso8601($notice->created);
$entry['id'] = "tag:$server,$entry[published]:$entry[link]"; $entry['id'] = "tag:$server,2008:$entry[link]";
$entry['updated'] = $entry['published']; $entry['updated'] = $entry['published'];
# RSS Item specific # RSS Item specific
@ -98,6 +98,29 @@ class TwitterapiAction extends Action {
return $entry; return $entry;
} }
function twitter_rss_dmsg_array($message) {
$server = common_config('site', 'server');
$entry = array();
$entry['title'] = sprintf('Message from %s to %s',
$message->getFrom()->nickname, $message->getTo()->nickname);
$entry['content'] = $message->content;
$entry['link'] = $message->uri;
$entry['published'] = common_date_iso8601($message->created);
$entry['id'] = "tag:$server,2008:$entry[link]";
$entry['updated'] = $entry['published'];
# RSS Item specific
$entry['description'] = $message->content;
$entry['pubDate'] = common_date_rfc2822($message->created);
$entry['guid'] = $entry['link'];
return $entry;
}
function twitter_dm_array($message) { function twitter_dm_array($message) {
$twitter_dm = array(); $twitter_dm = array();