BasicTrade is a backend application designed to manage products and their variants, with robust authorization, authentication, and validation mechanisms. It leverages Gin Gonic for routing, GORM for ORM, JWT for authentication, and Cloudinary for image uploads.
- Admin Management
- Create, update, and delete products
- Upload product photos to Cloudinary
- Create, update, and delete product variants
- Authorization & Authentication
- Only the user who created a product can modify it
- JSON Web Token (JWT) based authentication
- Validation
- Field validations for all tables
- Image upload validations (format and size)
- Search & Pagination
- Search products by name
- Search variants by name
- Pagination for products and variants
Endpoint | Method | Description | Authorization |
---|---|---|---|
/login | POST | Authenticate admin and receive JWT token | No |
Endpoint | Method | Description | Authorization |
---|---|---|---|
/products | GET | Retrieve all products with optional name search and pagination | No |
/products/:uuid | GET | Retrieve product details by UUID | No |
/products | POST | Create a new product | Yes |
/products/:uuid | PUT | Update product details | Yes |
/products/:uuid | DELETE | Delete a product | Yes |
Endpoint | Method | Description | Authorization |
---|---|---|---|
/variants | GET | Retrieve all variants with optional name search and pagination | No |
/variants/:uuid | GET | Retrieve variant details by UUID | No |
/products/:uuid/variants | POST | Create a new variant for a product | Yes |
/variants/:uuid | PUT | Update variant details | Yes |
/variants/:uuid | DELETE | Delete a variant | Yes |
- Framework: Gin Gonic
- ORM: GORM
- Authentication: JWT
- Image Upload: Cloudinary
- Database: PostgreSQL
github.com/golang-jwt/jwt/v5
golang.org/x/crypto
github.com/cloudinary/cloudinary-go/v2
- Go 1.16+
- PostgreSQL
- Cloudinary Account
To use BasicTrade, follow these steps:
-
Access the Application
- Access the application locally at http://localhost:7070.
-
Interact with Endpoints
- Use tools like Postman or any REST client to interact with the endpoints.
- Refer to the Endpoints section in the README for a list of available endpoints and their descriptions.
-
Authentication
- Certain endpoints require authentication using JSON Web Tokens (JWT). Make sure to obtain a JWT token by logging in via the
/login
endpoint before accessing authenticated endpoints.
- Certain endpoints require authentication using JSON Web Tokens (JWT). Make sure to obtain a JWT token by logging in via the
-
Testing
- Test different scenarios by sending requests to various endpoints.
- Ensure proper handling of validations, authorization, and error responses as per the API documentation.
-
Deployment
- Deploy the application to your preferred environment for production use. Ensure all necessary configurations (database, Cloudinary credentials, etc.) are correctly set up.
-
Feedback and Contributions
- Provide feedback or suggestions for improvement by raising an issue or submitting a pull request on the project's repository.