const { exec } = require('child_process');
const { resolve, join} = require('path');
const { rm, writeFile } = require('fs/promises');
-const { debuglog, promisify } = require('util');
+const { promisify } = require('util');
const Pinboard = require('node-pinboard').default;
const internals = {
exec: promisify(exec),
- debuglog: debuglog('blog'),
+
apiToken: process.env.PINBOARD_TOKEN,
+ blogUrl: process.env.BLOG_URL,
+ archiveUrl: process.env.ARCHIVE_URL,
+
date: (new Date()).toISOString().split('T')[0],
generateGemtext(posts) {
async function run() {
const pinboard = new Pinboard(internals.apiToken);
- const getPins = promisify(pinboard.get);
+ const getPins = promisify(pinboard.all);
const addPin = promisify(pinboard.add);
- internals.debuglog('Fetching Pins');
const pins = await getPins({ tag: 'linkblog' });
- internals.debuglog(`Found ${pins.posts.length} pins`);
if (pins.posts.length === 0) {
console.error('No links to post');
return;
}
- internals.debuglog('Generating gemtext');
const gemtext = internals.generateGemtext(pins.posts);
const gemfile = resolve(join(__dirname, `linkblog-${internals.date}.gmi`));
- internals.debuglog(`Writing to ${gemfile}`);
await writeFile(gemfile, gemtext);
- internals.debuglog('Adding gemfile to log');
- const output = await internals.exec(`blog --add ${gemfile}`);
- internals.debuglog(output.stderr);
- internals.debuglog(`Removing ${gemfile}`);
+ await internals.exec(`blog --add ${gemfile}`);
+ await internals.exec(`blog --publish ${internals.blogUrl}`);
+ await internals.exec(`blog --publish-archive ${internals.archiveUrl}`);
await rm(gemfile);
for (const pin of pins.posts) {
- internals.debuglog(`Updating ${pin.href}`);
await addPin({
url: pin.href,
description: pin.description,