mirror of
https://github.com/gyurix1968/guacamole-client.git
synced 2025-09-06 13:17:41 +00:00
209 lines
8.2 KiB
JavaScript
209 lines
8.2 KiB
JavaScript
/*
|
|
* Licensed to the Apache Software Foundation (ASF) under one
|
|
* or more contributor license agreements. See the NOTICE file
|
|
* distributed with this work for additional information
|
|
* regarding copyright ownership. The ASF licenses this file
|
|
* to you under the Apache License, Version 2.0 (the
|
|
* "License"); you may not use this file except in compliance
|
|
* with the License. You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing,
|
|
* software distributed under the License is distributed on an
|
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
* KIND, either express or implied. See the License for the
|
|
* specific language governing permissions and limitations
|
|
* under the License.
|
|
*/
|
|
|
|
/**
|
|
* Service for operating on connection groups via the REST API.
|
|
*/
|
|
angular.module('rest').factory('connectionGroupService', ['$injector',
|
|
function connectionGroupService($injector) {
|
|
|
|
// Required services
|
|
var requestService = $injector.get('requestService');
|
|
var $q = $injector.get('$q');
|
|
var authenticationService = $injector.get('authenticationService');
|
|
var cacheService = $injector.get('cacheService');
|
|
|
|
// Required types
|
|
var ConnectionGroup = $injector.get('ConnectionGroup');
|
|
|
|
var service = {};
|
|
|
|
/**
|
|
* Makes a request to the REST API to get an individual connection group
|
|
* and all descendants, returning a promise that provides the corresponding
|
|
* @link{ConnectionGroup} if successful. Descendant groups and connections
|
|
* will be stored as children of that connection group. If a permission
|
|
* type is specified, the result will be filtering by that permission.
|
|
*
|
|
* @param {String} [connectionGroupID=ConnectionGroup.ROOT_IDENTIFIER]
|
|
* The ID of the connection group to retrieve. If not provided, the
|
|
* root connection group will be retrieved by default.
|
|
*
|
|
* @param {String[]} [permissionTypes]
|
|
* The set of permissions to filter with. A user must have one or more
|
|
* of these permissions for a connection to appear in the result.
|
|
* If null, no filtering will be performed. Valid values are listed
|
|
* within PermissionSet.ObjectType.
|
|
*
|
|
* @returns {Promise.ConnectionGroup}
|
|
* A promise which will resolve with a @link{ConnectionGroup} upon
|
|
* success.
|
|
*/
|
|
service.getConnectionGroupTree = function getConnectionGroupTree(dataSource, connectionGroupID, permissionTypes) {
|
|
|
|
// Use the root connection group ID if no ID is passed in
|
|
connectionGroupID = connectionGroupID || ConnectionGroup.ROOT_IDENTIFIER;
|
|
|
|
// Build HTTP parameters set
|
|
var httpParameters = {
|
|
token : authenticationService.getCurrentToken()
|
|
};
|
|
|
|
// Add permission filter if specified
|
|
if (permissionTypes)
|
|
httpParameters.permission = permissionTypes;
|
|
|
|
// Retrieve connection group
|
|
return requestService({
|
|
cache : cacheService.connections,
|
|
method : 'GET',
|
|
url : 'api/session/data/' + encodeURIComponent(dataSource) + '/connectionGroups/' + encodeURIComponent(connectionGroupID) + '/tree',
|
|
params : httpParameters
|
|
});
|
|
|
|
};
|
|
|
|
/**
|
|
* Makes a request to the REST API to get an individual connection group,
|
|
* returning a promise that provides the corresponding
|
|
* @link{ConnectionGroup} if successful.
|
|
*
|
|
* @param {String} [connectionGroupID=ConnectionGroup.ROOT_IDENTIFIER]
|
|
* The ID of the connection group to retrieve. If not provided, the
|
|
* root connection group will be retrieved by default.
|
|
*
|
|
* @returns {Promise.<ConnectionGroup>} A promise for the HTTP call.
|
|
* A promise which will resolve with a @link{ConnectionGroup} upon
|
|
* success.
|
|
*/
|
|
service.getConnectionGroup = function getConnectionGroup(dataSource, connectionGroupID) {
|
|
|
|
// Use the root connection group ID if no ID is passed in
|
|
connectionGroupID = connectionGroupID || ConnectionGroup.ROOT_IDENTIFIER;
|
|
|
|
// Build HTTP parameters set
|
|
var httpParameters = {
|
|
token : authenticationService.getCurrentToken()
|
|
};
|
|
|
|
// Retrieve connection group
|
|
return requestService({
|
|
cache : cacheService.connections,
|
|
method : 'GET',
|
|
url : 'api/session/data/' + encodeURIComponent(dataSource) + '/connectionGroups/' + encodeURIComponent(connectionGroupID),
|
|
params : httpParameters
|
|
});
|
|
|
|
};
|
|
|
|
/**
|
|
* Makes a request to the REST API to save a connection group, returning a
|
|
* promise that can be used for processing the results of the call. If the
|
|
* connection group is new, and thus does not yet have an associated
|
|
* identifier, the identifier will be automatically set in the provided
|
|
* connection group upon success.
|
|
*
|
|
* @param {ConnectionGroup} connectionGroup The connection group to update.
|
|
*
|
|
* @returns {Promise}
|
|
* A promise for the HTTP call which will succeed if and only if the
|
|
* save operation is successful.
|
|
*/
|
|
service.saveConnectionGroup = function saveConnectionGroup(dataSource, connectionGroup) {
|
|
|
|
// Build HTTP parameters set
|
|
var httpParameters = {
|
|
token : authenticationService.getCurrentToken()
|
|
};
|
|
|
|
// If connection group is new, add it and set the identifier automatically
|
|
if (!connectionGroup.identifier) {
|
|
return requestService({
|
|
method : 'POST',
|
|
url : 'api/session/data/' + encodeURIComponent(dataSource) + '/connectionGroups',
|
|
params : httpParameters,
|
|
data : connectionGroup
|
|
})
|
|
|
|
// Set the identifier on the new connection group and clear the cache
|
|
.then(function connectionGroupCreated(newConnectionGroup){
|
|
connectionGroup.identifier = newConnectionGroup.identifier;
|
|
cacheService.connections.removeAll();
|
|
|
|
// Clear users cache to force reload of permissions for this
|
|
// newly created connection group
|
|
cacheService.users.removeAll();
|
|
});
|
|
}
|
|
|
|
// Otherwise, update the existing connection group
|
|
else {
|
|
return requestService({
|
|
method : 'PUT',
|
|
url : 'api/session/data/' + encodeURIComponent(dataSource) + '/connectionGroups/' + encodeURIComponent(connectionGroup.identifier),
|
|
params : httpParameters,
|
|
data : connectionGroup
|
|
})
|
|
|
|
// Clear the cache
|
|
.then(function connectionGroupUpdated(){
|
|
cacheService.connections.removeAll();
|
|
|
|
// Clear users cache to force reload of permissions for this
|
|
// newly updated connection group
|
|
cacheService.users.removeAll();
|
|
});
|
|
}
|
|
|
|
};
|
|
|
|
/**
|
|
* Makes a request to the REST API to delete a connection group, returning
|
|
* a promise that can be used for processing the results of the call.
|
|
*
|
|
* @param {ConnectionGroup} connectionGroup The connection group to delete.
|
|
*
|
|
* @returns {Promise}
|
|
* A promise for the HTTP call which will succeed if and only if the
|
|
* delete operation is successful.
|
|
*/
|
|
service.deleteConnectionGroup = function deleteConnectionGroup(dataSource, connectionGroup) {
|
|
|
|
// Build HTTP parameters set
|
|
var httpParameters = {
|
|
token : authenticationService.getCurrentToken()
|
|
};
|
|
|
|
// Delete connection group
|
|
return requestService({
|
|
method : 'DELETE',
|
|
url : 'api/session/data/' + encodeURIComponent(dataSource) + '/connectionGroups/' + encodeURIComponent(connectionGroup.identifier),
|
|
params : httpParameters
|
|
})
|
|
|
|
// Clear the cache
|
|
.then(function connectionGroupDeleted(){
|
|
cacheService.connections.removeAll();
|
|
});
|
|
|
|
};
|
|
|
|
return service;
|
|
}]);
|