mirror of
https://github.com/gyurix1968/guacamole-client.git
synced 2025-09-06 05:07:41 +00:00
Merge 1.3.0 changes back to master.
This commit is contained in:
@@ -24,6 +24,7 @@ import com.google.inject.assistedinject.Assisted;
|
||||
import com.google.inject.assistedinject.AssistedInject;
|
||||
import javax.ws.rs.Consumes;
|
||||
import javax.ws.rs.DefaultValue;
|
||||
import javax.ws.rs.GET;
|
||||
import javax.ws.rs.Path;
|
||||
import javax.ws.rs.PathParam;
|
||||
import javax.ws.rs.Produces;
|
||||
@@ -31,8 +32,10 @@ import javax.ws.rs.QueryParam;
|
||||
import javax.ws.rs.core.MediaType;
|
||||
import org.apache.guacamole.GuacamoleException;
|
||||
import org.apache.guacamole.GuacamoleResourceNotFoundException;
|
||||
import org.apache.guacamole.environment.Environment;
|
||||
import org.apache.guacamole.net.auth.ActiveConnection;
|
||||
import org.apache.guacamole.net.auth.UserContext;
|
||||
import org.apache.guacamole.protocols.ProtocolInfo;
|
||||
import org.apache.guacamole.rest.activeconnection.APIActiveConnection;
|
||||
import org.apache.guacamole.rest.directory.DirectoryObjectResource;
|
||||
import org.apache.guacamole.rest.directory.DirectoryObjectResourceFactory;
|
||||
@@ -57,6 +60,12 @@ public class TunnelResource {
|
||||
*/
|
||||
private final UserTunnel tunnel;
|
||||
|
||||
/**
|
||||
* The Guacamole server environment.
|
||||
*/
|
||||
@Inject
|
||||
private Environment environment;
|
||||
|
||||
/**
|
||||
* A factory which can be used to create instances of resources representing
|
||||
* ActiveConnections.
|
||||
@@ -106,6 +115,39 @@ public class TunnelResource {
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieves the underlying protocol used by the connection associated with
|
||||
* this tunnel. If possible, the parameters available for that protocol are
|
||||
* retrieved, as well.
|
||||
*
|
||||
* @return
|
||||
* A ProtocolInfo object describing the protocol used by the connection
|
||||
* associated with this tunnel.
|
||||
*
|
||||
* @throws GuacamoleException
|
||||
* If the protocol used by the connection associated with this tunnel
|
||||
* cannot be determined.
|
||||
*/
|
||||
@GET
|
||||
@Path("protocol")
|
||||
public ProtocolInfo getProtocol() throws GuacamoleException {
|
||||
|
||||
// Pull protocol name from underlying socket
|
||||
String protocol = tunnel.getSocket().getProtocol();
|
||||
if (protocol == null)
|
||||
throw new GuacamoleResourceNotFoundException("Protocol of tunnel is not known/exposed.");
|
||||
|
||||
// If there is no such protocol defined, provide as much info as is
|
||||
// known (just the name)
|
||||
ProtocolInfo info = environment.getProtocol(protocol);
|
||||
if (info == null)
|
||||
return new ProtocolInfo(protocol);
|
||||
|
||||
// All protocol information for this tunnel is known
|
||||
return info;
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Intercepts and returns the entire contents of a specific stream.
|
||||
*
|
||||
|
@@ -386,7 +386,16 @@ angular.module('client').factory('ManagedClient', ['$rootScope', '$injector',
|
||||
status.code);
|
||||
});
|
||||
};
|
||||
|
||||
|
||||
// Pull protocol-specific information from tunnel once tunnel UUID is
|
||||
// known
|
||||
tunnel.onuuid = function tunnelAssignedUUID(uuid) {
|
||||
tunnelService.getProtocol(uuid).then(function protocolRetrieved(protocol) {
|
||||
managedClient.protocol = protocol.name;
|
||||
managedClient.forms = protocol.connectionForms;
|
||||
}, requestService.WARN);
|
||||
};
|
||||
|
||||
// Update connection state as tunnel state changes
|
||||
tunnel.onstatechange = function tunnelStateChanged(state) {
|
||||
$rootScope.$evalAsync(function updateTunnelState() {
|
||||
@@ -612,14 +621,9 @@ angular.module('client').factory('ManagedClient', ['$rootScope', '$injector',
|
||||
|
||||
// If using a connection, pull connection name and protocol information
|
||||
if (clientIdentifier.type === ClientIdentifier.Types.CONNECTION) {
|
||||
$q.all({
|
||||
connection : connectionService.getConnection(clientIdentifier.dataSource, clientIdentifier.id),
|
||||
protocols : schemaService.getProtocols(clientIdentifier.dataSource)
|
||||
})
|
||||
.then(function dataRetrieved(values) {
|
||||
managedClient.name = managedClient.title = values.connection.name;
|
||||
managedClient.protocol = values.connection.protocol;
|
||||
managedClient.forms = values.protocols[values.connection.protocol].connectionForms;
|
||||
connectionService.getConnection(clientIdentifier.dataSource, clientIdentifier.id)
|
||||
.then(function connectionRetrieved(connection) {
|
||||
managedClient.name = managedClient.title = connection.name;
|
||||
}, requestService.WARN);
|
||||
}
|
||||
|
||||
@@ -640,14 +644,9 @@ angular.module('client').factory('ManagedClient', ['$rootScope', '$injector',
|
||||
// Attempt to retrieve connection details only if the
|
||||
// underlying connection is known
|
||||
if (activeConnection.connectionIdentifier) {
|
||||
$q.all({
|
||||
connection : connectionService.getConnection(clientIdentifier.dataSource, activeConnection.connectionIdentifier),
|
||||
protocols : schemaService.getProtocols(clientIdentifier.dataSource)
|
||||
})
|
||||
.then(function dataRetrieved(values) {
|
||||
managedClient.name = managedClient.title = values.connection.name;
|
||||
managedClient.protocol = values.connection.protocol;
|
||||
managedClient.forms = values.protocols[values.connection.protocol].connectionForms;
|
||||
connectionService.getConnection(clientIdentifier.dataSource, activeConnection.connectionIdentifier)
|
||||
.then(function connectionRetrieved(connection) {
|
||||
managedClient.name = managedClient.title = connection.name;
|
||||
}, requestService.WARN);
|
||||
}
|
||||
|
||||
|
@@ -79,6 +79,36 @@ angular.module('rest').factory('tunnelService', ['$injector',
|
||||
|
||||
};
|
||||
|
||||
/**
|
||||
* Makes a request to the REST API to retrieve the underlying protocol of
|
||||
* the connection associated with a particular tunnel, returning a promise
|
||||
* that provides a @link{Protocol} object if successful.
|
||||
*
|
||||
* @param {String} tunnel
|
||||
* The UUID of the tunnel associated with the Guacamole connection
|
||||
* whose underlying protocol is being retrieved.
|
||||
*
|
||||
* @returns {Promise.<Protocol>}
|
||||
* A promise which will resolve with a @link{Protocol} object upon
|
||||
* success.
|
||||
*/
|
||||
service.getProtocol = function getProtocol(tunnel) {
|
||||
|
||||
// Build HTTP parameters set
|
||||
var httpParameters = {
|
||||
token : authenticationService.getCurrentToken()
|
||||
};
|
||||
|
||||
// Retrieve the protocol details of the specified tunnel
|
||||
return requestService({
|
||||
method : 'GET',
|
||||
url : 'api/session/tunnels/' + encodeURIComponent(tunnel)
|
||||
+ '/protocol',
|
||||
params : httpParameters
|
||||
});
|
||||
|
||||
};
|
||||
|
||||
/**
|
||||
* Retrieves the set of sharing profiles that the current user can use to
|
||||
* share the active connection of the given tunnel.
|
||||
|
Reference in New Issue
Block a user