Deploy Next SSG with Storyblok to Cloudflare Pages
Storyblok is the first headless CMS that works for developers & marketers alike.
In this tutorial, we will explore how to deploy applications built with Storyblok on Cloudflare pages (opens in a new window) . We'll deploy a blog application built with Next.js (opens in a new window) and Storyblok on Cloudflare pages and configure a deploy hook (opens in a new window) to publish changes we make on our application automatically.
This tutorial benefits readers interested in Storyblok, Next.js, and who plan on deploying their applications built with Storyblok to Cloudflare.
Requirements
The following are required for this tutorial:
- Basic knowledge of Next.js and React
- Node, yarn (or npm), and npx installed
- An account on Storyblok to manage content
If you're new to Storyblok, We highly recommend our tutorial Add a headless CMS to Next.js in 5 minutes (opens in a new window) .
Setup Next project
For this article, I prepared a blog application written with Next.js. Clone the project repository here to your local computer using the command below:
git clone https://github.com/storyblok/cloudflare-next-example.git
Run either of the commands below in the project’s root folder to install dependencies:
npm install
Configure Storyblok space
Next, set up a Storyblok space for the blog following this guide (opens in a new window) . After setting up the space, the content should look like this:
data:image/s3,"s3://crabby-images/504fb/504fb23d5a49172b0dc50a8b70ce0b9acbdcd091" alt="Set up your Storyblok space")
Set up your Storyblok space
Create your preview token
Navigate to your settings tab {1} in your space, in the new page click on API-keys tab {2} and toggle to get your space preview token {3}
data:image/s3,"s3://crabby-images/82518/82518b3119224383149d283a212245f08387939c" alt="create your preview token")
create your Storyblok preview token
Adding environment variables to Next SSG
In the root folder of your Next.js application, create an env.local
file, inside it, add your environment variables which include your Storyblok API keys, your space preview token and a Fallback=true.
We will need this to prevent Next.js fallback error during deployment.
Your .env.local
file should look like this:
STORYBLOK_API_KEY={YOUR STORYBLOK SPACE PREVIEW TOKEN}
STORYBLOK_PREVIEW_SECRET={YOUR RANDOMLY CREATED SECRET FOR PREVIEW}
FALLBACK=true
Deploying to Cloudflare Pages
We are going to deploy our project as an SSG. Read more about NEXT static site generation (SSG) here (opens in a new window) . To deploy your application, create a GitHub repository for the application and push it to that repository. We need to do this because we can only deploy to Cloudflare pages from Github or Gitlab.
After this, create a Cloudflare account from here (opens in a new window) . After creating an account and signing in, navigate to Home {1}, and click on pages {2}:
data:image/s3,"s3://crabby-images/12271/12271d88c6ce9dd35a83c79fd0c50a630397d4e0" alt="deploy to cloudflare pages")
deploy to cloudflare pages
Click on the Create a project {1} button:
data:image/s3,"s3://crabby-images/8f2d4/8f2d477d0bad0690e903f9421bec12f6a487897f" alt="Create a pages project")
Create a pages project
Choose the Git repository you hosted your project on by connecting GitHub {1} or GitLab {2}, and grant Cloudflare access. Select the project and begin setup:
data:image/s3,"s3://crabby-images/663b1/663b1c05d0984312e71dd09e6101eaf5e031c079" alt="connect GitHub or GitLab")
connect GitHub or GitLab
On the setup page, under Build settings {1} > Framework Preset {2}, choose the Next.js preset {3}. It will add a deployment command and specify the folder to deploy after the build. We also need to add environment variables:
Make sure you add all the variables in the .env.local file of the project except FALLBACK. We don’t want a fallback in our getStaticPaths function in production as this could cause a fallback: true
export error.
A fallback:true
export error occurs when fallback is added to getStaticProps
which renders the build invalid. Click on Save and Deploy.
data:image/s3,"s3://crabby-images/230c0/230c03eec597d6333ea49c5ff245bdf5e8c3b1ce" alt="set up pages")
set up pages
Set up webhooks
To set up deploy hooks on Cloudflare pages. Go to Settings {1} on Cloudflare pages, under builds and deployment {2} look for the create deploy hooks section {3}. Create a new hook and set the branch you want to deploy.
With the deploy hook, whenever we add or edit any content in our Blog Storyblok space and publish it, Cloudflare will automatically redeploy our app.
data:image/s3,"s3://crabby-images/e5df0/e5df0dd8c8bba85ce07688323c7f7afa249231ed" alt="Cloudflare deploy hook")
Cloudflare deploy hook
Copy the generated hook, then Go to Settings of your Storyblok space and under that General tab, you will find the Webhooks section {1}. Paste your recently copied webhook into the Story published & unpublished
field {2}. Finally, add the deploy hook to the input for webhook then save it:
data:image/s3,"s3://crabby-images/40db5/40db5e2de56faa21f7cfaa217a199a6e098f40af" alt="Adding web hooks to storyblok")
Adding hooks to storyblok
Now, every time you publish or unpublish your content in the space, Storyblok will trigger the webhook and Cloudflare will automatically start the deployment of your page. You can see a live version of the application here (opens in a new window) .
Conclusion
In this article, we learned how to deploy applications built with Next and Storyblok to Cloudflare pages and set up a deploy hook for redeployment when any change is unpublished in our Storyblok space. We also looked at static site generation (SSG).
Resources | Link |
---|---|
Project Example Repo | https://github.com/storyblok/cloudflare-next-example.git |
Adding Storyblok to Next.js | https://www.storyblok.com/tp/add-a-headless-cms-to-next-js-in-5-minutes |
Cloudflare Pages Docs | https://developers.cloudflare.com/pages/ |