+++ /dev/null
-const { mkdir, readdir, rm, writeFile } = require('fs/promises');
-const { debuglog, promisify } = require('util');
-const { ncp } = require('ncp');
-const { resolve, join } = require('path');
-
-const internals = {
- 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))
- .sort((a, b) => Number(b) - Number(a));
- const posts = [];
- for (const id of postIds) {
- const postDirectory = join(archiveDirectory, id);
- const slug = (await readdir(postDirectory))
- .filter((entry) => internals.kGeminiRe.test(entry))[0];
-
- posts.push({ id, slug })
- };
-
- internals.debuglog(`Read ${posts.length} posts`);
-
- 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');
- await rm(internals.kArchiveName, { recursive: true });
- }
- finally {
- internals.debuglog('Creating index');
- await mkdir(internals.kArchiveName);
- const indexFile = join(internals.kArchiveName, internals.kIndexName);
- await writeFile(indexFile, index);
-
- internals.debuglog('Copying posts to archive');
- await internals.ncp(archiveDirectory, internals.kArchiveName);
- }
-};