Minimalist podcast website built with GraphCMS, NextJs, Now and Twillio Sendgrid.
Podcasts are a great way to get start an indie movement, build a loyal user base or simply get your message out. But many times, the "off the shelf" solutions are slightly overly simplistic, are difficult to customize or suffer from being drowned out on centralized platforms. Using a headless CMS, you can create a completely unique experience, tailored to your exact needs.
- GraphCMS: Manages the shows, subscribers and newsletters.
- Next: Acts as a powerful framework that lets us query for live data and use serverless functions in Now.
- Now: A static host that also supports Lambda functions where we handle our subscriptions, unsubscribes and new RSS generation.
- Sendgrid: Sending notification emails for confirmation.
-
GraphCMS will house our entire content architecture. We will discuss the architecture in further detail at the connected blog post. The rough structure (though not hierarchial) looks like this: Episodes -> (Sponsors | Audio | Hosts | Guests) | Subscribers | Feeds | Sponsors
-
Next will power our application where we fetch content from GraphCMS (through a GraphQL proxy that authenticates our GraphCMS endpoint, hosted locally in a lambda function).
-
The "Subscribe/Unsubscribe" function is handled server-side in a lambda, executed by now. This will sign a user up to be notified of new episodes.
-
GraphCMS will kick off a Webhook on subscriber creation to another Now hosted endpoint that will send a confirmation email through Sendgrid to the subscriber.
-
In the email to the subscriber, a link will be exposed where they can confirm their subscription, again through a function hosted in Now, for the "double opt-in" that's become an industry standard.
If you wish to extend and work with this example locally, follow the instructions below.
If you'd rather check out a demo or deploy to your own Now account, you can do that too.
First, you will need accounts at GraphCMS, Sendgrid and Now.
git clone [email protected]:github.com/GraphCMS/nextjs-graphcms-podcast-starter.git
cd nextjs-graphcms-podcast-starter
yarn # npm install
cp .env.buld.sample .env.build
cp .env.sample .env
Install the Now-CLI
You will need to create a project from template inside GraphCMS to carefully match what is expected from GraphCMS.
You'll need an account with GraphCMS. It's recommended you use separate API keys for development and production.
Env Vars
Add the necessary variables to .env
and .env.build
files.
Deployment URLS
Add your own domain for the production version of your application in the now.config.js
file at line 17.
Secrets
Now keeps a strict wall of separation between your project env
an your lambda env
- called a secret
. You can read more about them and the philosophy of separation as well as how to add them here
You'll need to add the following secrets, which you should already have filled out in your envs
.
demo-graphcms-podcast-token
demo-graphcms-podcast-mutation-token
demo-graphcms-podcast-endpoint
demo-graphcms-podcast-sendgrid-api-key
demo-graphcms-podcast-sender-address
api
path, and you will need to deploy to Now first to do that.
Once all dependencies and environment variables are satisfied, you can run Next locally to build in development, including the API endpoints with now
:
now dev