matterbridge 3.2.4-dev-20250830-5c48452 → 3.2.4
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/dist/cli.d.ts +26 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +91 -2
- package/dist/cli.js.map +1 -0
- package/dist/cliEmitter.d.ts +34 -0
- package/dist/cliEmitter.d.ts.map +1 -0
- package/dist/cliEmitter.js +30 -0
- package/dist/cliEmitter.js.map +1 -0
- package/dist/clusters/export.d.ts +2 -0
- package/dist/clusters/export.d.ts.map +1 -0
- package/dist/clusters/export.js +2 -0
- package/dist/clusters/export.js.map +1 -0
- package/dist/defaultConfigSchema.d.ts +28 -0
- package/dist/defaultConfigSchema.d.ts.map +1 -0
- package/dist/defaultConfigSchema.js +24 -0
- package/dist/defaultConfigSchema.js.map +1 -0
- package/dist/deviceManager.d.ts +112 -0
- package/dist/deviceManager.d.ts.map +1 -0
- package/dist/deviceManager.js +94 -1
- package/dist/deviceManager.js.map +1 -0
- package/dist/devices/batteryStorage.d.ts +48 -0
- package/dist/devices/batteryStorage.d.ts.map +1 -0
- package/dist/devices/batteryStorage.js +48 -1
- package/dist/devices/batteryStorage.js.map +1 -0
- package/dist/devices/cooktop.d.ts +60 -0
- package/dist/devices/cooktop.d.ts.map +1 -0
- package/dist/devices/cooktop.js +55 -0
- package/dist/devices/cooktop.js.map +1 -0
- package/dist/devices/dishwasher.d.ts +71 -0
- package/dist/devices/dishwasher.d.ts.map +1 -0
- package/dist/devices/dishwasher.js +57 -0
- package/dist/devices/dishwasher.js.map +1 -0
- package/dist/devices/evse.d.ts +75 -0
- package/dist/devices/evse.d.ts.map +1 -0
- package/dist/devices/evse.js +74 -10
- package/dist/devices/evse.js.map +1 -0
- package/dist/devices/export.d.ts +15 -0
- package/dist/devices/export.d.ts.map +1 -0
- package/dist/devices/export.js +4 -0
- package/dist/devices/export.js.map +1 -0
- package/dist/devices/extractorHood.d.ts +46 -0
- package/dist/devices/extractorHood.d.ts.map +1 -0
- package/dist/devices/extractorHood.js +42 -0
- package/dist/devices/extractorHood.js.map +1 -0
- package/dist/devices/heatPump.d.ts +47 -0
- package/dist/devices/heatPump.d.ts.map +1 -0
- package/dist/devices/heatPump.js +50 -2
- package/dist/devices/heatPump.js.map +1 -0
- package/dist/devices/laundryDryer.d.ts +67 -0
- package/dist/devices/laundryDryer.d.ts.map +1 -0
- package/dist/devices/laundryDryer.js +62 -3
- package/dist/devices/laundryDryer.js.map +1 -0
- package/dist/devices/laundryWasher.d.ts +81 -0
- package/dist/devices/laundryWasher.d.ts.map +1 -0
- package/dist/devices/laundryWasher.js +70 -4
- package/dist/devices/laundryWasher.js.map +1 -0
- package/dist/devices/microwaveOven.d.ts +168 -0
- package/dist/devices/microwaveOven.d.ts.map +1 -0
- package/dist/devices/microwaveOven.js +88 -5
- package/dist/devices/microwaveOven.js.map +1 -0
- package/dist/devices/oven.d.ts +105 -0
- package/dist/devices/oven.d.ts.map +1 -0
- package/dist/devices/oven.js +85 -0
- package/dist/devices/oven.js.map +1 -0
- package/dist/devices/refrigerator.d.ts +93 -0
- package/dist/devices/refrigerator.d.ts.map +1 -0
- package/dist/devices/refrigerator.js +80 -0
- package/dist/devices/refrigerator.js.map +1 -0
- package/dist/devices/roboticVacuumCleaner.d.ts +112 -0
- package/dist/devices/roboticVacuumCleaner.d.ts.map +1 -0
- package/dist/devices/roboticVacuumCleaner.js +93 -7
- package/dist/devices/roboticVacuumCleaner.js.map +1 -0
- package/dist/devices/solarPower.d.ts +40 -0
- package/dist/devices/solarPower.d.ts.map +1 -0
- package/dist/devices/solarPower.js +38 -0
- package/dist/devices/solarPower.js.map +1 -0
- package/dist/devices/temperatureControl.d.ts +166 -0
- package/dist/devices/temperatureControl.d.ts.map +1 -0
- package/dist/devices/temperatureControl.js +25 -3
- package/dist/devices/temperatureControl.js.map +1 -0
- package/dist/devices/waterHeater.d.ts +111 -0
- package/dist/devices/waterHeater.d.ts.map +1 -0
- package/dist/devices/waterHeater.js +82 -2
- package/dist/devices/waterHeater.js.map +1 -0
- package/dist/dgram/coap.d.ts +205 -0
- package/dist/dgram/coap.d.ts.map +1 -0
- package/dist/dgram/coap.js +126 -13
- package/dist/dgram/coap.js.map +1 -0
- package/dist/dgram/dgram.d.ts +140 -0
- package/dist/dgram/dgram.d.ts.map +1 -0
- package/dist/dgram/dgram.js +113 -2
- package/dist/dgram/dgram.js.map +1 -0
- package/dist/dgram/mb_coap.d.ts +24 -0
- package/dist/dgram/mb_coap.d.ts.map +1 -0
- package/dist/dgram/mb_coap.js +41 -3
- package/dist/dgram/mb_coap.js.map +1 -0
- package/dist/dgram/mb_mdns.d.ts +24 -0
- package/dist/dgram/mb_mdns.d.ts.map +1 -0
- package/dist/dgram/mb_mdns.js +51 -13
- package/dist/dgram/mb_mdns.js.map +1 -0
- package/dist/dgram/mdns.d.ts +288 -0
- package/dist/dgram/mdns.d.ts.map +1 -0
- package/dist/dgram/mdns.js +298 -137
- package/dist/dgram/mdns.js.map +1 -0
- package/dist/dgram/multicast.d.ts +65 -0
- package/dist/dgram/multicast.d.ts.map +1 -0
- package/dist/dgram/multicast.js +60 -1
- package/dist/dgram/multicast.js.map +1 -0
- package/dist/dgram/unicast.d.ts +56 -0
- package/dist/dgram/unicast.d.ts.map +1 -0
- package/dist/dgram/unicast.js +54 -0
- package/dist/dgram/unicast.js.map +1 -0
- package/dist/frontend.d.ts +313 -0
- package/dist/frontend.d.ts.map +1 -0
- package/dist/frontend.js +451 -24
- package/dist/frontend.js.map +1 -0
- package/dist/globalMatterbridge.d.ts +59 -0
- package/dist/globalMatterbridge.d.ts.map +1 -0
- package/dist/globalMatterbridge.js +47 -0
- package/dist/globalMatterbridge.js.map +1 -0
- package/dist/helpers.d.ts +48 -0
- package/dist/helpers.d.ts.map +1 -0
- package/dist/helpers.js +53 -0
- package/dist/helpers.js.map +1 -0
- package/dist/index.d.ts +33 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +30 -1
- package/dist/index.js.map +1 -0
- package/dist/logger/export.d.ts +2 -0
- package/dist/logger/export.d.ts.map +1 -0
- package/dist/logger/export.js +1 -0
- package/dist/logger/export.js.map +1 -0
- package/dist/matter/behaviors.d.ts +2 -0
- package/dist/matter/behaviors.d.ts.map +1 -0
- package/dist/matter/behaviors.js +2 -0
- package/dist/matter/behaviors.js.map +1 -0
- package/dist/matter/clusters.d.ts +2 -0
- package/dist/matter/clusters.d.ts.map +1 -0
- package/dist/matter/clusters.js +2 -0
- package/dist/matter/clusters.js.map +1 -0
- package/dist/matter/devices.d.ts +2 -0
- package/dist/matter/devices.d.ts.map +1 -0
- package/dist/matter/devices.js +2 -0
- package/dist/matter/devices.js.map +1 -0
- package/dist/matter/endpoints.d.ts +2 -0
- package/dist/matter/endpoints.d.ts.map +1 -0
- package/dist/matter/endpoints.js +2 -0
- package/dist/matter/endpoints.js.map +1 -0
- package/dist/matter/export.d.ts +5 -0
- package/dist/matter/export.d.ts.map +1 -0
- package/dist/matter/export.js +3 -0
- package/dist/matter/export.js.map +1 -0
- package/dist/matter/types.d.ts +3 -0
- package/dist/matter/types.d.ts.map +1 -0
- package/dist/matter/types.js +3 -0
- package/dist/matter/types.js.map +1 -0
- package/dist/matterbridge.d.ts +462 -0
- package/dist/matterbridge.d.ts.map +1 -0
- package/dist/matterbridge.js +789 -50
- package/dist/matterbridge.js.map +1 -0
- package/dist/matterbridgeAccessoryPlatform.d.ts +42 -0
- package/dist/matterbridgeAccessoryPlatform.d.ts.map +1 -0
- package/dist/matterbridgeAccessoryPlatform.js +36 -0
- package/dist/matterbridgeAccessoryPlatform.js.map +1 -0
- package/dist/matterbridgeBehaviors.d.ts +1351 -0
- package/dist/matterbridgeBehaviors.d.ts.map +1 -0
- package/dist/matterbridgeBehaviors.js +65 -5
- package/dist/matterbridgeBehaviors.js.map +1 -0
- package/dist/matterbridgeDeviceTypes.d.ts +709 -0
- package/dist/matterbridgeDeviceTypes.d.ts.map +1 -0
- package/dist/matterbridgeDeviceTypes.js +579 -15
- package/dist/matterbridgeDeviceTypes.js.map +1 -0
- package/dist/matterbridgeDynamicPlatform.d.ts +42 -0
- package/dist/matterbridgeDynamicPlatform.d.ts.map +1 -0
- package/dist/matterbridgeDynamicPlatform.js +36 -0
- package/dist/matterbridgeDynamicPlatform.js.map +1 -0
- package/dist/matterbridgeEndpoint.d.ts +1356 -0
- package/dist/matterbridgeEndpoint.d.ts.map +1 -0
- package/dist/matterbridgeEndpoint.js +1220 -54
- package/dist/matterbridgeEndpoint.js.map +1 -0
- package/dist/matterbridgeEndpointHelpers.d.ts +407 -0
- package/dist/matterbridgeEndpointHelpers.d.ts.map +1 -0
- package/dist/matterbridgeEndpointHelpers.js +345 -12
- package/dist/matterbridgeEndpointHelpers.js.map +1 -0
- package/dist/matterbridgePlatform.d.ts +331 -0
- package/dist/matterbridgePlatform.d.ts.map +1 -0
- package/dist/matterbridgePlatform.js +256 -0
- package/dist/matterbridgePlatform.js.map +1 -0
- package/dist/matterbridgeTypes.d.ts +198 -0
- package/dist/matterbridgeTypes.d.ts.map +1 -0
- package/dist/matterbridgeTypes.js +25 -0
- package/dist/matterbridgeTypes.js.map +1 -0
- package/dist/pluginManager.d.ts +270 -0
- package/dist/pluginManager.d.ts.map +1 -0
- package/dist/pluginManager.js +249 -3
- package/dist/pluginManager.js.map +1 -0
- package/dist/shelly.d.ts +174 -0
- package/dist/shelly.d.ts.map +1 -0
- package/dist/shelly.js +168 -7
- package/dist/shelly.js.map +1 -0
- package/dist/storage/export.d.ts +2 -0
- package/dist/storage/export.d.ts.map +1 -0
- package/dist/storage/export.js +1 -0
- package/dist/storage/export.js.map +1 -0
- package/dist/update.d.ts +75 -0
- package/dist/update.d.ts.map +1 -0
- package/dist/update.js +69 -0
- package/dist/update.js.map +1 -0
- package/dist/utils/colorUtils.d.ts +99 -0
- package/dist/utils/colorUtils.d.ts.map +1 -0
- package/dist/utils/colorUtils.js +97 -2
- package/dist/utils/colorUtils.js.map +1 -0
- package/dist/utils/commandLine.d.ts +59 -0
- package/dist/utils/commandLine.d.ts.map +1 -0
- package/dist/utils/commandLine.js +54 -0
- package/dist/utils/commandLine.js.map +1 -0
- package/dist/utils/copyDirectory.d.ts +33 -0
- package/dist/utils/copyDirectory.d.ts.map +1 -0
- package/dist/utils/copyDirectory.js +38 -1
- package/dist/utils/copyDirectory.js.map +1 -0
- package/dist/utils/createDirectory.d.ts +34 -0
- package/dist/utils/createDirectory.d.ts.map +1 -0
- package/dist/utils/createDirectory.js +33 -0
- package/dist/utils/createDirectory.js.map +1 -0
- package/dist/utils/createZip.d.ts +39 -0
- package/dist/utils/createZip.d.ts.map +1 -0
- package/dist/utils/createZip.js +47 -2
- package/dist/utils/createZip.js.map +1 -0
- package/dist/utils/deepCopy.d.ts +32 -0
- package/dist/utils/deepCopy.d.ts.map +1 -0
- package/dist/utils/deepCopy.js +39 -0
- package/dist/utils/deepCopy.js.map +1 -0
- package/dist/utils/deepEqual.d.ts +54 -0
- package/dist/utils/deepEqual.d.ts.map +1 -0
- package/dist/utils/deepEqual.js +72 -1
- package/dist/utils/deepEqual.js.map +1 -0
- package/dist/utils/error.d.ts +44 -0
- package/dist/utils/error.d.ts.map +1 -0
- package/dist/utils/error.js +41 -0
- package/dist/utils/error.js.map +1 -0
- package/dist/utils/export.d.ts +12 -0
- package/dist/utils/export.d.ts.map +1 -0
- package/dist/utils/export.js +1 -0
- package/dist/utils/export.js.map +1 -0
- package/dist/utils/hex.d.ts +89 -0
- package/dist/utils/hex.d.ts.map +1 -0
- package/dist/utils/hex.js +124 -0
- package/dist/utils/hex.js.map +1 -0
- package/dist/utils/isvalid.d.ts +103 -0
- package/dist/utils/isvalid.d.ts.map +1 -0
- package/dist/utils/isvalid.js +101 -0
- package/dist/utils/isvalid.js.map +1 -0
- package/dist/utils/network.d.ts +84 -0
- package/dist/utils/network.d.ts.map +1 -0
- package/dist/utils/network.js +91 -5
- package/dist/utils/network.js.map +1 -0
- package/dist/utils/spawn.d.ts +33 -0
- package/dist/utils/spawn.d.ts.map +1 -0
- package/dist/utils/spawn.js +40 -0
- package/dist/utils/spawn.js.map +1 -0
- package/dist/utils/wait.d.ts +54 -0
- package/dist/utils/wait.d.ts.map +1 -0
- package/dist/utils/wait.js +60 -8
- package/dist/utils/wait.js.map +1 -0
- package/npm-shrinkwrap.json +2 -2
- package/package.json +2 -1
|
@@ -0,0 +1,313 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* This file contains the class Frontend.
|
|
3
|
+
*
|
|
4
|
+
* @file frontend.ts
|
|
5
|
+
* @author Luca Liguori
|
|
6
|
+
* @created 2025-01-13
|
|
7
|
+
* @version 1.2.0
|
|
8
|
+
* @license Apache-2.0
|
|
9
|
+
*
|
|
10
|
+
* Copyright 2025, 2026, 2027 Luca Liguori.
|
|
11
|
+
*
|
|
12
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
13
|
+
* you may not use this file except in compliance with the License.
|
|
14
|
+
* You may obtain a copy of the License at
|
|
15
|
+
*
|
|
16
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
17
|
+
*
|
|
18
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
19
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
20
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
21
|
+
* See the License for the specific language governing permissions and
|
|
22
|
+
* limitations under the License.
|
|
23
|
+
*/
|
|
24
|
+
import EventEmitter from 'node:events';
|
|
25
|
+
import { LogLevel } from 'node-ansi-logger';
|
|
26
|
+
import { Matterbridge } from './matterbridge.js';
|
|
27
|
+
/**
|
|
28
|
+
* Websocket message ID for logging.
|
|
29
|
+
*
|
|
30
|
+
* @constant {number}
|
|
31
|
+
*/
|
|
32
|
+
export declare const WS_ID_LOG = 0;
|
|
33
|
+
/**
|
|
34
|
+
* Websocket message ID indicating a refresh is needed.
|
|
35
|
+
*
|
|
36
|
+
* @constant {number}
|
|
37
|
+
*/
|
|
38
|
+
export declare const WS_ID_REFRESH_NEEDED = 1;
|
|
39
|
+
/**
|
|
40
|
+
* Websocket message ID indicating a restart is needed.
|
|
41
|
+
*
|
|
42
|
+
* @constant {number}
|
|
43
|
+
*/
|
|
44
|
+
export declare const WS_ID_RESTART_NEEDED = 2;
|
|
45
|
+
/**
|
|
46
|
+
* Websocket message ID indicating a cpu update.
|
|
47
|
+
*
|
|
48
|
+
* @constant {number}
|
|
49
|
+
*/
|
|
50
|
+
export declare const WS_ID_CPU_UPDATE = 3;
|
|
51
|
+
/**
|
|
52
|
+
* Websocket message ID indicating a memory update.
|
|
53
|
+
*
|
|
54
|
+
* @constant {number}
|
|
55
|
+
*/
|
|
56
|
+
export declare const WS_ID_MEMORY_UPDATE = 4;
|
|
57
|
+
/**
|
|
58
|
+
* Websocket message ID indicating an uptime update.
|
|
59
|
+
*
|
|
60
|
+
* @constant {number}
|
|
61
|
+
*/
|
|
62
|
+
export declare const WS_ID_UPTIME_UPDATE = 5;
|
|
63
|
+
/**
|
|
64
|
+
* Websocket message ID indicating a snackbar message.
|
|
65
|
+
*
|
|
66
|
+
* @constant {number}
|
|
67
|
+
*/
|
|
68
|
+
export declare const WS_ID_SNACKBAR = 6;
|
|
69
|
+
/**
|
|
70
|
+
* Websocket message ID indicating matterbridge has un update available.
|
|
71
|
+
*
|
|
72
|
+
* @constant {number}
|
|
73
|
+
*/
|
|
74
|
+
export declare const WS_ID_UPDATE_NEEDED = 7;
|
|
75
|
+
/**
|
|
76
|
+
* Websocket message ID indicating a state update.
|
|
77
|
+
*
|
|
78
|
+
* @constant {number}
|
|
79
|
+
*/
|
|
80
|
+
export declare const WS_ID_STATEUPDATE = 8;
|
|
81
|
+
/**
|
|
82
|
+
* Websocket message ID indicating to close a permanent snackbar message.
|
|
83
|
+
*
|
|
84
|
+
* @constant {number}
|
|
85
|
+
*/
|
|
86
|
+
export declare const WS_ID_CLOSE_SNACKBAR = 9;
|
|
87
|
+
/**
|
|
88
|
+
* Websocket message ID indicating a shelly system update.
|
|
89
|
+
* check:
|
|
90
|
+
* curl -k http://127.0.0.1:8101/api/updates/sys/check
|
|
91
|
+
* perform:
|
|
92
|
+
* curl -k http://127.0.0.1:8101/api/updates/sys/perform
|
|
93
|
+
*
|
|
94
|
+
* @constant {number}
|
|
95
|
+
*/
|
|
96
|
+
export declare const WS_ID_SHELLY_SYS_UPDATE = 100;
|
|
97
|
+
/**
|
|
98
|
+
* Websocket message ID indicating a shelly main update.
|
|
99
|
+
* check:
|
|
100
|
+
* curl -k http://127.0.0.1:8101/api/updates/main/check
|
|
101
|
+
* perform:
|
|
102
|
+
* curl -k http://127.0.0.1:8101/api/updates/main/perform
|
|
103
|
+
*
|
|
104
|
+
* @constant {number}
|
|
105
|
+
*/
|
|
106
|
+
export declare const WS_ID_SHELLY_MAIN_UPDATE = 101;
|
|
107
|
+
/**
|
|
108
|
+
* Represents the Matterbridge events.
|
|
109
|
+
*/
|
|
110
|
+
interface FrontendEvents {
|
|
111
|
+
server_listening: [protocol: string, port: number, address?: string];
|
|
112
|
+
server_error: [error: Error];
|
|
113
|
+
server_stopped: [];
|
|
114
|
+
websocket_server_listening: [host: string];
|
|
115
|
+
websocket_server_stopped: [];
|
|
116
|
+
}
|
|
117
|
+
export declare class Frontend extends EventEmitter<FrontendEvents> {
|
|
118
|
+
private matterbridge;
|
|
119
|
+
private log;
|
|
120
|
+
private port;
|
|
121
|
+
private expressApp;
|
|
122
|
+
private httpServer;
|
|
123
|
+
private httpsServer;
|
|
124
|
+
private webSocketServer;
|
|
125
|
+
constructor(matterbridge: Matterbridge);
|
|
126
|
+
set logLevel(logLevel: LogLevel);
|
|
127
|
+
start(port?: number): Promise<void>;
|
|
128
|
+
stop(): Promise<void>;
|
|
129
|
+
private formatMemoryUsage;
|
|
130
|
+
private formatOsUpTime;
|
|
131
|
+
/**
|
|
132
|
+
* Retrieves the api settings data.
|
|
133
|
+
*
|
|
134
|
+
* @returns {Promise<{ matterbridgeInformation: MatterbridgeInformation, systemInformation: SystemInformation }>} A promise that resolve in the api settings object.
|
|
135
|
+
*/
|
|
136
|
+
private getApiSettings;
|
|
137
|
+
/**
|
|
138
|
+
* Retrieves the reachable attribute.
|
|
139
|
+
*
|
|
140
|
+
* @param {MatterbridgeEndpoint} device - The MatterbridgeEndpoint object.
|
|
141
|
+
* @returns {boolean} The reachable attribute.
|
|
142
|
+
*/
|
|
143
|
+
private getReachability;
|
|
144
|
+
/**
|
|
145
|
+
* Retrieves the power source attribute.
|
|
146
|
+
*
|
|
147
|
+
* @param {MatterbridgeEndpoint} endpoint - The MatterbridgeDevice to retrieve the power source from.
|
|
148
|
+
* @returns {'ac' | 'dc' | 'ok' | 'warning' | 'critical' | undefined} The power source attribute.
|
|
149
|
+
*/
|
|
150
|
+
private getPowerSource;
|
|
151
|
+
/**
|
|
152
|
+
* Retrieves the commissioned status, matter pairing codes, fabrics and sessions from a given device in server mode.
|
|
153
|
+
*
|
|
154
|
+
* @param {MatterbridgeEndpoint} device - The MatterbridgeEndpoint to retrieve the data from.
|
|
155
|
+
* @returns {ApiDevicesMatter | undefined} An ApiDevicesMatter object or undefined if not found.
|
|
156
|
+
*/
|
|
157
|
+
private getMatterDataFromDevice;
|
|
158
|
+
/**
|
|
159
|
+
* Retrieves the cluster text description from a given device.
|
|
160
|
+
* The output is a string with the attributes description of the cluster servers in the device to show in the frontend.
|
|
161
|
+
*
|
|
162
|
+
* @param {MatterbridgeEndpoint} device - The MatterbridgeEndpoint to retrieve the cluster text from.
|
|
163
|
+
* @returns {string} The attributes description of the cluster servers in the device.
|
|
164
|
+
*/
|
|
165
|
+
private getClusterTextFromDevice;
|
|
166
|
+
/**
|
|
167
|
+
* Retrieves the registered plugins sanitized for res.json().
|
|
168
|
+
*
|
|
169
|
+
* @returns {BaseRegisteredPlugin[]} An array of BaseRegisteredPlugin.
|
|
170
|
+
*/
|
|
171
|
+
private getPlugins;
|
|
172
|
+
/**
|
|
173
|
+
* Retrieves the devices from Matterbridge.
|
|
174
|
+
*
|
|
175
|
+
* @param {string} [pluginName] - The name of the plugin to filter devices by.
|
|
176
|
+
* @returns {Promise<ApiDevices[]>} A promise that resolves to an array of ApiDevices for the frontend.
|
|
177
|
+
*/
|
|
178
|
+
private getDevices;
|
|
179
|
+
/**
|
|
180
|
+
* Retrieves the clusters from a given plugin and endpoint number.
|
|
181
|
+
*
|
|
182
|
+
* Response for /api/clusters
|
|
183
|
+
*
|
|
184
|
+
* @param {string} pluginName - The name of the plugin.
|
|
185
|
+
* @param {number} endpointNumber - The endpoint number.
|
|
186
|
+
* @returns {ApiClustersResponse | undefined} A promise that resolves to the clusters or undefined if not found.
|
|
187
|
+
*/
|
|
188
|
+
private getClusters;
|
|
189
|
+
/**
|
|
190
|
+
* Handles incoming websocket messages for the Matterbridge frontend.
|
|
191
|
+
*
|
|
192
|
+
* @param {WebSocket} client - The websocket client that sent the message.
|
|
193
|
+
* @param {WebSocket.RawData} message - The raw data of the message received from the client.
|
|
194
|
+
* @returns {Promise<void>} A promise that resolves when the message has been handled.
|
|
195
|
+
*/
|
|
196
|
+
private wsMessageHandler;
|
|
197
|
+
/**
|
|
198
|
+
* Sends a WebSocket log message to all connected clients. The function is called by AnsiLogger.setGlobalCallback.
|
|
199
|
+
*
|
|
200
|
+
* @param {string} level - The logger level of the message: debug info notice warn error fatal...
|
|
201
|
+
* @param {string} time - The time string of the message
|
|
202
|
+
* @param {string} name - The logger name of the message
|
|
203
|
+
* @param {string} message - The content of the message.
|
|
204
|
+
*
|
|
205
|
+
* @remarks
|
|
206
|
+
* The function removes ANSI escape codes, leading asterisks, non-printable characters, and replaces all occurrences of \t and \n.
|
|
207
|
+
* It also replaces all occurrences of \" with " and angle-brackets with < and >.
|
|
208
|
+
* The function sends the message to all connected clients.
|
|
209
|
+
*/
|
|
210
|
+
wssSendMessage(level: string, time: string, name: string, message: string): void;
|
|
211
|
+
/**
|
|
212
|
+
* Sends a need to refresh WebSocket message to all connected clients.
|
|
213
|
+
*
|
|
214
|
+
* @param {string} changed - The changed value. If null, the whole page will be refreshed.
|
|
215
|
+
* possible values:
|
|
216
|
+
* - 'matterbridgeLatestVersion'
|
|
217
|
+
* - 'matterbridgeDevVersion'
|
|
218
|
+
* - 'matterbridgeAdvertise'
|
|
219
|
+
* - 'online'
|
|
220
|
+
* - 'offline'
|
|
221
|
+
* - 'reachability'
|
|
222
|
+
* - 'settings'
|
|
223
|
+
* - 'plugins'
|
|
224
|
+
* - 'pluginsRestart'
|
|
225
|
+
* - 'devices'
|
|
226
|
+
* - 'fabrics'
|
|
227
|
+
* - 'sessions'
|
|
228
|
+
*/
|
|
229
|
+
wssSendRefreshRequired(changed?: string | null): void;
|
|
230
|
+
/**
|
|
231
|
+
* Sends a need to restart WebSocket message to all connected clients.
|
|
232
|
+
*
|
|
233
|
+
* @param {boolean} snackbar - If true, a snackbar message will be sent to all connected clients. Default is true.
|
|
234
|
+
* @param {boolean} fixed - If true, the restart is fixed and will not be reset by plugin restarts. Default is false.
|
|
235
|
+
*/
|
|
236
|
+
wssSendRestartRequired(snackbar?: boolean, fixed?: boolean): void;
|
|
237
|
+
/**
|
|
238
|
+
* Sends a no need to restart WebSocket message to all connected clients.
|
|
239
|
+
*
|
|
240
|
+
* @param {boolean} snackbar - If true, the snackbar message will be cleared from all connected clients.
|
|
241
|
+
*/
|
|
242
|
+
wssSendRestartNotRequired(snackbar?: boolean): void;
|
|
243
|
+
/**
|
|
244
|
+
* Sends a need to update WebSocket message to all connected clients.
|
|
245
|
+
*
|
|
246
|
+
* @param {boolean} devVersion - If true, the update is for a development version.
|
|
247
|
+
*/
|
|
248
|
+
wssSendUpdateRequired(devVersion?: boolean): void;
|
|
249
|
+
/**
|
|
250
|
+
* Sends a cpu update message to all connected clients.
|
|
251
|
+
*
|
|
252
|
+
* @param {number} cpuUsage - The CPU usage percentage to send.
|
|
253
|
+
*/
|
|
254
|
+
wssSendCpuUpdate(cpuUsage: number): void;
|
|
255
|
+
/**
|
|
256
|
+
* Sends a memory update message to all connected clients.
|
|
257
|
+
*
|
|
258
|
+
* @param {string} totalMemory - The total memory in bytes.
|
|
259
|
+
* @param {string} freeMemory - The free memory in bytes.
|
|
260
|
+
* @param {string} rss - The resident set size in bytes.
|
|
261
|
+
* @param {string} heapTotal - The total heap memory in bytes.
|
|
262
|
+
* @param {string} heapUsed - The used heap memory in bytes.
|
|
263
|
+
* @param {string} external - The external memory in bytes.
|
|
264
|
+
* @param {string} arrayBuffers - The array buffers memory in bytes.
|
|
265
|
+
*/
|
|
266
|
+
wssSendMemoryUpdate(totalMemory: string, freeMemory: string, rss: string, heapTotal: string, heapUsed: string, external: string, arrayBuffers: string): void;
|
|
267
|
+
/**
|
|
268
|
+
* Sends an uptime update message to all connected clients.
|
|
269
|
+
*
|
|
270
|
+
* @param {string} systemUptime - The system uptime in a human-readable format.
|
|
271
|
+
* @param {string} processUptime - The process uptime in a human-readable format.
|
|
272
|
+
*/
|
|
273
|
+
wssSendUptimeUpdate(systemUptime: string, processUptime: string): void;
|
|
274
|
+
/**
|
|
275
|
+
* Sends an open snackbar message to all connected clients.
|
|
276
|
+
*
|
|
277
|
+
* @param {string} message - The message to send.
|
|
278
|
+
* @param {number} timeout - The timeout in seconds for the snackbar message.
|
|
279
|
+
* @param {'info' | 'warning' | 'error' | 'success'} severity - The severity of the snackbar message (default info).
|
|
280
|
+
*/
|
|
281
|
+
wssSendSnackbarMessage(message: string, timeout?: number, severity?: 'info' | 'warning' | 'error' | 'success'): void;
|
|
282
|
+
/**
|
|
283
|
+
* Sends a close snackbar message to all connected clients.
|
|
284
|
+
*
|
|
285
|
+
* @param {string} message - The message to send.
|
|
286
|
+
*/
|
|
287
|
+
wssSendCloseSnackbarMessage(message: string): void;
|
|
288
|
+
/**
|
|
289
|
+
* Sends an attribute update message to all connected WebSocket clients.
|
|
290
|
+
*
|
|
291
|
+
* @param {string | undefined} plugin - The name of the plugin.
|
|
292
|
+
* @param {string | undefined} serialNumber - The serial number of the device.
|
|
293
|
+
* @param {string | undefined} uniqueId - The unique identifier of the device.
|
|
294
|
+
* @param {string} cluster - The cluster name where the attribute belongs.
|
|
295
|
+
* @param {string} attribute - The name of the attribute that changed.
|
|
296
|
+
* @param {number | string | boolean} value - The new value of the attribute.
|
|
297
|
+
*
|
|
298
|
+
* @remarks
|
|
299
|
+
* This method logs a debug message and sends a JSON-formatted message to all connected WebSocket clients
|
|
300
|
+
* with the updated attribute information.
|
|
301
|
+
*/
|
|
302
|
+
wssSendAttributeChangedMessage(plugin: string | undefined, serialNumber: string | undefined, uniqueId: string | undefined, cluster: string, attribute: string, value: number | string | boolean): void;
|
|
303
|
+
/**
|
|
304
|
+
* Sends a message to all connected clients.
|
|
305
|
+
*
|
|
306
|
+
* @param {number} id - The message id.
|
|
307
|
+
* @param {string} method - The message method.
|
|
308
|
+
* @param {Record<string, string | number | boolean>} params - The message parameters.
|
|
309
|
+
*/
|
|
310
|
+
wssBroadcastMessage(id: number, method?: string, params?: Record<string, string | number | boolean>): void;
|
|
311
|
+
}
|
|
312
|
+
export {};
|
|
313
|
+
//# sourceMappingURL=frontend.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"frontend.d.ts","sourceRoot":"","sources":["../src/frontend.ts"],"names":[],"mappings":"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"}
|