This project is a shop management system developed using FastApi and SQLAlchemy. It provides functionalities for managing users, products, categories, orders, comments, and images. Additionally, it offers RESTful API routes for common operations related to user management, orders, products, categories, comments, and file handling.
- User: Represents a user of the system with attributes such as name, email, phone number, etc.
- Product: Represents a product available in the shop with attributes like name, stock, price, etc.
- Category: Represents a category to which products can be associated.
- Order: Represents an order made by a user, containing information like quantity, total price, etc.
- Comment: Represents a comment left by a user on a product.
- Image: Represents an image associated with a product.
- GET /api/v1/user/me: Get current user details.
- POST /api/v1/user/login: User login.
- PATCH /api/v1/user/change_password/: Change user's password.
- PATCH /api/v1/user/update_info/: Update user's information.
- POST /api/v1/order/new: Create a new order.
- GET /api/v1/order/{order_id}: Get details of a specific order.
- POST /api/v1/product/new/: Create a new product.
- GET /api/v1/product/{product_id}: Get details of a specific product.
- GET /api/v1/product/{product_id}/comments/: Get comments associated with a specific product.
- POST /api/v1/comment/new/: Add a new comment.
- GET /api/v1/comment/{comment_id}: Get details of a specific comment.
- POST /api/v1/category/new/: Create a new category.
- GET /api/v1/category/{category_id}: Get details of a specific category by ID.
- GET /api/v1/category/{category_slug}: Get details of a specific category by slug.
- GET /api/v1/category/all/: Get details of all categories.
- POST /api/v1/file/upload_image/: Upload an image.
This project is a shop management system developed using FastApi and SQLAlchemy. It provides functionalities for managing users, products, categories, orders, comments, and images. Additionally, it offers RESTful API routes for common operations related to user management, orders, products, categories, comments, and file handling.
- Python: Utilized for backend development and business logic implementation.
- FastAPI: Chosen as the web framework for its performance, ease of use, and automatic generation of OpenAPI documentation.
- SQLAlchemy: Employed for database management and Object-Relational Mapping (ORM) between Python classes and database tables.
- Docker: Employed for containerization, facilitating easy deployment and scalability of the application.
- Supervisor: Utilized for process control and monitoring to ensure the reliability and availability of the application.
- Backend Development: Proficient in developing web applications using FastApi, designing RESTful APIs, and handling HTTP requests and responses.
- Database Management: Skilled in designing database schemas, implementing data models using SQLAlchemy, and performing CRUD operations on database entities.
- Containerization: Experienced in containerizing applications using Docker for portability, consistency, and isolation of development environments.
- Process Management: Proficient in managing application processes using Supervisor, ensuring system reliability, and monitoring performance metrics.
- Clone the repository:
git clone https://github.com/mosishon/shop-backend.git
- Build Container:
docker build -t shop .
- Rename
.env.sample
to.env
and update the.env
file with the appropriate values for your environment settings. - Run container as you wish
- Define your database schema by extending the provided base class
Base
and creating your model classes. - Customize the models according to your shop's requirements, modifying attributes and relationships as needed.
- Implement the provided RESTful API routes in your application for managing users, orders, products, categories, comments, and images.
- Utilize Docker for containerization and Supervisor for process management to deploy and monitor your application.
This project is licensed under the MIT License.