matterbridge 3.3.0-dev-20251004-43d8106 → 3.3.1-dev-20251007-4e5eaac
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +29 -3
- package/README.md +9 -1
- package/dist/broadcastServer.js +73 -0
- package/dist/broadcastServerTypes.js +1 -0
- package/dist/deviceManager.js +44 -5
- package/dist/frontend.js +150 -190
- package/dist/helpers.js +4 -4
- package/dist/index.js +0 -12
- package/dist/matterbridge.js +112 -117
- package/dist/matterbridgePlatform.js +1 -1
- package/dist/pluginManager.js +130 -5
- package/dist/shelly.js +4 -4
- package/dist/update.js +0 -2
- package/dist/utils/network.js +71 -38
- package/dist/utils/spawn.js +5 -6
- package/frontend/build/assets/index.js +4 -7
- package/frontend/build/assets/vendor_mui.js +1 -1
- package/frontend/package.json +1 -1
- package/npm-shrinkwrap.json +44 -44
- package/package.json +2 -2
- package/dist/globalMatterbridge.js +0 -23
package/dist/shelly.js
CHANGED
|
@@ -12,7 +12,7 @@ export async function getShellySysUpdate(matterbridge) {
|
|
|
12
12
|
const updates = (await getShelly('/api/updates/sys/check'));
|
|
13
13
|
if (updates.length === 0)
|
|
14
14
|
return;
|
|
15
|
-
matterbridge.
|
|
15
|
+
matterbridge.shellySysUpdate = true;
|
|
16
16
|
matterbridge.frontend.wssBroadcastMessage({ id: 0, src: 'Matterbridge', dst: 'Frontend', method: 'shelly_sys_update', success: true, response: { available: true } });
|
|
17
17
|
for (const { name } of updates) {
|
|
18
18
|
if (!name)
|
|
@@ -29,7 +29,7 @@ export async function triggerShellySysUpdate(matterbridge) {
|
|
|
29
29
|
try {
|
|
30
30
|
await getShelly('/api/updates/sys/perform');
|
|
31
31
|
matterbridge.log.notice('Installing Shelly system update...');
|
|
32
|
-
matterbridge.
|
|
32
|
+
matterbridge.shellySysUpdate = false;
|
|
33
33
|
matterbridge.frontend.wssSendSnackbarMessage('Installing Shelly system update...', 15);
|
|
34
34
|
matterbridge.frontend.wssBroadcastMessage({ id: 0, src: 'Matterbridge', dst: 'Frontend', method: 'shelly_sys_update', success: true, response: { available: false } });
|
|
35
35
|
await verifyShellyUpdate(matterbridge, '/api/updates/sys/status', 'Shelly system update');
|
|
@@ -43,7 +43,7 @@ export async function getShellyMainUpdate(matterbridge) {
|
|
|
43
43
|
const updates = (await getShelly('/api/updates/main/check'));
|
|
44
44
|
if (updates.length === 0)
|
|
45
45
|
return;
|
|
46
|
-
matterbridge.
|
|
46
|
+
matterbridge.shellyMainUpdate = true;
|
|
47
47
|
matterbridge.frontend.wssBroadcastMessage({ id: 0, src: 'Matterbridge', dst: 'Frontend', method: 'shelly_main_update', success: true, response: { available: true } });
|
|
48
48
|
for (const { name } of updates) {
|
|
49
49
|
if (!name)
|
|
@@ -60,7 +60,7 @@ export async function triggerShellyMainUpdate(matterbridge) {
|
|
|
60
60
|
try {
|
|
61
61
|
await getShelly('/api/updates/main/perform');
|
|
62
62
|
matterbridge.log.notice('Installing Shelly software update...');
|
|
63
|
-
matterbridge.
|
|
63
|
+
matterbridge.shellyMainUpdate = false;
|
|
64
64
|
matterbridge.frontend.wssSendSnackbarMessage('Installing Shelly software update...', 15);
|
|
65
65
|
matterbridge.frontend.wssBroadcastMessage({ id: 0, src: 'Matterbridge', dst: 'Frontend', method: 'shelly_main_update', success: true, response: { available: false } });
|
|
66
66
|
await verifyShellyUpdate(matterbridge, '/api/updates/main/status', 'Shelly software update');
|
package/dist/update.js
CHANGED
|
@@ -46,7 +46,6 @@ export async function getMatterbridgeLatestVersion(matterbridge) {
|
|
|
46
46
|
try {
|
|
47
47
|
const version = await getNpmPackageVersion('matterbridge');
|
|
48
48
|
matterbridge.matterbridgeLatestVersion = version;
|
|
49
|
-
matterbridge.matterbridgeInformation.matterbridgeLatestVersion = version;
|
|
50
49
|
await matterbridge.nodeContext?.set('matterbridgeLatestVersion', matterbridge.matterbridgeLatestVersion);
|
|
51
50
|
if (matterbridge.matterbridgeVersion !== matterbridge.matterbridgeLatestVersion) {
|
|
52
51
|
matterbridge.log.notice(`Matterbridge is out of date. Current version: ${matterbridge.matterbridgeVersion}. Latest version: ${matterbridge.matterbridgeLatestVersion}.`);
|
|
@@ -68,7 +67,6 @@ export async function getMatterbridgeDevVersion(matterbridge) {
|
|
|
68
67
|
try {
|
|
69
68
|
const version = await getNpmPackageVersion('matterbridge', 'dev');
|
|
70
69
|
matterbridge.matterbridgeDevVersion = version;
|
|
71
|
-
matterbridge.matterbridgeInformation.matterbridgeDevVersion = version;
|
|
72
70
|
await matterbridge.nodeContext?.set('matterbridgeDevVersion', version);
|
|
73
71
|
if (matterbridge.matterbridgeVersion.includes('-dev-') && matterbridge.matterbridgeVersion !== version) {
|
|
74
72
|
matterbridge.log.notice(`Matterbridge@dev is out of date. Current version: ${matterbridge.matterbridgeVersion}. Latest dev version: ${matterbridge.matterbridgeDevVersion}.`);
|
package/dist/utils/network.js
CHANGED
|
@@ -1,58 +1,65 @@
|
|
|
1
1
|
import os from 'node:os';
|
|
2
2
|
import { AnsiLogger, BLUE, CYAN, nf } from 'node-ansi-logger';
|
|
3
|
-
export function
|
|
4
|
-
|
|
5
|
-
const
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
3
|
+
export function getInterfaceDetails() {
|
|
4
|
+
const result = { interfaceName: '', ipv4Address: undefined, ipv6Address: undefined, macAddress: undefined };
|
|
5
|
+
for (const [interfaceName, interfaceDetails] of Object.entries(os.networkInterfaces())) {
|
|
6
|
+
if (!interfaceName || !interfaceDetails || interfaceDetails.length === 0)
|
|
7
|
+
continue;
|
|
8
|
+
for (const detail of interfaceDetails) {
|
|
9
|
+
if (detail.internal)
|
|
10
|
+
continue;
|
|
11
|
+
if (!result.interfaceName)
|
|
12
|
+
result.interfaceName = interfaceName;
|
|
13
|
+
if (interfaceName === result.interfaceName && !result.ipv4Address && detail.family === 'IPv4')
|
|
14
|
+
result.ipv4Address = detail.address;
|
|
15
|
+
if (interfaceName === result.interfaceName && !result.ipv6Address && detail.family === 'IPv6')
|
|
16
|
+
result.ipv6Address = detail.address;
|
|
17
|
+
if (interfaceName === result.interfaceName && !result.macAddress)
|
|
18
|
+
result.macAddress = detail.mac;
|
|
9
19
|
}
|
|
20
|
+
}
|
|
21
|
+
if (result.interfaceName)
|
|
22
|
+
return result;
|
|
23
|
+
}
|
|
24
|
+
export function getInterfaceName() {
|
|
25
|
+
for (const [interfaceName, interfaceDetails] of Object.entries(os.networkInterfaces())) {
|
|
26
|
+
if (!interfaceName || !interfaceDetails || interfaceDetails.length === 0)
|
|
27
|
+
continue;
|
|
10
28
|
for (const detail of interfaceDetails) {
|
|
11
|
-
if (
|
|
12
|
-
|
|
13
|
-
}
|
|
29
|
+
if (!detail.internal)
|
|
30
|
+
return interfaceName;
|
|
14
31
|
}
|
|
15
|
-
|
|
16
|
-
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
export function getIpv4InterfaceAddress() {
|
|
35
|
+
for (const [interfaceName, interfaceDetails] of Object.entries(os.networkInterfaces())) {
|
|
36
|
+
if (!interfaceName || !interfaceDetails || interfaceDetails.length === 0)
|
|
37
|
+
continue;
|
|
38
|
+
for (const detail of interfaceDetails) {
|
|
39
|
+
if (detail.family === 'IPv4' && !detail.internal)
|
|
40
|
+
return detail.address;
|
|
17
41
|
}
|
|
18
42
|
}
|
|
19
|
-
return ipv4Address;
|
|
20
43
|
}
|
|
21
44
|
export function getIpv6InterfaceAddress() {
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
if (!interfaceDetails) {
|
|
26
|
-
break;
|
|
27
|
-
}
|
|
45
|
+
for (const [interfaceName, interfaceDetails] of Object.entries(os.networkInterfaces())) {
|
|
46
|
+
if (!interfaceName || !interfaceDetails || interfaceDetails.length === 0)
|
|
47
|
+
continue;
|
|
28
48
|
for (const detail of interfaceDetails) {
|
|
29
|
-
if (detail.family === 'IPv6' && !detail.internal
|
|
30
|
-
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
if (ipv6Address !== undefined) {
|
|
34
|
-
break;
|
|
49
|
+
if (detail.family === 'IPv6' && !detail.internal)
|
|
50
|
+
return detail.address;
|
|
35
51
|
}
|
|
36
52
|
}
|
|
37
|
-
return ipv6Address;
|
|
38
53
|
}
|
|
39
54
|
export function getMacAddress() {
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
if (!interfaceDetails) {
|
|
44
|
-
break;
|
|
45
|
-
}
|
|
55
|
+
for (const [interfaceName, interfaceDetails] of Object.entries(os.networkInterfaces())) {
|
|
56
|
+
if (!interfaceName || !interfaceDetails || interfaceDetails.length === 0)
|
|
57
|
+
continue;
|
|
46
58
|
for (const detail of interfaceDetails) {
|
|
47
|
-
if (!detail.internal
|
|
48
|
-
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
if (macAddress !== undefined) {
|
|
52
|
-
break;
|
|
59
|
+
if (!detail.internal)
|
|
60
|
+
return detail.mac;
|
|
53
61
|
}
|
|
54
62
|
}
|
|
55
|
-
return macAddress;
|
|
56
63
|
}
|
|
57
64
|
export function logInterfaces() {
|
|
58
65
|
const log = new AnsiLogger({ logName: 'MatterbridgeUtils', logTimestampFormat: 4, logLevel: "info" });
|
|
@@ -173,3 +180,29 @@ export async function getGlobalNodeModules() {
|
|
|
173
180
|
});
|
|
174
181
|
});
|
|
175
182
|
}
|
|
183
|
+
export function formatMemoryUsage(bytes) {
|
|
184
|
+
if (bytes >= 1024 ** 3) {
|
|
185
|
+
return `${(bytes / 1024 ** 3).toFixed(2)} GB`;
|
|
186
|
+
}
|
|
187
|
+
else if (bytes >= 1024 ** 2) {
|
|
188
|
+
return `${(bytes / 1024 ** 2).toFixed(2)} MB`;
|
|
189
|
+
}
|
|
190
|
+
else {
|
|
191
|
+
return `${(bytes / 1024).toFixed(2)} KB`;
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
export function formatOsUpTime(seconds) {
|
|
195
|
+
if (seconds >= 86400) {
|
|
196
|
+
const days = Math.floor(seconds / 86400);
|
|
197
|
+
return `${days} day${days !== 1 ? 's' : ''}`;
|
|
198
|
+
}
|
|
199
|
+
if (seconds >= 3600) {
|
|
200
|
+
const hours = Math.floor(seconds / 3600);
|
|
201
|
+
return `${hours} hour${hours !== 1 ? 's' : ''}`;
|
|
202
|
+
}
|
|
203
|
+
if (seconds >= 60) {
|
|
204
|
+
const minutes = Math.floor(seconds / 60);
|
|
205
|
+
return `${minutes} minute${minutes !== 1 ? 's' : ''}`;
|
|
206
|
+
}
|
|
207
|
+
return `${seconds} second${seconds !== 1 ? 's' : ''}`;
|
|
208
|
+
}
|
package/dist/utils/spawn.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { hasParameter } from './commandLine.js';
|
|
2
|
-
export async function spawnCommand(matterbridge, command, args, packageName) {
|
|
2
|
+
export async function spawnCommand(matterbridge, command, args, packageCommand, packageName) {
|
|
3
3
|
const { spawn } = await import('node:child_process');
|
|
4
4
|
const cmdLine = command + ' ' + args.join(' ');
|
|
5
5
|
if (process.platform === 'win32' && command === 'npm') {
|
|
@@ -13,7 +13,10 @@ export async function spawnCommand(matterbridge, command, args, packageName) {
|
|
|
13
13
|
}
|
|
14
14
|
matterbridge.log.debug(`Spawn command ${command} with ${args.join(' ')}`);
|
|
15
15
|
return new Promise((resolve, reject) => {
|
|
16
|
-
|
|
16
|
+
if (packageCommand === 'install')
|
|
17
|
+
matterbridge.frontend.wssSendLogMessage('spawn', matterbridge.log.now(), 'Matterbridge:spawn-init', `Installing ${packageName}`);
|
|
18
|
+
else if (packageCommand === 'uninstall')
|
|
19
|
+
matterbridge.frontend.wssSendLogMessage('spawn', matterbridge.log.now(), 'Matterbridge:spawn-init', `Uninstalling ${packageName}`);
|
|
17
20
|
const childProcess = spawn(command, args, {
|
|
18
21
|
stdio: ['inherit', 'pipe', 'pipe'],
|
|
19
22
|
});
|
|
@@ -23,10 +26,7 @@ export async function spawnCommand(matterbridge, command, args, packageName) {
|
|
|
23
26
|
reject(err);
|
|
24
27
|
});
|
|
25
28
|
childProcess.on('close', (code, signal) => {
|
|
26
|
-
matterbridge.frontend.wssSendLogMessage('spawn', matterbridge.log.now(), 'Matterbridge:spawn', `child process closed with code ${code} and signal ${signal}`);
|
|
27
29
|
if (code === 0) {
|
|
28
|
-
if (cmdLine.startsWith('npm install -g'))
|
|
29
|
-
matterbridge.log.notice(`Package ${cmdLine.replace('npm install -g ', '').replace('--verbose', '').replace('--omit=dev', '')} installed correctly`);
|
|
30
30
|
matterbridge.log.debug(`Child process "${cmdLine}" closed with code ${code} and signal ${signal}`);
|
|
31
31
|
matterbridge.frontend.wssSendLogMessage('spawn', matterbridge.log.now(), 'Matterbridge:spawn-exit-success', 'Child process closed');
|
|
32
32
|
resolve(true);
|
|
@@ -38,7 +38,6 @@ export async function spawnCommand(matterbridge, command, args, packageName) {
|
|
|
38
38
|
}
|
|
39
39
|
});
|
|
40
40
|
childProcess.on('exit', (code, signal) => {
|
|
41
|
-
matterbridge.frontend.wssSendLogMessage('spawn', matterbridge.log.now(), 'Matterbridge:spawn', `child process exited with code ${code} and signal ${signal}`);
|
|
42
41
|
if (code === 0) {
|
|
43
42
|
matterbridge.log.debug(`Child process "${cmdLine}" exited with code ${code} and signal ${signal}`);
|
|
44
43
|
matterbridge.frontend.wssSendLogMessage('spawn', matterbridge.log.now(), 'Matterbridge:spawn-exit-success', 'Child process exited');
|