Abordagem: Utilizado um projeto meu de base acrescentando a o app e o viewset Coupon (Cupom) onde o POST /coupon/ trata-se da criação do cupom e o POST /coupon/use_coupon/ trata-se da utilização do cupom.
Por que desta abordagem? Acredito que um cupom não seja apenas um ID inteiro, caso fosse poderia tratar-se com o próprio POST de criação e o PUT para sua utilização/atualização.
Entretanto, acredito que um cupom possa ser várias letras e números, podendo em caso de ser utilizado como chave primária prejudicar consultas e performance. Também, deixaria exposto o cupom como chave ao ser utilizado no navegador.
Versão do Python 3.8.10
python3 -m venv venv
OR
virtualenv --python=python3 venv
source venv/bin/activate
pip install -r requirements.txt
sudo -i -u postgres
psql
CREATE USER user_default WITH PASSWORD 'defaultdatabase';
ALTER USER user_default CREATEDB;
CREATE DATABASE default_database;
ALTER DATABASE default_database OWNER TO user_default;
CREATE EXTENSION pg_trgm;
python manage.py migrate
python manage.py collectstatic
python manage.py runserver
python manage.py createsuperuser
To login use email and password
/docs
/docs/redoc
python manage.py test --failfast coupon
coverage run --source='./coupon' manage.py test
coverage report
coverage html
python manage.py makemessages --locale pt_BR
Change to pt-br on settings:
LANGUAGE_CODE= 'pt-BT'
Obs: Necessary translate to portuguese.
Use endpoint /auth/signup/
Before use /auth/jwt/create/
Now you have your access_token and refresh_token
Bearer {access_token}
python manage.py dumpdata {app} --indent 4 > seed/{app}.json
bash migrate_and_seed.sh