Multiplayer stock trading simulator built with React + MERN π
View the demo Β»
Read API Docs
Β·
Report Bug
Β·
Request Feature
Home | Stock View |
---|---|
Login | Signup | Leaderboard |
---|---|---|
Stotra is a multiplayer STOck TRAading simulator that allows users to engage in real-time virtual trading of stocks, currencies, and cryptocurrencies. With Stotra, users can practice trading without risking real money, making it an ideal platform for beginners to learn the ropes of trading. The project is powered by AWS, utilizing Amplify for the React frontend and Elastic Cloud Compute for the Express API.
I built Stotra in 70 hours split across 3 weeks of design, development, and deployment. I set development goals and stayed on top of them with Trello and tracked time spent on each portion with Toggl Track.
- πͺ Real-time virtual trading of stocks, currencies, and cryptocurrencies
- π Multiplayer leaderboard for competitive trading with friends
- π Interactive charts and visualizations for better decision-making
- ποΈ Access to financial news for informed trading
- π¨ Beautiful design with dark mode and customizable accent color
- π± Responsive design for trading on-the-go
The design was inspired by Robinhood and this Dribbble shot. The frontend uses Chakra UI for a consistent and minimal design, with Manrope for the headings and Inter for the body text.
The accent color defaults to Chakra's "Cyan 500" (#00B5D8
), which can be changed in the app to any of Chakra's sleek colors. Using the toggle in the top right, one can switch between light and dark mode, as shown in the "Sign up" screenshot above.
Stotra utilizes a robust and custom-built authentication system designed to ensure the security of user data and access to its services. Developed using TypeScript, the system incorporates features for user sign-up, login, and verification. To authenticate users, Stotra employs JSON Web Tokens (JWT), issuing a JWT to users upon successful login, which is then used for identity and permission verification in subsequent requests. As an added layer of security, Stotra integrates Cloudflare Turnstile, a gatekeeping service that prevents unauthorized access to the platform.
- Users were authenticated with access tokens but not refresh tokens. Adding this additional check may verify users further and could allow storing the login in React's state. Currently, JWT tokens are stored in localStorage to allow access by React, something not possible with
httpOnly
Cookies. This is vulnerable to DOM-based XSS attacks just as state-stored tokens would be, albeit state-stored tokens are not as simple to access as localStorage ones. - The system does not offer a password reset feature. This would most likely require an email sending service and for the sake of simplicity, I left it out in this project. For a production-level deployment, this is definitely something to add.
- Two-factor authentication is not included in the current security model. This is relatively minor for a stock trading simulator but would be possible to implement with otpauth.
Stotra uses a microservices architecture, with separate services for the frontend and backend. The two services are stored in separate directories within this monorepo and are meant to be run simultaneously on different ports of the host. The frontend is built with React which interfaces with the Node.js/Express backend over a Restful API. The backend sends to and reads from the MongoDB database (run on MongoDB Atlas for the demo version). The project is hosted on AWS, with Amplify for the frontend and Elastic Cloud Compute for the backend.
- Node.js (v14.18+)
- MongoDB
- I used MongoDB Atlas for the demo version
- Cloudflare Turnstile (for authentication)
- Create a free account to get an API key
- Clone the repo
$ git clone https://github.com/spikecodes/stotra.git
$ cd stotra
- Install NPM packages for both the frontend and backend
$ cd app
$ npm install
$ cd ../server
$ npm install
- Create a
.env
file in theserver
directory and add the following environment variables:
STOTRA_MONGODB_USERNAME=<username>
STOTRA_MONGODB_PASSWORD=<pass>
STOTRA_MONGODB_CLUSTER=<example: cluster0.example.mongodb.net>
STOTRA_JWT_SECRET=<random string of characters>
STOTRA_TURNSTILE_SECRET=<api key for turnstile>
# Optional: (for real-time news and stock data)
STOTRA_NEWSFILTER_API=<api key for news descriptions>
STOTRA_ALPHAVANTAGE_API=<api key for real-time stock data>
- Run the frontend and backend in separate terminals
$ cd app
$ npm run dev
> [email protected] dev
> vite
VITE v4.4.9 ready in 503 ms
β Local: http://localhost:5173/
β Network: http://192.168.1.242:5173/
β press h to show help
$ cd server
$ npm run dev
> [email protected] dev
> ts-node-dev --respawn --pretty --transpile-only ./src/index.ts
[INFO] 17:21:04 ts-node-dev ver. 2.0.0 (using ts-node ver. 10.9.1, typescript ver. 5.1.6)
Example app listening at http://0.0.0.0:3010
Swagger-autogen: Success β
Swagger docs available at http://0.0.0.0:3010/api/docs
Connected to Database
- Frontend: React, TypeScript Chakra UI, Axios, Highcharts
- Backend: Node.js, Express, MongoDB, Mongoose, JWT
π€ Spike
- Website: spike.codes
- Twitter: @spikecodes
- Github: @spikecodes
Give a βοΈ if this project helped you!
Copyright Β© 2023 Spike.
This project is MIT License licensed.