Skip to content

Latest commit

 

History

History
273 lines (201 loc) · 10.8 KB

README.md

File metadata and controls

273 lines (201 loc) · 10.8 KB

Vue3 & FastAPI WebApp template

License

Code style: black Code style: flake8 code style: prettier

ci cd


This project is a template for a fullstack web application using Vue3 and FastAPI. It includes a basic example of a web application with a simple API and a frontend that consumes it, a simple web application that allows users to create notes. New notes and deleted notes are broadcasted to all connected clients using web sockets.

Template features

  • Modern Frameworks and Tools:

    • FastAPI: A modern, fast (high-performance), web framework for building APIs with Python 3.6+ based on standard Python type hints.
      • Web sockets: The backend includes an example of a WebSocket endpoint that the frontend connects to.q
    • Vue3: A progressive JavaScript framework for building user interfaces.
      • Router: Vue Router: The official router for Vue.js.
      • State management: Pinia: A Vue Store that is designed to be used in a modular way.
      • HTTP client: Axios: Promise based HTTP client for the browser and Node.js.
      • Vuetify: A Material Design component framework for Vue.js.
    • ArangoDB: A multi-model database system that supports document, key/value, and graph data models.
  • Containerization:

    • Docker: A platform for developing, shipping, and running applications using containerization. This project includes a Dockerfile that builds an image of the application.
    • Docker Compose: A tool for defining and running multi-container Docker applications. This project includes a docker-compose.yml file that defines the services for the frontend and backend.
    • Configuration with environment variables: The backend uses environment variables to configure the application.
  • Code Quality:

    • Black and Prettier: Code formatters that automatically format the code.
    • Flake8: A tool that checks the code for style and quality.
    • Cspell: A spell checker that checks the spelling in the code, edit the cspell.json file to add custom words or languages.
  • Testing:

    • Pytest: A testing framework for Python that makes it easy to write small tests.
  • Continuous Integration and Continuous Deployment:

    • GitHub Actions: This project includes a GitHub Actions workflow that runs the tests, linters, pushes the Docker image to the Docker Hub image registry, and deploys the application by calling an SSH script.

Getting started

Running the application in development mode

Prerequisites

  1. Clone the repository:
git clone https://github.com/Tomansion/Vue3-FastAPI-WebApp-template.git
cd Vue3-FastAPI-WebApp-template
  1. Install the backend and frontend dependencies:
make install

# Or manually:
cd backend
pip install -r requirements.txt
cd ../frontend
npm install
  1. Modify the configuration:

Follow the instructions in the backend/config/README.md. Modifying the configuration is required to give the application access to the ArangoDB instance.

  1. Run the backend and frontend:
make run

# Or manually:
cd backend
uvicorn websrv:app --reload --host 0.0.0.0 --port 3000
cd frontend # In another terminal
npm run serve
# Backend expected output
INFO:     Uvicorn running on http://127.0.0.1:8000 (Press CTRL+C to quit)
INFO:     Started reloader process [125657] using WatchFiles
No build directory found. Running in development mode.

Initializing configuration...
 - Set NOTES / NOTES_NUMBER_MAX
 - Set NOTES / NOTES_TITLE_LENGTH_MAX
 - Set NOTES / NOTES_CONTENT_LENGTH_MAX
 - Set ARANGODB / HOST
 - Set ARANGODB / PORT
 - Set ARANGODB / DATABASE
 - Set ARANGODB / USER
 - Set ARANGODB / PASSWORD

Connecting to ArangoDB...
 - Host: ***
 - Port: ***
 - Database: WebAppTemplate
 - User: WebAppTemplate
 - Connection to Arango Arango 3.11.5 established

Running FastAPI app...
 - FastAPI is available at http://localhost:3000/api
 - Swagger UI is available at http://localhost:3000/docs
 - Redoc is available at http://localhost:3000/redoc

INFO:     Started server process [125659]
INFO:     Waiting for application startup.
INFO:     Application startup complete.
  1. Open the different services in your browser:

Running the tests

# Install the test dependencies:
make install_test

# Run the tests:
make test

# Or manually:
cd backend
pytest --cov-report term --cov=. --cov-report=html -sx
firefox htmlcov/index.html
# Expected output
Name                         Stmts   Miss  Cover
------------------------------------------------
config/init_config.py           51     14    73%
services/notes_services.py      36      0   100%
utils/database_utils.py         76      6    92%
------------------------------------------------
TOTAL                          163     20    88%

============= 10 passed in 1.52s ===============
# The detailed coverage report wil be available in the `htmlcov` directory.

Code quality

This application provide a Makefile with some commands to help you with the code quality:

# Format the code with Black and Prettier:
make format

# Check the code with Black, Prettier, Flake8, and cSpell:
make check

# A pipeline is included in the GitHub Actions workflow that runs the linters, so make sure to fix any issues before pushing the code.

Running the application with Docker Compose

# Clone the repository:
git clone https://github.com/Tomansion/Vue3-FastAPI-WebApp-template.git
cd Vue3-FastAPI-WebApp-template

# Set the docker-compose environment variables
# More information in the backend/config/config.env file
nano docker-compose.yml

# Build and run the application with Docker Compose:
docker-compose up --build

The application should be available at: http://localhost:3000

Setting up the GitHub continuous deployment pipeline

This project includes a GitHub Actions workflow that builds the Docker image, pushes it to the Docker Hub image registry, and deploys the application by calling an SSH script.

Prerequisites

  • A Linux server with Docker and Docker Compose installed.
  • A Docker Hub account.

Steps

  1. Create a new repository from this template and push it to GitHub.
  2. Copy and edit the docker-compose.yml file to your server.
    • Edit the images to point to your Docker Hub repository.
    • Edit the environment variables to match your configuration.
    • Edit the container names and the other configurations as needed.
    • Add your Nginx or Traefik configuration if needed.
  3. Create, on your server a deploy.sh script with the following content:
# deploy.sh
cd /path/to/your/application
docker-compose pull
docker-compose up -d
# Use chmod +x deploy.sh to make the script executable
  1. Add the following secrets to your repository:
    • DOCKER_USERNAME: Your Docker Hub username.
    • DOCKER_PASSWORD: Your Docker Hub password.
    • SSH_HOST: The IP address of the server where you want to deploy the application.
    • SSH_PORT: The port to connect to the server.
    • SSH_USERNAME: The username to connect to the server.
    • SSH_PASSWORD: The user password to connect to the server.
    • SSH_SCRIPT_PATH: The absolute path to the deploy.sh script on the server.
  2. Modify the APP_NAMEin the continuous-deployment.yml file to match your application name.
  3. Push the changes to your repository.

The GitHub Actions workflow will run when you push the changes to the repository main branch. It will build the Docker image, push it to the Docker Hub image registry, and deploy the application by calling the deploy.sh script on your server.

Recommended VSCode extensions

Help

If you have any questions or need help, feel free to open an issue.

Contributing

I'm open to contributions and suggestions. Feel free to open an issue or a make a pull request.

TODO

  • Generate config.ini.example and config.env files automatically
  • Custom styles
  • I18n
  • Documentation
  • Authentication
  • Frontend tests
  • Frontend to mobile app
  • CI/CD pipeline
  • Demo link
  • Pinia store
  • Arango Database
  • Backend tests and coverage