An open API service indexing awesome lists of open source software.

https://github.com/rami-sabbagh/node-interception

A windows library for intercepting and controlling keyboards and mouses with multiple devices support.
https://github.com/rami-sabbagh/node-interception

bindings interception keyboard mouse node-addon-api nodejs typescript wrapper

Last synced: 4 months ago
JSON representation

A windows library for intercepting and controlling keyboards and mouses with multiple devices support.

Awesome Lists containing this project

README

          

# node-interception

[![GitHub](https://flat.badgen.net/badge/icon/GitHub?icon=github&color=black&label)][GitHub]
[![NPM](https://flat.badgen.net/npm/v/node-interception?icon=npm&color=red&label)][NPM]
[![License](https://flat.badgen.net/github/license/Rami-Sabbagh/node-interception?color=yellow&label)][License]
[![Documentation](https://flat.badgen.net/npm/types/node-interception?icon=typescript&label)][Documentation]
[![Dependabot](https://flat.badgen.net/github/dependabot/Rami-Sabbagh/node-interception?icon=dependabot&label)][Dependabot]

A **windows** library for intercepting and controlling keyboards and mouses with multiple devices support.

The package provides Node.js bindings for the original [Interception](https://github.com/oblitum/Interception) library by [Oblitum](https://github.com/oblitum), and supports it with a wrapper and TypeScript definitions.

## Example

```ts
// Increase the process priority to prevent input lagging.
import * as os from 'os';
os.setPriority(os.constants.priority.PRIORITY_HIGH);

import { Interception, FilterKeyState, FilterMouseState } from 'node-interception';
const interception = new Interception();

// Display the list of available devices.
console.log('Devices:', interception.getDevices().map(device => `${device}`));

// Enable the capturing of all strokes.
interception.setFilter('keyboard', FilterKeyState.ALL);
interception.setFilter('mouse', FilterMouseState.ALL);

const SCANCODE_ESC = 0x01;

async function listen() {
console.info('Press any key or move the mouse to generate strokes.');
console.info('Press ESC to exit and restore back control.');

while (true) {
const device = await interception.wait();
const stroke = device?.receive();

if (!device || !stroke || (stroke?.type === 'keyboard' && stroke.code === SCANCODE_ESC)) break;

console.log(`${device}`, stroke);
}

interception.destroy();
}

// Start listening for keyboard and mouse strokes.
listen().catch(console.error);
```

## Features

- Contains prebuilt binaries for 32-bit (`ia32`) and 64-bit (`x64`) Windows machines.
- Written using N-API and `node-addon-api` so it should work with different node versions and electron without rebuilding.
- Written in TypeScript to provide enhanced IDE support.
- Allows working with each mouse and keyboard as independent devices, so different logic can be used for each keyboard/mouse.
- Allows blocking or modifying the devices strokes.

## Interception use cases

As the original library author ([Oblitum]) written:

> Interception has been used around the world in cases I couldn't imagine when I first created it:
>
> - Helping people with accessibility limitations, tailoring systems according to their limitations.
> - By companies in aviation training, to connect many devices at once and customizing each one.
> - By companies providing SCADA (supervisory control and data acquisition) solutions.
> - In game applications like BOTs and control customization.
> - To construct an emacs mode of the system.
> - To customize supermarket cashier's systems.
> - In doctoral thesis about typing pattern recognition for security applications.
> - Home theater automation.
> - ...

## Documentation

The API documentation is generated using [TypeDoc](https://typedoc.org/) and available on [GitHub Pages][Documentation].

## When in need for more help

You can create an issue here or email me on [rami.sab07@gmail.com](mailto:rami.sab07@gmail.com).

Please mind that I made this project in my free time for nothing in return.
And that it usually takes up to 5 days for me to reply back (possibly more on some occasions).

## Installation

### Installing the package

```cmd
yarn add node-interception
rem -- or using npm
npm install node-interception
```

### Installing the driver

Using a command prompt with **Administrative Privileges**:

```cmd
npx node-interception /install
```

> You can uninstall it later using `/uninstall` instead.

You'll need to **restart** for the driver installation to be complete.

## License

The binding and wrapper are licensed under `LGPL-3.0-or-later`, check the `LICENSE` file.

The original Interception library is licensed under `LGPL-3.0` too for un-commercial usage and has a seperate license for commercial usage, check it in it's repository.

The package and repository of this module contains a redistribution of the interception library as that's permitted by the `LGPL-3.0` license, please create an issue if that's incorrect.

## Credits

- [Oblitum] for creating the original interception library.
- [Rami Sabbagh] for writing the binding and wrapper.

[NPM]: https://www.npmjs.com/package/node-interception
[GitHub]: https://github.com/Rami-Sabbagh/node-interception/
[Documentation]: https://rami-sabbagh.github.io/node-interception/
[License]: https://github.com/Rami-Sabbagh/node-interception/blob/main/LICENSE
[Actions]: https://github.com/Rami-Sabbagh/node-interception/actions
[Dependabot]: https://github.com/Rami-Sabbagh/node-interception/network/updates
[Interception]: https://github.com/oblitum/Interception
[Oblitum]: https://github.com/oblitum
[Rami Sabbagh]: https://github.com/Rami-Sabbagh