Skip to content

maniacmusic/nextjs-graphcms-podcast-starter

 
 

Repository files navigation

GraphCMS Podcast Demo

Minimalist podcast website built with GraphCMS, NextJs, Now and Twillio Sendgrid.

Read more

The stack

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.

How it works

  1. 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

  2. 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).

  3. 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.

  4. 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.

  5. 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.

⚠️ You need to have an account and API keys for Sendgrid for this to work.

How to use

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.

1. Download and install dependencies

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

2. Create your project on GraphCMS

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.

3. Setup development environment variables

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. ⚠️ You'll need to add your own domain for this step, and you will need to deploy to Now first to do that.

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

4. Add Webhooks to your GraphCMS project

Webhooks Image

⚠️ You'll need to add your own domain before the api path, and you will need to deploy to Now first to do that.

5. Run locally

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

About

Starter project built with GraphCMS, NextJS and Twilio SendGrid.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 99.3%
  • CSS 0.7%