2017-08-04 12:19:56 +02:00
|
|
|
|
/*
|
2019-01-09 11:25:21 +01:00
|
|
|
|
* Copyright (c) 2019 ETH Zürich, Educational Development and Technology (LET)
|
2017-08-04 12:19:56 +02:00
|
|
|
|
*
|
|
|
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
using System;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Windows.Input;
|
2019-08-30 09:55:26 +02:00
|
|
|
|
using SafeExamBrowser.Configuration.Contracts.Settings;
|
|
|
|
|
using SafeExamBrowser.Logging.Contracts;
|
2019-09-05 09:00:41 +02:00
|
|
|
|
using SafeExamBrowser.Monitoring.Contracts.Keyboard;
|
2017-08-04 12:19:56 +02:00
|
|
|
|
|
|
|
|
|
namespace SafeExamBrowser.Monitoring.Keyboard
|
|
|
|
|
{
|
|
|
|
|
public class KeyboardInterceptor : IKeyboardInterceptor
|
|
|
|
|
{
|
2018-02-15 15:42:54 +01:00
|
|
|
|
private KeyboardSettings settings;
|
2017-08-04 12:19:56 +02:00
|
|
|
|
private ILogger logger;
|
|
|
|
|
|
2018-02-15 15:42:54 +01:00
|
|
|
|
public KeyboardInterceptor(KeyboardSettings settings, ILogger logger)
|
2017-08-04 12:19:56 +02:00
|
|
|
|
{
|
|
|
|
|
this.logger = logger;
|
|
|
|
|
this.settings = settings;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public bool Block(int keyCode, KeyModifier modifier, KeyState state)
|
|
|
|
|
{
|
|
|
|
|
var block = false;
|
|
|
|
|
var key = KeyInterop.KeyFromVirtualKey(keyCode);
|
|
|
|
|
|
|
|
|
|
block |= key == Key.Apps;
|
2019-01-09 16:01:56 +01:00
|
|
|
|
block |= key == Key.Escape && modifier == KeyModifier.None && !settings.AllowEsc;
|
|
|
|
|
block |= key == Key.F1 && !settings.AllowF1;
|
|
|
|
|
block |= key == Key.F2 && !settings.AllowF2;
|
|
|
|
|
block |= key == Key.F3 && !settings.AllowF3;
|
|
|
|
|
block |= key == Key.F4 && !settings.AllowF4;
|
|
|
|
|
block |= key == Key.F5 && !settings.AllowF5;
|
|
|
|
|
block |= key == Key.F6 && !settings.AllowF6;
|
|
|
|
|
block |= key == Key.F7 && !settings.AllowF7;
|
|
|
|
|
block |= key == Key.F8 && !settings.AllowF8;
|
|
|
|
|
block |= key == Key.F9 && !settings.AllowF9;
|
|
|
|
|
block |= key == Key.F10 && !settings.AllowF10;
|
|
|
|
|
block |= key == Key.F11 && !settings.AllowF11;
|
|
|
|
|
block |= key == Key.F12 && !settings.AllowF12;
|
|
|
|
|
block |= key == Key.LWin && !settings.AllowSystemKey;
|
|
|
|
|
block |= key == Key.PrintScreen && !settings.AllowPrintScreen;
|
|
|
|
|
block |= key == Key.RWin && !settings.AllowSystemKey;
|
|
|
|
|
block |= modifier.HasFlag(KeyModifier.Alt) && key == Key.Escape && !settings.AllowAltEsc;
|
|
|
|
|
block |= modifier.HasFlag(KeyModifier.Alt) && key == Key.F4 && !settings.AllowAltF4;
|
|
|
|
|
block |= modifier.HasFlag(KeyModifier.Alt) && key == Key.Space;
|
|
|
|
|
block |= modifier.HasFlag(KeyModifier.Alt) && key == Key.Tab && !settings.AllowAltTab;
|
|
|
|
|
block |= modifier.HasFlag(KeyModifier.Ctrl) && key == Key.Escape && !settings.AllowCtrlEsc;
|
2017-08-04 12:19:56 +02:00
|
|
|
|
|
|
|
|
|
if (block)
|
|
|
|
|
{
|
|
|
|
|
Log(key, keyCode, modifier, state);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return block;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void Log(Key key, int keyCode, KeyModifier modifier, KeyState state)
|
|
|
|
|
{
|
|
|
|
|
var modifierFlags = Enum.GetValues(typeof(KeyModifier)).OfType<KeyModifier>().Where(m => m != KeyModifier.None && modifier.HasFlag(m));
|
|
|
|
|
var modifiers = modifierFlags.Any() ? String.Join(" + ", modifierFlags) + " + " : string.Empty;
|
|
|
|
|
|
|
|
|
|
logger.Info($"Blocked '{modifiers}{key}' ({key} = {keyCode}) when {state.ToString().ToLower()}.");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|