- Introduction
- DevStack
- Features
- Installation and Setup
- Usage
- API Endpoints
- Known Issues
- Contributing
- Future Features
Welcome to Percent! a simple graphical tools illustrates what percentage of life passed for individuals in different countries. This app allows users to register, sign in, add their residences with specific date ranges and purpose of residing in a particular country. The app then provides a visual representation of the time spent in different countries using a diagram.
The percent app is build using the following technologies:
- FastAPI: A modern, fast, web framework for building APIs with Python.
- Poetry: A dependency management tool for Python projects.
- JWT: JSON Web Tokens for secure user authentication.
- PostgresSQL:
- SQLAlchemy: A powerful and flexible ORM (Object-Relational Mapping) for interacting with the database.
- Alembic: A database migration tool to manage the evolution of the database schema.
- Pydantic: A data validation and parsing library used to define data schemas.
- JavaScript: Used for enhancing for app's frontend interactivity.
- Docker and Docker Compose: For containerization and simplifying the deployment process.
- Matplotlib: A Python library for creating visualizations and diagram.
The initial version of the Percent app includes the following features:
- User Registration and Login: Users can creat new accounts and log in securely using JWT-based authentication.
- Residence: Users can add their residences in different countries with specific start and end dates and provide a reason for residing there (e.g. Matherlands, Work, Study, or Travel)
- Edit Residences: User can edit or delete residences later.
Set up needs the following steps:
- Clone the repository from Github:
git clone [email protected]:Karimai/percent.git
- Install Poetry: Follow instructions on poetry docs for installation.
- Alternatively, you can use Docker. Ensure Docker and Docker Compose are installed. By running the
docker-compose up --build
, you can bring up the app in container and browse the app with http://127.0.0.1:8000/.
Visit http://localhost:8000/ in your browser to access the app.
The main of APIs are listed as follow:
- /login
- /user/logout
- /user/register/
- /residence/residences
- /residence/newresidence
- /diagram
- /docs: for documentation.
It is an initial version and there are a lot of points for improvements:
- some sanity check in entrance a new residence. Even time are not checking at the moments. The end time can be before the start time.
- keep the access_token has a security issue. It should be removed.
- Need a User Profile page.
- User should be able to choose different type of graph type.
- Use Dependency Injection for user login. Now I use http middleware.
- Access token should not be kept in the cookie and it should be kept in request header. Currently it is relying on server-side session. Pass the access token as an Authentication header in the request.
Contributions to the Percent app are welcome! You can help me to make it better if you write to me your suggestions or report bugs that you found during your surf.
- Add Present checkbox in the new residence page
- A lot of improvement in diagram page.
The Percent app is licensed under the MIT License. Feel free to use, modify, and distribute the app according to the license.
While the main goal of this project is for working with Google Cloud Platform (GCP), still the basic functionalities can be seen with https://percent-app-th4sozzjba-uc.a.run.app/