aboutsummaryrefslogtreecommitdiff
path: root/formats
diff options
context:
space:
mode:
Diffstat (limited to 'formats')
-rw-r--r--formats/AtomFormat.php113
-rw-r--r--formats/HtmlFormat.php85
-rw-r--r--formats/JsonFormat.php23
-rw-r--r--formats/MrssFormat.php106
-rw-r--r--formats/PlaintextFormat.php24
5 files changed, 175 insertions, 176 deletions
diff --git a/formats/AtomFormat.php b/formats/AtomFormat.php
index 238dc884..fd2016bc 100644
--- a/formats/AtomFormat.php
+++ b/formats/AtomFormat.php
@@ -1,79 +1,80 @@
<?php
/**
* Atom
-* Documentation Source http://en.wikipedia.org/wiki/Atom_%28standard%29 and http://tools.ietf.org/html/rfc4287
+* Documentation Source http://en.wikipedia.org/wiki/Atom_%28standard%29 and
+* http://tools.ietf.org/html/rfc4287
*/
class AtomFormat extends FormatAbstract{
- 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'] : '';
+ 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'] : '';
- $serverRequestUri = $this->xml_encode($_SERVER['REQUEST_URI']);
+ $serverRequestUri = $this->xml_encode($_SERVER['REQUEST_URI']);
- $extraInfos = $this->getExtraInfos();
- $title = $this->xml_encode($extraInfos['name']);
- $uri = !empty($extraInfos['uri']) ? $extraInfos['uri'] : 'https://github.com/sebsauvage/rss-bridge';
- $icon = $this->xml_encode('http://icons.better-idea.org/icon?url='. $uri .'&size=64');
- $uri = $this->xml_encode($uri);
+ $extraInfos = $this->getExtraInfos();
+ $title = $this->xml_encode($extraInfos['name']);
+ $uri = !empty($extraInfos['uri']) ? $extraInfos['uri'] : 'https://github.com/sebsauvage/rss-bridge';
+ $icon = $this->xml_encode('http://icons.better-idea.org/icon?url='. $uri .'&size=64');
+ $uri = $this->xml_encode($uri);
- $entries = '';
- foreach($this->getItems() as $item){
- $entryAuthor = isset($item['author']) ? $this->xml_encode($item['author']) : '';
- $entryTitle = isset($item['title']) ? $this->xml_encode($item['title']) : '';
- $entryUri = isset($item['uri']) ? $this->xml_encode($item['uri']) : '';
- $entryTimestamp = isset($item['timestamp']) ? $this->xml_encode(date(DATE_ATOM, $item['timestamp'])) : '';
- $entryContent = isset($item['content']) ? $this->xml_encode($this->sanitizeHtml($item['content'])) : '';
- $entries .= <<<EOD
+ $entries = '';
+ foreach($this->getItems() as $item){
+ $entryAuthor = isset($item['author']) ? $this->xml_encode($item['author']) : '';
+ $entryTitle = isset($item['title']) ? $this->xml_encode($item['title']) : '';
+ $entryUri = isset($item['uri']) ? $this->xml_encode($item['uri']) : '';
+ $entryTimestamp = isset($item['timestamp']) ? $this->xml_encode(date(DATE_ATOM, $item['timestamp'])) : '';
+ $entryContent = isset($item['content']) ? $this->xml_encode($this->sanitizeHtml($item['content'])) : '';
+ $entries .= <<<EOD
- <entry>
- <author>
- <name>{$entryAuthor}</name>
- </author>
- <title type="html"><![CDATA[{$entryTitle}]]></title>
- <link rel="alternate" type="text/html" href="{$entryUri}" />
- <id>{$entryUri}</id>
- <updated>{$entryTimestamp}</updated>
- <content type="html">{$entryContent}</content>
- </entry>
+ <entry>
+ <author>
+ <name>{$entryAuthor}</name>
+ </author>
+ <title type="html"><![CDATA[{$entryTitle}]]></title>
+ <link rel="alternate" type="text/html" href="{$entryUri}" />
+ <id>{$entryUri}</id>
+ <updated>{$entryTimestamp}</updated>
+ <content type="html">{$entryContent}</content>
+ </entry>
EOD;
- }
+ }
- $feedTimestamp = date(DATE_ATOM, time());
+ $feedTimestamp = date(DATE_ATOM, time());
- /* Data are prepared, now let's begin the "MAGIE !!!" */
- $toReturn = '<?xml version="1.0" encoding="UTF-8"?>';
- $toReturn .= <<<EOD
+ /* Data are prepared, now let's begin the "MAGIE !!!" */
+ $toReturn = '<?xml version="1.0" encoding="UTF-8"?>';
+ $toReturn .= <<<EOD
<feed xmlns="http://www.w3.org/2005/Atom" xmlns:thr="http://purl.org/syndication/thread/1.0" xml:lang="en-US">
- <title type="text">{$title}</title>
- <id>http{$https}://{$httpHost}{$httpInfo}/</id>
- <icon>{$icon}</icon>
- <logo>{$icon}</logo>
- <updated>{$feedTimestamp}</updated>
- <link rel="alternate" type="text/html" href="{$uri}" />
- <link rel="self" href="http{$https}://{$httpHost}{$serverRequestUri}" />
+ <title type="text">{$title}</title>
+ <id>http{$https}://{$httpHost}{$httpInfo}/</id>
+ <icon>{$icon}</icon>
+ <logo>{$icon}</logo>
+ <updated>{$feedTimestamp}</updated>
+ <link rel="alternate" type="text/html" href="{$uri}" />
+ <link rel="self" href="http{$https}://{$httpHost}{$serverRequestUri}" />
{$entries}
</feed>
EOD;
-
- // Remove invalid non-UTF8 characters
- ini_set('mbstring.substitute_character', 'none');
- $toReturn= mb_convert_encoding($toReturn, 'UTF-8', 'UTF-8');
- return $toReturn;
- }
- public function display(){
- $this
- ->setContentType('application/atom+xml; charset=UTF-8')
- ->callContentType();
+ // Remove invalid non-UTF8 characters
+ ini_set('mbstring.substitute_character', 'none');
+ $toReturn = mb_convert_encoding($toReturn, 'UTF-8', 'UTF-8');
+ return $toReturn;
+ }
- return parent::display();
- }
+ public function display(){
+ $this
+ ->setContentType('application/atom+xml; charset=UTF-8')
+ ->callContentType();
- private function xml_encode($text) {
- return htmlspecialchars($text, ENT_XML1);
- }
+ return parent::display();
+ }
+
+ private function xml_encode($text){
+ return htmlspecialchars($text, ENT_XML1);
+ }
}
diff --git a/formats/HtmlFormat.php b/formats/HtmlFormat.php
index d7c927b0..1001acfc 100644
--- a/formats/HtmlFormat.php
+++ b/formats/HtmlFormat.php
@@ -1,63 +1,62 @@
<?php
-class HtmlFormat extends FormatAbstract{
-
- public function stringify(){
- $extraInfos = $this->getExtraInfos();
- $title = htmlspecialchars($extraInfos['name']);
- $uri = htmlspecialchars($extraInfos['uri']);
- $atomquery = str_replace('format=Html', 'format=Atom', htmlentities($_SERVER['QUERY_STRING']));
- $mrssquery = str_replace('format=Html', 'format=Mrss', htmlentities($_SERVER['QUERY_STRING']));
-
- $entries = '';
- foreach($this->getItems() as $item){
- $entryAuthor = isset($item['author']) ? '<br /><p class="author">by: ' . $item['author'] . '</p>' : '';
- $entryTitle = isset($item['title']) ? $this->sanitizeHtml(strip_tags($item['title'])) : '';
- $entryUri = isset($item['uri']) ? $item['uri'] : $uri;
- $entryTimestamp = isset($item['timestamp']) ? '<time datetime="' . date(DATE_ATOM, $item['timestamp']) . '">' . date(DATE_ATOM, $item['timestamp']) . '</time>' : '';
- $entryContent = isset($item['content']) ? '<div class="content">' . $this->sanitizeHtml($item['content']). '</div>' : '';
- $entries .= <<<EOD
+class HtmlFormat extends FormatAbstract {
+
+ public function stringify(){
+ $extraInfos = $this->getExtraInfos();
+ $title = htmlspecialchars($extraInfos['name']);
+ $uri = htmlspecialchars($extraInfos['uri']);
+ $atomquery = str_replace('format=Html', 'format=Atom', htmlentities($_SERVER['QUERY_STRING']));
+ $mrssquery = str_replace('format=Html', 'format=Mrss', htmlentities($_SERVER['QUERY_STRING']));
+
+ $entries = '';
+ foreach($this->getItems() as $item){
+ $entryAuthor = isset($item['author']) ? '<br /><p class="author">by: ' . $item['author'] . '</p>' : '';
+ $entryTitle = isset($item['title']) ? $this->sanitizeHtml(strip_tags($item['title'])) : '';
+ $entryUri = isset($item['uri']) ? $item['uri'] : $uri;
+ $entryTimestamp = isset($item['timestamp']) ? '<time datetime="' . date(DATE_ATOM, $item['timestamp']) . '">' . date(DATE_ATOM, $item['timestamp']) . '</time>' : '';
+ $entryContent = isset($item['content']) ? '<div class="content">' . $this->sanitizeHtml($item['content']). '</div>' : '';
+ $entries .= <<<EOD
<section class="feeditem">
- <h2><a class="itemtitle" href="{$entryUri}">{$entryTitle}</a></h2>
- {$entryTimestamp}
- {$entryAuthor}
- {$entryContent}
+ <h2><a class="itemtitle" href="{$entryUri}">{$entryTitle}</a></h2>
+ {$entryTimestamp}
+ {$entryAuthor}
+ {$entryContent}
</section>
EOD;
- }
+ }
-
- /* Data are prepared, now let's begin the "MAGIE !!!" */
- $toReturn = <<<EOD
+ /* Data are prepared, now let's begin the "MAGIE !!!" */
+ $toReturn = <<<EOD
<!DOCTYPE html>
<html>
<head>
- <meta charset="UTF-8">
- <title>{$title}</title>
- <link href="css/HtmlFormat.css" rel="stylesheet">
- <meta name="robots" content="noindex, follow">
+ <meta charset="UTF-8">
+ <title>{$title}</title>
+ <link href="css/HtmlFormat.css" rel="stylesheet">
+ <meta name="robots" content="noindex, follow">
</head>
<body>
- <h1 class="pagetitle"><a href="{$uri}" target="_blank">{$title}</a></h1>
- <div class="buttons">
- <a href="./#bridge-{$_GET['bridge']}"><button class="backbutton">← back to rss-bridge</button></a>
- <a href="./?{$atomquery}"><button class="rss-feed">RSS feed (ATOM)</button></a>
- <a href="./?{$mrssquery}"><button class="rss-feed">RSS feed (MRSS)</button></a>
- </div>
+ <h1 class="pagetitle"><a href="{$uri}" target="_blank">{$title}</a></h1>
+ <div class="buttons">
+ <a href="./#bridge-{$_GET['bridge']}"><button class="backbutton">← back to rss-bridge</button></a>
+ <a href="./?{$atomquery}"><button class="rss-feed">RSS feed (ATOM)</button></a>
+ <a href="./?{$mrssquery}"><button class="rss-feed">RSS feed (MRSS)</button></a>
+ </div>
{$entries}
</body>
</html>
EOD;
- return $toReturn;
- }
+ return $toReturn;
+ }
- public function display() {
- $this
- ->setContentType('text/html; charset=' . $this->getCharset())
- ->callContentType();
+ public function display() {
+ $this
+ ->setContentType('text/html; charset=' . $this->getCharset())
+ ->callContentType();
- return parent::display();
- }
+ return parent::display();
+ }
}
diff --git a/formats/JsonFormat.php b/formats/JsonFormat.php
index e173f230..ac6e450a 100644
--- a/formats/JsonFormat.php
+++ b/formats/JsonFormat.php
@@ -3,19 +3,18 @@
* Json
* Builds a JSON string from $this->items and return it to browser.
*/
-class JsonFormat extends FormatAbstract{
+class JsonFormat extends FormatAbstract {
- public function stringify(){
- $items = $this->getItems();
+ public function stringify(){
+ $items = $this->getItems();
+ return json_encode($items, JSON_PRETTY_PRINT);
+ }
- return json_encode($items, JSON_PRETTY_PRINT);
- }
+ public function display(){
+ $this
+ ->setContentType('application/json')
+ ->callContentType();
- public function display(){
- $this
- ->setContentType('application/json')
- ->callContentType();
-
- return parent::display();
- }
+ return parent::display();
+ }
}
diff --git a/formats/MrssFormat.php b/formats/MrssFormat.php
index ddbd5d35..fddbf0ac 100644
--- a/formats/MrssFormat.php
+++ b/formats/MrssFormat.php
@@ -3,72 +3,72 @@
* Mrss
* Documentation Source http://www.rssboard.org/media-rss
*/
-class MrssFormat extends FormatAbstract{
+class MrssFormat extends FormatAbstract {
- 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'] : '';
+ 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'] : '';
- $serverRequestUri = $this->xml_encode($_SERVER['REQUEST_URI']);
+ $serverRequestUri = $this->xml_encode($_SERVER['REQUEST_URI']);
- $extraInfos = $this->getExtraInfos();
- $title = $this->xml_encode($extraInfos['name']);
- $uri = $this->xml_encode(!empty($extraInfos['uri']) ? $extraInfos['uri'] : 'https://github.com/sebsauvage/rss-bridge');
- $icon = $this->xml_encode('http://icons.better-idea.org/icon?url='. $uri .'&size=64');
+ $extraInfos = $this->getExtraInfos();
+ $title = $this->xml_encode($extraInfos['name']);
+ $uri = $this->xml_encode(!empty($extraInfos['uri']) ? $extraInfos['uri'] : 'https://github.com/sebsauvage/rss-bridge');
+ $icon = $this->xml_encode('http://icons.better-idea.org/icon?url='. $uri .'&size=64');
- $items = '';
- foreach($this->getItems() as $item){
- $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'])) : '';
- $items .= <<<EOD
+ $items = '';
+ foreach($this->getItems() as $item){
+ $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'])) : '';
+ $items .= <<<EOD
- <item>
- <title>{$itemTitle}</title>
- <link>{$itemUri}</link>
- <guid isPermaLink="true">{$itemUri}</guid>
- <pubDate>{$itemTimestamp}</pubDate>
- <description>{$itemContent}</description>
- <author>{$itemAuthor}</author>
- </item>
+ <item>
+ <title>{$itemTitle}</title>
+ <link>{$itemUri}</link>
+ <guid isPermaLink="true">{$itemUri}</guid>
+ <pubDate>{$itemTimestamp}</pubDate>
+ <description>{$itemContent}</description>
+ <author>{$itemAuthor}</author>
+ </item>
EOD;
- }
+ }
- /* Data are prepared, now let's begin the "MAGIE !!!" */
- $toReturn = '<?xml version="1.0" encoding="UTF-8"?>';
- $toReturn .= <<<EOD
+ /* Data are prepared, now let's begin the "MAGIE !!!" */
+ $toReturn = '<?xml version="1.0" encoding="UTF-8"?>';
+ $toReturn .= <<<EOD
<rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:media="http://search.yahoo.com/mrss/" xmlns:atom="http://www.w3.org/2005/Atom">
- <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>
+ <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>
</rss>
EOD;
- // Remove invalid non-UTF8 characters
- ini_set('mbstring.substitute_character', 'none');
- $toReturn= mb_convert_encoding($toReturn, 'UTF-8', 'UTF-8');
- return $toReturn;
- }
+ // Remove invalid non-UTF8 characters
+ ini_set('mbstring.substitute_character', 'none');
+ $toReturn = mb_convert_encoding($toReturn, 'UTF-8', 'UTF-8');
+ return $toReturn;
+ }
- public function display(){
- $this
- ->setContentType('application/rss+xml; charset=UTF-8')
- ->callContentType();
+ public function display(){
+ $this
+ ->setContentType('application/rss+xml; charset=UTF-8')
+ ->callContentType();
- return parent::display();
- }
+ return parent::display();
+ }
- private function xml_encode($text) {
- return htmlspecialchars($text, ENT_XML1);
- }
+ private function xml_encode($text){
+ return htmlspecialchars($text, ENT_XML1);
+ }
}
diff --git a/formats/PlaintextFormat.php b/formats/PlaintextFormat.php
index e2cf0b94..593e938d 100644
--- a/formats/PlaintextFormat.php
+++ b/formats/PlaintextFormat.php
@@ -3,18 +3,18 @@
* Plaintext
* Returns $this->items as raw php data.
*/
-class PlaintextFormat extends FormatAbstract{
+class PlaintextFormat extends FormatAbstract {
- public function stringify(){
- $items = $this->getItems();
- return print_r($items, true);
- }
+ public function stringify(){
+ $items = $this->getItems();
+ return print_r($items, true);
+ }
- public function display(){
- $this
- ->setContentType('text/plain;charset=' . $this->getCharset())
- ->callContentType();
+ public function display(){
+ $this
+ ->setContentType('text/plain;charset=' . $this->getCharset())
+ ->callContentType();
- return parent::display();
- }
-} \ No newline at end of file
+ return parent::display();
+ }
+}