As the name suggests, this project is a clone of a famous Q/A website for professional and enthusiast programmers built solely by me using a completely different stack.
🆕 New Update: newly added features are mentioned in issue(#15)
My Tech Stack (MERN)
Front-end
- Front-end Framework:
React.js (with Redux)
- Styling:
SASS
andBOOTSTRAP
Back-end
- For handling server requests:
Node.js with Express.js Framework
- As Database:
MySQL
- API tested using:
POSTMAN
Original Tech Stack
- For handling server requests:
C#
- As Database:
Microsoft SQL Server
.NET
as well
Contributing
- Go to
Contributing.md
Guidelines to setup
- Create a
.env
file and the format should be as given in.env.example
. - Run these commands then -
npm run installDep (To install all the dependencies) npm run auditDep (Run this to audit fix all the vulnerabilities)
- Run
databaseConfig.sql
file in the mysql clientsource <file path>/data/databaseConfig.sql
- (Optional) Run
seed.sql
file in the mysql client for seed dataNote: Change the database name insource <file path>/data/seed.sql
databaseConfig.sql
&seed.sql
underUSE
command - Start the servers
Option 1 (for running both the servers simultaneously): npm run dev Option 2 (for running both the servers individually): npm run server (for backend server only) npm run client (for frontend server only)
NOTE: Might take sometime to start as there will be 2 servers running.
API Endpoints
http://localhost:5000/api
Base Url - Users
GET /auth
POST /auth
POST /users/:id
GET /users
GET /users/:id
Posts
GET /posts
GET /posts/top
GET /posts/tag/:tagname
GET /posts/:id
POST /posts/
DELETE /posts/:id
Answers
GET /posts/answers/:id
POST /posts/answers/:id
DELETE /posts/answers/:id
Comments
GET /posts/comments/:id
POST /posts/comments/:id
DELETE /posts/comments/:id
Tags
GET /tags
GET /tags/:tag_name
Future Scope
- Setup
Sequelize
withMySQL
in theAPI
. - Deploy the database to cloud, API, and client-side.
DEMO
Watch the video
VIDEO -Video Last Updated on 22nd March, 2020