Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/automation-stack/node-machine-id
Unique machine (desktop) id (no admin privileges required)
https://github.com/automation-stack/node-machine-id
electron id machine-id node
Last synced: 3 days ago
JSON representation
Unique machine (desktop) id (no admin privileges required)
- Host: GitHub
- URL: https://github.com/automation-stack/node-machine-id
- Owner: automation-stack
- License: mit
- Created: 2016-07-12T14:07:22.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2024-08-27T20:03:58.000Z (4 months ago)
- Last Synced: 2024-10-29T17:43:23.833Z (2 months ago)
- Topics: electron, id, machine-id, node
- Language: JavaScript
- Homepage:
- Size: 64.5 KB
- Stars: 581
- Watchers: 7
- Forks: 61
- Open Issues: 26
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
**Cross-platform unique machine (desktop) id discovery**
## Use cases
- Software restrictions
- Installation tracking## Features
- Hardware independent
- Unique within the OS installation
- No elevated rights required
- No external dependencies and does not require any native bindings
- Cross-platform (OSx, Win, Linux)## How it works
Module based on OS native UUID/GUID which used for internal needs.
**All others approaches requires elevated rights or much depends on hardware components, but this approach summarize the methods of selecting the most reliable unique identifier**
- **Win32/64** uses key ```MachineGuid``` in registry
```HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Cryptography``` **(can be changed by administrator but with unpredictable consequences)**
> It is generated during OS installation and won't change unless you make another OS
> updates or reinstall. Depending on the OS version it may contain the network adapter
> MAC address embedded (plus some other numbers, including random), or a pseudorandom number.- **OSx** uses ```IOPlatformUUID``` (the same Hardware UUID)
``` ioreg -rd1 -c IOPlatformExpertDevice ```
> Value from I/O Kit registry in IOPlatformExpertDevice class- **Linux** uses ```/var/lib/dbus/machine-id``` **(can be changed by ```root``` but with unpredictable consequences)**
http://man7.org/linux/man-pages/man5/machine-id.5.html
> The /var/lib/dbus/machine-id file contains the unique machine ID of the local
> system that is set during installation. The machine ID is a single
> newline-terminated, hexadecimal, 32-character, lowercase machine ID
> string. When decoded from hexadecimal, this corresponds with a
> 16-byte/128-bit string.
>
> The machine ID is usually generated from a random source during
> system installation and stays constant for all subsequent boots.
> Optionally, for stateless systems, it is generated during runtime at
> early boot if it is found to be empty.
>
> The machine ID does not change based on user configuration or when
> hardware is replaced.## Installation
```
npm install node-machine-id
```## Usage
### Function: machineId(original)
- **original** ``````, If ```true``` return original value of machine id, otherwise return hashed value (sha-256), default: ```false```### Function: machineIdSync(original);
- syncronous version of ```machineId``````js
import {machineId, machineIdSync} from 'node-machine-id';// Asyncronous call with async/await or Promise
async function getMachineId() {
let id = await machineId();
...
}machineId().then((id) => {
...
})// Syncronous call
let id = machineIdSync()
// id = c24b0fe51856497eebb6a2bfcd120247aac0d6334d670bb92e09a00ce8169365
let id = machineIdSync(true)
// id = 98912984-c4e9-5ceb-8000-03882a0485e4
```
### Caveats- Image-based environments have usually the same `machine-id`
> As a workaround you can generate new machine-ids for each instance (or container) with `dbus-uuidgen` and changed them in the respective > files: `/etc/machine-id` and `/var/lib/dbus/machine-id`. Thanks [@stefanhuber](https://github.com/stefanhuber)