Commit d5f2f449 authored by Wandenberg Peixoto's avatar Wandenberg Peixoto

changing global reference to iframe

parent eae6a274
...@@ -30,8 +30,6 @@ ...@@ -30,8 +30,6 @@
var PATTERN_MESSAGE = /\{\"id\":([\-\d]*),\"channel\":\"(.*)\",\"text\":\"(.*)\"\}/; var PATTERN_MESSAGE = /\{\"id\":([\-\d]*),\"channel\":\"(.*)\",\"text\":\"(.*)\"\}/;
var PATTERN_MESSAGE_WITH_EVENT_ID = /\{\"id\":([\-\d]*),\"channel\":\"(.*)\",\"text\":\"(.*)\",\"eventid\":\"(.*)\"\}/; var PATTERN_MESSAGE_WITH_EVENT_ID = /\{\"id\":([\-\d]*),\"channel\":\"(.*)\",\"text\":\"(.*)\",\"eventid\":\"(.*)\"\}/;
var streamWrappersCount = 0;
var Log4js = { var Log4js = {
debug : function() { if (PushStream.LOG_LEVEL === 'debug') Log4js._log.apply(Log4js._log, arguments); }, debug : function() { if (PushStream.LOG_LEVEL === 'debug') Log4js._log.apply(Log4js._log, arguments); },
info : function() { if ((PushStream.LOG_LEVEL === 'info') || (PushStream.LOG_LEVEL === 'debug')) Log4js._log.apply(Log4js._log, arguments); }, info : function() { if ((PushStream.LOG_LEVEL === 'info') || (PushStream.LOG_LEVEL === 'debug')) Log4js._log.apply(Log4js._log, arguments); },
...@@ -160,7 +158,7 @@ ...@@ -160,7 +158,7 @@
clearTimeout(timer); clearTimeout(timer);
} }
return null; return null;
} };
/* common callbacks */ /* common callbacks */
var onmessageCallback = function(event) { var onmessageCallback = function(event) {
...@@ -266,8 +264,6 @@ ...@@ -266,8 +264,6 @@
this.url = null; this.url = null;
this.frameloadtimer = null; this.frameloadtimer = null;
this.pingtimer = null; this.pingtimer = null;
this.streamId = "streamWrapper_" + streamWrappersCount++;
window[this.streamId] = this;
}; };
StreamWrapper.TYPE = "Stream"; StreamWrapper.TYPE = "Stream";
...@@ -281,8 +277,7 @@ ...@@ -281,8 +277,7 @@
} catch(e) { } catch(e) {
Log4js.error("[Stream] (warning) problem setting document.domain = " + domain + " (OBS: IE8 does not support set IP numbers as domain)"); Log4js.error("[Stream] (warning) problem setting document.domain = " + domain + " (OBS: IE8 does not support set IP numbers as domain)");
} }
this.url = getSubscriberUrl(this.pushstream, this.pushstream.urlPrefixStream); this.url = getSubscriberUrl(this.pushstream, this.pushstream.urlPrefixStream) + "&streamid=" + this.pushstream.id;
this.url += "&streamid=" + this.streamId;
Log4js.debug("[Stream] connecting to:", this.url); Log4js.debug("[Stream] connecting to:", this.url);
this.loadFrame(this.url); this.loadFrame(this.url);
}, },
...@@ -462,9 +457,13 @@ ...@@ -462,9 +457,13 @@
/* mains class */ /* mains class */
var PushStreamManager = [];
var PushStream = function(settings) { var PushStream = function(settings) {
settings = settings || {}; settings = settings || {};
this.id = PushStreamManager.push(this) - 1;
this.useSSL = settings.useSSL || false; this.useSSL = settings.useSSL || false;
this.host = settings.host || window.location.hostname; this.host = settings.host || window.location.hostname;
this.port = settings.port || (this.useSSL ? 443 : 80); this.port = settings.port || (this.useSSL ? 443 : 80);
...@@ -603,11 +602,13 @@ ...@@ -603,11 +602,13 @@
}, },
_onopen: function() { _onopen: function() {
this.reconnecttimer = clearTimer(this.reconnecttimer);
this._setState(PushStream.OPEN); this._setState(PushStream.OPEN);
this._lastUsedMode--; //use same mode on next connection this._lastUsedMode--; //use same mode on next connection
}, },
_onclose: function() { _onclose: function() {
this.reconnecttimer = clearTimer(this.reconnecttimer);
this._setState(PushStream.CLOSED); this._setState(PushStream.CLOSED);
this._reconnect(this.reconnecttimeout); this._reconnect(this.reconnecttimeout);
}, },
...@@ -652,12 +653,13 @@ ...@@ -652,12 +653,13 @@
// by a url parameter we find the stream wrapper instance // by a url parameter we find the stream wrapper instance
PushStream.register = function(iframe) { PushStream.register = function(iframe) {
var matcher = iframe.window.location.href.match(/streamid=(.*)&?$/); var matcher = iframe.window.location.href.match(/streamid=(.*)&?$/);
if (matcher[1] && window[matcher[1]]) { if (matcher[1] && PushStreamManager[matcher[1]]) {
window[matcher[1]].register(iframe); PushStreamManager[matcher[1]].wrapper.register(iframe);
} }
}; };
/* make class public */ /* make class public */
window.PushStream = PushStream; window.PushStream = PushStream;
window.PushStreamManager = PushStreamManager;
})(window); })(window);
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment