2017-07-27 11:46:31 +02:00
|
|
|
|
/*
|
2022-01-21 16:33:52 +01:00
|
|
|
|
* Copyright (c) 2022 ETH Zürich, Educational Development and Technology (LET)
|
2017-07-27 11:46:31 +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.Collections.Generic;
|
2019-08-30 09:55:26 +02:00
|
|
|
|
using SafeExamBrowser.WindowsApi.Contracts.Events;
|
2017-07-27 11:46:31 +02:00
|
|
|
|
|
2019-08-30 09:55:26 +02:00
|
|
|
|
namespace SafeExamBrowser.WindowsApi.Contracts
|
2017-07-27 11:46:31 +02:00
|
|
|
|
{
|
2018-03-06 11:38:12 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Defines and wraps the functionality available via the native Windows API.
|
|
|
|
|
/// </summary>
|
2017-07-27 11:46:31 +02:00
|
|
|
|
public interface INativeMethods
|
|
|
|
|
{
|
2019-11-29 14:59:54 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Brings the window with the given handle to the foreground and activates it.
|
|
|
|
|
/// </summary>
|
|
|
|
|
void ActivateWindow(IntPtr handle);
|
|
|
|
|
|
2017-08-04 15:20:33 +02:00
|
|
|
|
/// <summary>
|
2019-10-01 11:30:53 +02:00
|
|
|
|
/// Deregisters a previously registered keyboard hook.
|
2017-08-04 15:20:33 +02:00
|
|
|
|
/// </summary>
|
|
|
|
|
/// <exception cref="System.ComponentModel.Win32Exception">
|
2019-10-01 11:30:53 +02:00
|
|
|
|
/// If the hook could not be successfully removed.
|
2017-08-04 15:20:33 +02:00
|
|
|
|
/// </exception>
|
2019-10-01 11:30:53 +02:00
|
|
|
|
void DeregisterKeyboardHook(Guid hookId);
|
2017-08-04 15:20:33 +02:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
2019-10-01 11:30:53 +02:00
|
|
|
|
/// Deregisters a previously registered mouse hook.
|
2017-08-04 15:20:33 +02:00
|
|
|
|
/// </summary>
|
|
|
|
|
/// <exception cref="System.ComponentModel.Win32Exception">
|
2019-10-01 11:30:53 +02:00
|
|
|
|
/// If the hook could not be successfully removed.
|
2017-08-04 15:20:33 +02:00
|
|
|
|
/// </exception>
|
2019-10-01 11:30:53 +02:00
|
|
|
|
void DeregisterMouseHook(Guid hookId);
|
2017-08-04 15:20:33 +02:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
2018-09-27 11:24:13 +02:00
|
|
|
|
/// Deregisters a previously registered system event hook.
|
2017-08-04 15:20:33 +02:00
|
|
|
|
/// </summary>
|
|
|
|
|
/// <exception cref="System.ComponentModel.Win32Exception">
|
|
|
|
|
/// If the event hook could not be successfully removed.
|
|
|
|
|
/// </exception>
|
2018-09-27 11:24:13 +02:00
|
|
|
|
void DeregisterSystemEventHook(Guid hookId);
|
2017-08-04 15:20:33 +02:00
|
|
|
|
|
2017-08-07 18:08:55 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Empties the clipboard.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <exception cref="System.ComponentModel.Win32Exception">
|
|
|
|
|
/// If the emptying of the clipboard failed.
|
|
|
|
|
/// </exception>
|
|
|
|
|
void EmptyClipboard();
|
|
|
|
|
|
2019-11-14 14:03:43 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Retrieves the current position of the mouse cursor.
|
|
|
|
|
/// </summary>
|
|
|
|
|
(int x, int y) GetCursorPosition();
|
|
|
|
|
|
2017-07-27 11:46:31 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Retrieves a collection of handles to all currently open (i.e. visible) windows.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <exception cref="System.ComponentModel.Win32Exception">
|
|
|
|
|
/// If the open windows could not be retrieved.
|
|
|
|
|
/// </exception>
|
|
|
|
|
IEnumerable<IntPtr> GetOpenWindows();
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Retrieves the process identifier for the specified window handle.
|
|
|
|
|
/// </summary>
|
|
|
|
|
uint GetProcessIdFor(IntPtr window);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2019-10-01 11:30:53 +02:00
|
|
|
|
/// Retrieves a window handle to the Windows taskbar. Returns <c>IntPtr.Zero</c> if the taskbar could not be found (i.e. if it isn't running).
|
2017-07-27 11:46:31 +02:00
|
|
|
|
/// </summary>
|
|
|
|
|
IntPtr GetShellWindowHandle();
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2019-10-01 11:30:53 +02:00
|
|
|
|
/// Retrieves the process identifier of the main Windows explorer instance controlling desktop and taskbar or <c>0</c>, if the process isn't running.
|
2017-07-27 11:46:31 +02:00
|
|
|
|
/// </summary>
|
|
|
|
|
uint GetShellProcessId();
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2017-08-11 08:28:17 +02:00
|
|
|
|
/// Retrieves the path of the currently configured wallpaper image, or an empty string, if there is no wallpaper set.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <exception cref="System.ComponentModel.Win32Exception">
|
|
|
|
|
/// If the wallpaper path could not be retrieved.
|
|
|
|
|
/// </exception>
|
|
|
|
|
string GetWallpaperPath();
|
|
|
|
|
|
2019-12-03 15:43:48 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Attempts to retrieve the icon of the given window. Returns a handle to the icon, or <see cref="IntPtr.Zero"/> if the icon could not be retrieved.
|
|
|
|
|
/// </summary>
|
|
|
|
|
IntPtr GetWindowIcon(IntPtr window);
|
|
|
|
|
|
2017-08-11 08:28:17 +02:00
|
|
|
|
/// <summary>
|
2019-11-29 14:59:54 +01:00
|
|
|
|
/// Retrieves the title of the window with the given handle, or an empty string if the given window does not have a title.
|
2017-07-27 11:46:31 +02:00
|
|
|
|
/// </summary>
|
|
|
|
|
string GetWindowTitle(IntPtr window);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Retrieves the currently configured working area of the primary screen.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <exception cref="System.ComponentModel.Win32Exception">
|
|
|
|
|
/// If the working area could not be retrieved.
|
|
|
|
|
/// </exception>
|
2017-08-04 08:25:49 +02:00
|
|
|
|
IBounds GetWorkingArea();
|
2017-07-27 11:46:31 +02:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
2017-07-27 13:57:12 +02:00
|
|
|
|
/// Hides the given window. Returns <c>true</c> if successful, otherwise <c>false</c>.
|
2017-07-27 11:46:31 +02:00
|
|
|
|
/// </summary>
|
2017-07-27 13:57:12 +02:00
|
|
|
|
bool HideWindow(IntPtr window);
|
2017-07-27 11:46:31 +02:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Minimizes all open windows.
|
|
|
|
|
/// </summary>
|
|
|
|
|
void MinimizeAllOpenWindows();
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Instructs the main Windows explorer process to shut down.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <exception cref="System.ComponentModel.Win32Exception">
|
|
|
|
|
/// If the message could not be successfully posted. Does not apply if the process isn't running!
|
|
|
|
|
/// </exception>
|
|
|
|
|
void PostCloseMessageToShell();
|
|
|
|
|
|
2017-08-11 11:16:44 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Prevents Windows from entering sleep mode and keeps all displays powered on.
|
|
|
|
|
/// </summary>
|
|
|
|
|
void PreventSleepMode();
|
|
|
|
|
|
2017-08-03 15:35:22 +02:00
|
|
|
|
/// <summary>
|
2019-10-01 11:30:53 +02:00
|
|
|
|
/// Registers a keyboard hook for the given callback. Returns the identifier of the newly registered hook.
|
2017-08-03 15:35:22 +02:00
|
|
|
|
/// </summary>
|
2019-10-01 11:30:53 +02:00
|
|
|
|
Guid RegisterKeyboardHook(KeyboardHookCallback callback);
|
2017-08-03 15:35:22 +02:00
|
|
|
|
|
2017-08-04 15:20:33 +02:00
|
|
|
|
/// <summary>
|
2019-10-01 11:30:53 +02:00
|
|
|
|
/// Registers a mouse hook for the given callback. Returns the identifier of the newly registered hook.
|
2017-08-04 15:20:33 +02:00
|
|
|
|
/// </summary>
|
2019-10-01 11:30:53 +02:00
|
|
|
|
Guid RegisterMouseHook(MouseHookCallback callback);
|
2017-08-04 15:20:33 +02:00
|
|
|
|
|
2017-07-27 11:46:31 +02:00
|
|
|
|
/// <summary>
|
2019-10-01 11:30:53 +02:00
|
|
|
|
/// Registers a system event which will invoke the specified callback when a window has received mouse capture. Returns the identifier of
|
|
|
|
|
/// the newly registered Windows event hook.
|
2017-07-27 11:46:31 +02:00
|
|
|
|
/// </summary>
|
2018-09-27 11:24:13 +02:00
|
|
|
|
Guid RegisterSystemCaptureStartEvent(SystemEventCallback callback);
|
2017-07-27 11:46:31 +02:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
2019-10-01 11:30:53 +02:00
|
|
|
|
/// Registers a system event which will invoke the specified callback when the foreground window has changed. Returns the identifier of the
|
|
|
|
|
/// newly registered Windows event hook.
|
2017-07-27 11:46:31 +02:00
|
|
|
|
/// </summary>
|
2018-09-27 11:24:13 +02:00
|
|
|
|
Guid RegisterSystemForegroundEvent(SystemEventCallback callback);
|
2017-07-27 11:46:31 +02:00
|
|
|
|
|
2017-08-11 08:28:17 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Removes the currently configured desktop wallpaper.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <exception cref="System.ComponentModel.Win32Exception">
|
|
|
|
|
/// If the wallpaper could not be removed.
|
|
|
|
|
/// </exception>
|
|
|
|
|
void RemoveWallpaper();
|
|
|
|
|
|
2017-07-27 11:46:31 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Restores the specified window to its original size and position.
|
|
|
|
|
/// </summary>
|
|
|
|
|
void RestoreWindow(IntPtr window);
|
|
|
|
|
|
2018-09-21 11:33:32 +02:00
|
|
|
|
/// <summary>
|
2019-10-01 11:30:53 +02:00
|
|
|
|
/// Attempts to resume the thread referenced by the given thread identifier. Returns <c>true</c> if the thread was successfully resumed,
|
2018-09-21 11:33:32 +02:00
|
|
|
|
/// otherwise <c>false</c>.
|
|
|
|
|
/// </summary>
|
|
|
|
|
bool ResumeThread(int threadId);
|
|
|
|
|
|
2017-07-27 13:57:12 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Sends a close message to the given window.
|
|
|
|
|
/// </summary>
|
|
|
|
|
void SendCloseMessageTo(IntPtr window);
|
|
|
|
|
|
2017-08-11 08:28:17 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Sets the wallpaper to the image located at the specified file path.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <exception cref="System.ComponentModel.Win32Exception">
|
|
|
|
|
/// If the wallpaper could not be set.
|
|
|
|
|
/// </exception>
|
|
|
|
|
void SetWallpaper(string filePath);
|
|
|
|
|
|
2017-07-27 11:46:31 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Sets the working area of the primary screen according to the given dimensions.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <exception cref="System.ComponentModel.Win32Exception">
|
|
|
|
|
/// If the working area could not be set.
|
|
|
|
|
/// </exception>
|
2017-08-04 08:25:49 +02:00
|
|
|
|
void SetWorkingArea(IBounds bounds);
|
2018-09-21 11:33:32 +02:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
2019-10-01 11:30:53 +02:00
|
|
|
|
/// Attempts to suspend the thread referenced by the given thread identifier. Returns <c>true</c> if the thread was successfully suspended,
|
2018-09-21 11:33:32 +02:00
|
|
|
|
/// otherwise <c>false</c>.
|
|
|
|
|
/// </summary>
|
|
|
|
|
bool SuspendThread(int threadId);
|
2017-07-27 11:46:31 +02:00
|
|
|
|
}
|
|
|
|
|
}
|