Installation¶
To install the API you need a Python 3.x installed also venv module and pip.
Here will be covered two types of installation for debugging and for production.
Mutual Steps¶
Clone the repository with the command
Rename.env.example
to .env
In linux
Enter the environment variables in .env
file.
PAGINATION_PAGE_SIZE
is used for pagination used in the API certain endpoint.DJANGO_SECRET
you can generate the secret online -> link
or with the following command if you have installed django on the machineX_AUTH_HEADER
also you can generate random UUID online that will be used for authentication
for the read only endpoint. Example header261ec18d-0e81-4073-8d9e-b34a7a1e5e06
(Don`t use it this is for demo purpose)
Installing locally (Debug mode)¶
You can create a virtual environment and click of the API. Note replace the 3.x with actual Python version
Make the needed migrations so Django can create sqlite database file with tables.
$ cd forkapi
$ python manage.py makemigrations authentication
$ python manage.py makemigrations recipe
$ python manage.py migrate
At this point everything should be ok, and you can start the server.
localhost:8000
.
In this mode you can use it locally if in debug mode which you can change in /forkapi/settings.py
file line 27
Installing in Docker container (Production)¶
To installing in Docker container follow the steps bellow.
For Raspberry Pi with Raspbian OS make sure to uncomment the packages in the main Dockerfile on line 16
- First steps is setting up the
fullchain.pem
andprivkey.pem
files needed for the ssl settings innginx
used as reverse proxy. - After you obtain ssl certificates for your domain you need to copy them in the
nginx/ssl
folder. - Replace the
localhost
value forserver_name
on lines8
and14
with your actual domain name in theforkapi/forkapi.nginx.conf
configuration file. -
That all you need to run the
docker compose
command and the API will be deployed on the server instance or locally on your machine. -
Access the admin dashboard at
your-domain:80
oryour-domain:443
Info
I will not include steps for setting the domain name servers on this as you can follow the official documentation on your server or the Raspberry Pi documentation.
Follow next step to check how you can and must made your first request.