Finance planner app to track and calculate finance info from expenses, banking, investments, savings, insurance and get advice from AI features. Developed with MERN, Firebase, Go, GraphQL, Redis, Postgresql, and ML based APIs.
- Client: React frontend web application which sends requests to the Finance Planner and Finance Predict APIs. The frontend is developed using JavaScript with a TypeScript shift currently in place. State is managed by Redux and the React context API. UI is developed using Material UI, styled components, Tailwind and Bootstrap. It is also deployed with Docker. The client supports requests for the following:
- Chatbot responses
- Expenses
- Banking
- Historic market data
- Finance prediction
- Investments
- Savings
- Insurance
- Miscellaneous financial tools
- Authentication
- Authentication: Authentication is handled using Firebase Authentication and Functions.
- Finance Planner API: API developed using Express and GraphQL, which services majority of requests from the client, excluding predictions. The API requests MongoDB clusters, Redis, Cloud Firestore, AWS RDS databases. Additionally, it requests the ml-job-scheduler to trigger a job to generate finance predictions. It also uses the OpenAI API, polygon.io and other external APIs.
- Finance Predict API: Finance prediction API developed using django and deployed to AWS EC2. API serves requests for finance prediction, market data queries and chatbot queries.
- Services: The following services are used:
- OpenAI: Services chatbot requests
- polygon.io: Provides market data for requests from the Finance Planner API
- External APIs: Includes APIs for financial calculations, tools, country specific financial data, etc.
- Databases: The following databases are used:
- MongoDB:
- Expenses
- Banking
- Finance prediction
- Investments
- Savings
- Insurance
- Redis:
- Cached data
- Cloud Firestore:
- Authentication
- AWS RDS:
- ML training data
- Machine learning: ML models for BTC and stock predictions developed using TensorFlow / PyTorch. ml-job-scheduler handles the automated job runs from preprocessing, training, predictions, postprocessing, etc. The logs of the job runs are stored in S3 and the data is stored in MongoDB.
- Data engineering: Performs manual data migration using an external ETL / ELT API developed in Go, etl-elt-api
- Security: AWS security services (AWS Inspector and GuardDuty) which monitors the security of APIs. Later, data and logs from the services are queried and viewed using an external security tool.
- Monitoring: Monitoring service which collects data and logs from APIs using CloudWatch, then stores them in S3 to be viewed as a dashboard via an external monitoring tool.
- Notifications: Receives various data and logs in S3 buckets and later sends emails (on issues or failures) using SQS and Lambda.
- Cloning the repository: You would first need to clone this repository on the host you want to set up your development environment:
git clone https://github.com/tahmid-saj/fin-tracker.git
- Installing dependencies: Install the required NPM packages in package.json:
npm install
- Environment variables: The required environment variables are used:
# firebase
REACT_APP_FIREBASE_API_KEY=""
REACT_APP_FIREBASE_AUTH_DOMAIN=""
REACT_APP_FIREBASE_PROJECT_ID=""
REACT_APP_FIREBASE_STORAGE_BUCKET=""
REACT_APP_FIREBASE_MESSAGING_SENTER_ID=""
REACT_APP_FIREBASE_APP_ID=""
# There are several other environment variables for the APIs and services used in the client
- APIs: Client requests go to two APIs:
- Finance Planner API
- Finance Predict API
- Services: API keys are used from the following services in the Finance Planner API:
- OpenAI: Services chatbot requests
- polygon.io: Provides market data for requests from the Finance Planner API
- External APIs: There are several other external APIs providing financial calculations, tools, country specific financial data, etc.
- Databases: A MongoDB cluster and collections are created, and a connection is established with the Finance Planner and Finance Predict APIs. A Redis cluster is also created for storing cached data. Additionally Cloud Firestore and AWS RDS are both initialized for storing authentication and ML model training data respectively.
- Data engineering: The set up for the development environment for the data engineering tool can be found here.
- Machine learning: The set up for the development environment for the ML job scheduler can be found here.
- AWS: Setting up the AWS services is an optional step as this is on a development environment. However, the same services could be used to create the tools mentioned in the high level view.
- Running the client: The client can be run using:
npm start