15815213711
2024-08-26 67b8b6731811983447e053d4396b3708c14dfe3c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
"use strict";
 
const os = require("os");
const path = require('path');
const fs = require('fs');
const { exec, execSync } = require('child_process');
const { createHash } = require('crypto');
const Ps = require('../ps');
const UtilsJson = require('./json');
 
// machine id
const { platform } = process;
const win32RegBinPath = {
  native: '%windir%\\System32',
  mixed: '%windir%\\sysnative\\cmd.exe /c %windir%\\System32'
};
const MachineGuid = {
  darwin: 'ioreg -rd1 -c IOPlatformExpertDevice',
  win32: `${win32RegBinPath[isWindowsProcessMixedOrNativeArchitecture()]}\\REG.exe ` +
      'QUERY HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Cryptography ' +
      '/v MachineGuid',
  linux: '( cat /var/lib/dbus/machine-id /etc/machine-id 2> /dev/null || hostname ) | head -n 1 || :',
  freebsd: 'kenv -q smbios.system.uuid || sysctl -n kern.hostuuid'
};
 
/**
 * 获取项目根目录package.json
 */
exports.getPackage = function() {
  const json = UtilsJson.readSync(path.join(Ps.getHomeDir(), 'package.json'));
  
  return json;
};
 
/**
 * Get the first proper MAC address
 * @param iface If provided, restrict MAC address fetching to this interface
 */
exports.getMAC = function(iface) {
  const zeroRegex = /(?:[0]{1,2}[:-]){5}[0]{1,2}/;
  const list = os.networkInterfaces();
  if (iface) {
      const parts = list[iface];
      if (!parts) {
          throw new Error(`interface ${iface} was not found`);
      }
      for (const part of parts) {
          if (zeroRegex.test(part.mac) === false) {
              return part.mac;
          }
      }
      throw new Error(`interface ${iface} had no valid mac addresses`);
  }
  else {
      for (const [key, parts] of Object.entries(list)) {
          // for some reason beyond me, this is needed to satisfy typescript
          // fix https://github.com/bevry/getmac/issues/100
          if (!parts)
              continue;
          for (const part of parts) {
              if (zeroRegex.test(part.mac) === false) {
                  return part.mac;
              }
          }
      }
  }
  throw new Error('failed to get the MAC address');
}
 
/**
 * Check if the input is a valid MAC address
 */
exports.isMAC = function(macAddress) {
  const macRegex = /(?:[a-z0-9]{1,2}[:-]){5}[a-z0-9]{1,2}/i;
  return macRegex.test(macAddress);
}
 
/**
 * is encrypt
 */
exports.isEncrypt = function(basePath) {
  const encryptDir = Ps.getEncryptDir(basePath);
  if (fs.existsSync(encryptDir)) {
    return true;
  }
  return false;
}
 
/**
 * get machine id
 */
exports.machineIdSync = function(original) {
  let id = expose(execSync(MachineGuid[platform]).toString());
  return original ? id : hash(id);
}
 
/**
 * get machine id (promise)
 * original <Boolean>, If true return original value of machine id, otherwise return hashed value (sha-256), default: false
 */
exports.machineId = function(original) {
  return new Promise((resolve, reject) => {
    return exec(MachineGuid[platform], {}, (err, stdout, stderr) => {
      if (err) {
        return reject(
            new Error(`Error while obtaining machine id: ${err.stack}`)
        );
      }
      let id = expose(stdout.toString());
      return resolve(original ? id : hash(id));
    });
  });
}
 
function isWindowsProcessMixedOrNativeArchitecture() {
  // detect if the node binary is the same arch as the Windows OS.
  // or if this is 32 bit node on 64 bit windows.
  if(process.platform !== 'win32') {
    return '';
  }
  if( process.arch === 'ia32' && process.env.hasOwnProperty('PROCESSOR_ARCHITEW6432') ) {
    return 'mixed';
  }
  return 'native';
}
 
function hash(guid) {
  return createHash('sha256').update(guid).digest('hex');
}
 
function expose(result) {
  switch (platform) {
    case 'darwin':
      return result
        .split('IOPlatformUUID')[1]
        .split('\n')[0].replace(/\=|\s+|\"/ig, '')
        .toLowerCase();
    case 'win32':
      return result
        .toString()
        .split('REG_SZ')[1]
        .replace(/\r+|\n+|\s+/ig, '')
        .toLowerCase();
    case 'linux':
      return result
        .toString()
        .replace(/\r+|\n+|\s+/ig, '')
        .toLowerCase();
    case 'freebsd':
      return result
        .toString()
        .replace(/\r+|\n+|\s+/ig, '')
        .toLowerCase();
    default:
      throw new Error(`Unsupported platform: ${process.platform}`);
  }
}