Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hima890/techstore-platform
Reconnecting tech businesses with their audience
https://github.com/hima890/techstore-platform
alx alx-africa alx-software-engineering api-rest e-commerce flask flask-api js mysql-database nginx otp-verification python3 react sqlalchemy sqlalchemy-python token-based-authentication ubuntu-server ubuntuserver webapp
Last synced: 8 days ago
JSON representation
Reconnecting tech businesses with their audience
- Host: GitHub
- URL: https://github.com/hima890/techstore-platform
- Owner: hima890
- License: gpl-3.0
- Created: 2024-07-19T13:02:07.000Z (6 months ago)
- Default Branch: main
- Last Pushed: 2024-10-06T06:14:13.000Z (3 months ago)
- Last Synced: 2024-11-06T13:09:01.193Z (about 2 months ago)
- Topics: alx, alx-africa, alx-software-engineering, api-rest, e-commerce, flask, flask-api, js, mysql-database, nginx, otp-verification, python3, react, sqlalchemy, sqlalchemy-python, token-based-authentication, ubuntu-server, ubuntuserver, webapp
- Language: Python
- Homepage:
- Size: 17 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# TechStore Platform
TechStore Platform is a web-based application built to help tech gadget store owners manage their businesses online by reconnecting them with their customers. The platform is designed to provide seamless management of stores, products, and orders in an organized and user-friendly way. It allows providers (store owners) to manage their inventories, while customers can browse stores and place orders directly on the platform.
## Key Features
- **Store Management**: Providers can create, update, and delete stores with details such as name, location, contact information, and images.
- **Product Management**: Providers can manage product inventories, including adding, updating, and deleting products, each associated with a store.
- **Order Management**: Customers can browse products and place orders from any store.
- **Search Functionality**: Customers can search for products based on category or store name.
- **User Authentication**: Both providers and customers must be authenticated using JWT (JSON Web Tokens) for secure access.
- **Rate Limiting**: Protects the platform from abuse by limiting the number of requests per user.
- **Image Management**: Handles file uploads for store and product images.
- **Flask Swagger Integration**: Provides automatic API documentation for ease of use.## Technologies Used
- **Backend**: Flask (Python)
- **Database**: SQLAlchemy for ORM, with support for PostgreSQL or SQLite
- **Authentication**: JWT (JSON Web Token) for secure user authentication
- **Rate Limiting**: Flask-Limiter for request rate limiting
- **Image Upload**: Custom utilities for managing product and store images
- **API Documentation**: Swagger (via Flasgger) for auto-generated API documentation
- **Containerization**: Docker and Docker Compose for development and deployment
- **Testing**: Pytest for unit testing## Project Overview
TechStore Platform consists of two main user roles: **Providers** (store owners) and **Customers**. Providers can manage their stores and product inventories, while customers can search for products and place orders.### Provider Features
- Register and manage stores
- Add, update, and delete products in their stores
- Upload and manage product images
- View and manage customer orders### Customer Features
- Search for products by category or store name
- Browse stores and view product details
- Place orders from stores
- View order status and history## Setup and Installation
### Prerequisites
- Python 3.8+
- PostgreSQL or SQLite for database management
- Docker (optional, for containerization)### Installation
1. **Clone the repository**:
```bash
git clone https://github.com/yourusername/TechStore-Platform.git
cd TechStore-Platform
```2. **Create and activate a virtual environment**:
```bash
python3 -m venv venv
source venv/bin/activate
```3. **Install dependencies**:
```bash
pip install -r requirements.txt
```4. **Set up environment variables**:
Create a `.env` file in the root directory and add:
```env
FLASK_ENV=development
SECRET_KEY=your_secret_key
SQLALCHEMY_DATABASE_URI=sqlite:///your_database.db
JWT_SECRET_KEY=your_jwt_secret
```5. **Initialize the database**:
```bash
flask db upgrade
```6. **Run the application**:
```bash
flask run
```7. **Access the app**:
Navigate to `http://127.0.0.1:5000` in your browser.## Deployment
### Using Docker
1. **Build and run the container**:
```bash
docker-compose up --build
```2. **Access the application**:
Once the container is running, the application will be available at `http://localhost:5000`.## Contributing
If you want to contribute to TechStore Platform, please follow these steps:
1. Fork the repository.
2. Create a new branch for your feature or bugfix.
3. Commit your changes.
4. Push your branch and create a pull request.## Authors
- Ibrahim hanafi - Github
- Ruba Salih - Github
- Mohamed Alamen - Github## License
This project is licensed under the MIT License. See the [LICENSE](LICENSE) file for details.