Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/victorgoubet/capitalquest

The best capital quizz of the world
https://github.com/victorgoubet/capitalquest

api capital fastapi pydantic python quizz streamlit webapp

Last synced: 3 months ago
JSON representation

The best capital quizz of the world

Awesome Lists containing this project

README

        



Capital Quest Logo

Capital Quest


Test your knowledge of world capitals with this interactive quiz game!

ยท Play here ยท



CI Pipeline

## Table of Contents ๐Ÿ“™
- [Play the Game](#play-the-game-)
- [Installation for Developers](#installation-for-developers-)
- [Prerequisites](#prerequisites)
- [Option 1: Git Clone](#option-1-git-clone-)
- [Option 2: Docker](#option-2-docker-)


## Play the Game ๐ŸŒ

Play Capital Quest [here][game-url]

## Installation for Developers ๐Ÿ› ๏ธ

If you want to run Capital Quest locally, follow these steps:

### Prerequisites

- Python 3.10 or higher
- Git

### Option 1: Git Clone ๐Ÿ™

1. Clone the repository:
```bash
git clone https://github.com/VictorGoubet/capitalquest.git
cd capitalquest
```

2. Install dependencies:
```bash
pip install -r requirements.txt
```
3. Run the application:
```bash
python launch.py
```

This will start both the API and front-end components in development mode.

Customize with options:
- `--env`: Choose between `dev` (default) or `prod` environments
- `--component`: Run `api`, `front`, or `both` (default) components
- `--api-host`, `--api-port`: Set custom API host/port (default: localhost:8000)
- `--front-host`, `--front-port`: Set custom front-end host/port (default: localhost:8051)

Example:
```bash
python launch.py --env prod --component api --api-port 8080
```

Note: You can also set these options using environment variables or a .env file:
```bash
export api_host=localhost
export api_port=8000
export front_host=localhost
export front_port=8051
export environment=dev
```

4. Open your browser and navigate to `http://localhost:8051` (or your custom front-end port)

### Option 2: Docker ๐Ÿณ

A Docker image is available for easy setup:

1. Pull the Docker image:
```bash
docker pull victorgoubet/capitalquest:latest
```

2. Run the container:
```bash
docker run -p 8051:8051 victorgoubet/capitalquest:latest
```

3. Access the game at `http://localhost:8051`

---

[game-url]: https://capitalquest-nvde.onrender.com/