site/backend/README.md

76 lines
1.6 KiB
Markdown
Raw Normal View History

2024-08-01 22:21:07 -07:00
## Workflow:
- should work with flask run locally and dockerfile build
- local dev
- local / venv pip install
- record versionless pips manually here
- pip freeze snapshots into project requirements
- docker build then copies frozen requirements
2024-08-01 06:35:28 -07:00
2024-08-01 03:53:33 -07:00
2024-08-01 22:21:07 -07:00
## pip:
2024-08-03 08:37:27 -07:00
mariadb may take extra work: gcc, libmariadb-dev
2024-08-01 03:53:33 -07:00
```
2024-07-31 23:56:27 -07:00
pip install flask
pip install python-dotenv
2024-08-01 03:53:33 -07:00
pip install flask-wtf
2024-08-01 06:35:28 -07:00
pip install flask-sqlalchemy
pip install flask-migrate
2024-08-01 11:10:49 -07:00
pip install flask-login
pip install email-validator
2024-08-03 02:14:20 -07:00
pip install pydenticon
2024-08-04 22:00:07 -07:00
pip install flask-mail
pip install pyjwt
2024-08-04 04:39:49 -07:00
Prod only, require sys packages:
2024-08-03 08:37:27 -07:00
pip install mariadb
2024-08-04 04:39:49 -07:00
pip install uwsgi
2024-08-01 22:21:07 -07:00
...
2024-08-04 05:44:20 -07:00
```
Freeze/requirements.txt. Better to audit this inside python:3-bookworm-slim container.
```
2024-08-01 06:35:28 -07:00
pip freeze > requirements.txt
```
2024-08-01 22:21:07 -07:00
## db cheat:
2024-08-03 05:38:58 -07:00
After db schema change:
2024-08-01 03:53:33 -07:00
```
2024-08-03 05:38:58 -07:00
flask db migrate -m "add users table"
2024-08-01 06:35:28 -07:00
flask db upgrade
2024-08-03 05:38:58 -07:00
```
2024-08-01 06:35:28 -07:00
2024-08-03 05:38:58 -07:00
Dump data if db in good state:
```
flask db downgrade base
2024-08-01 06:35:28 -07:00
flask db upgrade
2024-08-03 05:38:58 -07:00
```
2024-08-03 04:59:05 -07:00
2024-08-04 04:39:49 -07:00
Full reset or maria init:
2024-08-03 05:38:58 -07:00
```
2024-08-04 04:39:49 -07:00
sql:
drop table users;
drop table posts;
2024-08-03 04:59:05 -07:00
rm app.db
rm -r migrations
flask db init
flask db migrate
flask db upgrade
2024-08-01 06:35:28 -07:00
```
2024-08-03 05:38:58 -07:00
2024-08-01 22:21:07 -07:00
## build notes:
Dockerfile needs dockerignore or preferably explicitly defined copies for:
- app
- config
- project dir
- requirements
- not dotflaskenv, vars set with dockerfile
2024-08-03 11:45:37 -07:00
## docker setup:
- py logger handler StreamHandler is buggy to the point of being useless. Use logfile and link to stdout in Docker build
2024-08-01 22:21:07 -07:00
## notes:
- compose has entry that overrides flask with uwsgi for prod
- miminal environment vars come through project env, pass through compose
- no dotenv here, dotflaskenv goes into image
- keep env untracked but templated, dotflaskenv is tracked and public