This project involves the development of a cross-platform mobile application for fitness tracking, workout planning, and personalized nutrition. The app aims to simplify the fitness journey by combining various features like progress tracking, workout and nutrition plan creation, and a marketplace for fitness influencers to sell their programs.
- User Authentication: Secure login and registration system for users.
- Workout & Nutrition Plans: Users can create, track, and edit their custom workout and nutrition plans.
- Progress Tracking: Log workouts, monitor performance, and track body measurements over time.
- Influencer Marketplace: Fitness influencers can sell their training plans directly within the app.
- Public Plan Sharing: Users can browse, rate, and share fitness plans with the community.
- Membership System: Paid membership provides access to exclusive content and additional programs.
- Payment Integration: In-app payments for purchasing plans and membership subscriptions.
- Frontend: React Native for cross-platform mobile app development.
- Backend: Go programming language with the Echo framework for building the backend.
- Database: SQL-based database for storing user data, plans, and progress.
- Deployment: AWS for hosting the backend and mobile application deployment on App Store and Google Play.
- Security: JWT authentication, encryption, and best practices for data protection.
- Agile methodology for iterative development, with regular testing and feedback.
- Develop a fully functional fitness app that allows users to manage their fitness journey, from tracking progress to accessing personalized plans.
- Provide a seamless experience for fitness influencers to monetize their content.
- Learn and apply mobile and web development practices, including database management, security, and payment integration.
To set up the project locally, follow these steps:
- Clone the repository:
git clone https://github.com/thisisby/final_year_project.git
- Implements the Clean Architecture pattern for a scalable and maintainable codebase
- Uses the Gin framework for efficient and fast handling of HTTP requests
- Integrates with PostgreSQL databases using SQLx.DB for powerful and flexible database operations
- Supports JWT authentication with configurable expiration and issuer, allowing for flexible and secure authentication processes.
- Supports OTP authentication with configurable expiration and Redis caching to store and retrieve the OTP codes, providing fast and efficient authentication processes.
- Go version 1.17 or higher
- PostgreSQL version 9.1 or higher
The application can be configured using environment variables to fit your specific needs. A sample environment file is provided as .env.example with the following variables available for customization:
PORT
: The port on which the server will listen (defaults to 8080)ENVIRONMENT
: The environment the application is running in (defaults to "development")DEBUG
: Enable or disable debug mode (defaults to true)
PostgreSQL
DB_POSTGRE_DRIVER
: The database driver to use (defaults to "postgres")DB_POSTGRE_DSN
: The database connection URI in DSN format (defaults to "user=myuser password=mypassword host=myhost port=5432 dbname=mydb sslmode=disable timezone=Asia/Jakarta")DB_POSTGRE_URL
: The database connection URI in URL format (defaults to "postgres://user:pass@host/db")
JWT_SECRET
: The secret key used to sign and verify JWT tokens (defaults to "dont-tuch-mytralalala-mydangdingdong")JWT_EXPIRED
: The number of hours until JWT tokens expire (defaults to 5)JWT_ISSUER
: The issuer of JWT tokens (defaults to "snykk_here")
OTP_EMAIL
: The email address to send OTP codes to (defaults to "[email protected]")OTP_PASSWORD
: The password to use for sending OTP codes (defaults to "idonthavepassword")
Redis
REDIS_HOST
: The host and port of the Redis server (defaults to "localhost:6969")REDIS_PASS
: The password to use for connecting to Redis (defaults to "mydangdingdong")REDIS_EXPIRED
: The number of minutes until cache items expire in Redis (defaults to 5)
root/
|-- cmd/
| |-- api
| | |-- server/
| | |-- main.go
| |-- cron/
| | |-- jobs/
| | |-- main.go
| |-- migration/
| | |-- migrations/
| | |-- main.go
| |-- seed
| |-- seeds/
| |-- main.go
|-- deploy/
| |-- Dockerfile
| |-- docker-compose.yml
|-- docs/
| |-- swagger.yaml
|-- internal/
| |-- business/
| | |-- domains
| | | |-- v1
| | | |-- domains.users.go
| | |-- usecases
| | |-- v1
| | |-- usecase.users.go
| | |-- usecase.users_test.go
| |-- config/
| | |-- .env
| | |-- .env.example
| | |-- config.go
| |-- constants/
| | |-- constant.users.go
| |-- datasources/
| | |-- caches/
| | | |-- cache.redis.go
| | |-- drivers/
| | | |-- driver.postgre.go
| | |-- records/
| | | |-- record.user.go
| | | |-- record.user_mapper_v1.go
| | |-- repositories
| | | |-- postgres/
| | | | |-- v1
| | | | |-- postgre.user.go
| | | |-- mongos/
| |-- http/
| | |-- datatransfers/
| | | |-- requests/
| | | | |-- request.users.go
| | | |-- responses/
| | | |-- response.users.go
| | |-- handlers/
| | | |-- v1/
| | | |-- handler.base_response.go
| | | |-- handler.users.go
| | | |-- handler.users_test.go
| | |-- middlewares/
| | | |-- middleware.auth.go
| | | |-- middleware.auth_test.go
| | |-- routes/
| | |-- route.users.go
| |-- mocks/
| | |-- mock.cache_redis.go
| |-- utils/
|-- pkg/
| |-- helpers/
| | |-- helper.bcrypt.go
| | |-- helper.bcrypt_test.go
| |-- jwt/
| | |-- jwt.go
| | |-- jwt_test.go
| |-- logger/
| |-- mailer/
| |-- validators/
|-- vendor/
|-- go.mod
|-- go.sum
|-- makefile
|-- README.md (thisfile)
|-- rest.http
This folder contains all the entry points of the application. There are four sub-folders in the cmd
folder:
-
api
: This folder contains the main entry point of the REST API server. Themain.go
file in theserver
sub-folder is responsible for starting the server and setting up all the necessary routes. -
cron
: This folder contains the main entry point for any cron jobs that need to be run. -
migration
: This folder contains the main entry point for managing database migrations. -
seed
: This folder contains the main entry point for seed data into the database.
This folder contains the necessary configuration files for deploying the application to a production environment.
-
Dockerfile
: This file is used to build a Docker image of the application. -
docker-compose.yml
: This file is used to start the application and its dependencies (such as the database) using Docker Compose.
This folder contains the documentation for the REST API, including the swagger.yaml
file which defines the API specification.
This folder contains all the business logic and other implementation details of the application. It is structured as follows:
-
business
folder-
domains folder: This folder contains domain-specific logic, such as the business rules for creating, updating, and deleting users.
-
usecases folder: This folder contains the implementation of the use cases that are defined in the domains folder.
-
-
config
folder.env
: This file contains the environment variables that are used by the application..env.example
: This file is an example of the .env file, with all the necessary environment variables listed.config.go
: This file reads the environment variables and sets up the configuration for the application.
-
constants
folder- this folder contains constant values used throughout the application.
-
datasources
foldercaches
folder: This folder contains the implementation of cache storage, such as Redis.drivers
folder: This folder contains the implementation of database drivers, such as PostgreSQL.records
folder: This folder contains the implementation of database records, such as User.repositories
folder: This folder contains the implementation of database repositories, such as PostgreSQL and MongoDB.
-
http
folderdatatransfers
folder: This folder contains the implementation of data transfer objects, such as request and response objects.handlers
folder: This folder contains the implementation of HTTP handlers, which handle incoming HTTP requests and send responses back to the client.middlewares
folder: This folder contains the implementation of middlewares, which are executed before the request is handled by the handler.routes
folder: This folder contains the implementation of routes, which map URLs to handlers.
-
mocks
folder- this folder contains the implementation of mock objects used in tests.
-
utils
folder- this folder contains utility functions and classes used throughout the application.
This folder contains reusable packages that are shared across different parts of the application.
This project is open for contributions and suggestions. If you have an idea for a new feature or a bug fix, don't hesitate to open a pull request
This project is licensed under the MIT License. See the LICENSE file for details.