Local Development Environment Setup
Environment setup instructions are written for developers using the latest public release of macOS. Windows/Linux developers may find that additional/alternate steps are needed to install dependencies and set up their local environment. Official Windows/Linux instructions coming soon.
Install Dependencies
When working with Organic CMS for the first time, Organic strongly recommends installing all listed dependencies, regardless of your role as a frontend, backend, or fullstack developer.
Organic encourages all developers to install and use Homebrew to efficiently manage packages/dependencies locally. A command is provided below for installing all dependencies at once using Homebrew.
Docker installation
Download and install the latest Docker Desktop app.
Homebrew Bulk Install Command
brew install \
awscli \
python3 \
node \
yarn \
nss mkcert
Homebrew Individual Install Commands
If you run into any errors installing dependencies in bulk, individual formulae can be installed with brew install <FORMULA_NAME>
commands.
brew install awscli
brew install python3
brew install node
brew install yarn
brew install nss mkcert
Configure Dependencies
Configure the AWS CLI
Click here for detailed instructions for configuring the AWS CLI.
Summary:
- Request AWS access from Organic Support.
- Create an AWS Access Key.
- Configure an AWS CLI Profile using
aws configure
.
Name | Value |
---|---|
AWS Access Key ID | See Detailed Instructions |
AWS Secret Access Key ID | See Detailed Instructions |
Default Region Name | us-west-2 |
Default Output Format | json |
Configure SSH for GitHub
Click here for instructions on configuring SSH for GitHub.
This is required for interacting with GitHub from the command line. It allows you to access and write data in your repositories.
Set Up a Site for Local Development
1. Clone your site's GitHub repository
This step creates a local copy of your site's repository.
git clone git@github.com:orgnc/<REPOSITORY_NAME>.git <LOCAL_PROJECT_FOLDER>
cd <LOCAL_PROJECT_FOLDER>
2. Install the Organic Dev tool
This step updates to the latest version of pip3
, creates a virtual Python environment, and installs the latest version of the Organic Dev tool.
pip3 install --upgrade pip
python3 -m venv $HOME/organic-dev-venv && source $HOME/organic-dev-venv/bin/activate
aws codeartifact login --tool pip --domain organic --repository organic
pip install organic-dev-core
Add path to isolated env to your shell start script:
echo 'export PATH="$PATH:$HOME/organic-dev-venv/bin"' >> ~/.zshrc
( or ~/.bashrc for linux)
3. Run environment setup command
This step spins up base Docker containers, generates local SSL certificates, updates localhost files, and creates git-commit hooks.
organic-cli setup
The organic-dev
command is now organic-cli
. If you configured your environment using the old command, you'll need to update Organic Dev.
4. Prepare environment variables
In this step, we'll define environment variables for our project.
Project environment variables
- Navigate to your project folder and copy the
.env.example
file. Name it.env
.- This file may not be visible in Finder. To show hidden files, press
Command + Shift + .
.
- This file may not be visible in Finder. To show hidden files, press
- Open the
.env
file in your IDE or text editor. - MacOS Users: Uncomment
DOCKER_HOST=host.docker.internal
. - Replace
your-token-here
with an Artifactory token provided to you by Organic Support. Contact Organic Support for a token if you don't have one. - Save & close the file.
Backend environment variables
- Navigate to the
backend/src
folder and copy the.env.example
file. Name it.env
. - Replace
<aws_access_key_id>
with a personal AWS Access Key ID. This can be the same AWS Access Key ID created for the AWS CLI above. - Replace
<aws_secret_access_key>
with a personal AWS Secret Access Key. This can be the same AWS Secret Access Key created for the AWS CLI above. - Save & close the file.
Frontend environment variables
Navigate to the frontend
folder and copy the .env.local.example
file. Name it .env.local
.
Enable previews
To enable CMS previews:
-
Retrieve token from AWS Secrets Manager
aws secretsmanager get-secret-value --secret-id GRAPHQL_BASIC_AUTH_STRING --query "SecretString"
-
Set the following variables in your
.env
file:HEADLESS_API_TOKEN={Token retrieved from repo}
GRAPHQL_BASIC_AUTH_STRING={Token retrieved from aws secrets manager}You can find
HEADLESS_API_TOKEN
by viewing the following file:orgnc/your-repo-name/frontend/kubernetes/configmap.yaml
ororgnc/your-repo-name/frontend/kubernetes/overlays/production/configmap.yaml
-
Ensure that the JSON Basic Authentication WordPress plugin is enabled.
infoPreview functionality will not work locally if you're pointing to the staging backend, since it's restricted using Basic Auth.
5. Build and run the local backend site
You can now run the site locally! organic-cli up
is the command to use each time you want to start a single site for development.
Note: The first time you run organic-cli up
for a given site, you will need to include the --build
flag:
organic-cli up --build
In the future when you need to bring a site up, simply run:
organic-cli up
6. Restore Site Database
In this step, we'll restore the latest site database backup from Amazon S3.
Download and restore the latest database backup from S3:
organic-cli restore-db-backup --latest
Depending on the size of the database backup and the speed of your internet connection, this step may take some time to complete.
7. Frontend development steps
- Navigate to the
frontend
folder. - Run the following login command:
yarn npm login --scope orgnc
- Enter
token
asusername
and the Artifactory token provided to you above as yourpassword
. - Run
yarn install
to install frontend dependencies. - Run
yarn dev
to run the frontend development server.
Two URLs should now be accessible:
https://lcl.example.com/
(used locally to see the frontend)https://lcl-cms.example.com/wp/wp-admin/
(used locally to access the WordPress Admin)
Updating the Organic Dev tool
To update or upgrade organic-dev-core
, simply run:
aws codeartifact login --tool pip --domain organic --repository organic
pip3 install --upgrade organic-dev-core
It's important to do this periodically to get access to new features and ensure our documentation is correct for your version of the tool.
Get the application logs
You can get the latest application logs from staging or production environment by running the following cmd:
organic-cli get-logs --env <staging|production> --app_type <backend|frontend>
example: organic-cli get-logs --env staging --app_type backend
Notes:
- This command returns the most recent access log records for the last 10 minutes.
- The amount of delivered record can be large for production environment.
- There is a maximum 5 minutes delay for the logs delivering from kubernetes containers to the logs storage.
Upload local DB to staging
You can upload the local DB to staging environment by running the following command:
organic-cli upload-local-db
Notes:
- This command makes full backup of the local WP database, uploads it to S3 and and replaces the staging DB with it.
- Please keep in mind that this process means full DB replacement, so all the previous data in staging DB will be lost,
so it might be a good idea to a make a staging backup first using
organic-cli make-backup
.