matterbridge 1.7.3 → 2.0.0-edge1
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 +20 -1
- package/dist/cli.js +3 -13
- package/dist/cli.js.map +1 -1
- package/dist/deviceManager.d.ts +7 -7
- package/dist/deviceManager.d.ts.map +1 -1
- package/dist/deviceManager.js +2 -2
- package/dist/deviceManager.js.map +1 -1
- package/dist/frontend.d.ts +98 -0
- package/dist/frontend.d.ts.map +1 -0
- package/dist/frontend.js +1377 -0
- package/dist/frontend.js.map +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -6
- package/dist/index.js.map +1 -1
- package/dist/matter/export.d.ts.map +1 -1
- package/dist/matter/export.js +0 -1
- package/dist/matter/export.js.map +1 -1
- package/dist/matterbridge.d.ts +82 -208
- package/dist/matterbridge.d.ts.map +1 -1
- package/dist/matterbridge.js +777 -2310
- package/dist/matterbridge.js.map +1 -1
- package/dist/matterbridgeBehaviors.d.ts +32 -851
- package/dist/matterbridgeBehaviors.d.ts.map +1 -1
- package/dist/matterbridgeBehaviors.js +22 -2
- package/dist/matterbridgeBehaviors.js.map +1 -1
- package/dist/matterbridgeEndpoint.d.ts +100 -9089
- package/dist/matterbridgeEndpoint.d.ts.map +1 -1
- package/dist/matterbridgeEndpoint.js +59 -31
- package/dist/matterbridgeEndpoint.js.map +1 -1
- package/dist/matterbridgePlatform.d.ts +14 -28
- package/dist/matterbridgePlatform.d.ts.map +1 -1
- package/dist/matterbridgePlatform.js +7 -23
- package/dist/matterbridgePlatform.js.map +1 -1
- package/dist/matterbridgeTypes.d.ts.map +1 -1
- package/dist/matterbridgeTypes.js +4 -0
- package/dist/matterbridgeTypes.js.map +1 -1
- package/dist/pluginManager.d.ts +1 -1
- package/dist/pluginManager.d.ts.map +1 -1
- package/dist/pluginManager.js +5 -11
- package/dist/pluginManager.js.map +1 -1
- package/dist/utils/utils.d.ts +1 -1
- package/dist/utils/utils.d.ts.map +1 -1
- package/dist/utils/utils.js +6 -6
- package/dist/utils/utils.js.map +1 -1
- package/frontend/build/asset-manifest.json +3 -3
- package/frontend/build/index.html +1 -1
- package/frontend/build/static/js/{main.6bbd1772.js → main.ea28015b.js} +3 -3
- package/frontend/build/static/js/main.ea28015b.js.map +1 -0
- package/npm-shrinkwrap.json +9 -9
- package/package.json +2 -3
- package/dist/cli.d.ts +0 -25
- package/dist/cluster/export.d.ts +0 -2
- package/dist/defaultConfigSchema.d.ts +0 -27
- package/dist/index.d.ts +0 -40
- package/dist/logger/export.d.ts +0 -2
- package/dist/matter/export.d.ts +0 -11
- package/dist/matterbridgeAccessoryPlatform.d.ts +0 -39
- package/dist/matterbridgeDevice.d.ts +0 -7077
- package/dist/matterbridgeDevice.d.ts.map +0 -1
- package/dist/matterbridgeDevice.js +0 -2736
- package/dist/matterbridgeDevice.js.map +0 -1
- package/dist/matterbridgeDynamicPlatform.d.ts +0 -39
- package/dist/matterbridgeEdge.d.ts +0 -91
- package/dist/matterbridgeEdge.d.ts.map +0 -1
- package/dist/matterbridgeEdge.js +0 -1077
- package/dist/matterbridgeEdge.js.map +0 -1
- package/dist/matterbridgeTypes.d.ts +0 -172
- package/dist/matterbridgeWebsocket.d.ts +0 -49
- package/dist/matterbridgeWebsocket.d.ts.map +0 -1
- package/dist/matterbridgeWebsocket.js +0 -325
- package/dist/matterbridgeWebsocket.js.map +0 -1
- package/dist/storage/export.d.ts +0 -2
- package/dist/utils/colorUtils.d.ts +0 -61
- package/dist/utils/export.d.ts +0 -3
- package/frontend/build/static/js/main.6bbd1772.js.map +0 -1
- /package/frontend/build/static/js/{main.6bbd1772.js.LICENSE.txt → main.ea28015b.js.LICENSE.txt} +0 -0
package/CHANGELOG.md
CHANGED
|
@@ -15,11 +15,30 @@ Tamer (https://github.com/tammeryousef1006) has created the Matterbridge Discord
|
|
|
15
15
|
|
|
16
16
|
### Breaking Changes
|
|
17
17
|
|
|
18
|
-
|
|
18
|
+
Starting from v. 2.0.0 Matterbridge is running only in mode edge (no parameter needed).
|
|
19
|
+
The legacy old api have been completely removed.
|
|
19
20
|
|
|
20
21
|
The frontend has a new dark and light mode. The dark mode is now the default mode.
|
|
21
22
|
It is possible to change the mode (Classic, Dark or Light) in Settings, Matterbridge settings.
|
|
22
23
|
|
|
24
|
+
## [2.0.0-edge.1] - 2025-01-14
|
|
25
|
+
|
|
26
|
+
### Added
|
|
27
|
+
|
|
28
|
+
- [behavior]: Added MatterbridgeValveConfigurationAndControlServer behavior with open close command.
|
|
29
|
+
|
|
30
|
+
### Changed
|
|
31
|
+
|
|
32
|
+
- [legacy]: Removed MatterbridgeDevice and MatterbridgeEdge classes.
|
|
33
|
+
- [factoryreset]: Now it deletes also the backup files and backup directories.
|
|
34
|
+
- [mattebridge]: Restyled the Matterbridge class and created the Frontend class that manages the frontend express and websocket api calls.
|
|
35
|
+
- [frontend]: Frontend v.2.3.12.
|
|
36
|
+
- [package]: Update dependencies.
|
|
37
|
+
|
|
38
|
+
<a href="https://www.buymeacoffee.com/luligugithub">
|
|
39
|
+
<img src="./yellow-button.png" alt="Buy me a coffee" width="120">
|
|
40
|
+
</a>
|
|
41
|
+
|
|
23
42
|
## [1.7.3] - 2025-01-11
|
|
24
43
|
|
|
25
44
|
### Added
|
package/dist/cli.js
CHANGED
|
@@ -23,7 +23,6 @@
|
|
|
23
23
|
*/
|
|
24
24
|
/* eslint-disable no-console */
|
|
25
25
|
import { Matterbridge } from './matterbridge.js';
|
|
26
|
-
import { MatterbridgeEdge } from './matterbridgeEdge.js';
|
|
27
26
|
let instance;
|
|
28
27
|
const cli = '\u001B[32m';
|
|
29
28
|
const er = '\u001B[38;5;9m';
|
|
@@ -31,10 +30,7 @@ const rs = '\u001B[40;0m';
|
|
|
31
30
|
async function main() {
|
|
32
31
|
if (process.argv.includes('-debug'))
|
|
33
32
|
console.log(cli + `CLI: ${process.argv.includes('-edge') ? 'MatterbridgeEdge' : 'Matterbridge'}.loadInstance() called` + rs);
|
|
34
|
-
|
|
35
|
-
instance = await MatterbridgeEdge.loadInstance(true);
|
|
36
|
-
else
|
|
37
|
-
instance = await Matterbridge.loadInstance(true);
|
|
33
|
+
instance = await Matterbridge.loadInstance(true);
|
|
38
34
|
registerHandlers();
|
|
39
35
|
if (process.argv.includes('-debug'))
|
|
40
36
|
console.log(cli + `CLI: ${process.argv.includes('-edge') ? 'MatterbridgeEdge' : 'Matterbridge'}.loadInstance() exited` + rs);
|
|
@@ -55,20 +51,14 @@ async function shutdown() {
|
|
|
55
51
|
async function restart() {
|
|
56
52
|
if (process.argv.includes('-debug'))
|
|
57
53
|
console.log(cli + 'CLI: received restart event, loading...' + rs);
|
|
58
|
-
|
|
59
|
-
instance = await MatterbridgeEdge.loadInstance(true);
|
|
60
|
-
else
|
|
61
|
-
instance = await Matterbridge.loadInstance(true);
|
|
54
|
+
instance = await Matterbridge.loadInstance(true);
|
|
62
55
|
registerHandlers();
|
|
63
56
|
}
|
|
64
57
|
async function update() {
|
|
65
58
|
if (process.argv.includes('-debug'))
|
|
66
59
|
console.log(cli + 'CLI: received update event, updating...' + rs);
|
|
67
60
|
// TODO: Implement update logic outside of matterbridge
|
|
68
|
-
|
|
69
|
-
instance = await MatterbridgeEdge.loadInstance();
|
|
70
|
-
else
|
|
71
|
-
instance = await Matterbridge.loadInstance(true);
|
|
61
|
+
instance = await Matterbridge.loadInstance(true);
|
|
72
62
|
registerHandlers();
|
|
73
63
|
}
|
|
74
64
|
process.title = 'matterbridge';
|
package/dist/cli.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":";AACA;;;;;;;;;;;;;;;;;;;;;GAqBG;AAEH,+BAA+B;AAC/B,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":";AACA;;;;;;;;;;;;;;;;;;;;;GAqBG;AAEH,+BAA+B;AAC/B,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAEjD,IAAI,QAAkC,CAAC;AACvC,MAAM,GAAG,GAAG,YAAY,CAAC;AACzB,MAAM,EAAE,GAAG,gBAAgB,CAAC;AAC5B,MAAM,EAAE,GAAG,cAAc,CAAC;AAE1B,KAAK,UAAU,IAAI;IACjB,IAAI,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;QAAE,OAAO,CAAC,GAAG,CAAC,GAAG,GAAG,QAAQ,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,cAAc,wBAAwB,GAAG,EAAE,CAAC,CAAC;IAClK,QAAQ,GAAG,MAAM,YAAY,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IACjD,gBAAgB,EAAE,CAAC;IACnB,IAAI,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;QAAE,OAAO,CAAC,GAAG,CAAC,GAAG,GAAG,QAAQ,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,cAAc,wBAAwB,GAAG,EAAE,CAAC,CAAC;AACpK,CAAC;AAED,SAAS,gBAAgB;IACvB,IAAI,QAAQ;QAAE,QAAQ,CAAC,EAAE,CAAC,UAAU,EAAE,KAAK,IAAI,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC;IAC9D,IAAI,QAAQ;QAAE,QAAQ,CAAC,EAAE,CAAC,SAAS,EAAE,KAAK,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC,CAAC;IAC5D,IAAI,QAAQ;QAAE,QAAQ,CAAC,EAAE,CAAC,QAAQ,EAAE,KAAK,IAAI,EAAE,CAAC,MAAM,EAAE,CAAC,CAAC;AAC5D,CAAC;AAED,KAAK,UAAU,QAAQ;IACrB,IAAI,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;QAAE,OAAO,CAAC,GAAG,CAAC,GAAG,GAAG,0CAA0C,GAAG,EAAE,CAAC,CAAC;IACxG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC;AAED,KAAK,UAAU,OAAO;IACpB,IAAI,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;QAAE,OAAO,CAAC,GAAG,CAAC,GAAG,GAAG,yCAAyC,GAAG,EAAE,CAAC,CAAC;IACvG,QAAQ,GAAG,MAAM,YAAY,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IACjD,gBAAgB,EAAE,CAAC;AACrB,CAAC;AAED,KAAK,UAAU,MAAM;IACnB,IAAI,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;QAAE,OAAO,CAAC,GAAG,CAAC,GAAG,GAAG,yCAAyC,GAAG,EAAE,CAAC,CAAC;IACvG,uDAAuD;IACvD,QAAQ,GAAG,MAAM,YAAY,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IACjD,gBAAgB,EAAE,CAAC;AACrB,CAAC;AAED,OAAO,CAAC,KAAK,GAAG,cAAc,CAAC;AAE/B,wBAAwB;AACxB,IAAI,EAAE,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE;IACrB,OAAO,CAAC,KAAK,CAAC,EAAE,GAAG,uDAAuD,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC;AAC1F,CAAC,CAAC,CAAC"}
|
package/dist/deviceManager.d.ts
CHANGED
|
@@ -23,8 +23,9 @@
|
|
|
23
23
|
import { LogLevel } from 'node-ansi-logger';
|
|
24
24
|
import { NodeStorage } from 'node-persist-manager';
|
|
25
25
|
import { Matterbridge } from './matterbridge.js';
|
|
26
|
-
import {
|
|
26
|
+
import { MatterbridgeEndpoint } from './matterbridgeEndpoint.js';
|
|
27
27
|
export declare class DeviceManager {
|
|
28
|
+
[x: number]: () => any;
|
|
28
29
|
private readonly _devices;
|
|
29
30
|
private readonly matterbridge;
|
|
30
31
|
private readonly nodeContext;
|
|
@@ -33,13 +34,12 @@ export declare class DeviceManager {
|
|
|
33
34
|
get length(): number;
|
|
34
35
|
get size(): number;
|
|
35
36
|
has(uniqueId: string): boolean;
|
|
36
|
-
get(uniqueId: string):
|
|
37
|
-
set(device:
|
|
38
|
-
remove(device:
|
|
37
|
+
get(uniqueId: string): MatterbridgeEndpoint | undefined;
|
|
38
|
+
set(device: MatterbridgeEndpoint): MatterbridgeEndpoint;
|
|
39
|
+
remove(device: MatterbridgeEndpoint): boolean;
|
|
39
40
|
clear(): void;
|
|
40
|
-
array():
|
|
41
|
-
|
|
42
|
-
forEach(callback: (device: MatterbridgeDevice) => Promise<void>): Promise<void>;
|
|
41
|
+
array(): MatterbridgeEndpoint[];
|
|
42
|
+
forEach(callback: (device: MatterbridgeEndpoint) => Promise<void>): Promise<void>;
|
|
43
43
|
get logLevel(): LogLevel;
|
|
44
44
|
set logLevel(logLevel: LogLevel);
|
|
45
45
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"deviceManager.d.ts","sourceRoot":"","sources":["../src/deviceManager.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;GAqBG;AAGH,OAAO,EAAwB,QAAQ,EAAmB,MAAM,kBAAkB,CAAC;AACnF,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAGnD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"deviceManager.d.ts","sourceRoot":"","sources":["../src/deviceManager.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;GAqBG;AAGH,OAAO,EAAwB,QAAQ,EAAmB,MAAM,kBAAkB,CAAC;AACnF,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAGnD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AAGjE,qBAAa,aAAa;;IACxB,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAA2C;IACpE,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAe;IAC5C,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAc;IAC1C,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAa;gBAErB,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,WAAW;IAOhE,IAAI,MAAM,IAAI,MAAM,CAEnB;IAED,IAAI,IAAI,IAAI,MAAM,CAEjB;IAED,GAAG,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO;IAI9B,GAAG,CAAC,QAAQ,EAAE,MAAM,GAAG,oBAAoB,GAAG,SAAS;IAIvD,GAAG,CAAC,MAAM,EAAE,oBAAoB,GAAG,oBAAoB;IAOvD,MAAM,CAAC,MAAM,EAAE,oBAAoB,GAAG,OAAO;IAM7C,KAAK,IAAI,IAAI;IAIb,KAAK,IAAI,oBAAoB,EAAE;IAQzB,OAAO,CAAC,QAAQ,EAAE,CAAC,MAAM,EAAE,oBAAoB,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAYvF,IAAI,QAAQ,IAAI,QAAQ,CAEvB;IAED,IAAI,QAAQ,CAAC,QAAQ,EAAE,QAAQ,EAE9B;CAgCF"}
|
package/dist/deviceManager.js
CHANGED
|
@@ -21,7 +21,7 @@
|
|
|
21
21
|
* limitations under the License. *
|
|
22
22
|
*/
|
|
23
23
|
// NodeStorage and AnsiLogger modules
|
|
24
|
-
import { AnsiLogger, BLUE, er } from 'node-ansi-logger';
|
|
24
|
+
import { AnsiLogger, BLUE, er, TimestampFormat } from 'node-ansi-logger';
|
|
25
25
|
import { dev } from './matterbridgeTypes.js';
|
|
26
26
|
export class DeviceManager {
|
|
27
27
|
_devices = new Map();
|
|
@@ -31,7 +31,7 @@ export class DeviceManager {
|
|
|
31
31
|
constructor(matterbridge, nodeContext) {
|
|
32
32
|
this.matterbridge = matterbridge;
|
|
33
33
|
this.nodeContext = nodeContext;
|
|
34
|
-
this.log = new AnsiLogger({ logName: 'DeviceManager', logTimestampFormat:
|
|
34
|
+
this.log = new AnsiLogger({ logName: 'DeviceManager', logTimestampFormat: TimestampFormat.TIME_MILLIS, logLevel: matterbridge.log.logLevel });
|
|
35
35
|
this.log.debug('Matterbridge device manager starting...');
|
|
36
36
|
}
|
|
37
37
|
get length() {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"deviceManager.js","sourceRoot":"","sources":["../src/deviceManager.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;GAqBG;AAEH,qCAAqC;AACrC,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,EAAE,
|
|
1
|
+
{"version":3,"file":"deviceManager.js","sourceRoot":"","sources":["../src/deviceManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* This file contains the class Frontend.
|
|
3
|
+
*
|
|
4
|
+
* @file frontend.ts
|
|
5
|
+
* @author Luca Liguori
|
|
6
|
+
* @date 2025-01-13
|
|
7
|
+
* @version 1.0.0
|
|
8
|
+
*
|
|
9
|
+
* Copyright 2025, 2026, 2027 Luca Liguori.
|
|
10
|
+
*
|
|
11
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
12
|
+
* you may not use this file except in compliance with the License.
|
|
13
|
+
* You may obtain a copy of the License at
|
|
14
|
+
*
|
|
15
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
16
|
+
*
|
|
17
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
18
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
19
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
20
|
+
* See the License for the specific language governing permissions and
|
|
21
|
+
* limitations under the License. *
|
|
22
|
+
*/
|
|
23
|
+
import { BaseRegisteredPlugin } from './matterbridgeTypes.js';
|
|
24
|
+
import { Matterbridge } from './matterbridge.js';
|
|
25
|
+
import { MatterbridgeEndpoint } from './matterbridgeEndpoint.js';
|
|
26
|
+
/**
|
|
27
|
+
* Websocket message ID for logging.
|
|
28
|
+
* @constant {number}
|
|
29
|
+
*/
|
|
30
|
+
export declare const WS_ID_LOG = 0;
|
|
31
|
+
/**
|
|
32
|
+
* Websocket message ID indicating a refresh is needed.
|
|
33
|
+
* @constant {number}
|
|
34
|
+
*/
|
|
35
|
+
export declare const WS_ID_REFRESH_NEEDED = 1;
|
|
36
|
+
/**
|
|
37
|
+
* Websocket message ID indicating a restart is needed.
|
|
38
|
+
* @constant {number}
|
|
39
|
+
*/
|
|
40
|
+
export declare const WS_ID_RESTART_NEEDED = 2;
|
|
41
|
+
/**
|
|
42
|
+
* Initializes the frontend of Matterbridge.
|
|
43
|
+
*
|
|
44
|
+
* @param port The port number to run the frontend server on. Default is 8283.
|
|
45
|
+
*/
|
|
46
|
+
export declare class Frontend {
|
|
47
|
+
private matterbridge;
|
|
48
|
+
private log;
|
|
49
|
+
private port;
|
|
50
|
+
private initializeError;
|
|
51
|
+
private expressApp;
|
|
52
|
+
private httpServer;
|
|
53
|
+
private httpsServer;
|
|
54
|
+
private webSocketServer;
|
|
55
|
+
constructor(matterbridge: Matterbridge);
|
|
56
|
+
start(port?: number): any;
|
|
57
|
+
stop(): any;
|
|
58
|
+
/**
|
|
59
|
+
* Retrieves the cluster text description from a given device.
|
|
60
|
+
* @param {MatterbridgeDevice} device - The MatterbridgeDevice object.
|
|
61
|
+
* @returns {string} The attributes description of the cluster servers in the device.
|
|
62
|
+
*/
|
|
63
|
+
protected getClusterTextFromDevice(device: MatterbridgeEndpoint): string;
|
|
64
|
+
/**
|
|
65
|
+
* Retrieves the base registered plugins sanitized for res.json().
|
|
66
|
+
* @returns {BaseRegisteredPlugin[]} A promise that resolves to an array of BaseRegisteredPlugin objects.
|
|
67
|
+
*/
|
|
68
|
+
getBaseRegisteredPlugins(): Promise<BaseRegisteredPlugin[]>;
|
|
69
|
+
/**
|
|
70
|
+
* Handles incoming websocket messages for the Matterbridge.
|
|
71
|
+
*
|
|
72
|
+
* @param {Matterbridge} this - The Matterbridge instance.
|
|
73
|
+
* @param {WebSocket} client - The websocket client that sent the message.
|
|
74
|
+
* @param {WebSocket.RawData} message - The raw data of the message received from the client.
|
|
75
|
+
* @returns {Promise<void>} A promise that resolves when the message has been handled.
|
|
76
|
+
*/
|
|
77
|
+
private wsMessageHandler;
|
|
78
|
+
/**
|
|
79
|
+
* Sends a WebSocket message to all connected clients.
|
|
80
|
+
*
|
|
81
|
+
* @param {string} level - The logger level of the message: debug info notice warn error fatal...
|
|
82
|
+
* @param {string} time - The time string of the message
|
|
83
|
+
* @param {string} name - The logger name of the message
|
|
84
|
+
* @param {string} message - The content of the message.
|
|
85
|
+
*/
|
|
86
|
+
wssSendMessage(level: string, time: string, name: string, message: string): void;
|
|
87
|
+
/**
|
|
88
|
+
* Sends a need to refresh WebSocket message to all connected clients.
|
|
89
|
+
*
|
|
90
|
+
*/
|
|
91
|
+
wssSendRefreshRequired(): void;
|
|
92
|
+
/**
|
|
93
|
+
* Sends a need to restart WebSocket message to all connected clients.
|
|
94
|
+
*
|
|
95
|
+
*/
|
|
96
|
+
wssSendRestartRequired(): void;
|
|
97
|
+
}
|
|
98
|
+
//# sourceMappingURL=frontend.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"frontend.d.ts","sourceRoot":"","sources":["../src/frontend.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;GAqBG;AAmBH,OAAO,EAA2B,oBAAoB,EAAyB,MAAM,wBAAwB,CAAC;AAC9G,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AAEjE;;;GAGG;AACH,eAAO,MAAM,SAAS,IAAI,CAAC;AAE3B;;;GAGG;AACH,eAAO,MAAM,oBAAoB,IAAI,CAAC;AAEtC;;;GAGG;AACH,eAAO,MAAM,oBAAoB,IAAI,CAAC;AAEtC;;;;GAIG;AACH,qBAAa,QAAQ;IACnB,OAAO,CAAC,YAAY,CAAe;IACnC,OAAO,CAAC,GAAG,CAAa;IACxB,OAAO,CAAC,IAAI,CAAQ;IACpB,OAAO,CAAC,eAAe,CAAS;IAEhC,OAAO,CAAC,UAAU,CAA8B;IAChD,OAAO,CAAC,UAAU,CAAyB;IAC3C,OAAO,CAAC,WAAW,CAA2B;IAC9C,OAAO,CAAC,eAAe,CAA8B;gBAEzC,YAAY,EAAE,YAAY;IAKhC,KAAK,CAAC,IAAI,SAAO;IAwwBjB,IAAI;IA2CV;;;;OAIG;IACH,SAAS,CAAC,wBAAwB,CAAC,MAAM,EAAE,oBAAoB,GAAG,MAAM;IAmFxE;;;OAGG;IACG,wBAAwB,IAAI,OAAO,CAAC,oBAAoB,EAAE,CAAC;IAgCjE;;;;;;;OAOG;YACW,gBAAgB;IAqP9B;;;;;;;OAOG;IACH,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM;IAuCzE;;;OAGG;IACH,sBAAsB;IAWtB;;;OAGG;IACH,sBAAsB;CAUvB"}
|