This is a demonstration project for the amazing Wagtail CMS.
The demo site is designed to provide examples of common features and recipes to introduce you to Wagtail development. Beyond the code, it will also let you explore the admin/editorial interface of the CMS.
Note we do not recommend using this project to start your own site - the demo is intended to be a springboard to get you started. Feel free to copy code from the demo into your own project.
This demo is aimed primarily at developers wanting to learn more about the internals of Wagtail, and assumes you'll be reading its source code. After browsing the features, pay special attention to code we've used for:
- Dividing a project up into multiple apps
- Custom content models and "contexts" in the "breads" and "locations" apps
- A typical weblog in the "blog" app
- Example of using a "base" app to contain misc additional functionality (e.g. Contact Form, About, etc.)
- "StandardPage" model using mixins borrowed from other apps
- Example of customizing the Wagtail Admin via wagtail_hooks
- Example of using the Wagtail "snippets" system to represent bread categories, countries, and ingredients
- Example of a custom "Galleries" feature that pulls in images used in other content types in the system
- Example of creating ManyToMany relationships via the Ingredients feature on BreadPage
- Lots more
Document contents
If you want to see what Wagtail is all about, we suggest trying it out locally in a virtual environment: Setup with venv.
If you're new to Python and/or Django, we suggest you run this project on a Virtual Machine using Docker or Vagrant (whichever you're most comfortable with). Both Vagrant and Docker will help resolve common software dependency issues.
Once you've installed the necessary dependencies run the following commands:
git clone https://github.com/wagtail/bakerydemo.git
cd bakerydemo
vagrant up
vagrant ssh
# then, within the SSH session:
./manage.py runserver 0.0.0.0:8000The demo site will now be accessible at http://localhost:8000/ and the Wagtail admin interface at http://localhost:8000/admin/.
Log into the admin with the credentials admin / changeme.
Use Ctrl+c to stop the local server. To stop the Vagrant environment, run exit then vagrant halt.
Run the following commands:
git clone https://github.com/wagtail/bakerydemo.git --config core.autocrlf=input
cd bakerydemo
docker compose up --build -dAfter this command completes and returns to the command prompt, wait 10 more seconds for the database setup to complete. Then run:
docker compose run app /venv/bin/python manage.py migrate
docker compose run app /venv/bin/python manage.py load_initial_dataIf this fails with a database error, wait 10 more seconds and re-try. Finally, run:
docker compose upThe demo site will now be accessible at http://localhost:8000/ and the Wagtail admin interface at http://localhost:8000/admin/.
Log into the admin with the credentials admin / changeme.
Important: This docker-compose.yml is configured for local testing only, and is not intended for production use.
To tail the logs from the Docker containers in realtime, run:
docker compose logs -fYou can run the Wagtail demo locally without setting up Vagrant or Docker and simply use venv, which is the recommended installation approach for Django itself.
- Python 3.10+
- venv
On GNU/Linux or macOS (bash):
python -m venv .venv
source .venv/bin/activateOn Windows, activate the virtual environment using the appropriate command for your shell:
# PowerShell
.venv\Scripts\Activate.ps1
# Command Prompt (cmd.exe)
.venv\Scripts\activate.batNote (PowerShell Execution Policy) If activating with
Activate.ps1fails with an error like “running scripts is disabled on this system”, you can either:
- use
.venv\Scripts\activate.batin Command Prompt, or- allow scripts in PowerShell for your user account:
Set-ExecutionPolicy -Scope CurrentUser RemoteSigned
Now we're ready to set up the bakery demo project itself:
cd ~/dev [or your preferred dev directory]
git clone https://github.com/wagtail/bakerydemo.git
cd bakerydemo
pip install -r requirements/development.txtNext, we need to create the files .env and bakerydemo/settings/local.py, which provide a place for local configuration settings that need to be kept outside of version control. No such settings are required for a standard installation, but warnings will be displayed if these files are not present:
cp bakerydemo/settings/local.py.example bakerydemo/settings/local.py
cp .env.example .env
# `cp` is used for bash. Windows Command Prompt uses `copy`To set up your database and load initial data, run the following commands:
./manage.py migrate
./manage.py load_initial_data
./manage.py runserverLog into the admin with the credentials admin / changeme.
Hopefully after you've experimented with the demo you'll want to create your own site. To do that you'll want to run the wagtail start command in your environment of choice. You can find more information in the getting started Wagtail CMS docs.
Check out our contributing documentation for our contributing guidelines and docs for common tasks.
The bakerydemo/settings/local.py file can be used to store local Django settings such as database connection details that need to be kept outside of version control.
Additionally, various settings can be controlled through environment variables. The python-dotenv package is used to load these variables from a .env file in the project root.
Because we can't (easily) use ElasticSearch for this demo, we use wagtail's native DB search.
However, native DB search can't search specific fields in our models on a generalized Page query.
So for demo purposes ONLY, we hard-code the model names we want to search into search.views, which is
not ideal. In production, use ElasticSearch and a simplified search query, per
https://docs.wagtail.org/en/stable/topics/search/searching.html.
The following setting in base.py and production.py ensures that live email is not sent by the demo contact form.
EMAIL_BACKEND = 'django.core.mail.backends.console.EmailBackend'
In production on your own site, you'll need to change this to:
EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'
and configure SMTP settings appropriate for your email provider.
The demo data includes users with different roles and preferences. You can use these users to quickly test the permission system in Wagtail or how localization is handled in the admin interface.
| Username | Password | Superuser | Groups | Preferred language | Timezone | Active |
|---|---|---|---|---|---|---|
admin |
changeme |
Yes | None | undefined | undefined | Yes |
editor |
changeme |
No | Editors | undefined | undefined | Yes |
moderator |
changeme |
No | Moderators | undefined | undefined | Yes |
inactive |
changeme |
yes | None | undefined | undefined | No |
german |
changeme |
yes | None | German | Europe/Berlin | Yes |
arabic |
changeme |
yes | None | Arabic | Asia/Beirut | Yes |
All content in the demo is public domain. Textual content in this project is either sourced from Wikimedia (Wikipedia for blog posts, Wikibooks for recipes) or is lorem ipsum. All images are from either Wikimedia Commons or other copyright-free sources.