summaryrefslogtreecommitdiffstats
path: root/atom.php
diff options
context:
space:
mode:
authorPascal Chevrel <pascal@chevrel.org>2012-05-05 22:39:34 +0200
committerPascal Chevrel <pascal@chevrel.org>2012-05-05 22:39:34 +0200
commit2c494ce0492c9b0b38c3fc989105ad7bac9c8580 (patch)
tree3cbe548c152bf19199b43f0e020161e6aecd1408 /atom.php
parent2d5084e43c0263e1257f294b3a8631776d343220 (diff)
downloadplanet-2c494ce0492c9b0b38c3fc989105ad7bac9c8580.tar
planet-2c494ce0492c9b0b38c3fc989105ad7bac9c8580.tar.gz
planet-2c494ce0492c9b0b38c3fc989105ad7bac9c8580.tar.bz2
planet-2c494ce0492c9b0b38c3fc989105ad7bac9c8580.tar.xz
planet-2c494ce0492c9b0b38c3fc989105ad7bac9c8580.zip
Issue 42: create atom.php at root, delete old 'atom10' template, update all internal links to point to the new location, put a redirect in place so as that moonmoon installs don't loose their users upon upgrading to a newer moonmoon
Diffstat (limited to 'atom.php')
-rw-r--r--atom.php66
1 files changed, 66 insertions, 0 deletions
diff --git a/atom.php b/atom.php
new file mode 100644
index 0000000..035d049
--- /dev/null
+++ b/atom.php
@@ -0,0 +1,66 @@
+<?php
+include_once(dirname(__FILE__).'/app/app.php');
+include_once(dirname(__FILE__).'/app/lib/Cache.php');
+
+//Installed ?
+if (!isset($Planet)) {
+ echo '<p>' . _g('You might want to <a href="install.php">install moonmoon</a>.') . '</p>';
+ exit;
+}
+
+//Load from cache
+$items = Array();
+if (0 < $Planet->loadOpml(dirname(__FILE__).'/custom/people.opml')) {
+ $Planet->loadFeeds();
+ $items = $Planet->getItems();
+}
+
+//Prepare output cache
+Cache::$enabled = false;
+$cache_key = (count($items)) ? $items[0]->get_id() : '';
+$last_modified = (count($items)) ? $items[0]->get_date() : '';
+$cache_duration = $PlanetConfig->getOutputTimeout()*60;
+
+Cache::setStore(dirname(__FILE__) . '/' . $conf['cachedir'] . '/');
+//Go display
+if (!isset($_GET['type']) ||
+ !is_file(dirname(__FILE__).'/custom/views/'.$_GET['type'].'/index.tpl.php') ||
+ strpos($_GET['type'], DIRECTORY_SEPARATOR)){
+ $_GET['type'] = 'default';
+}
+
+if (!OutputCache::Start($_GET['type'], $cache_key, $cache_duration)) {
+ include_once(dirname(__FILE__).'/custom/views/'.$_GET['type'].'/index.tpl.php');
+ OutputCache::End();
+}
+
+var_dump($PlanetConfig, $Planet);
+$limit = $PlanetConfig->getMaxDisplay();
+$count = 0;
+
+header('Content-Type: application/atom+xml; charset=UTF-8');
+echo '<?xml version="1.0" encoding="UTF-8" ?>';
+?><feed xmlns="http://www.w3.org/2005/Atom">
+ <title><?php echo htmlspecialchars($PlanetConfig->getName()); ?></title>
+ <subtitle><?php echo htmlspecialchars($PlanetConfig->getName()); ?></subtitle>
+ <id><?php echo $PlanetConfig->getUrl(); ?></id>
+ <link rel="self" type="application/atom+xml" href="<?php echo $PlanetConfig->getUrl(); ?>atom.php" />
+ <link rel="alternate" type="text/html" href="<?php echo $PlanetConfig->getUrl(); ?>" />
+ <updated><?php echo date("Y-m-d\TH:i:s\Z") ?></updated>
+ <author><name>Author</name></author>
+
+ <?php $count = 0; ?>
+ <?php foreach ($items as $item): ?>
+ <entry>
+ <title type="html"><?php echo htmlspecialchars($item->get_feed()->getName()); ?> : <?php echo htmlspecialchars($item->get_title());?></title>
+ <id><?php echo htmlspecialchars($item->get_permalink());?></id>
+ <link rel="alternate" href="<?php echo htmlspecialchars($item->get_permalink());?>"/>
+ <published><?php echo $item->get_date('Y-m-d\\TH:i:s+00:00'); ?></published>
+ <updated><?php echo $item->get_date('Y-m-d\\TH:i:s+00:00'); ?></updated>
+ <author><name><?php echo ($item->get_author()? $item->get_author()->get_name() : 'anonymous'); ?></name></author>
+
+ <content type="html"><![CDATA[<?php echo $item->get_content();?>]]></content>
+ </entry>
+ <?php if (++$count == $limit) { break; } ?>
+ <?php endforeach; ?>
+</feed>