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
Name | Type | Default | Description |
---|---|---|---|
local_backend | boolean | Proxy Config | false | Activates 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
- 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.
- Start your local development server (e.g. run
gatsby develop
). - 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 is8000
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
Name | Type | Default | Description |
---|---|---|---|
url | string | https://localhost:8081/api/v1 | URL for proxy server |
allowed_hosts | list 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' |
- Create a
.env
file in the project's root folder and define the PORT you'd like the proxy server to use.
PORT=8082
- Update the
local_backend
object inconfig
and specify aurl
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']