Skip to content

Commit

Permalink
Implements server side connection establishment
Browse files Browse the repository at this point in the history
  • Loading branch information
hristoterezov committed Mar 28, 2016
1 parent 0bde7de commit bf9c4ea
Show file tree
Hide file tree
Showing 8 changed files with 202 additions and 52 deletions.
5 changes: 3 additions & 2 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -31,8 +31,9 @@ deploy-appbundle:

deploy-lib-jitsi-meet:
cp $(LIBJITSIMEET_DIR)/lib-jitsi-meet.min.js \
$(LIBJITSIMEET_DIR)/lib-jitsi-meet.min.map $(DEPLOY_DIR)

$(LIBJITSIMEET_DIR)/lib-jitsi-meet.min.map \
$(LIBJITSIMEET_DIR)/connection_optimization/external_connect.js \
$(DEPLOY_DIR)
deploy-css:
(cd css; cat $(CSS_FILES)) | $(CLEANCSS) > css/all.css

Expand Down
50 changes: 22 additions & 28 deletions app.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/* global $, JitsiMeetJS, config */
/* global $, JitsiMeetJS, config, getRoomName */
/* application specific logic */

import "babel-polyfill";
Expand All @@ -23,40 +23,34 @@ import API from './modules/API/API';

import UIEvents from './service/UI/UIEvents';


/**
* Builds and returns the room name.
*/
function buildRoomName () {
let path = window.location.pathname;
let roomName;

// determinde the room node from the url
// TODO: just the roomnode or the whole bare jid?
if (config.getroomnode && typeof config.getroomnode === 'function') {
// custom function might be responsible for doing the pushstate
roomName = config.getroomnode(path);
} else {
/* fall back to default strategy
* this is making assumptions about how the URL->room mapping happens.
* It currently assumes deployment at root, with a rewrite like the
* following one (for nginx):
location ~ ^/([a-zA-Z0-9]+)$ {
rewrite ^/(.*)$ / break;
}
*/
if (path.length > 1) {
roomName = path.substr(1).toLowerCase();
} else {
let word = RoomnameGenerator.generateRoomWithoutSeparator();
roomName = word.toLowerCase();
window.history.pushState(
'VideoChat', `Room: ${word}`, window.location.pathname + word
);
}
let roomName = getRoomName();

if(!roomName) {
let word = RoomnameGenerator.generateRoomWithoutSeparator();
roomName = word.toLowerCase();
window.history.pushState(
'VideoChat', `Room: ${word}`, window.location.pathname + word
);
}

return roomName;
}

const APP = {
// Used by do_external_connect.js if we receive the attach data after
// connect was already executed. status property can be "initialized",
// "ready" or "connecting". We are interested in "ready" status only which
// means that connect was executed but we have to wait for the attach data.
// In status "ready" handler property will be set to a function that will
// finish the connect process when the attach data or error is received.
connect: {
status: "initialized",
handler: null
},
UI,
settings,
conference,
Expand Down
38 changes: 36 additions & 2 deletions connection.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,39 @@ import LoginDialog from './modules/UI/authentication/LoginDialog';
const ConnectionEvents = JitsiMeetJS.events.connection;
const ConnectionErrors = JitsiMeetJS.errors.connection;

/**
* Checks if we have data to use attach instead of connect. If we have the data
* executes attach otherwise check if we have to wait for the data. If we have
* to wait for the attach data we are setting handler to APP.connect.handler
* which is going to be called when the attach data is received otherwise
* executes connect.
*
* @param {string} [id] user id
* @param {string} [password] password
* @param {string} [roomName] the name of the conference.
*/
function checkForAttachParametersAndConnect(id, password, connection) {
console.log("call checkForAttachParametersAndConnect");
if(window.XMPPAttachInfo){
APP.connect.status = "connecting";
if(window.XMPPAttachInfo.status === "error") {
connection.connect({id, password});
return;
}

var attachOptions = window.XMPPAttachInfo.data;
if(attachOptions) {
connection.attach(attachOptions);
} else {
connection.connect({id, password});
}
} else {
APP.connect.status = "ready";
APP.connect.handler = checkForAttachParametersAndConnect.bind(null,
id, password, connection);
}
}

/**
* Try to open connection using provided credentials.
* @param {string} [id]
Expand All @@ -18,7 +51,8 @@ function connect(id, password, roomName) {
let connectionConfig = config;

connectionConfig.bosh += '?room=' + roomName;
let connection = new JitsiMeetJS.JitsiConnection(null, null, config);
let connection
= new JitsiMeetJS.JitsiConnection(null, config.token, config);

return new Promise(function (resolve, reject) {
connection.addEventListener(
Expand Down Expand Up @@ -50,7 +84,7 @@ function connect(id, password, roomName) {
reject(err);
}

connection.connect({id, password});
checkForAttachParametersAndConnect(id, password, connection);
});
}

Expand Down
Empty file.
79 changes: 79 additions & 0 deletions connection_optimization/do_external_connect.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,79 @@
/* global config, getRoomName, getConfigParamsFromUrl */
/* global createConnectionExternally */
/**
* Implements extrnal connect using createConnectionExtenally function defined
* in external_connect.js for Jitsi Meet. Parses the room name and token from
* the url and executes createConnectionExtenally.
*
* NOTE: If you are using lib-jitsi-meet without Jitsi Meet you should use this
* file as reference only because the implementation is Jitsi Meet specific.
*
* NOTE: For optimal results this file should be included right after
* exrnal_connect.js.
*/



/**
* Gets the token from the URL.
*/
function buildToken(){
var params = getConfigParamsFromUrl();
return params["config.token"] || config.token;
}

/**
* Executes createConnectionExternally function.
*/
(function () {
// FIXME: Add implementation for changing that config from the url for
// consistency
var url = config.externalConnectUrl;

/**
* Check if connect from connection.js was executed and executes the handler
* that is going to finish the connect work.
*/
function checkForConnectHandlerAndConnect() {

if(window.APP && window.APP.connect.status === "ready") {
window.APP.connect.handler();
}
}

function error_callback(error){
console.warn(error);
// Sets that global variable to be used later by connect method in
// connection.js
window.XMPPAttachInfo = {
status: "error"
};
checkForConnectHandlerAndConnect();
}

if(!url || !window.createConnectionExternally) {
error_callback();
return;
}
var room_name = getRoomName();
if(!room_name) {
error_callback();
return;
}

url += "?room=" + room_name;

var token = buildToken();
if(token)
url += "&token=" + token;

createConnectionExternally(url, function(connectionInfo) {
// Sets that global variable to be used later by connect method in
// connection.js
window.XMPPAttachInfo = {
status: "success",
data: connectionInfo
};
checkForConnectHandlerAndConnect();
}, error_callback);
})();
14 changes: 8 additions & 6 deletions index.html
Original file line number Diff line number Diff line change
@@ -1,6 +1,13 @@
<html itemscope itemtype="http://schema.org/Product" prefix="og: http://ogp.me/ns#" xmlns="http://www.w3.org/1999/html">
<head>
<!--#include virtual="title.html" -->
<script>console.log("(TIME) index.html loaded:\t", window.performance.now());</script>
<script src="config.js?v=15"></script><!-- adapt to your needs, i.e. set hosts and bosh path -->
<script src="utils.js?v=1"></script>
<!--#include virtual="connection_optimization/connection_optimization.html" -->
<script src="interface_config.js?v=6"></script>
<script src="libs/lib-jitsi-meet.min.js?v=139"></script>
<script src="libs/app.bundle.min.js?v=139"></script>
<link rel="icon" type="image/png" href="/images/favicon.ico?v=1"/>
<meta property="og:title" content="Jitsi Meet"/>
<meta property="og:image" content="/images/jitsilogo.png?v=1"/>
Expand All @@ -9,12 +16,7 @@
<meta itemprop="name" content="Jitsi Meet"/>
<meta itemprop="description" content="Join a WebRTC video conference powered by the Jitsi Videobridge"/>
<meta itemprop="image" content="/images/jitsilogo.png?v=1"/>
<link rel="stylesheet" href="css/all.css"/>
<script>console.log("(TIME) index.html loaded:\t", window.performance.now());</script>
<script src="config.js?v=15"></script><!-- adapt to your needs, i.e. set hosts and bosh path -->
<script src="interface_config.js?v=6"></script>
<script src="libs/lib-jitsi-meet.min.js?v=139"></script>
<script src="libs/app.bundle.min.js?v=139"></script>
<link rel="stylesheet" href="css/all.css"/>
<!--#include virtual="plugin.head.html" -->
</head>
<body>
Expand Down
16 changes: 2 additions & 14 deletions modules/config/URLProcessor.js
Original file line number Diff line number Diff line change
@@ -1,18 +1,6 @@
/* global $, $iq, config, interfaceConfig */
/* global $, $iq, config, interfaceConfig, getConfigParamsFromUrl */
var configUtils = require('./Util');
var params = {};
function getConfigParamsFromUrl() {
if (!location.hash)
return {};
var hash = location.hash.substr(1);
var result = {};
hash.split("&").forEach(function (part) {
var item = part.split("=");
result[item[0]] = JSON.parse(
decodeURIComponent(item[1]).replace(/\\&/, "&"));
});
return result;
}

params = getConfigParamsFromUrl();

Expand Down Expand Up @@ -62,4 +50,4 @@ var URLProcessor = {
}
};

module.exports = URLProcessor;
module.exports = URLProcessor;
52 changes: 52 additions & 0 deletions utils.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
/* global config */

/**
* Defines some utility methods that are used before the other JS files are
* loaded.
*/


/**
* Builds and returns the room name.
*/
function getRoomName () {
var path = window.location.pathname;
var roomName;

// determinde the room node from the url
// TODO: just the roomnode or the whole bare jid?
if (config.getroomnode && typeof config.getroomnode === 'function') {
// custom function might be responsible for doing the pushstate
roomName = config.getroomnode(path);
} else {
/* fall back to default strategy
* this is making assumptions about how the URL->room mapping happens.
* It currently assumes deployment at root, with a rewrite like the
* following one (for nginx):
location ~ ^/([a-zA-Z0-9]+)$ {
rewrite ^/(.*)$ / break;
}
*/
if (path.length > 1) {
roomName = path.substr(1).toLowerCase();
}
}

return roomName;
}

/**
* Parses the hash parameters from the URL and returns them as a JS object.
*/
function getConfigParamsFromUrl() {
if (!location.hash)
return {};
var hash = location.hash.substr(1);
var result = {};
hash.split("&").forEach(function (part) {
var item = part.split("=");
result[item[0]] = JSON.parse(
decodeURIComponent(item[1]).replace(/\\&/, "&"));
});
return result;
}

0 comments on commit bf9c4ea

Please sign in to comment.