Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/passidel/thalia
Thalia book price tracker
https://github.com/passidel/thalia
books bun docker nuxt price thalia tracker vue
Last synced: about 1 month ago
JSON representation
Thalia book price tracker
- Host: GitHub
- URL: https://github.com/passidel/thalia
- Owner: PassiDel
- License: gpl-3.0
- Created: 2024-10-26T14:03:01.000Z (3 months ago)
- Default Branch: main
- Last Pushed: 2024-11-22T15:46:07.000Z (2 months ago)
- Last Synced: 2024-11-22T16:35:19.945Z (2 months ago)
- Topics: books, bun, docker, nuxt, price, thalia, tracker, vue
- Language: TypeScript
- Homepage: https://thalia.syma.dev/
- Size: 735 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Thalia book price tracker
Track the pricing of books over time.
## Tech
### Infrastructure
[Nuxt](https://nuxt.com/) is used as an integrated solution for the front and back end. The backend, based on Nitro
endpoints, requests data
from the Influx and Redis database and sends it to the frontend. If another book is to be tracked, a new schedule is
inserted via [BullMQ](https://bullmq.io/). Both the Nuxt application and the worker run using [Bun](https://bun.sh/).![Infrastructure](assets/infra.drawio.png)
The web, worker and proxy container can be scaled as pleased, because of the included "load balancing" of docker network
using DNS.### Fetching price data - Sequence diagram
![Sequence diagram](assets/sequence.drawio.png)
## Setup
Make sure to install dependencies:
```bash
# bun
cp .env.example .env
# now change the values
docker compose up -dbun install
cd queue
bun install
```## Development Server
Start the development server on `http://localhost:3000`:
```bash
# bun
bun run devcd queue
bun run worker
```## Production
Copy both the `docker-compose.yml` and `.env.example`, change the parameters to your liking and then start the stack:
```bash
cp .env.example .env
# now change the valuesdocker compose --profile prod pull
docker compose --profile prod up -d
```