Skip to content

Latest commit

 

History

History
84 lines (60 loc) · 2.87 KB

README.md

File metadata and controls

84 lines (60 loc) · 2.87 KB

Enchanté Backend

Banner

About

Enchanté Core-API, This project was to create a backend that ensures a smooth functioning of the app for Enchanté.

Users can regiter via Google OAuth. Once registering and filling in relevant details, they will be given a Rapyd Wallet to handle all the transactions. They will now be displayed all the event that are nearby and along with that all other events that are based on an intelligent recommendation system.

The user can now register for the event and the pass they like, they will also be displayed the offers that are applicable to them and the corresponding event. The user's budget will be maintained and any time the budget is crossed, they will be notified before spending their money.

Once registered for the event, the user can pay for in-event items directly through Augmented Reality without touching or asking for a single item physically.

Add your friends and find them on the map right in the app so that it is easy to stay connected during the event.

About the Backend

Run in Postman

  • Standard response structure was followed for a smoother integration
  • Google Oauth were used for the authentication along with Passport JWT
  • MVC architecture was implemented
  • Robust error handling to send specific errors to the frontend for a better UX experience
  • MongoDB deployed on Atlas was used as our database
  • Staging branch was deployed on Heroku to test the features before they were deployed to production
  • The master branch had the production code and was deployed on Microsoft Azure

ER Diagram

ER Diagram

Tech Stack

  • Node
  • Typescript
  • Express
  • MongoDB
  • Rapyd API
  • Azure
  • Heroku

Environment Variables

In order to run this project successfully, create a .env file filled with keys are shown below. Make sure to fill your credentials and values

DB_URI=<MongoDB URI>
private_key_id=<from Firebase config>
private_key=<from Firebase config>
client_email=<from Firebase config>
client_id=<from Firebase config>
auth_uri=<from Firebase config>
token_uri=<from Firebase config>
auth_provider_x509_cert_url=<from Firebase config>
client_x509_cert_url=<from Firebase config>
JWT_SECRET=<JWT secret key>
RAPYD_SECRET_KEY=<Rapyd api secret key>
RAPYD_ACCESS_KEY=<Rapyd api access key>

Development Run

yarn install
yarn dev

Production Run

yarn install
yarn build
yarn start

Important Links

Made with ❤ by Team Alpha