195 lines
6.6 KiB
JavaScript
195 lines
6.6 KiB
JavaScript
var OpenVidu = require('openvidu-node-client').OpenVidu;
|
|
var Session = require('openvidu-node-client').Session;
|
|
var OpenViduRole = require('openvidu-node-client').OpenViduRole;
|
|
var TokenOptions = require('openvidu-node-client').TokenOptions;
|
|
|
|
// Check launch arguments
|
|
if (process.argv.length != 4) {
|
|
console.log("Usage: node " + __filename + " OPENVIDU_URL OPENVIDU_SECRET");
|
|
process.exit(-1);
|
|
}
|
|
// For demo purposes we ignore self-signed certificate
|
|
process.env.NODE_TLS_REJECT_UNAUTHORIZED = "0"
|
|
|
|
// Imports
|
|
var express = require('express');
|
|
var fs = require('fs');
|
|
var session = require('express-session');
|
|
var https = require('https');
|
|
var bodyParser = require('body-parser'); // pull information from HTML POST (express4)
|
|
var app = express(); // create our app w/ express
|
|
|
|
// Configuration
|
|
app.use(session({
|
|
saveUninitialized: true,
|
|
resave: false,
|
|
secret: 'MY_SECRET'
|
|
}));
|
|
app.use(express.static(__dirname + '/public')); // set the static files location /public/img will be /img for users
|
|
app.use(bodyParser.urlencoded({
|
|
'extended': 'true'
|
|
})); // parse application/x-www-form-urlencoded
|
|
app.use(bodyParser.json()); // parse application/json
|
|
app.use(bodyParser.json({
|
|
type: 'application/vnd.api+json'
|
|
})); // parse application/vnd.api+json as json
|
|
|
|
// listen (start app with node server.js)
|
|
var options = {
|
|
key: fs.readFileSync('openvidukey.pem'),
|
|
cert: fs.readFileSync('openviducert.pem')
|
|
};
|
|
https.createServer(options, app).listen(5000);
|
|
console.log("App listening on port https://[]:5000");
|
|
|
|
// Mock database
|
|
var users = [{
|
|
user: "publisher1",
|
|
pass: "pass",
|
|
role: OpenViduRole.PUBLISHER
|
|
}, {
|
|
user: "publisher2",
|
|
pass: "pass",
|
|
role: OpenViduRole.PUBLISHER
|
|
}, {
|
|
user: "subscriber",
|
|
pass: "pass",
|
|
role: OpenViduRole.SUBSCRIBER
|
|
}];
|
|
|
|
|
|
// Environment variables
|
|
var OPENVIDU_URL = process.argv[2];
|
|
var OPENVIDU_SECRET = process.argv[3];
|
|
|
|
// OpenVidu object
|
|
var OV = new OpenVidu(OPENVIDU_URL, OPENVIDU_SECRET);
|
|
|
|
// Objects for storing active sessions and users
|
|
var mapSessionNameSession = {};
|
|
var mapSessionIdTokens = {};
|
|
|
|
|
|
// APIRest
|
|
app.post('/api-login/login', function (req, res) {
|
|
var user = req.body.user;
|
|
var pass = req.body.pass;
|
|
console.log("Logging in | {user, pass}={" + user + ", " + pass + "}");
|
|
|
|
if (login(user, pass)) {
|
|
console.log("'" + user + "' has logged in");
|
|
req.session.loggedUser = user;
|
|
res.status(200).send();
|
|
} else {
|
|
console.log("'" + user + "' invalid credentials");
|
|
req.session.destroy();
|
|
res.status(401).send('User/Pass incorrect');
|
|
}
|
|
});
|
|
|
|
app.get('/api-login/logout', function (req, res) {
|
|
console.log("'" + req.session.loggedUser + "' has logged out");
|
|
req.session.destroy();
|
|
res.status(200).send();
|
|
});
|
|
|
|
app.post('/api-sessions/get-sessionid-token', function (req, res) {
|
|
if (!isLogged(req.session)) {
|
|
req.session.destroy();
|
|
res.status(401).send('User not logged');
|
|
} else {
|
|
var sessionName = req.body.session;
|
|
var role = users.find(u => (u.user === req.session.loggedUser)).role;
|
|
var serverData = '{"serverData": "' + req.session.loggedUser + '"}';
|
|
console.log("Getting sessionId and token | {sessionName}={" + sessionName + "}");
|
|
|
|
var mySession = mapSessionNameSession[sessionName];
|
|
var tokenOptions = new TokenOptions.Builder()
|
|
.role(role)
|
|
.data('{"serverData": "' + req.session.loggedUser + '"}')
|
|
.build();
|
|
|
|
if (mySession) {
|
|
console.log('Existing session ' + sessionName);
|
|
mySession.generateToken(tokenOptions, function (token) {
|
|
var sessionId = mySession.getSessionId();
|
|
mapSessionIdTokens[sessionId].push(token);
|
|
console.log('SESSIONID: ' + sessionId);
|
|
console.log('TOKEN: ' + token);
|
|
res.status(200).send({
|
|
0: sessionId,
|
|
1: token
|
|
});
|
|
});
|
|
} else {
|
|
console.log('New session ' + sessionName);
|
|
mySession = OV.createSession();
|
|
mySession.getSessionId(function (sessionId) {
|
|
mapSessionNameSession[sessionName] = mySession;
|
|
mapSessionIdTokens[sessionId] = [];
|
|
|
|
mySession.generateToken(tokenOptions, function (token) {
|
|
mapSessionIdTokens[sessionId].push(token);
|
|
console.log('SESSIONID: ' + sessionId);
|
|
console.log('TOKEN: ' + token);
|
|
res.status(200).send({
|
|
0: sessionId,
|
|
1: token
|
|
});
|
|
});
|
|
});
|
|
}
|
|
}
|
|
});
|
|
|
|
app.post('/api-sessions/remove-user', function (req, res) {
|
|
if (!isLogged(req.session)) {
|
|
req.session.destroy();
|
|
res.status(401).send('User not logged');
|
|
} else {
|
|
var sessionName = req.body.sessionName;
|
|
var token = req.body.token;
|
|
console.log('Removing user | {sessionName, token}={' + sessionName + ", " + token + '}');
|
|
var mySession = mapSessionNameSession[sessionName];
|
|
if (mySession) {
|
|
var tokens = mapSessionIdTokens[mySession.getSessionId()];
|
|
if (tokens) {
|
|
var index = tokens.indexOf(token);
|
|
if (index !== -1) { // User left the session
|
|
tokens.splice(index, 1);
|
|
console.log(sessionName + ': ' + mapSessionIdTokens[mySession.getSessionId()].toString());
|
|
} else {
|
|
var msg = 'Problems in the app server: the TOKEN wasn\'t valid';
|
|
console.log(msg);
|
|
res.status(500).send(msg);
|
|
}
|
|
if (mapSessionIdTokens[mySession.getSessionId()].length == 0) { // Last user left the session
|
|
console.log(sessionName + ' empty!');
|
|
delete mapSessionNameSession[sessionName];
|
|
}
|
|
res.status(200).send();
|
|
} else {
|
|
var msg = 'Problems in the app server: the SESSIONID wasn\'t valid';
|
|
console.log(msg);
|
|
res.status(500).send(msg);
|
|
}
|
|
} else {
|
|
var msg = 'Problems in the app server: the SESSION does not exist';
|
|
console.log(msg);
|
|
res.status(500).send(msg);
|
|
}
|
|
}
|
|
});
|
|
|
|
|
|
function login(user, pass) {
|
|
return (users.find(u => (u.user === user) && (u.pass === pass)));
|
|
}
|
|
|
|
function isLogged(session) {
|
|
return (session.loggedUser != null);
|
|
}
|
|
|
|
function getBasicAuth() {
|
|
return 'Basic ' + (new Buffer('OPENVIDUAPP:' + OPENVIDU_SECRET).toString('base64'));
|
|
} |