The Virtual Bank API and web application are designed as a comprehensive solution for developers and learners who need a safe and controlled environment to simulate banking transactions. Whether you’re an aspiring developer exploring the intricacies of APIs, a tester validating the robustness of e-commerce platforms, or a professional working on complex payment gateway integrations, Virtual Bank offers a versatile platform tailored to meet these needs.
Built on the powerful Django framework, Virtual Bank not only facilitates the simulation of transactions but also provides an extensive range of features, including account management, transaction histories, and user authentication. This makes it an ideal tool for educational purposes, development, and testing scenarios where using real bank APIs would be impractical or risky.
By leveraging Virtual Bank, developers can experiment freely, test different use cases, and gain hands-on experience with financial transactions—all without the constraints or concerns of working with real banking systems. Whether you are building the next big fintech application or just beginning your journey in API development, Virtual Bank is here to support your learning and development needs.
- Virtual Bank API
- Table of Contents
Here are some potential ways the Virtual Bank API can be used, implemented, or integrated:
-
Personal Finance Management Apps: Integrate with personal finance tools to help users track expenses, incomes, and transfers between accounts.
-
Banking as a Service (BaaS): Offer the API as a BaaS platform, enabling developers to build financial services apps with a ready-made backend.
-
Integration with Payment Gateways: Connect with external payment processors like PayPal, Stripe, or Flutterwave to enable deposits and withdrawals between virtual and real-world accounts.
-
Mobile Banking Applications: Extend the API to support a mobile app that allows users to manage accounts, perform real-time transactions, and view account history.
-
E-Commerce Platforms: Integrate with e-commerce platforms to handle transactions for payments, refunds, or wallet top-ups, enabling seamless online shopping experiences.
-
Fintech APIs: Implement as part of a larger fintech platform, allowing companies to offer bank-like services without building a full banking infrastructure.
-
Integration with Analytics Tools: Use the API with business analytics tools to generate reports and visualizations of transaction data, helping businesses track cash flow and financial health.
-
Customizable Corporate Banking Solutions: Enable businesses to manage internal funds, process payroll, or allocate budgets to departments using the API.
-
Educational Tools: Implement as a tool for teaching financial literacy, using the API to simulate real-world banking scenarios.
-
API Gateway for Multiple Banking Services: Integrate the Virtual Bank API with other banking APIs to create a unified platform for users to manage multiple accounts and services.
-
Multi-Currency Support: Enhance to support multiple currencies and use in a global financial application where users can hold and exchange different currencies.
-
Blockchain Integration: Integrate with blockchain technologies to create secure, decentralized banking solutions, allowing for blockchain-based transfers and transactions.
-
Microloan Platforms: Adapt or Enhance the API to enable peer-to-peer lending services, where users can request loans, track repayments, and manage interest rates.
-
Digital Wallets for E-learning Platforms: Integrate with e-learning platforms to offer students a digital wallet for course payments, scholarships, or reward systems.
To set up the Virtual Bank project locally, follow these steps:
-
Clone the repository:
git clone https://github.com/GoldenThrust/virtual-bank.git cd virtual-bank
-
Create and activate a Python virtual environment:
Install the necessary packages, create and activate the virtual environment:
sudo apt install python3.10-venv python3 -m venv venv source venv/bin/activate
Install Python 3 if not already installed (you can use Homebrew to install it), then create and activate the virtual environment:
python3 -m venv venv source venv/bin/activate
If you don’t have Homebrew installed, you can install it by running:
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)" brew install python
Open the command prompt (or PowerShell) as an administrator. Run the following commands to create and activate the virtual environment:
python -m venv venv venv\Scripts\activate
Install pip (if necessary) and upgrade it: For all platforms (Linux, macOS, Windows):
python3 -m pip install --upgrade pip
Install project dependencies: Inside the activated virtual environment, run:
python3 -m pip install -r requirements.txt
Run the installation script:
Make the installation script executable and run it:
chmod +x install.sh ./install.sh
You may need to run the script manually if .sh files are not supported:
bash install.sh
-
Redis Setup for Django Channels Register on Redis Cloud: Go to Redis.io and register for a free Redis Cloud account. After registration, create a new Redis database instance and retrieve the connection URL.
This URL will be used to configure Redis in your Django project.
Add the Redis URL to your .env file: After setting up your Redis Cloud account, add the Redis connection URL to your .env file:
REDIS_URL=redis://your_redis_cloud_url:6379
-
Rename
.env-example
file in the root directory and edit environment variables:DEV=TRUE SECRET_KEY=b309e3c3f0f6d3fb71a62617c100f59bb166a585b6b124d2 JWT_KEY=00276c14dc8d8b2990a4b20024278907eccb2feec2a02eb8 DB_USER=postgres DB_PASSWORD=******* DB_NAME=virtual_bank DB_HOST=localhost DB_PORT=5432 PGHOST='example.us-east-2.aws.neon.tech' PGDATABASE='virtualbank' PGUSER='vb_owner' PGPASSWORD='*********' REDIS_URL=redis://your_redis_cloud_url:6379
- Default Configuration (PostgreSQL):
- Configure your PostgreSQL database by creating a user with the provided credentials (DB_USER and DB_PASSWORD). If you need help setting up PostgreSQL, you can refer to the official documentation.
- Other Databases:
- For different databases, refer to the Django documentation on database setup.
# .env file for local PostgreSQL DB_USER=your_db_username DB_PASSWORD=your_db_password DB_HOST=localhost DB_PORT=5432 DB_NAME=virtualbank
Neon is a cloud-native serverless Postgres solution that allows you to easily deploy scalable PostgreSQL databases. The Virtual Bank API project uses PostgreSQL for data management, and leveraging Neon for deployment provides a robust, cloud-based infrastructure with features like autoscaling, backups, and connection pooling.
Steps to Set Up Neon PostgreSQL for Your Virtual Bank Project:
-
Create an Account on Neon: Visit Neon.tech and register for a free account. Neon offers a free tier, which is perfect for development and testing purposes. Once your account is created, you can access the Neon dashboard, where you'll be able to create and manage your PostgreSQL instances.
-
Create a PostgreSQL Instance: From the Neon dashboard, click on the button to create a new PostgreSQL instance. You can configure the database with any specifications needed, such as the region (e.g., us-east-2), scaling preferences, and performance options. After creating the instance, Neon will provide you with the connection details, including the host, database name, user, and password. Keep these details secure, as they will be used in your application to connect to the remote PostgreSQL database. Configure Your .env File: After setting up the PostgreSQL instance on Neon, you'll need to configure the connection information in your project's .env file. The .env file stores environment variables, which provide your Django application with the necessary credentials to connect to Neon.
Here's an example of the necessary configuration:
# .env file for Neon PostgreSQL DB_HOST='example.us-east-2.aws.neon.tech' # The host address of your Neon database DB_NAME='virtualbank' # The name of your PostgreSQL database DB_USER='vb_owner' # The PostgreSQL user with access to the database DB_PASSWORD='your_password_here' # The password for the database user
- DB_HOST: The host address provided by Neon for your PostgreSQL instance.
- DB_NAME: The name of the database you created (e.g., virtualbank).
- DB_USER: The username associated with your PostgreSQL instance. Typically, this is the owner of the database (e.g., vb_owner).
- DB_PASSWORD: The password that was set during the creation of the PostgreSQL instance.
Modify Django Database Settings: In your Django settings.py file, you will need to use the above environment variables to configure the connection to Neon PostgreSQL. Modify your DATABASES configuration like this:
# For Neon PostgreSQL (deployment)
- Default Configuration (PostgreSQL):
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.postgresql', 'NAME': os.getenv('DB_NAME'), 'USER': os.getenv('DB_USER'), 'PASSWORD': os.getenv('DB_PASSWORD'), 'HOST': os.getenv('DB_HOST'), 'PORT': os.getenv('DB_PORT'), 'OPTIONS': { 'sslmode': 'require', }, } }
1. **Run migrations**:
```bash
cd api/
python3 manage.py makemigrations
python3 manage.py migrate
Clients:
cd clients/
python3 manage.py makemigrations
-
Start the development server: API:
cd api/ python3 manage.py runserver
Clients:
cd clients/ python3 manage.py runserver 8001
Access the application in your browser at http://localhost:8000/ or http://localhost:8001/ for clients.
The Virtual Bank API uses JWT (JSON Web Token) for authentication. After logging in, you will receive a token that must be passed in all subsequent requests.
Authorization Header: Include the JWT token in the Authorization header for all requests:
Authorization: Bearer <your_token>
As a Cookie: Alternatively, you can pass the JWT token as a Cookie:
Cookie: jwt=<your_token>
To start the development server, navigate to the corresponding directories and run the following commands.
For API:
cd api/
python3 manage.py runserver
For Clients:
cd clients/
python3 manage.py runserver 8001
To create a new user, use the following curl
command:
curl -X POST http://localhost:8000/api/users/create/ \
-H 'Content-Type: application/json' \
-d '{
"username": "max_miller",
"password": "maxm1234",
"first_name": "Max",
"last_name": "Miller",
"email": "[email protected]",
"address": "606 Oakwood Dr",
"city": "Mountainview",
"state": "CO",
"country": "USA",
"date_of_birth": "1998-01-22",
"phone_number": "+199999999999"
}'
After creating a user, obtain the JWT token by logging in:
curl -X POST http://localhost:8000/api/users/login/ \
-H 'Content-Type: application/json' \
-d '{
"username": "max_miller",
"password": "maxm1234"
}'
The response will contain the access token, which you can use for authenticated requests:
{
"access": "your_jwt_access_token",
"refresh": "your_jwt_refresh_token"
}
To create an account, use the JWT token obtained from the login step. Include the token in the Authorization header:
curl -X POST http://localhost:8000/api/accounts/create/ \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer your_jwt_access_token' \
-d '{
"name": "Biznumd",
"account_type": "CURRENT",
"balance": 7500,
"currency": "USD"
}'
Make sure to replace your_jwt_access_token
with the actual token you received during login.
The API also supports WebSocket connections for real-time transaction and notification updates using Django Channels. Whenever a transaction is saved, a Django signal triggers a WebSocket event, providing instant updates to connected clients.
Endpoint: /ws/socket/
Example Frontend WebSocket Listener:
const socket = new WebSocket("ws://localhost:8000/ws/socket/");
socket.addEventListener("message", (e) => {
const data = JSON.parse(e.data);
console.log(data.content, data.event);
if (data.event === "transaction") {
} else if (data.event === "notification") {
}
});
The API is mostly finished, and I am currently working on the frontend. It is now possible to make transfers and deposits on the frontend with real-time updates and chart visualization of transactions.
This API provides endpoints for managing users, accounts, debit cards, deposits, notifications, transactions, transfers, and more. It includes both public and admin-only endpoints.
This API uses Both Basic and JWT (JSON Web Token) for authentication. The following endpoints are related to authentication:
- Login: /auth/login/
- Refresh Token: /auth/refresh/
- Logout: /auth/logout/ After obtaining the token via login, include the JWT token in the Authorization header for all requests as follows: Authorization: Bearer <your_token> Or send the token has cookie
-
List Users
- Endpoint:
GET /admin/users/
- Description: Create a users or returns a list of all users (admin only).
- Authorization: Bearer Token (Admin)
- Method: GET, POST
- Request Body:
{ "username": "string", "first_name": "string", "last_name": "string", "password": "string", "email": "[email protected]", "address": "string", "city": "string", "state": "string", "country": "string", "date_of_birth": "2019-08-24T14:15:22Z", "phone_number": -9223372036854776000, "date_joined": "2019-08-24T14:15:22Z" }
- Endpoint:
-
User Detail
- Endpoint:
GET /admin/users/{id}/
- Description: Retrieves, delete, or update details of a specific user by their
id
(admin only). - Authorization: Bearer Token (Admin)
- Method: GET, PUT, DELETE
- Request Body:
{ "username": "string", "first_name": "string", "last_name": "string", "password": "string", "email": "[email protected]", "address": "string", "city": "string", "state": "string", "country": "string", "date_of_birth": "2019-08-24T14:15:22Z", "phone_number": -9223372036854776000, "date_joined": "2019-08-24T14:15:22Z" }
- Endpoint:
-
List Accounts
- Endpoint:
GET /admin/accounts/
- Description: Create Account or returns a list of all accounts (admin only).
- Authorization: Bearer Token (Admin)
- Method: GET, POST
- Request Body:
{ "name": "string", "account_type": "SAVINGS", "balance": "string", "currency": "USD" }
- Endpoint:
-
Account Detail
- Endpoint:
GET /admin/accounts/{id}/
- Description: Retrieves details of a specific account by its
id
(admin only). - Authorization: Bearer Token (Admin)
- Method: GET, PUT, DELETE
- Request Body:
{ "name": "string", "account_type": "SAVINGS", "balance": "string", "currency": "USD" }
- Endpoint:
-
List Notifications
- Endpoint:
GET /admin/notifications/
- Description: Create Notifications or returns a list of all notifications (admin only).
- Authorization: Bearer Token (Admin)
- Method: GET, POST
- Request Body:
{ "user": 0, "notification_type": "USER_NOTIFICATION", "content": "string", "status": "READ" }
- Endpoint:
-
Notification Detail
- Endpoint:
GET /admin/notifications/{id}/
- Description: Retrieves, delete, or update details of a specific notification by its
id
(admin only). - Authorization: Bearer Token (Admin)
- Method: GET, PUT, DELETE
- Request Body:
{ "user": 0, "notification_type": "USER_NOTIFICATION", "content": "string", "status": "READ" }
- Endpoint:
-
List Transactions
- Endpoint:
GET /admin/transactions/
- Description: create or returns a list of all transactions (admin only).
- Authorization: Bearer Token (Admin)
- Method: GET, POST
- Request Body:
{ "transaction_type": "DEPOSIT", "amount_sent": "string", "amount_received": "string", "currency_sent": "USD", "currency_received": "USD", "description": "string", "rate": "string", "account": 0, "payer": 0, "payee": 0 }
- Endpoint:
-
Transaction Detail
- Endpoint:
GET /admin/transactions/{id}/
- Description: Retrieves, delete, or update details of a specific transaction by its
id
(admin only). - Authorization: Bearer Token (Admin)
- Method: GET, PUT, DELETE
- Request Body:
- Request Body:
{ "transaction_type": "DEPOSIT", "amount_sent": "string", "amount_received": "string", "currency_sent": "USD", "currency_received": "USD", "description": "string", "rate": "string", "account": 0, "payer": 0, "payee": 0 }
- Endpoint:
-
Verify Token
- Endpoint:
POST /auth/token/verify/
- Description: Verifies the provided JWT token.
- Method: POST
- Request Body:
{ "token": "jwt_access_token" }
- Endpoint:
-
Register User Note: profile_picture can be
- Endpoint:
POST /auth/register/
- Description: Registers a new user.
- Method: POST
- Request Body:
{ "username": "string", "first_name": "string", "last_name": "string", "password": "string", "email": "[email protected]", "address": "string", "city": "string", "state": "string", "country": "string", "profile_picture": "image_file", "date_of_birth": "2019-08-24T14:15:22Z", "phone_number": -9223372036854776000, "date_joined": "2019-08-24T14:15:22Z" }
-
Notes: The profile_picture field is optional. If included, it should be uploaded as an image file in the form-data.
For file uploads, ensure that your server is configured to handle multipart/form-data and save the uploaded files properly.
If profile_picture is omitted, the user will be registered without a profile picture.
-
Handling File Uploads: As URL: Provide the URL of the image in the profile_picture field.
As Base64 String: Provide the base64-encoded image string in the profile_picture field.
As File Upload: Use multipart/form-data to include the file in the profile_picture field.
- Endpoint:
-
Update User
- Endpoint:
PUT /auth/update/
- Description: Updates user information.
- Method: PUT
- Request Body:
{ "username": "string", "first_name": "string", "last_name": "string", "password": "string", "email": "[email protected]", "address": "string", "city": "string", "state": "string", "country": "string", "date_of_birth": "2019-08-24T14:15:22Z", "phone_number": -9223372036854776000, "date_joined": "2019-08-24T14:15:22Z" }
- Endpoint:
-
Verify User
- Endpoint:
GET /auth/verify/
- Description: Retrieves the currently authenticated user's information.
- Method: GET
- Endpoint:
-
Login
- Endpoint:
POST /auth/login/
- Description: Logs in a user and returns a JWT token.
- Method: POST
- Request Body:
{ "username": "string", "password": "string" }
- Endpoint:
-
Refresh Token
- Endpoint:
POST /auth/token/refresh/
- Description: Refreshes the JWT token.
- Method: POST'
- Request Body:
{ "refresh": "jwt_refresh_token" }
- Endpoint:
-
Logout
- Endpoint:
GET /auth/logout/
- Description: Logs out the user and invalidates the JWT token.
- Method: GET
- Endpoint:
-
List User Accounts
- Endpoint:
GET /accounts/
- Description: Returns a list of all accounts associated with the authenticated user.
- Method: GET
- Endpoint:
-
Create Account
- Endpoint:
POST /accounts/create/
- Description: Creates a new account for the authenticated user.
- Method: POST
- Request Body:
{ "name": "string", "account_type": "SAVINGS | CURRENT", "balance": "string", "currency": "USD" }
- Endpoint:
-
Account Detail
- Endpoint:
GET /accounts/{account_number}/
- Description: Retrieves details of a specific account by its
account_number
. - Method: GET
- Endpoint:
-
List User Debit Cards
- Endpoint:
GET /debit-cards/
- Description: Returns a list of all debit cards associated with the authenticated user.
- Method: GET
- Endpoint:
-
Debit Card Detail
- Endpoint:
GET /debit-cards/{card_number}/
- Description: Retrieves details of a specific debit card by its
card_number
. - Method: GET
- Endpoint:
-
List Debit Card Transactions
- Endpoint:
GET /debit-cards/transactions/
- Description: Returns a list of transactions for the authenticated user's debit cards.
- Method: GET
- Query Parameters::
role
(optional): The role of the authenticated user in the transaction (payer
,payee
).account_number
(optional): Filters the transactions based on the specified account number.page
(optional): The page number to retrieve. Defaults to 1 (the first page).size
(optional): The number of results to return per page. Defaults to 100.
- Endpoint:
-
Debit Card Transaction Detail
- Endpoint:
GET /debit-cards/transactions/{transaction_id}/
- Description: Retrieves details of a specific debit card transaction by its
transaction_identifier
. - Method: GET
- Endpoint:
-
Make Payment
- Endpoint:
POST /debit-cards/payment/
- Description: Makes a payment using a debit card.
- Method: POST
- Request Body:
{ "amount": 0, "payee_account_number": 100000000, "card_number": 1000000000, "cvv": 100, "expiration_date": "22/08", "description": "string", }
- Endpoint:
-
List User Deposits
- Endpoint:
GET /deposits/
- Description: Returns a list of all deposits made by the authenticated user.
- Method: GET
- Endpoint:
-
Create Deposit
- Endpoint:
POST /deposits/create/
- Description: Creates a new deposit for the authenticated user.
- Method: POST
- Request Body:
{ "amount": 0, "account_number": 10000000000, "description": "string", }
- Query Parameters::
account_number
(optional): Filters the transactions based on the specified account number.page
(optional): The page number to retrieve. Defaults to 1 (the first page).size
(optional): The number of results to return per page. Defaults to 100.
- Endpoint:
-
Deposit Detail
- Endpoint:
GET /deposits/{deposit_id}/
- Description: Retrieves details of a specific deposit by its
deposit_id
. - Method: GET
- Endpoint:
-
List User Notifications
- Endpoint:
GET /notifications/
- Description: Returns a list of notifications for the authenticated user.
- Method: GET
- Query Parameters::
type
(optional): The type of notification to return.user | account | transaction | security
page
(optional): The page number to retrieve. Defaults to 1 (the first page).size
(optional): The number of results to return per page. Defaults to 100.
- Endpoint:
-
Notification Detail
- Endpoint:
GET /notifications/{id}/
- Description: Retrieves a specific notification by its
id
. - Method: GET
- Endpoint:
-
List Transaction History
- Endpoint:
GET /transactions/
- Description: Returns the transaction history for the authenticated user.
- Method: GET
- Query Parameters::
role
(optional): The role of the authenticated user in the transaction (payer
,payee
).account_number
(optional): Filters the transactions based on the specified account number.page
(optional): The page number to retrieve. Defaults to 1 (the first page).size
(optional): The number of results to return per page. Defaults to 100.
- Endpoint:
-
Transaction Detail
- Endpoint:
GET /transactions/{transaction_id}/
- Description: Retrieves details of a specific transaction by its
transaction_identifier
. - Method: GET
- Endpoint:
-
List User Transfers
- Endpoint:
GET /transfers/
- Description: Returns a list of all transfers made by the authenticated user.
- Method: GET
- Query Parameters::
role
(optional): The role of the authenticated user in the transaction (payer
,payee
).account_number
(optional): Filters the transactions based on the specified account number.page
(optional): The page number to retrieve. Defaults to 1 (the first page).size
(optional): The number of results to return per page. Defaults to 100.
- Endpoint:
-
Create Transfer
- Endpoint:
POST /transfers/create/
- Description: Creates a new transfer for the authenticated user.
- Method: POST
- Request Body:
{ "amount": 0, "payer_account_number": 100000000, "payee_account_number": 100000000, "description": "string" }
- Endpoint:
-
Transfer Detail
- Endpoint:
GET /transfers/{transfer_id}/
- Description: Retrieves details of a specific transfer by its
transfer_identifier
. - Method: GET
- Endpoint:
Contributions are welcome! Follow these steps to contribute:
- Fork the repository.
- Create a new branch:
git checkout -b feature/new-feature
- Make your changes and commit them:
git commit -m 'Add new feature'
. - Push to the branch:
git push origin feature/new-feature
. - Submit a pull request.
The Virtual Bank project is licensed under the MIT License, ensuring open-source availability and contributions from the community.
For any inquiries or support, please contact Adeniji Olajide at [email protected].