X-Git-Url: https://git.r.bdr.sh/rbdr/pinboard-linkblog-updater/blobdiff_plain/893264177a03bc7dd3e306753024fe1394fc3e77..28414efe202e391d22012590c932f676f80c3323:/index.js?ds=sidebyside diff --git a/index.js b/index.js index 78c3d26..c0e41dc 100644 --- a/index.js +++ b/index.js @@ -1,13 +1,16 @@ 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) { @@ -25,31 +28,25 @@ const internals = { 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) { + if (pins.length === 0) { console.error('No links to post'); return; } - internals.debuglog('Generating gemtext'); - const gemtext = internals.generateGemtext(pins.posts); + const gemtext = internals.generateGemtext(pins); 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}`); + for (const pin of pins) { await addPin({ url: pin.href, description: pin.description,