Skip to main content

A tool to create Model-W-compliant projects

Project description

Model W Project Maker

This project maker is the simplest way to start a Model W project.

The goal is to be extremely simple:

curl -s https://pypi.run/modelw-project-maker/model_w.project_maker | python3.11

This will ask you a few questions and create the project's directory for you.

Prerequisites

In order to execute the script, you need:

  • Python 3.11 (you can use pyenv to load it in your current shell)
  • Poetry (follow the instructions on their website)
  • Git (you know where to get it)
  • Git Flow (apt install git-flow or brew install git-flow depending on your OS)
  • Node and NPM (get it your favorite way)
  • PostgreSQL and Redis (if you enable the API side)

What to do next

Once the script is done, you'll have a directory with the project's name. You can then cd into it and start working on it.

Environment setup

You can start by installing the dependencies:

# If you enabled the API
cd api
poetry install
cd ..

# If you enabled the frontend
cd front
npm install

If you enabled the API, you then need to create the database:

sudo -u postgres psql -c "CREATE DATABASE <project_name>"
sudo -u postgres psql -c "CREATE USER <project_name> WITH LOGIN PASSWORD '<project_name>'"
sudo -u postgres psql -c "GRANT ALL PRIVILEGES ON DATABASE <project_name> TO <project_name>"

Finally, have a look at api/.env and/or front/.env and make sure that values there are correct.

For the Django side, until you add more settings by yourself to settings.py, you can use all the settings from the Model W Django Preset.

If you've enabled Wagtail, you need to configure the storage environment variables, which should be commented out in your .env. You need to check with someone in charge of the infrastructure to get those values (if it's yourself, you're in luck).

Django models customization

Something important in Django is to customize the User model to your needs. Even if you don't need it right now, you'll eventually be happy that you did it because you'll always need to add fields to it.

Thus one of the first things you should do is to go check in the people app's models the custom User model that is provided by default in this template. Modify it to your needs.

Note — If you modify the User model and you are not satisfied with the initial migration then you can delete it and create it anew. The only thing is that you'll have to manually add CreateExtension("citext") on top of the operations list in the 0001_initial.py migration file.

If you've enabled Wagtail, the same applies for the Image and Document models present in the cms app.

Still in Wagtail, the root page is replaced by a HomePage (defined in cms/models.py) in one of the migrations generated by the template. If that's not okay for you, now is the time to change it. However most likely it's going to be convenient for you, because otherwise you'll need to do it manually in Wagtail's admin. The only drawback is that when you'll want to add fields to the HomePage you will have to figure default values.

Once you've adjusted all the models to your needs, feel free to make the migrations and run them:

api/pmanage makemigrations
api/pmanage migrate

Note — You'll notice that there is a pmanage script in addition of the manage.py script. It's simply a wrapper to call manage.py through the Poetry virtual environment.

SvelteKit/Wagtail integration

If you have chosen a CMS, there will be a SvelteKit/Wagtail integration, using Wagtail's v2 API.

A [...cmsPath] directory will be created in the front directory, which is a catch-all for all the CMS paths.

Inside, $lib/components/ there is a cms directory, which contains the Svelte components for the CMS such as blocks and pages.

To make a CMS page work, create a component in the cms directory with the same name as the Wagtail page type, and it will automatically be imported and rendered when landing on a page of that type.

Contributing

If you're developing this package and you want to make a release, you can simply run:

make release VERSION=<version>

Then you'll still need to push the branches and tags.

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

modelw_project_maker-2024.10.1.tar.gz (213.1 kB view details)

Uploaded Source

Built Distribution

modelw_project_maker-2024.10.1-py3-none-any.whl (261.9 kB view details)

Uploaded Python 3

File details

Details for the file modelw_project_maker-2024.10.1.tar.gz.

File metadata

  • Download URL: modelw_project_maker-2024.10.1.tar.gz
  • Upload date:
  • Size: 213.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.10.12 Linux/6.8.0-1014-azure

File hashes

Hashes for modelw_project_maker-2024.10.1.tar.gz
Algorithm Hash digest
SHA256 a2be57499d3b8ae65b520125695be71c5e1455c1edd07045ab02d15f8f423268
MD5 18cb0ac425ef896ecef8734b9a4318a2
BLAKE2b-256 b8b9e1be3350ad3d9ead2139cd1eded14ff98995ae835fe0b39b3ef4f5711c44

See more details on using hashes here.

File details

Details for the file modelw_project_maker-2024.10.1-py3-none-any.whl.

File metadata

File hashes

Hashes for modelw_project_maker-2024.10.1-py3-none-any.whl
Algorithm Hash digest
SHA256 825607b079790793201c863141a9f31bd3d295f42477f4d7e9c1168bafd38afb
MD5 c15fd16638fabb94f3549ffee4eca886
BLAKE2b-256 1a9c726270e0d2ba44a6391367ceae5815a4457c800c88996e31caf18fba8938

See more details on using hashes here.

Supported by

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