X-Git-Url: https://git.r.bdr.sh/rbdr/pinboard-linkblog-updater/blobdiff_plain/f0b2faff6e6e69de483fccb940f7fc989c4c9030..HEAD:/index.js diff --git a/index.js b/index.js index 549e223..518cc79 100644 --- a/index.js +++ b/index.js @@ -10,6 +10,10 @@ const internals = { apiToken: process.env.PINBOARD_TOKEN, blogUrl: process.env.BLOG_URL, archiveUrl: process.env.ARCHIVE_URL, + blogPublicUrl: process.env.BLOG_PUBLIC_URL, + archivePublicUrl: process.env.ARCHIVE_PUBLIC_URL, + tootToken: process.env.TOOT_TOKEN, + mastodonDomain: process.env.MASTODON_DOMAIN, date: (new Date()).toISOString().split('T')[0], @@ -20,7 +24,7 @@ const internals = { getText(posts) { - const linkText = posts.map((post) => { + return posts.map((post) => { return `=> ${post.href} ${post.description}\n${post.extended}`; }).join('\n\n'); @@ -29,7 +33,7 @@ const internals = { getTitle(posts) { if (posts.length === 1) { - return posts[0].description; + return `Link: ${posts[0].description}`; } return `${posts.length} links for ${internals.date}`; }, @@ -37,7 +41,24 @@ const internals = { slugify(text) { return text.toLowerCase().replace(/[^a-z0-9 ]/g, '').replace(/ +/g, '-') + }, + + async toot(title) { + + const body = new FormData(); + body.set( + 'status', + `New post: ${title}\n\nAvailable on:\n\n♊️ the gemini archive ${internals.archivePublicUrl}\n\n or, the ephemeral blog 🌐: ${internals.blogPublicUrl}` + ); + return fetch(`https://${internals.mastodonDomain}/api/v1/statuses`, { + method: 'post', + headers: { + Authorization: `Bearer ${internals.tootToken}`, + }, + body + }); } + }; @@ -53,8 +74,8 @@ async function run() { return; } - const title = internals.getTitle(posts); - const text = internals.getText(posts); + const title = internals.getTitle(pins); + const text = internals.getText(pins); const gemtext = internals.generateGemtext(title, text); const filename = internals.slugify(title); @@ -74,6 +95,10 @@ async function run() { tags: pin.tags.replace('linkblog', 'linkblog-posted') }); } + + if (internals.tootToken) { + await internals.toot(title); + } } run()