mirror of
https://github.com/gyurix1968/guacamole-client.git
synced 2025-09-06 13:17:41 +00:00
197 lines
6.4 KiB
JavaScript
197 lines
6.4 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.
|
|
*/
|
|
|
|
/**
|
|
* The controller for the root of the application.
|
|
*/
|
|
angular.module('index').controller('indexController', ['$scope', '$injector',
|
|
function indexController($scope, $injector) {
|
|
|
|
// Required services
|
|
var $document = $injector.get('$document');
|
|
var $window = $injector.get('$window');
|
|
var clipboardService = $injector.get('clipboardService');
|
|
var guacNotification = $injector.get('guacNotification');
|
|
|
|
/**
|
|
* The notification service.
|
|
*/
|
|
$scope.guacNotification = guacNotification;
|
|
|
|
/**
|
|
* The message to display to the user as instructions for the login
|
|
* process.
|
|
*
|
|
* @type TranslatableMessage
|
|
*/
|
|
$scope.loginHelpText = null;
|
|
|
|
/**
|
|
* The credentials that the authentication service is has already accepted,
|
|
* pending additional credentials, if any. If the user is logged in, or no
|
|
* credentials have been accepted, this will be null. If credentials have
|
|
* been accepted, this will be a map of name/value pairs corresponding to
|
|
* the parameters submitted in a previous authentication attempt.
|
|
*
|
|
* @type Object.<String, String>
|
|
*/
|
|
$scope.acceptedCredentials = null;
|
|
|
|
/**
|
|
* The credentials that the authentication service is currently expecting,
|
|
* if any. If the user is logged in, this will be null.
|
|
*
|
|
* @type Field[]
|
|
*/
|
|
$scope.expectedCredentials = null;
|
|
|
|
/**
|
|
* Basic page-level information.
|
|
*/
|
|
$scope.page = {
|
|
|
|
/**
|
|
* The title of the page.
|
|
*
|
|
* @type String
|
|
*/
|
|
title: '',
|
|
|
|
/**
|
|
* The name of the CSS class to apply to the page body, if any.
|
|
*
|
|
* @type String
|
|
*/
|
|
bodyClassName: ''
|
|
|
|
};
|
|
|
|
// Add default destination for input events
|
|
var sink = new Guacamole.InputSink();
|
|
$document[0].body.appendChild(sink.getElement());
|
|
|
|
// Create event listeners at the global level
|
|
var keyboard = new Guacamole.Keyboard($document[0]);
|
|
keyboard.listenTo(sink.getElement());
|
|
|
|
// Broadcast keydown events
|
|
keyboard.onkeydown = function onkeydown(keysym) {
|
|
|
|
// Do not handle key events if not logged in
|
|
if ($scope.expectedCredentials)
|
|
return true;
|
|
|
|
// Warn of pending keydown
|
|
var guacBeforeKeydownEvent = $scope.$broadcast('guacBeforeKeydown', keysym, keyboard);
|
|
if (guacBeforeKeydownEvent.defaultPrevented)
|
|
return true;
|
|
|
|
// If not prevented via guacBeforeKeydown, fire corresponding keydown event
|
|
var guacKeydownEvent = $scope.$broadcast('guacKeydown', keysym, keyboard);
|
|
return !guacKeydownEvent.defaultPrevented;
|
|
|
|
};
|
|
|
|
// Broadcast keyup events
|
|
keyboard.onkeyup = function onkeyup(keysym) {
|
|
|
|
// Do not handle key events if not logged in
|
|
if ($scope.expectedCredentials)
|
|
return;
|
|
|
|
// Warn of pending keyup
|
|
var guacBeforeKeydownEvent = $scope.$broadcast('guacBeforeKeyup', keysym, keyboard);
|
|
if (guacBeforeKeydownEvent.defaultPrevented)
|
|
return;
|
|
|
|
// If not prevented via guacBeforeKeyup, fire corresponding keydown event
|
|
$scope.$broadcast('guacKeyup', keysym, keyboard);
|
|
|
|
};
|
|
|
|
// Release all keys when window loses focus
|
|
$window.onblur = function () {
|
|
keyboard.reset();
|
|
};
|
|
|
|
/**
|
|
* Checks whether the clipboard data has changed, firing a new
|
|
* "guacClipboard" event if it has.
|
|
*/
|
|
var checkClipboard = function checkClipboard() {
|
|
clipboardService.getLocalClipboard().then(function clipboardRead(data) {
|
|
$scope.$broadcast('guacClipboard', data);
|
|
});
|
|
};
|
|
|
|
// Attempt to read the clipboard if it may have changed
|
|
$window.addEventListener('load', checkClipboard, true);
|
|
$window.addEventListener('copy', checkClipboard);
|
|
$window.addEventListener('cut', checkClipboard);
|
|
$window.addEventListener('focus', function focusGained(e) {
|
|
|
|
// Only recheck clipboard if it's the window itself that gained focus
|
|
if (e.target === $window)
|
|
checkClipboard();
|
|
|
|
}, true);
|
|
|
|
// Display login screen if a whole new set of credentials is needed
|
|
$scope.$on('guacInvalidCredentials', function loginInvalid(event, parameters, error) {
|
|
$scope.page.title = 'APP.NAME';
|
|
$scope.page.bodyClassName = '';
|
|
$scope.loginHelpText = null;
|
|
$scope.acceptedCredentials = {};
|
|
$scope.expectedCredentials = error.expected;
|
|
});
|
|
|
|
// Prompt for remaining credentials if provided credentials were not enough
|
|
$scope.$on('guacInsufficientCredentials', function loginInsufficient(event, parameters, error) {
|
|
$scope.page.title = 'APP.NAME';
|
|
$scope.page.bodyClassName = '';
|
|
$scope.loginHelpText = error.translatableMessage;
|
|
$scope.acceptedCredentials = parameters;
|
|
$scope.expectedCredentials = error.expected;
|
|
});
|
|
|
|
// Update title and CSS class upon navigation
|
|
$scope.$on('$routeChangeSuccess', function(event, current, previous) {
|
|
|
|
// If the current route is available
|
|
if (current.$$route) {
|
|
|
|
// Clear login screen if route change was successful (and thus
|
|
// login was either successful or not required)
|
|
$scope.loginHelpText = null;
|
|
$scope.acceptedCredentials = null;
|
|
$scope.expectedCredentials = null;
|
|
|
|
// Set title
|
|
var title = current.$$route.title;
|
|
if (title)
|
|
$scope.page.title = title;
|
|
|
|
// Set body CSS class
|
|
$scope.page.bodyClassName = current.$$route.bodyClassName || '';
|
|
}
|
|
|
|
});
|
|
|
|
}]);
|