X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=lib%2Frssaction.php;h=e8a3aca70bd3ea500ce9ba1b76feded45dfce064;hb=00a6f3d01510e01a5dcc0999a50fba7bafbcd5e1;hp=6409b1b934bcaa5a64671bdb7ce436af61ff1285;hpb=40b73c829f628f3ce1086ccd7a6e3341631aee34;p=quix0rs-gnu-social.git diff --git a/lib/rssaction.php b/lib/rssaction.php index 6409b1b934..e8a3aca70b 100644 --- a/lib/rssaction.php +++ b/lib/rssaction.php @@ -21,11 +21,11 @@ if (!defined('LACONICA')) { exit(1); } define('DEFAULT_RSS_LIMIT', 48); -# This will contain the details of each feed item's author and be used to generate SIOC data. -$creators = array(); - class Rss10Action extends Action { + # This will contain the details of each feed item's author and be used to generate SIOC data. + var $creators = array(); + function handle($args) { parent::handle($args); $limit = (int) $this->trimmed('limit'); @@ -75,7 +75,6 @@ class Rss10Action extends Action { } function show_channel($notices) { - global $config; $channel = $this->get_channel(); $image = $this->get_image(); @@ -84,7 +83,7 @@ class Rss10Action extends Action { common_element('title', NULL, $channel['title']); common_element('link', NULL, $channel['link']); common_element('description', NULL, $channel['description']); - common_element('cc:licence', array('rdf:resource' => $config['license']['url'])); + common_element('cc:licence', array('rdf:resource' => common_config('license','url'))); if ($image) { common_element('image', array('rdf:resource' => $image)); @@ -116,9 +115,9 @@ class Rss10Action extends Action { } function show_item($notice) { - global $config, $creators; $profile = Profile::staticGet($notice->profile_id); $nurl = common_local_url('shownotice', array('notice' => $notice->id)); + $creator_uri = common_profile_uri($profile); common_element_start('item', array('rdf:about' => $notice->uri)); $title = $profile->nickname . ': ' . $notice->content; common_element('title', NULL, $title); @@ -126,41 +125,31 @@ class Rss10Action extends Action { common_element('description', NULL, $profile->nickname."'s status on ".common_exact_date($notice->created)); common_element('dc:date', NULL, common_date_w3dtf($notice->created)); common_element('dc:creator', NULL, ($profile->fullname) ? $profile->fullname : $profile->nickname); - common_element('sioc:has_creator', array('rdf:resource' => - common_local_url('userbyid', array('id' => $profile->id)) - )); - common_element('cc:licence', array('rdf:resource' => $config['license']['url'])); + common_element('sioc:has_creator', array('rdf:resource' => $creator_uri)); + common_element('laconica:postIcon', array('rdf:resource' => common_profile_avatar_url($profile))); + common_element('cc:licence', array('rdf:resource' => common_config('license', 'url'))); common_element_end('item'); - $creators[$nurl] = $profile; + $this->creators[$creator_uri] = $profile; } function show_creators() { - global $creators; - - foreach ($creators as $nurl => $profile) { + foreach ($this->creators as $uri => $profile) { $id = $profile->id; $nickname = $profile->nickname; - common_element_start('sioc:User', array('rdf:about' => - common_local_url('userbyid', array('id' => $id)) - )); + common_element_start('sioc:User', array('rdf:about' => $uri)); common_element('foaf:nick', NULL, $nickname); if ($profile->fullname) { common_element('foaf:name', NULL, $profile->fullname); } common_element('sioc:id', NULL, $id); - common_element('sioc:avatar', array('rdf:resource' => - common_local_url('avatarbynickname', - array('nickname' => $nickname, - 'size' => 48 - )) - )); + $avatar = common_profile_avatar_url($profile); + common_element('sioc:avatar', array('rdf:resource' => $avatar)); common_element_end('sioc:User'); } } function init_rss() { - global $config; $channel = $this->get_channel(); header('Content-Type: application/rdf+xml'); @@ -178,11 +167,12 @@ class Rss10Action extends Action { 'http://rdfs.org/sioc/ns#', 'xmlns:sioct' => 'http://rdfs.org/sioc/types#', + 'xmlns:laconica' => + 'http://laconi.ca/ont/', 'xmlns' => 'http://purl.org/rss/1.0/')); - common_element_start('sioc:Site', array('rdf:about' => - 'http://identi.ca/')); - common_element('sioc:name', NULL, $config['site']['name']); + common_element_start('sioc:Site', array('rdf:about' => common_root_url())); + common_element('sioc:name', NULL, common_config('site', 'name')); common_element_start('sioc:container_of'); common_element('sioc:Container', array('rdf:about' => $channel['url']));