mirror of
https://github.com/gyurix1968/guacamole-client.git
synced 2025-09-07 05:31:22 +00:00
Tunnel JSDoc.
This commit is contained in:
@@ -29,14 +29,47 @@ var Guacamole = Guacamole || {};
|
|||||||
* @see Guacamole.HTTPTunnel
|
* @see Guacamole.HTTPTunnel
|
||||||
*/
|
*/
|
||||||
Guacamole.Tunnel = function() {
|
Guacamole.Tunnel = function() {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Connect to the tunnel with the given optional data. This data is
|
||||||
|
* typically used for authentication. The format of data accepted is
|
||||||
|
* up to the tunnel implementation.
|
||||||
|
*
|
||||||
|
* @param {String} data The data to send to the tunnel when connecting.
|
||||||
|
*/
|
||||||
this.connect = function(data) {};
|
this.connect = function(data) {};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Disconnect from the tunnel.
|
||||||
|
*/
|
||||||
this.disconnect = function() {};
|
this.disconnect = function() {};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Send the given message through the tunnel to the service on the other
|
||||||
|
* side. All messages are guaranteed to be received in the order sent.
|
||||||
|
*
|
||||||
|
* @param {String} message The message to send to the service on the other
|
||||||
|
* side of the tunnel.
|
||||||
|
*/
|
||||||
this.sendMessage = function(message) {};
|
this.sendMessage = function(message) {};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fired whenever an error is encountered by the tunnel.
|
||||||
|
*
|
||||||
|
* @event
|
||||||
|
* @param {String} message A human-readable description of the error that
|
||||||
|
* occurred.
|
||||||
|
*/
|
||||||
this.onerror = null;
|
this.onerror = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fired once for every complete Guacamole instruction received, in order.
|
||||||
|
*
|
||||||
|
* @event
|
||||||
|
* @param {String} opcode The Guacamole instruction opcode.
|
||||||
|
* @param {Array} parameters The parameters provided for the instruction,
|
||||||
|
* if any.
|
||||||
|
*/
|
||||||
this.oninstruction = null;
|
this.oninstruction = null;
|
||||||
|
|
||||||
};
|
};
|
||||||
@@ -50,6 +83,9 @@ Guacamole.Tunnel = function() {
|
|||||||
*/
|
*/
|
||||||
Guacamole.HTTPTunnel = function(tunnelURL) {
|
Guacamole.HTTPTunnel = function(tunnelURL) {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reference to this HTTP tunnel.
|
||||||
|
*/
|
||||||
var tunnel = this;
|
var tunnel = this;
|
||||||
|
|
||||||
var tunnel_uuid;
|
var tunnel_uuid;
|
||||||
@@ -70,10 +106,10 @@ Guacamole.HTTPTunnel = function(tunnelURL) {
|
|||||||
// Default to polling - will be turned off automatically if not needed
|
// Default to polling - will be turned off automatically if not needed
|
||||||
var pollingMode = POLLING_ENABLED;
|
var pollingMode = POLLING_ENABLED;
|
||||||
|
|
||||||
var sendingMessages = 0;
|
var sendingMessages = false;
|
||||||
var outputMessageBuffer = "";
|
var outputMessageBuffer = "";
|
||||||
|
|
||||||
function sendMessage(message) {
|
this.sendMessage = function(message) {
|
||||||
|
|
||||||
// Do not attempt to send messages if not connected
|
// Do not attempt to send messages if not connected
|
||||||
if (currentState != STATE_CONNECTED)
|
if (currentState != STATE_CONNECTED)
|
||||||
@@ -81,16 +117,16 @@ Guacamole.HTTPTunnel = function(tunnelURL) {
|
|||||||
|
|
||||||
// Add event to queue, restart send loop if finished.
|
// Add event to queue, restart send loop if finished.
|
||||||
outputMessageBuffer += message;
|
outputMessageBuffer += message;
|
||||||
if (sendingMessages == 0)
|
if (!sendingMessages)
|
||||||
sendPendingMessages();
|
sendPendingMessages();
|
||||||
|
|
||||||
}
|
};
|
||||||
|
|
||||||
function sendPendingMessages() {
|
function sendPendingMessages() {
|
||||||
|
|
||||||
if (outputMessageBuffer.length > 0) {
|
if (outputMessageBuffer.length > 0) {
|
||||||
|
|
||||||
sendingMessages = 1;
|
sendingMessages = true;
|
||||||
|
|
||||||
var message_xmlhttprequest = new XMLHttpRequest();
|
var message_xmlhttprequest = new XMLHttpRequest();
|
||||||
message_xmlhttprequest.open("POST", TUNNEL_WRITE + tunnel_uuid);
|
message_xmlhttprequest.open("POST", TUNNEL_WRITE + tunnel_uuid);
|
||||||
@@ -107,7 +143,7 @@ Guacamole.HTTPTunnel = function(tunnelURL) {
|
|||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
sendingMessages = 0;
|
sendingMessages = false;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -161,7 +197,7 @@ Guacamole.HTTPTunnel = function(tunnelURL) {
|
|||||||
if (tunnel.onerror) tunnel.onerror(message);
|
if (tunnel.onerror) tunnel.onerror(message);
|
||||||
|
|
||||||
// Finish
|
// Finish
|
||||||
disconnect();
|
tunnel.disconnect();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -255,7 +291,7 @@ Guacamole.HTTPTunnel = function(tunnelURL) {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function connect(data) {
|
this.connect = function(data) {
|
||||||
|
|
||||||
// Start tunnel and connect synchronously
|
// Start tunnel and connect synchronously
|
||||||
var connect_xmlhttprequest = new XMLHttpRequest();
|
var connect_xmlhttprequest = new XMLHttpRequest();
|
||||||
@@ -281,16 +317,11 @@ Guacamole.HTTPTunnel = function(tunnelURL) {
|
|||||||
currentState = STATE_CONNECTED;
|
currentState = STATE_CONNECTED;
|
||||||
handleResponse(makeRequest());
|
handleResponse(makeRequest());
|
||||||
|
|
||||||
}
|
};
|
||||||
|
|
||||||
function disconnect() {
|
this.disconnect = function() {
|
||||||
currentState = STATE_DISCONNECTED;
|
currentState = STATE_DISCONNECTED;
|
||||||
}
|
};
|
||||||
|
|
||||||
// External API
|
|
||||||
tunnel.connect = connect;
|
|
||||||
tunnel.disconnect = disconnect;
|
|
||||||
tunnel.sendMessage = sendMessage;
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user