index-dev-env
April 15, 2026 · View on GitHub
Local development environment for CreativeCommons.org (product name: index).
Overview
This repository has the configuration required to run the CreativeCommons.org website in a local Docker development environment.
The CreativeCommons.org website is comprised of five components that are split into two categories:
- dynamic component:
- WordPress (Vocabulary Theme)
- static components:
- Chooser
- FAQ
- Legal Tools (licenses and public domain)
- Platform Toolkit
Component repositories
| Path label | Path | Component name | Component repositories |
|---|---|---|---|
| Chooser | /choose | Chooser | chooser |
| FAQ | /faq | FAQ | faq |
| Licenses | /licenses | CC Legal Tools | cc-legal-tools-app, cc-legal-tools-data |
| Platform Toolkit | /platform/toolkit | Platform Toolkit | mp |
| Public Domain | /publicdomain | CC Legal Tools | cc-legal-tools-app, cc-legal-tools-data |
| WordPress | / (default) | Vocabulary Theme | vocabulary-theme |
Code of conduct
The Creative Commons team is committed to fostering a welcoming community. This project and all other Creative Commons open source projects are governed by our Code of Conduct. Please report unacceptable behavior to conduct@creativecommons.org per our reporting guidelines.
Contributing
See CONTRIBUTING.md.
Docker containers
The docker-compose.yml file defines the following
containers:
- index-db - Database server for WordPress
- index-phpmyadmin - Database administration
- index-web - Web server (WordPress and static HTML components)
Setup
- Ensure the following repositories are cloned adjacent to this repository:
PARENT_DIR ├── cc-legal-tools-data ├── chooser ├── dev-index-env ├── faq └── mp - Create the
.envfile:cp .env.example .env - Update
.envto set desired values for variables (WP_VERSION,WP_MOD_TYPE,WP_MOD_NAME, etc.) - Build/start Docker:
docker compose up - Wait for build and initialization to complete
- Setup WordPress:
./setup-wordpress.sh - Optional (CC staff only): import production data
- Ensure you have access to the production server and your local machine is properly configured to access it
- Pull production data
./staff_migrate.sh pull - Import production data
./staff_migrate.sh import
Path URLs
| Path label | Dev link | Stage link | Prod link |
|---|---|---|---|
| Chooser | Dev /choose | Stage /choose | Prod /choose |
| FAQ | Dev /faq | Stage /faq | Prod /faq |
| Licenses | Dev /licenses | Stage /licenses | Prod /licenses |
| Platform Toolkit | Dev /platform/toolkit | Stage /platform/toolkit | Prod /platform/toolkit |
| Public Domain | Dev /publicdomain | Stage /publicdomain | Prod /publicdomain |
| WordPress | Dev / (default) | Stage / (default) | Prod / (default) |
| WordPress Admin | Dev /wp-admin | Stage /wp-admin | Prod /wp-admin |
Dev configuration
Apache2
See config/web-sites-available/000-default.conf.
WordPress core
| Name | Version |
|---|---|
| WordPress | 6.3.1 |
Also see .env.example.
WordPress plugins
| Name | Version |
|---|---|
| Advanced Custom Fields | 6.2.1 |
| Advanced Custom Fields: Menu Chooser | 1.1.0 |
| Classic Editor | 1.6.3 |
| Monster Insights Google Analytics | 8.19 |
| Redirection | 5.3.10 |
| Tablepress | 2.1.7 |
| Wordfence | 7.10.4 |
| WordPress Importer | 0.8.1 |
| Yoast SEO | 21.2 |
Also see config/composer/composer.json.
WordPress themes
| Name | Version |
|---|---|
| Vocabulary Theme | 2.4 |
Also see config/composer/composer.json.
vocabulary-theme QA Checklist
vocabulary-theme release testing QA checklist
- run setup-wp script (again to make sure WP is current version)
- be sure to clear/disable caches locally
- review any new context/template/page
- review pages:
Stage and Prod configuration
The staging server and production server are configured via Salt managed in the creativecommons/sre-salt-prime repository. The list below include the specifics (is non-exhaustive):
pillars/states/
Copying
COPYING: All the content within this repository is dedicated to
the public domain under the CC0 1.0 Universal (CC0 1.0) Public Domain
Dedication.
