Static CMS
Star StaticJsCMS/static-cms on GitHub
v4.3.0DocsExamplesDemoCommunity

Local Backend

The local backend allows you to use Static CMS with a local git repository, instead of working with a live repo, regardless of backend provider. It will read and write file from your local file system inside your local git repository. You will still need to manually commit and push any files you have changed or added after completing the edits.

Configuration

NameTypeDefaultDescription
local_backendboolean
| Proxy Config
falseActivates the local backend for Static CMS, overriding other backend configurations

Example

# when using the default proxy server port
local_backend: true

backend:
  name: git-gateway

Usage

  1. Run npx @staticcms/proxy-server from the root directory of the above repository.
    • If the default port (8081) is in use, the proxy server will not start and you will see an error message. In this case, follow these steps before proceeding.
  2. Start your local development server (e.g. run gatsby develop).
  3. Open https://localhost:<port>/admin to verify that your can administer your content locally. Replace <port> with the port of your local development server. For example Gatsby's default port is 8000

Note: @staticcms/proxy-server runs an unauthenticated express server. As any client can send requests to the server, it should only be used for local development.

Configure Proxy Server Port

NameTypeDefaultDescription
urlstringhttps://localhost:8081/api/v1URL for proxy server
allowed_hostslist of hosts['localhost', '127.0.0.1']Whitelist of allowed hosts when accessing the local site from a host other than 'localhost' or '127.0.0.1'
  1. Create a .env file in the project's root folder and define the PORT you'd like the proxy server to use.
PORT=8082
  1. Update the local_backend object in config and specify a url property to use your custom port number
backend:
  name: git-gateway

local_backend:
  # when using a custom proxy server port
  url: http://localhost:8082/api/v1
  # when accessing the local site from a host other than 'localhost' or '127.0.0.1'
  allowed_hosts: ['192.168.0.1']