X-Git-Url: https://git.r.bdr.sh/rbdr/pinboard-linkblog-updater/blobdiff_plain/096cf8b12b95bb5c8bacdea03e695fd787cee025..f0b2faff6e6e69de483fccb940f7fc989c4c9030:/index.js diff --git a/index.js b/index.js index b6c3e10..549e223 100644 --- a/index.js +++ b/index.js @@ -13,15 +13,30 @@ const internals = { date: (new Date()).toISOString().split('T')[0], - generateGemtext(posts) { + generateGemtext(title, text) { - const title = posts.length === 1 ? 'A link' : `${posts.length} links`; + return `# ${title}\n\n${text}`; + }, - const linkText = posts.map((pin) => { - return `=> ${pin.href} ${pin.description}\n${pin.extended}`; + getText(posts) { + + const linkText = posts.map((post) => { + + return `=> ${post.href} ${post.description}\n${post.extended}`; }).join('\n\n'); + }, + + getTitle(posts) { - return `# ${title} for ${internals.date}\n\n${linkText}`; + if (posts.length === 1) { + return posts[0].description; + } + return `${posts.length} links for ${internals.date}`; + }, + + slugify(text) { + + return text.toLowerCase().replace(/[^a-z0-9 ]/g, '').replace(/ +/g, '-') } }; @@ -33,20 +48,24 @@ async function run() { const pins = await getPins({ tag: 'linkblog' }); - if (pins.posts.length === 0) { + if (pins.length === 0) { console.error('No links to post'); return; } - const gemtext = internals.generateGemtext(pins.posts); - const gemfile = resolve(join(__dirname, `linkblog-${internals.date}.gmi`)); + const title = internals.getTitle(posts); + const text = internals.getText(posts); + const gemtext = internals.generateGemtext(title, text); + const filename = internals.slugify(title); + + const gemfile = resolve(join(__dirname, `${filename}.gmi`)); await writeFile(gemfile, gemtext); 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) { + for (const pin of pins) { await addPin({ url: pin.href, description: pin.description,