Skip to content

Creating a Golang-based e-wallet app with PostgreSQL for secure user fund and transaction management. Features include strong transaction handling, user authentication, and smooth API integration for seamless financial operations.

Notifications You must be signed in to change notification settings

saadozone/Secure-Go-Wallet

Repository files navigation

Wallet Manager: Streamlined Digital Fund Transfers

Description

Wallet Manager is a robust and efficient application designed to simplify and secure digital fund transfers between user wallets. With an intuitive interface and powerful backend, Wallet Manager ensures seamless transactions and comprehensive management of user wallets.

Prerequisites

  • Docker
  • Docker Compose
  • PostgreSQL client

Getting Started

Step 1: Clone the Repository

Clone this repository to your local machine using:

git clone https://github.com/saadozone/Secure-Go-Wallet.git

Step 2: Set Up Environment Variables Create a .env file in the project root directory and add the following environment variables:

POSTGRES_USER=saadbinnoman
POSTGRES_PASSWORD=yourpassword
POSTGRES_DB=yourdatabase

Step 3: Docker Compose Up Navigate to the project directory and run Docker Compose to set up the PostgreSQL database container: docker-compose up Step 4: Create a New User:

Exec into the PostgreSQL container and create a new user: docker exec -it your-project-db-container psql -U saadbinnoman -d postgres Once inside the PostgreSQL shell, run:

CREATE USER newusername WITH PASSWORD 'newpassword';
GRANT ALL PRIVILEGES ON DATABASE postgres TO newusername;

Step 5: Perform SQL Data Dump To load your initial data and create the necessary tables and foreign keys, you need to perform an SQL data dump. Assuming your SQL dump file is named database_dump.sql and located in the root of your project directory, run:

docker cp database_dump.sql your-project-db-container:/database_dump.sql
docker exec -it your-project-db-container psql -U saadbinnoman -d postgres -f /database_dump.sql

Usage Checking the Source of Funds Table To check if the source_of_funds table exists and view its contents:

docker exec -it your-project-db-container psql -U saadbinnoman -d postgres

# Inside the PostgreSQL shell
\dt public.source_of_funds
SELECT * FROM public.source_of_funds;

Here’s a summary of the entities and their relationships:

Entities: graph LR
- User [Users] --> |deposits into| Wallet [Wallets]
- User [Users] --> |has many| Transaction [Transactions]
- Wallet [Wallets] --> |involved in| Transaction [Transactions]
- Source of Funds [Source of Funds] --> |has| Types of transsactions [Wallets]

ERD DIAGRAM: image

API Documentation : Transfer Endpoint, Endpoint for transferring funds.

URL: /deduct

Method: POST

Request Body:

{
  "amount": 50000,
  "wallet_number": 100001,
  "description": "Transfer to friend"
}

User Registration Endpoint Endpoint for registering a new user.

URL: /users/sign-up

Method: POST

Request Body:

{
  "name": "John Doe",
  "email": "[email protected]",
  "password": "securepassword"
}

User Login Endpoint Endpoint for logging in a user.

URL: /users/sign-in

Method: POST

Request Body:

{
  "email": "[email protected]",
  "password": "securepassword"
}

Get User Wallets Endpoint Endpoint for fetching all wallets associated with a user.

URL: /balance

Method: GET

Headers:

{
  "Authorization": "Bearer your_jwt_token"
}

Add Funds to Wallet Endpoint Endpoint for adding funds to a user's wallet.

URL: /wallets/topup

Method: POST

Request Body:

  "wallet_number": 100001,
  "amount": 10000,
  "source_of_funds_id": 1
}
and 
{
  "Authorization": "Bearer your_jwt_token"
}

Get Wallet Transactions Endpoint Endpoint for fetching all transactions of a specific wallet.

URL: /wallets/{wallet_number}/transactions

Method: GET

Headers:

{
  "Authorization": "Bearer your_jwt_token"
}

Tools Used In this project, several tools are utilized, although you can opt for similar libraries that serve the same purpose. However, be aware that different libraries may have varying implementation methods.

All libraries are listed in go.mod:

github.com/vektra/mockery: Used to generate mocks for testing purposes. github.com/swagger-api/swagger-ui: Used to create API documentation. Feel free to use equivalent libraries that suit your needs.

Troubleshooting : Common Issues If you encounter any issues with the database connection, ensure that the environment variables in the .env file match your Docker Compose configuration. Ensure that the database_dump.sql file is correctly formatted and contains all necessary SQL commands to set up your database schema

About

Creating a Golang-based e-wallet app with PostgreSQL for secure user fund and transaction management. Features include strong transaction handling, user authentication, and smooth API integration for seamless financial operations.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages