+++ /dev/null
-const { mkdir, readdir, rm, writeFile } = require('fs/promises');
-const { debuglog, promisify } = require('util');
-const { ncp } = require('ncp');
-const { join } = require('path');
-
-const internals = {
- kArchiveName: '.gemlog',
- kIndexName: 'index.gmi',
- kGeminiRe: /\.gmi$/i,
-
- ncp: promisify(ncp),
- debuglog: debuglog('blog'),
-};
-
-module.exports = async function(archiveDirectory) {
- internals.debuglog(`Reading archive ${archiveDirectory}`);
- const postIds = await readdir(archiveDirectory)
- 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', '',
- ...posts.map((post) => `=> ./${post.id}/${post.slug}`)].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);
- }
-};