]> git.r.bdr.sh - rbdr/blog/blobdiff - lib/archivers/gemlog.js
Add archive publishing
[rbdr/blog] / lib / archivers / gemlog.js
index d50d411bc8af23a4ff7777181cabc7c72cb3bcfd..50bb33407c7da12fc2f0356c9eb3af15d188c670 100644 (file)
@@ -1,20 +1,36 @@
 const { mkdir, readdir, rm, writeFile } = require('fs/promises');
 const { debuglog, promisify } = require('util');
 const { ncp } = require('ncp');
-const { join } = require('path');
+const { resolve, join } = require('path');
 
 const internals = {
-  kArchiveName: '.gemlog',
+  kArchiveName: resolve(join(__dirname, '../..', '.gemlog')),
   kIndexName: 'index.gmi',
   kGeminiRe: /\.gmi$/i,
 
   ncp: promisify(ncp),
   debuglog: debuglog('blog'),
+
+  buildUrl(id, slug) {
+    return `./${id}/${slug}`;
+  },
+
+  buildTitle (id, slug) {
+    const date = new Date(Number(id));
+    const shortDate = date.toISOString().split('T')[0]
+    const title = slug.split('-').join(' ');
+    return `${shortDate} ${title}`
+  },
+
+  buildLink(id, slug) {
+    return `=> ${internals.buildUrl(id,slug)} ${internals.buildTitle(id,slug)}`;
+  }
 };
 
 module.exports = async function(archiveDirectory) {
   internals.debuglog(`Reading archive ${archiveDirectory}`);
-  const postIds = await readdir(archiveDirectory)
+  const postIds = (await readdir(archiveDirectory))
+    .sort((a, b) => Number(b) - Number(a));
   const posts = [];
   for (const id of postIds) {
     const postDirectory = join(archiveDirectory, id);
@@ -26,8 +42,14 @@ module.exports = async function(archiveDirectory) {
 
   internals.debuglog(`Read ${posts.length} posts`);
 
-  const index = ['# Unlimited Pizza Gemlog Archive', '',
-    ...posts.map((post) => `=> ./${post.id}/${post.slug}`)].join('\n');
+  const index = [
+    '# Unlimited Pizza Gemlog Archive', '',
+    '=> https://blog.unlimited.pizza/feed.xml ðŸ“° RSS Feed',
+    '=> https://blog.unlimited.pizza/index.txt ðŸ“‘ http text version (latest 3 posts)',
+    '',
+    ...posts.map((post) => internals.buildLink(post.id, post.slug)),
+    '', '=> ../ ðŸŠī Back to main page'
+  ].join('\n');
 
   try {
     internals.debuglog('Removing index');