Skip to main content

Create Plone codebases (projects, add-ons, documentation) with ease!

Project description

Plone Logo

Cookieplone 🍪

PyPI PyPI - Python Version PyPI - Wheel PyPI - License PyPI - Status

Tests

GitHub contributors GitHub Repo stars

Static Badge

Welcome to Cookieplone, your starting point for every Plone project. Whether you're building an add-on, starting a new project, or even creating your own Plone Distribution, Cookieplone simplifies the process by using templates maintained by the Plone Community.

Key features 🌟

Cookieplone offers the following key features for each audience.

For users

  • One stop for all Plone templates: Cookieplone helps you find the correct template to start your new Plone project.
  • Simplified usage: Cookieplone provides an enhanced experience over standard Cookiecutter usage by offering predefined sane defaults and a unified approach to generating various Plone projects.
  • Batteries included: No need to install lots of dependencies. Run uvx cookieplone, and you will quickly generate your codebase.

For template creators

  • Built-in validators: Includes built-in validators to ensure user inputs are correct.
  • Jinja2 filters: Includes Jinja2 filters for advanced template control.
  • Subtemplates: Mechanism to easily instantiate subtemplates within cookiecutter hooks -- i.e. post_gen_hook -- , facilitating greater code reuse.

Installation 💾

Set up your system with Plone's Prerequisites for installation.

Usage 🛠️

Use uvx (command installed by uv) to run cookieplone and see all available template options:

uvx cookieplone

It is also possible to run a specific version of Cookieplone:

uvx cookieplone@1.0.0

Cookieplone will walk you through the necessary steps, using sensible defaults and offering customization options where needed.

Try a prerelease version

Plain uvx cookieplone (and uvx cookieplone@latest) always picks the latest stable release — prerelease versions (aN, bN, rcN, .devN) are excluded by default, following PEP 440 and the uv resolver defaults.

To opt in to a prerelease — for example, 2.0.0a1 — pin the exact version:

uvx cookieplone@2.0.0a1

Or allow the resolver to consider any prerelease:

uvx --prerelease=allow cookieplone

If you previously installed Cookieplone with uv tool install, upgrade the tool explicitly so the cached stable install is replaced:

uv tool install --reinstall --prerelease=allow cookieplone

You can confirm which version is active with:

uvx cookieplone --version

Use options to avoid prompts

Cookieplone will ask a lot of questions. You can use some of its options to avoid repeatedly entering the same values.

--answers

You can use the --answers to point to a file containing the answers you want to use to pre-populate default values.

--no-input

You can use the --no-input option to make Cookieplone not prompt for parameters and only use default values.

--replay and --replay-file

You can use the options --replay and --replay-file to not prompt for parameters and only use information entered previously or from a specified file. See Replay Project Generation in the cookiecutter documentation for more information.

Specify a template

You can also specify other templates.

Template Description Command
backend_addon Create a Plone add-on to be used with the backend. uvx cookieplone backend_addon
frontend_addon Create a Plone add-on to be used with the frontend. uvx cookieplone frontend_addon

The updated list of templates can be found at the cookieplone-templates repository.

Configure Cookieplone

Environment Variable Description Example
COOKIEPLONE_REPOSITORY Where to look for templates to be used. COOKIEPLONE_REPOSITORY=/home/plone/cookieplone-templates/ uvx cookieplone
COOKIEPLONE_REPOSITORY_TAG Which tag/branch to use from a remote repository. COOKIEPLONE_REPOSITORY_TAG=experimental uvx cookieplone
COOKIEPLONE_REPO_PASSWORD Password to use when using a remote repository that is password protected. COOKIEPLONE_REPO_PASSWORD=very-secure uvx cookieplone

Contribute 🤝

We welcome contributions to Cookieplone.

You can create an issue in the issue tracker, or contact a maintainer.

Branches

Branch Target version Status
main 2.0.0 (next major) Active development
1.x 1.x (patch and minor) Maintenance only

All new feature development targets the main branch and will be released as version 2.0.0. The 1.x branch is in maintenance mode and only receives bug fixes and minor improvements released as 1.x versions.

Development requirements

See Installation.

Setup

Create a local Python virtual environment with the following command.

make install

Run the checked out branch of Cookieplone

uv run cookieplone

Check and format the codebase

make check

Run tests

pytest is this package's test runner.

Run all tests with the following command.

make test

Run all tests, but stop on the first error and open a pdb session with the following command.

uv run pytest -x --pdb

Run only tests that match test_run_sanity_checks_fail with the following command.

uv run pytest -k test_run_sanity_checks_fail

Run only tests that match test_run_sanity_checks_fail, but stop on the first error and open a pdb session with the following command.

uv run pytest -k test_run_sanity_checks_fail -x --pdb

Support 📢

For support, questions, or more detailed documentation, visit the official Cookieplone repository.

Thank you for choosing Cookieplone for your Plone development needs!

This project is supported by

Plone Foundation Logo

License

The project is released under the MIT License.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cookieplone-2.0.0a1.tar.gz (113.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

cookieplone-2.0.0a1-py3-none-any.whl (70.5 kB view details)

Uploaded Python 3

File details

Details for the file cookieplone-2.0.0a1.tar.gz.

File metadata

  • Download URL: cookieplone-2.0.0a1.tar.gz
  • Upload date:
  • Size: 113.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.8 {"installer":{"name":"uv","version":"0.10.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for cookieplone-2.0.0a1.tar.gz
Algorithm Hash digest
SHA256 a340c5370c2f47ac39a8ebe2771cc92513094334ae5d5f744df186d4f6b3a140
MD5 d4504f5c2b2019d4b55c0076a87e7786
BLAKE2b-256 18e18f2f4c36ddb23e3776fed0afd2d0edc91814fc575553b30ab0072f7c7e6e

See more details on using hashes here.

File details

Details for the file cookieplone-2.0.0a1-py3-none-any.whl.

File metadata

  • Download URL: cookieplone-2.0.0a1-py3-none-any.whl
  • Upload date:
  • Size: 70.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.8 {"installer":{"name":"uv","version":"0.10.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for cookieplone-2.0.0a1-py3-none-any.whl
Algorithm Hash digest
SHA256 6e6e5ac2d0d56c824029d642ab58f4d09fb808c192f9b6a8af9c21ec39d0f971
MD5 77878f7a10b6b9841474868f044ee6f6
BLAKE2b-256 d41ca328c5dc0cdc2f53271dd61ff9cb1d2a4088b5b0ddb3dee518e7606ef20c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page