You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
31 lines
1.2 KiB
31 lines
1.2 KiB
# ladylilia.com
|
|
|
|
## Project structure
|
|
|
|
* `quotes-api` - Flask application implementing RESTful API for querying/manipulating the database of quotes
|
|
* `comments-api` - Flask application implementing RESTful API for querying the database of Twitch comments
|
|
* `cms` - Grav CMS (Content Management System)
|
|
* `apps/quotes` - Angular application for browsing quotes
|
|
* `apps/schedule` - Angular application for viewing livestream schedule
|
|
* `nginx` - Configuration of NGINX web server
|
|
|
|
## Deployment
|
|
|
|
This project consists of 4 container images (`quotes-api`, `comments-api`, `cms` and `nginx`), that depend on each other - they need to run simultaneously and share certain data between themselves.
|
|
|
|
Easiest way to manage that is using `docker-compose`. Just copy `docker-compose.yaml.example` into `docker-compose.yaml`, make necessary adjustments and fire it all up with:
|
|
|
|
```BASH
|
|
docker-compose up -d
|
|
```
|
|
|
|
## Quotes API key generation
|
|
|
|
Quotes API key is needed for `POST`, `PUT` and `DELETE` API methods.
|
|
|
|
If the `quotes-api` container is running, then the key can be generated like this:
|
|
|
|
```BASH
|
|
docker exec $QUOTES_API_CONTAINER_NAME python generate_api_key.py $USERNAME $EXPIRATION_TIME_IN_SECONDS
|
|
```
|