Skip to content

🛅 MyWallet is a full-stack project that allows users to create an account, log in and add incoming and outgoing transactions, as well as view all transactions made so far, displaying the current balance on the main screen.

Notifications You must be signed in to change notification settings

wallet-sn/my-wallet-API

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

26 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

My Wallet API

ℹ️ About

My Wallet Project is a web application that enables users to control their personal finances. It has a front-end, back-end and database deployed in the cloud. The project was separated into two different repositories, one for the front-end and one for the back-end, using Git for versioning. The back-end was architected in controllers, routers and middlewares, while the front-end was built using ReactJS. User registration was implemented, capable of creating an account by validating fields and passwords. The application also allows users to log in, view their transactions and add new ones.

My Wallet Project


🔸 Demo: https://my-wallet-wine.vercel.app/

🔸 Organization My Wallet: https://github.com/wallet-sn

🔸 Deploy Render: https://mywallet-api-w3g6.onrender.com


🛠️ Features

  • Separate the project into two different repositories, one for the front-end and another for the back-end, and use Git for versioning. - Each implemented feature should have a corresponding commit.
  • Implement the front-end using HTML, CSS, JS and React, always running on port 8000.
  • Architect the back-end in controllers, routers and middlewares, using dotenv to manage environment variables. The server should run on port 5000.
  • Register users in the database through a POST request, validating all fields, and returning the corresponding error message in case of failure.
  • Users can log in, view their transactions and add new ones.

🎯 Motivation

The My Wallet Project was developed to provide an easy-to-use web application that helps people manage their finances. The inspiration came from the need to have a single tool that could provide a comprehensive view of one's financial situation, including a summary of expenses, income and investments.


📌 Technologies


⚙️ Routes

POST /signUp

A route that creates a new user account. If there's a participant with this e-mail already registered, it returns a 409 status code error. If its sucessfull it returns a 201 status code. The request body should contain:

{
  {
  "name": "johnDoe",
  "email": "john@doe.com",
  "password": "123456"
}
}

POST /signIn

A route that will allow the user to sign in. If there's no user with the given e-mail registered it'll return a 404 status code error, if the password doesn't match with the ones given on signUp, it'll return a 401 status code error. It'll give a token as a response.

All routes after signIn will need an authentication token:

headers: { Authorization: `Bearer ${token}` }

POST /transactions

Creates a new income or expense transaction. All fields are required and cannot be empty. The request should include a token as a header. If any of the fields are missing or empty, the API returns a 422 status code error and an error message indicating that all fields are required and cannot be empty. It returns a 401 status code if the token doesn't exist or if there's no account with this token. The request body should contain the following:

The request body should be:
    {
        {
        "description": "salario",
        "amount": 1500
        }
    }
Note that if the amount is a whole number that ends with two zeros (e.g., 1200), do not include a decimal point. Otherwise, if it is a floating-point number or has one zero at the end (e.g., 275.5), include the decimal point.

GET /transactions

Retrieves a list of the user's income and expense transactions. If there are no transactions, it returns an empty array. The response body looks like this:

The date format is: (DD/MM)
[
    {
        "_id": "644438f94af2cf105bd042b5",
        "userId": "64443438f3722b44d6394f74",
        "description": "salário",
        "type": "entrada",
        "amount": 1500.89,
        "date": "10/06"
    },
    {
        "_id": "644439144af2cf105bd042b6",
        "userId": "64443438f3722b44d6394f74",
        "description": "conta de luz",
        "type": "saída",
        "amount": 150.1,
        "date": "12/06"
    }
]

🖇 How to run

To download and configure the project, follow these steps:

  1. Clone the front-end repository: git clone https://github.com/natividadesusana/my-wallet.git
  2. Clone the back-end repository: git clone https://github.com/natividadesusana/my-wallet-API.git
  3. Install the dependencies for both repositories using npm install
  4. Create a .env file in the root of the back-end directory, containing the following variables: MONGO_URI=<your-mongodb-uri> PORT=5000
  5. Start the back-end server by running npm start in the back-end directory.
  6. Start the front-end server by running npm start in the front-end directory.
  7. Access the application in your browser at http://localhost:8000

Note: This project requires MongoDB to be installed and running. If you don't have it installed, please follow the instructions in their website (https://www.mongodb.com/try/download/community).


🚀 Links


✨ Tutorials for deploying:

About

🛅 MyWallet is a full-stack project that allows users to create an account, log in and add incoming and outgoing transactions, as well as view all transactions made so far, displaying the current balance on the main screen.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published