Adding Webmentions to Astro Cactus
/ 4 min read
Updated:Table of Contents
TLDR
- Add a link on your homepage to either your GitHub profile and/or email address as per IndieLogin’s instructions. You could do this via src/components/SocialList.astro, just be sure to includeisWebmentionto the relevant link if doing so.
- Create an account @ Webmention.io by entering your website’s address.
- Add the link feed and api key to a .envfile with the keyWEBMENTION_URLandWEBMENTION_API_KEYrespectively, you could rename.env.examplefound in this template. You can also add the optionalWEBMENTION_PINGBACKlink here too.
- Go to brid.gy and sign-in to each social account[s] you wish to link.
- Publish and build your website, remember to add the api key, and it should now be ready to receive webmentions!
What are webmentions
Put simply, it’s a way to show users who like, comment, repost and more, on various pages on your website via social media.
This theme displays the number of likes, mentions and replies each blog post receives. There are a couple of more webmentions that I haven’t included, like reposts, which are currently filtered out, but shouldn’t be too difficult to include.
Steps to add it to your own site
Your going to have to create a couple of accounts to get things up-and-running. But, the first thing you need to ensure is that your social links are correct.
Add link(s) to your profile(s)
Firstly, you need to add a link on your site to prove ownership. If you have a look at IndieLogin’s instructions, it gives you 2 options, either an email address and/or GitHub account. I’ve created the component src/components/SocialList.astro where you can add your details into the socialLinks array, just include the isWebmention property to the relevant link which will add the rel="me authn" attribute. Whichever way you do it, make sure you have a link in your markup as per IndieLogin’s instructions
<a href="https://github.com/your-username" rel="me">GitHub</a>Sign up to Webmention.io
Next, head over to Webmention.io and create an account by signing in with your domain name, e.g. https://astro-cactus.chriswilliams.dev/. Please note that .app TLDs don’t function correctly. Once in, it will give you a couple of links for your domain to accept webmentions. Make a note of these and create a .env file (this template include an example .env.example which you could rename). Add the link feed and api key with the key/values of WEBMENTION_URL and WEBMENTION_API_KEY respectively, and the optional WEBMENTION_PINGBACK url if required. Please try not to publish this to a repository!
Sign up to Brid.gy
You’re now going to have to use brid.gy. As the name suggests, it links your website to your social media accounts. For every account you want to set up (e.g. Mastodon), click on the relevant button and connect each account you want brid.gy to search. Just to note again, brid.gy currently has an issue with .app TLDs.
Testing everything works
With everything set, it’s now time to build and publish your website. REMEMBER to set your environment variables WEBMENTION_API_KEY & WEBMENTION_URL with your host.
You can check to see if everything is working by sending a test webmention via webmentions.rocks. Log in with your domain, enter the auth code, and then the url of the page you want to test. For example, to test this page I would add https://astro-cactus.chriswilliams.dev/posts/webmentions/. To view it on your website, rebuild or (re)start dev mode locally, and you should see the result at the bottom of your page.
You can also view any test mentions in the browser via their api.
Things to add, things to consider
- 
At the moment, fresh webmentions are only fetched on a rebuild or restarting dev mode, which obviously means if you don’t update your site very often you wont get a lot of new content. It should be quite trivial to add a cron job to run the getAndCacheWebmentions()function insrc/utils/webmentions.tsand populate your blog with new content. This is probably what I’ll add next as a github action.
- 
I have seen some mentions have duplicates. Unfortunately, they’re quite difficult to filter out as they have different id’s. 
- 
I’m not a huge fan of the little external link icon for linking to comments/replies. It’s not particularly great on mobile due to its size, and will likely change it in the future. 
Acknowledgements
Many thanks to Kieran McGuire for sharing this with me, and the helpful posts. I’d never heard of webmentions before, and now with this update hopefully others will be able to make use of them. Additionally, articles and examples from kld and ryanmulligan.dev really helped in getting this set up and integrated, both a great resource if you’re looking for more information!