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) {
|
||||
|
||||
// Required services
|
||||
var requestService = $injector.get('requestService');
|
||||
var authenticationService = $injector.get('authenticationService');
|
||||
var clientAuthService = $injector.get('clientAuthService');
|
||||
|
||||
var directive = {
|
||||
restrict: 'A'
|
||||
@@ -42,23 +41,7 @@ angular.module('element').directive('guacSslAuth', ['$injector', function guacSs
|
||||
|
||||
// Attempt SSL/TLS client authentication upon click
|
||||
element.addEventListener('click', function elementClicked() {
|
||||
|
||||
// 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);
|
||||
|
||||
clientAuthService.authenticate();
|
||||
});
|
||||
|
||||
};
|
||||
|
@@ -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