Developing Pinry¶
Pinry currently has two major requirements:
- Python@3.6+
- NodeJS@18
For minor requirements you need two have installed two package managers that are not the defaults for these languages:
- Python, poetry
- NodeJS, pnpm
To install these is pretty simple, you can just run:
cd pinry
pip install poetry
npm install -g pnpm
After that you can install this project with:
poetry install
cd pinry-spa; pnpm install
You will need to run two separate items as of right now, the SPA and the backend:
poetry run python manage.py migrate
poetry run python manage.py runserver
And from another terminal:
cd pinry-spa; pnpm serve
Testing¶
We have many tests built into Pinry to ensure that changes don't break anything. If you are live dangerously and have cutting edge new Pinry features first you can use our master branch for your own instance. We recommend using our tags/versions though.
To run Pinry's tests inside the Pinry repo run:
poetry run python manage.py test
Docker¶
Follow the steps below to install Pinry locally or on any server. This process installs the minimal requirements to run Pinry. For development requirements and procedures, see testing above.
Current docker configuration will just mount source code directory to
docker app directory and run any codes existed in current git branch,
you may also add "local_settings.py" to customize settings without
changing settings file in pinry/settings
.
-
Install the requirements:
- Docker
- Docker Compose
-
Set any custom configuration options you need and run
cp docker-compose.example.yml docker-compose.yml
edit docker-compose.yml and change the secret-key,¶
don't forget to backup this config file.¶
You should build frontend first¶
docker-compose up build_frontend
then start the backend server¶
docker-compose up -d web
-
If you want to run Pinry with current user in docker
./start_docker_with_current_user.sh [-d]
-
Bootstrap the database(optional)
docker-compose exec web python3 manage.py migrate --settings=pinry.settings.docker
Note : No static file server configured, your should configure nginx or other server to serve
static files from ./static
(as path /static
) and ./pinry-spa/dist
(as html root /
)