WorkDesk https://workdesk.netlify.app/
Reatime screen sharing web application..
Client: HTML,CSS, Javascript,Bootsrap
Server: Node.js, Express.js , MongoDB, WebRTC, PeerJS library, Socket.io
- Home page
- Login/Signup
- Google OAuth
- Github OAuth
- Authentication using JWT
- Mongoose - connecting the database
- Server side -->> Node.js and Express
- MongoDB
- Screen Sharing
- Chatting
- Vedio calling
- First Create room
- User can share the screen
- Than user can join the room using room ID
- Enter room ID to join
- Click on stop share option
- First Create room
- User can join the call by using the room ID
- To end the call click on hang on button
- Enter the user name
- User can chat with online users
- For online users it will show green tick
peer = new Peer(room_id);
peer.on('open', (id) => {
console.log("Peer has joined ID no", id);
hideModal()
// media options...
getUserMedia({ video: true, audio: true },
(stream) => {
local_stream = stream;
setLocalStream(local_stream)
}, (err) => {
console.log(err);
})
notify("Waiting for the member to join.")
})
create user -> post: localhost:8080/user/register
sample data :
{
"name": "chikkuuu",
"email": "chikkuuu@gmail.com",
"password": "mayank"
}
-
login user -> post : localhost:8080/user/login
-
get new token -> get : localhost:8080/newtoken
-
logout user -> get : localhost:8080/logout
-
get all user -> get : localhost:8080/user
-
get one user -> get : localhost:8080/user/id
while making get request from fontend we need to send access_key(presented in .env)
github Oauth
1. Route login,dashboard
2. impelement auth
3. sessions
4. protected
5. logout
System_design