Sanity
Get a peek at our latest innovations at Sanity Product Day on Dec 8th →
July 03, 2021

Deploying Sanity Studio with Layer0

By Rishi Raj Jain

Sanity Studio is a single page app (SPA) written in React, where you can configure the document types and input fields, with simple JavaScript objects. This guide will walk you through how to deploy Sanity Studio with Layer0 in four simple steps.

Step 1: Setting Up your Sanity Studio Project

NOTE: You can skip this step if you already have a project set up.

First, install the Sanity CLI:

npm i -g @sanity/cli

To initiate a new project and download the Studio code to your computer, run the following in the command line:

sanity init

The Sanity CLI will walk you through the necessary steps to set up a project, letting you choose a schema template. When you're done with these steps, the CLI will download the source code and configuration to get you started. To start a local development server, cd into the project folder and run the following command:

sanity start

Step 2: Preparing for Deployment

First, install the Edgio CLI:

npm i -g @edgio/cli

To add Layer0 to an existing app, run the following:

edgio init --edgioVersion=5.0.4-next-1666555416-d7dfbab.0 --connector=@edgio/sanity-studio

The above command creates routes.ts and edgio.config.js.

Step 3: Preview Production Locally With Edgio

To preview production app locally run:

edgio build && edgio run --production

Step 4: Deploy With Edgio

To deploy run:

edgio deploy

Once Sanity Studio is deployed, you will need to add it's URL to Sanity’s CORS origins settings. You can do this from the command line:

sanity cors add https://your-url.layer0-limelight.link --credentials

Alternatively, you can navigate to manage.sanity.io, find your project and under Settings > API, add the Studio URL to the CORS origins list. You should allow credentials as the Studio requires authentication for added security.

Find the GitHub Repo containing the entire setup at edgio-docs/edgio-sanity-studio-example

Other guides by author