-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.js
More file actions
139 lines (112 loc) · 4.56 KB
/
server.js
File metadata and controls
139 lines (112 loc) · 4.56 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
//express server instance
const express = require("express");
const app = express();
//server made with http
const server = require("http").Server(app);
const io = require("socket.io")(server);
//peer server integration
const { ExpressPeerServer } = require("peer");
const cookie = require("cookie-session");
const passport = require("passport");
const flash = require("express-flash");
const mongoose = require("mongoose");
const peerServer = ExpressPeerServer(server, {
debug: true,
});
//importing the schemas which contain the basic requirements
const peerUser = require("./schema/peerUser");
const room = require("./schema/rooms");
const user = require("./schema/user");
//all the required routes
const videoRoom = require("./routes/video");
const signup = require("./routes/auth/signup");
const login = require("./routes/auth/login");
const logout = require("./routes/auth/logout");
const index = require("./routes/index");
const newMeeting = require("./routes/newMeeting");
//used to verify details and check if username or password already exists
const passportAuthenticator = require("./functions/passportStrategy");
passportAuthenticator(passport, user);
//database connection which on successful connection fires "database connected"
mongoose.connect("mongodb+srv://Aishani:whatisthis@cluster0.vl571.mongodb.net/myFirstDatabase?retryWrites=true&w=majority", {useNewUrlParser: true, useUnifiedTopology: true, useFindAndModify: false,
}).then(() => {
console.log("database connected");
});
//setting up json usage
app.use(express.json());
app.use("/peerjs", peerServer);
app.set("view engine", "ejs"); //for using embedded javascript
app.use(cookie({ maxAge: 30 * 24 * 60 * 60 * 1000, keys: ["aishani"] }));
app.use(express.urlencoded({ extended: false }));
app.use(passport.initialize());
app.use(passport.session());
app.use(express.static("public")); //accessing static files within public folder
app.use(flash());
app.use(require("express-ejs-layouts"));
app.set("layout", "layouts/layout");
//when a user tries to join a room through a link
app.post("/join-room", (req, res) => {
res.redirect(`/${req.body.room_id}`);
});
// index route
app.use("/", index);
// user id get
app.get("/user", async (req, res) => {
const roomData = await room.findOne({ roomId: req.query.room }).exec();
res.json({user: await peerUser.findOne({ peerId: req.query.peer }).exec(), admin: roomData.admin,
});
});
// new meeting
app.use("/new-meeting", newMeeting);
// login
app.use("/login", login);
// signup
app.use("/signup", signup);
// logout
app.use("/logout", logout);
// video room
app.use("/", videoRoom);
//socket IO related events
io.on("connection", (socket) => {
socket.on("join-room", async (roomId, peerId, userId, name, audio, video) => {
// add peer details
await peerUser({peerId: peerId,name: name,audio: audio,video: video,}).save();
// add room details
var roomData = await room.findOne({ roomId: roomId }).exec();
if (roomData == null) {
await room({roomId: roomId,userId: userId,admin: peerId,count: 1,}).save(); roomData = { count: 0 };}
else if (roomData.userId == userId) {
if (roomData.admin != peerId)
await room.updateOne({ roomId: roomId },{ admin: peerId, count: roomData.count + 1 });}
else
await room.updateOne({ roomId: roomId }, { count: roomData.count + 1 });
socket.join(roomId);
socket.to(roomId).broadcast.emit("user-connected",peerId,name,audio,video,roomData.count + 1);
//feature to toggle audio on and off
socket.on("audio-toggle", async (type) => {
await peerUser.updateOne({ peerId: peerId }, { audio: type });
socket.to(roomId).broadcast.emit("user-audio-toggle", peerId, type);
});
//feature to toggle video on and off
socket.on("video-toggle", async (type) => {
await peerUser.updateOne({ peerId: peerId }, { video: type });
socket.to(roomId).broadcast.emit("user-video-toggle", peerId, type);
});
//chat
socket.on("client-send", (data) => {
socket.to(roomId).broadcast.emit("client-podcast", data, name);
});
//when user disconnects, removing his video, updating count
socket.on("disconnect", async () => {
roomData = await room.findOne({ roomId: roomId }).exec();
await room.updateOne({ roomId: roomId }, { count: roomData.count - 1 });
// remove peer details
await peerUser.deleteOne({ peerId: peerId });
socket
.to(roomId)
.broadcast.emit("user-disconnected", peerId, roomData.count - 1);
});
});
});
//listening on port 3000 when running locally
server.listen(process.env.PORT || 3000);