2015-03-02 22:22:02 +01:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Mrss
|
|
|
|
* Documentation Source http://www.rssboard.org/media-rss
|
|
|
|
*/
|
2016-09-10 20:41:11 +02:00
|
|
|
class MrssFormat extends FormatAbstract {
|
2015-03-02 22:22:02 +01:00
|
|
|
|
2016-09-10 20:41:11 +02:00
|
|
|
public function stringify(){
|
|
|
|
$https = isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on' ? 's' : '';
|
|
|
|
$httpHost = isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : '';
|
|
|
|
$httpInfo = isset($_SERVER['PATH_INFO']) ? $_SERVER['PATH_INFO'] : '';
|
2015-03-02 22:22:02 +01:00
|
|
|
|
2016-09-10 20:41:11 +02:00
|
|
|
$serverRequestUri = $this->xml_encode($_SERVER['REQUEST_URI']);
|
2015-03-02 22:22:02 +01:00
|
|
|
|
2016-09-10 20:41:11 +02:00
|
|
|
$extraInfos = $this->getExtraInfos();
|
|
|
|
$title = $this->xml_encode($extraInfos['name']);
|
2016-09-10 21:01:02 +02:00
|
|
|
|
2017-07-29 19:28:00 +02:00
|
|
|
if(!empty($extraInfos['uri'])) {
|
2016-09-10 21:01:02 +02:00
|
|
|
$uri = $this->xml_encode($extraInfos['uri']);
|
|
|
|
} else {
|
2018-05-05 13:55:38 +01:00
|
|
|
$uri = 'https://github.com/RSS-Bridge/rss-bridge';
|
2016-09-10 21:01:02 +02:00
|
|
|
}
|
|
|
|
|
2018-06-30 10:16:16 +02:00
|
|
|
$uriparts = parse_url($uri);
|
|
|
|
$icon = $this->xml_encode($uriparts['scheme'] . '://' . $uriparts['host'] .'/favicon.ico');
|
2015-03-02 22:22:02 +01:00
|
|
|
|
2016-09-10 20:41:11 +02:00
|
|
|
$items = '';
|
2017-07-29 19:28:00 +02:00
|
|
|
foreach($this->getItems() as $item) {
|
2016-09-10 20:41:11 +02:00
|
|
|
$itemAuthor = isset($item['author']) ? $this->xml_encode($item['author']) : '';
|
|
|
|
$itemTitle = strip_tags(isset($item['title']) ? $this->xml_encode($item['title']) : '');
|
|
|
|
$itemUri = isset($item['uri']) ? $this->xml_encode($item['uri']) : '';
|
|
|
|
$itemTimestamp = isset($item['timestamp']) ? $this->xml_encode(date(DATE_RFC2822, $item['timestamp'])) : '';
|
|
|
|
$itemContent = isset($item['content']) ? $this->xml_encode($this->sanitizeHtml($item['content'])) : '';
|
2016-11-09 18:59:17 +01:00
|
|
|
|
2016-11-12 22:04:42 +01:00
|
|
|
$entryEnclosuresWarning = '';
|
|
|
|
$entryEnclosures = '';
|
2017-07-29 19:28:00 +02:00
|
|
|
if(isset($item['enclosures'])) {
|
2016-11-12 22:04:42 +01:00
|
|
|
$entryEnclosures .= '<enclosure url="'
|
|
|
|
. $this->xml_encode($item['enclosures'][0])
|
|
|
|
. '"/>';
|
|
|
|
|
2017-07-29 19:28:00 +02:00
|
|
|
if(count($item['enclosures']) > 1) {
|
2016-11-12 22:04:42 +01:00
|
|
|
$entryEnclosures .= PHP_EOL;
|
|
|
|
$entryEnclosuresWarning = '<br>Warning:
|
|
|
|
Some media files might not be shown to you. Consider using the ATOM format instead!';
|
2017-07-29 19:28:00 +02:00
|
|
|
foreach($item['enclosures'] as $enclosure) {
|
2016-11-12 22:04:42 +01:00
|
|
|
$entryEnclosures .= '<atom:link rel="enclosure" href="'
|
|
|
|
. $enclosure . '" />'
|
|
|
|
. PHP_EOL;
|
|
|
|
}
|
|
|
|
}
|
2016-11-09 18:59:17 +01:00
|
|
|
}
|
|
|
|
|
2016-09-10 20:41:11 +02:00
|
|
|
$items .= <<<EOD
|
2015-03-02 22:22:02 +01:00
|
|
|
|
2016-09-10 20:41:11 +02:00
|
|
|
<item>
|
|
|
|
<title>{$itemTitle}</title>
|
|
|
|
<link>{$itemUri}</link>
|
|
|
|
<guid isPermaLink="true">{$itemUri}</guid>
|
|
|
|
<pubDate>{$itemTimestamp}</pubDate>
|
2016-11-12 22:04:42 +01:00
|
|
|
<description>{$itemContent}{$entryEnclosuresWarning}</description>
|
2016-09-10 20:41:11 +02:00
|
|
|
<author>{$itemAuthor}</author>
|
2016-11-12 22:04:42 +01:00
|
|
|
{$entryEnclosures}
|
2016-09-10 20:41:11 +02:00
|
|
|
</item>
|
2015-03-02 22:22:02 +01:00
|
|
|
|
|
|
|
EOD;
|
2016-09-10 20:41:11 +02:00
|
|
|
}
|
2015-03-02 22:22:02 +01:00
|
|
|
|
2016-11-07 20:49:44 +01:00
|
|
|
$charset = $this->getCharset();
|
|
|
|
|
2016-09-10 20:41:11 +02:00
|
|
|
/* Data are prepared, now let's begin the "MAGIE !!!" */
|
2016-11-07 20:49:44 +01:00
|
|
|
$toReturn = <<<EOD
|
|
|
|
<?xml version="1.0" encoding="{$charset}"?>
|
|
|
|
<rss version="2.0"
|
|
|
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
|
|
|
xmlns:media="http://search.yahoo.com/mrss/"
|
2016-09-10 21:01:02 +02:00
|
|
|
xmlns:atom="http://www.w3.org/2005/Atom">
|
2016-09-10 20:41:11 +02:00
|
|
|
<channel>
|
|
|
|
<title>{$title}</title>
|
|
|
|
<link>http{$https}://{$httpHost}{$httpInfo}/</link>
|
|
|
|
<description>{$title}</description>
|
|
|
|
<image url="{$icon}" title="{$title}" link="{$uri}"/>
|
|
|
|
<atom:link rel="alternate" type="text/html" href="{$uri}" />
|
|
|
|
<atom:link rel="self" href="http{$https}://{$httpHost}{$serverRequestUri}" />
|
|
|
|
{$items}
|
|
|
|
</channel>
|
2015-03-02 22:22:02 +01:00
|
|
|
</rss>
|
|
|
|
EOD;
|
|
|
|
|
2016-09-10 20:41:11 +02:00
|
|
|
// Remove invalid non-UTF8 characters
|
|
|
|
ini_set('mbstring.substitute_character', 'none');
|
2016-11-07 20:49:44 +01:00
|
|
|
$toReturn = mb_convert_encoding($toReturn, $this->getCharset(), 'UTF-8');
|
2016-09-10 20:41:11 +02:00
|
|
|
return $toReturn;
|
|
|
|
}
|
2015-03-02 22:22:02 +01:00
|
|
|
|
2016-09-10 20:41:11 +02:00
|
|
|
public function display(){
|
|
|
|
$this
|
2016-11-07 20:49:44 +01:00
|
|
|
->setContentType('application/rss+xml; charset=' . $this->getCharset())
|
2016-09-10 20:41:11 +02:00
|
|
|
->callContentType();
|
2015-03-02 22:22:02 +01:00
|
|
|
|
2016-09-10 20:41:11 +02:00
|
|
|
return parent::display();
|
|
|
|
}
|
2016-08-09 17:05:29 +02:00
|
|
|
|
2016-09-10 20:41:11 +02:00
|
|
|
private function xml_encode($text){
|
|
|
|
return htmlspecialchars($text, ENT_XML1);
|
|
|
|
}
|
2015-03-02 22:22:02 +01:00
|
|
|
}
|