--- /dev/null
+<?php
+
+require_once __DIR__ . '/db.php';
+
+function post_to_item(DOMDocument $dom, Array $post) {
+      $mime_type = $post['MIME_TYPE'];
+      $post_id = $post['ID'];
+      $post_body = $post['BODY'];
+      $timestamp = $post['TIMESTAMP'];
+      $item = $dom->createElement('item');
+      $description = $dom->createElement('description', $post_body);
+      $link = $dom->createElement('link', "https://pics.jacobcasper.com/#post-{$post_id}");
+      $guid = $dom->createElement('guid', "https://pics.jacobcasper.com/#post-{$post_id}");
+      $pub_date = $dom->createElement('pubDate', date(DATE_RSS, $timestamp));
+      // TODO write the endpoint for this
+      //$enclosure = $dom->createElement('enclosure');
+      //$enclosure->setAttribute('url', "https://pics.jacobcasper.com/pic/{$post_id}");
+      //$enclosure->setAttribute('length', "9999");
+      //$enclosure->setAttribute('type', $mime_type);
+      $item->appendChild($description);
+      //$item->appendChild($enclosure);
+      $item->appendChild($link);
+      $item->appendChild($guid);
+      $item->appendChild($pub_date);
+      return $item;
+}
+
+$rss_template = file_get_contents('rss.template.xml');
+$rss_dom = new DOMDocument();
+$rss_dom->formatOutput = true;
+$rss_dom->loadXML($rss_template);
+$channel_node = $rss_dom->firstChild->childNodes[1];
+$db = get_db();
+$posts = $db->query('SELECT
+    p.ID, p.TIMESTAMP, pi.MIME_TYPE, c.BODY
+    FROM posts p
+    JOIN pics pi on p.id = pi.post_id
+    JOIN comments c on p.id = c.post_id
+    ORDER BY p.TIMESTAMP DESC');
+while ($post = $posts->fetchArray()) {
+    $item = post_to_item($rss_dom, $post);
+    $channel_node->appendChild($item);
+}
+
+file_put_contents('rss.xml', $rss_dom->saveXML());
 
--- /dev/null
+<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
+       <channel>
+               <atom:link href="https://pics.jacobcasper.com/rss.xml" rel="self" type="application/rss+xml"/>
+               <title>Jacob's Not-gram</title>
+               <link>https://pics.jacobcasper.com</link>
+               <description>picture of JC</description>
+               <language>en-US</language>
+               <webMaster>pics-wm@jacobcasper.com (Jacob Casper)</webMaster>
+        <ttl>1440</ttl> <!-- 24 hour cache (in minutes) -->
+       </channel>
+</rss>
 
--- /dev/null
+<?php
+
+require_once __DIR__ . '/rss.php';
+assert_options(ASSERT_ACTIVE, 1);
+
+function test_post_to_item_success() {
+    $post = [
+        'MIME_TYPE' => 'image/jpeg',
+        'ID' => 'uuid-v4',
+        'BODY' => 'lorem ipsum dolor',
+        'TIMESTAMP' => '1400000000',
+    ];
+    $dom = new DOMDocument();
+    $dom->formatOutput = true;
+    $item_node = post_to_item($dom, $post);
+    var_dump($item_node);
+    $dom->appendChild($item_node);
+    var_dump($dom->saveXML($dom));
+}
+
+test_post_to_item_success();