π A big thank you to our new sponsor, NexusTek! π
β¬ οΈ Security on the Agenda π§ Interoperability and Convergence Ahead β‘οΈ
Buttondown with 11ty on Netlify with GitHub
This installment is a look at how Fudge Sunday π€π‘π€―π€ newsletter gets made each week.
Every newsletter will have a set of steps to achieve the outcome of readers getting email and accessing an online archive of each new installment. My recipe, or set of steps, is meant to illustrate just one possible approach with minimal effort and the use of automation.
How to Buttondown
Iβve been a happy Buttondown customer since 2019. If you are thinking about writing a newsletter, considering the service to use, or are seeking options with an API, please consider using Buttondown using my referral link (thatβs my referral link where I will get a 25% lifetime commission and you get $9 off your first month).
Why Buttondown? Why this recipe?
In a prior life, I ran large email systems in the late 1990s until around 2010. I learned a lot.
The first thing I learned was that email delivery is rarely guaranteed due to the increased emphasis on the reputation scoring of senders. In short, there is a lot of unsolicited commercial bulk email (spam) out there and it can ruin your network neighborhood.
Iβm not doing email hosting for a living anymore butβ¦ anecdotally, I try to ensure that everything looks good from a Google Workspace Gmail headers point of view. As such, finding a solution like Buttondown means you are working with a sender that has a superb reputation.
Other senders like Mailgun (via Ghost) have a reputation that is almost as good as larger players (i.e. Substack) and that reputation is, in my opinion, light years better than Amazon SES.
After that, itβs probably going to be keyword, trigram, and late DCC whitelisting that might set off scoring toward the spam folders of other smaller email providers. Your mileage may vary.
Side note: One thing Iβve wondered about is the appetite for decentralized newsletters to be represented within M3AAWG. But, thatβs for another installment of this newsletter perhaps.
Code Local Commit Global
First, I write the newsletter locally as a blog post using 11ty (Eleventy) based upon an amazingly opinionated starter called Eleventy Excellent by Lene Saile. I use Visual Studio Code with a terminal running npm start
as I outlined for my setup in Zettelkasten End of Year for 2023.
Buttondown settings
Several configuration options enable me to write my blog post as the basis for an email distributed to my subscribers using Buttowndown.
Settings that help me keep things clean in my subscribe list include opt-in confirmations and limiting bots as well as a custom thank you page upon subscribing within Subscriber Flow in Buttondown Settings
Settings that can help me understand why subscribers leave the newsletter are important to me too and I use the Unsubscribe Reasons in Buttondown Settings to capture that optional information.
I also enjoy learning what is happening with my subscribers and I use Notifications in Buttondown Settings to get real-time updates.
RSS to Email
Once a post is created as a commit to GitHub, Netlify builds my RSS feed which includes the new post. Next, Buttondown takes the newsletter tasks from there.
Because I publish via RSS, this means Buttondown is doing the work for creating a Draft newsletter for me using βRSS to Emailβ function. RSS to Email is found in Buttondown Settings under Features.
Iβve added my RSS feed.
Iβve also customized the intake to lightly modify the import layout.
Finally, I append a few standard items using the Design (Email) Footer to add my physical mailing address.
Weekly Commit, Review, and Send
This results in a simple, repeatable recipe each week:
- GitHub receives my commit(s) on Sunday
- Netlify builds Fudge Sunday π€π‘π€―π€ newsletter and updates my RSS feed
- Buttondown creates a new email Draft from my newest RSS entry
- I manually inspect the email Draft in Buttondown and hit the big Send button
- I manually copy the contents of the Buttondown preview into LinkedIn Newsletter (this is admittedly, a chore)
- I craft two shareable LinkedIn posts
- to share the LinkedIn Newsletter
- to share the archive post on fudge.org
- GitHub workflows rebuild my special profile README and my personal website to reflect newsletter post updates
Of course, the details matter and this is a very high-level recipe. The next sections of this post will go into the other details that matter.
How to 11ty
My use of Eleventy i.e. 11ty makes my weekly writing pleasurable again. Iβve made some specific choices along the way to keep my readers enthusiastic and my content readily accessible.
Cache Rules Everything Around Me (CREAM)
For my Source references, I use the 11ty plugin unfurl and set the Fetch cache to several weeks which helps avoid throttling by the unfurl API provider microlink.io duration at 6 weeks (i.e. duration: "6w"
) and Iβve elected to avoid using the logo
since several readers mention it is harder to read in their preferred email application. π€
// unfurl plug section
eleventyConfig.addPlugin(pluginUnfurl, {
duration: "6w",
template: ({ title, publisher, url, logo }) => `<em><a href="${url}" class="unfurl">Source: ${publisher} β ${title}</a></em>`
});
*Side note: Speaking of plugins, when I was reading up on the many options available to the 11th community, my next project will be to add the Syntax Highlighting Plugin to prettify this code snippet above at a later date.
*
How to Netlify
The Netlify settings Iβve selected are minimal. I could be using more Netlify functionality but, for now, I opt to keep things simple.
I stage locally using npm start
and when I am pleased with the results I commit to main in GitHub which triggers deployment to Netlify per Branches and deploy contexts within Site Configuration on Netlify.
I also enable Pretty URLs
For Domain management and HTTPS, I use settings that allow me to maximize my other Cloudflare settings.
Specifically, I use Cloudflare CNAME flattening, Full SSL/TLS, Optimization, and Dynamic Redirect Normalization for my legacy Substack URLs i.e. (starts_with(http.request.full_uri, "https://sunday.fudge.org/p/"))
.
How to GitHub
The GitHub repository I use for Fudge Sunday π€π‘π€―π€ is public. Feel free to review my changelog.
Each week, I have two GitHub workflow files that execute to update my personal website jaycuthrell.com/newsletter and my special README file that customizes my GitHub profile.
In the future, Iβd like to make use of the Buttondown API and further automate the remaining few manual steps outlined above. That way I essentially can write, submit, and forgo any additional awareness of the remaining steps in my recipe.
So, what will be the next big technology change I use to make the Fudge Sunday π€π‘π€―π€ newsletter each week?
Until then⦠Place your bets!
Disclosure
I am linking to my disclosure.
p.s. As Iβve gotten older, I have come to appreciate getting snail mail. If you have time to drop me a postcard that would be amazing. βοΈ