mirror of
https://github.com/gyurix1968/guacamole-client.git
synced 2025-09-06 05:07:41 +00:00
GUACAMOLE-839: Move SSL/TLS client auth logic to separate service.
This commit is contained in:
@@ -24,8 +24,7 @@
|
|||||||
angular.module('element').directive('guacSslAuth', ['$injector', function guacSslAuth($injector) {
|
angular.module('element').directive('guacSslAuth', ['$injector', function guacSslAuth($injector) {
|
||||||
|
|
||||||
// Required services
|
// Required services
|
||||||
var requestService = $injector.get('requestService');
|
var clientAuthService = $injector.get('clientAuthService');
|
||||||
var authenticationService = $injector.get('authenticationService');
|
|
||||||
|
|
||||||
var directive = {
|
var directive = {
|
||||||
restrict: 'A'
|
restrict: 'A'
|
||||||
@@ -42,23 +41,7 @@ angular.module('element').directive('guacSslAuth', ['$injector', function guacSs
|
|||||||
|
|
||||||
// Attempt SSL/TLS client authentication upon click
|
// Attempt SSL/TLS client authentication upon click
|
||||||
element.addEventListener('click', function elementClicked() {
|
element.addEventListener('click', function elementClicked() {
|
||||||
|
clientAuthService.authenticate();
|
||||||
// Transform SSL/TLS identity into an opaque "state" value and
|
|
||||||
// attempt authentication using that value
|
|
||||||
authenticationService.authenticate(
|
|
||||||
requestService({
|
|
||||||
method: 'GET',
|
|
||||||
headers : {
|
|
||||||
'Cache-Control' : undefined, // Avoid sending headers that would result in a pre-flight OPTIONS request for CORS
|
|
||||||
'Pragma' : undefined
|
|
||||||
},
|
|
||||||
url: 'api/ext/ssl/identity'
|
|
||||||
})
|
|
||||||
.then(function identityRetrieved(data) {
|
|
||||||
return { 'state' : data.state || '' };
|
|
||||||
})
|
|
||||||
)['catch'](requestService.IGNORE);
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
};
|
};
|
||||||
|
@@ -0,0 +1,58 @@
|
|||||||
|
/*
|
||||||
|
* 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 authenticating a user using SSL/TLS client authentication.
|
||||||
|
*/
|
||||||
|
angular.module('guacSsoSsl').factory('clientAuthService', ['$injector',
|
||||||
|
function clientAuthServiceProvider($injector) {
|
||||||
|
|
||||||
|
// Required services
|
||||||
|
var requestService = $injector.get('requestService');
|
||||||
|
var authenticationService = $injector.get('authenticationService');
|
||||||
|
|
||||||
|
var service = {};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Attempt to authenticate using a unique token obtained through SSL/TLS
|
||||||
|
* client authentication.
|
||||||
|
*/
|
||||||
|
service.authenticate = function authenticate() {
|
||||||
|
|
||||||
|
// Transform SSL/TLS identity into an opaque "state" value and
|
||||||
|
// attempt authentication using that value
|
||||||
|
authenticationService.authenticate(
|
||||||
|
requestService({
|
||||||
|
method: 'GET',
|
||||||
|
headers : {
|
||||||
|
'Cache-Control' : undefined, // Avoid sending headers that would result in a pre-flight OPTIONS request for CORS
|
||||||
|
'Pragma' : undefined
|
||||||
|
},
|
||||||
|
url: 'api/ext/ssl/identity'
|
||||||
|
})
|
||||||
|
.then(function identityRetrieved(data) {
|
||||||
|
return { 'state' : data.state || '' };
|
||||||
|
})
|
||||||
|
)['catch'](requestService.IGNORE);
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
return service;
|
||||||
|
|
||||||
|
}]);
|
Reference in New Issue
Block a user