homebridge 2.0.0-alpha.4 → 2.0.0-alpha.40
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/README.md +1 -1
- package/bin/homebridge.js +22 -0
- package/config-sample.json +12 -1
- package/dist/api.d.ts +226 -0
- package/dist/api.d.ts.map +1 -0
- package/dist/api.js +166 -0
- package/dist/api.js.map +1 -0
- package/dist/bridgeService.d.ts +125 -0
- package/dist/bridgeService.d.ts.map +1 -0
- package/dist/bridgeService.js +396 -0
- package/dist/bridgeService.js.map +1 -0
- package/dist/childBridgeFork.d.ts +38 -0
- package/dist/childBridgeFork.d.ts.map +1 -0
- package/dist/childBridgeFork.js +241 -2
- package/dist/childBridgeFork.js.map +1 -7
- package/dist/childBridgeService.d.ts +203 -0
- package/dist/childBridgeService.d.ts.map +1 -0
- package/dist/childBridgeService.js +451 -0
- package/dist/childBridgeService.js.map +1 -0
- package/dist/cli.d.ts +3 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +90 -2
- package/dist/cli.js.map +1 -7
- package/dist/externalPortService.d.ts +33 -0
- package/dist/externalPortService.d.ts.map +1 -0
- package/dist/externalPortService.js +59 -0
- package/dist/externalPortService.js.map +1 -0
- package/dist/index.d.ts +85 -1099
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +20 -2
- package/dist/index.js.map +1 -7
- package/dist/ipcService.d.ts +30 -0
- package/dist/ipcService.d.ts.map +1 -0
- package/dist/ipcService.js +49 -0
- package/dist/ipcService.js.map +1 -0
- package/dist/logger.d.ts +78 -0
- package/dist/logger.d.ts.map +1 -0
- package/dist/logger.js +138 -0
- package/dist/logger.js.map +1 -0
- package/dist/matterConfigValidator.d.ts +34 -0
- package/dist/matterConfigValidator.d.ts.map +1 -0
- package/dist/matterConfigValidator.js +249 -0
- package/dist/matterConfigValidator.js.map +1 -0
- package/dist/matterService.d.ts +168 -0
- package/dist/matterService.d.ts.map +1 -0
- package/dist/matterService.js +677 -0
- package/dist/matterService.js.map +1 -0
- package/dist/matterTypes.d.ts +20 -0
- package/dist/matterTypes.d.ts.map +1 -0
- package/dist/matterTypes.js +278 -0
- package/dist/matterTypes.js.map +1 -0
- package/dist/platformAccessory.d.ts +56 -0
- package/dist/platformAccessory.d.ts.map +1 -0
- package/dist/platformAccessory.js +105 -0
- package/dist/platformAccessory.js.map +1 -0
- package/dist/plugin.d.ts +30 -0
- package/dist/plugin.d.ts.map +1 -0
- package/dist/plugin.js +182 -0
- package/dist/plugin.js.map +1 -0
- package/dist/pluginManager.d.ts +77 -0
- package/dist/pluginManager.d.ts.map +1 -0
- package/dist/pluginManager.js +375 -0
- package/dist/pluginManager.js.map +1 -0
- package/dist/server.d.ts +61 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +467 -0
- package/dist/server.js.map +1 -0
- package/dist/storageService.d.ts +13 -0
- package/dist/storageService.d.ts.map +1 -0
- package/dist/storageService.js +41 -0
- package/dist/storageService.js.map +1 -0
- package/dist/user.d.ts +13 -0
- package/dist/user.d.ts.map +1 -0
- package/dist/user.js +29 -0
- package/dist/user.js.map +1 -0
- package/dist/util/mac.d.ts +5 -0
- package/dist/util/mac.d.ts.map +1 -0
- package/dist/util/mac.js +14 -0
- package/dist/util/mac.js.map +1 -0
- package/dist/util/matter-cli.d.ts +3 -0
- package/dist/util/matter-cli.d.ts.map +1 -0
- package/dist/util/matter-cli.js +211 -0
- package/dist/util/matter-cli.js.map +1 -0
- package/dist/version.d.ts +3 -0
- package/dist/version.d.ts.map +1 -0
- package/dist/version.js +16 -0
- package/dist/version.js.map +1 -0
- package/package.json +31 -34
- package/bin/homebridge +0 -19
|
@@ -0,0 +1,396 @@
|
|
|
1
|
+
import { Accessory, Bridge, Characteristic, HAPLibraryVersion, once, Service, uuid, } from 'hap-nodejs';
|
|
2
|
+
import { getLogPrefix, Logger } from './logger.js';
|
|
3
|
+
import { PlatformAccessory } from './platformAccessory.js';
|
|
4
|
+
import { PluginManager } from './pluginManager.js';
|
|
5
|
+
import { StorageService } from './storageService.js';
|
|
6
|
+
import { generate } from './util/mac.js';
|
|
7
|
+
import getVersion from './version.js';
|
|
8
|
+
const log = Logger.internal;
|
|
9
|
+
export class BridgeService {
|
|
10
|
+
api;
|
|
11
|
+
pluginManager;
|
|
12
|
+
externalPortService;
|
|
13
|
+
bridgeOptions;
|
|
14
|
+
bridgeConfig;
|
|
15
|
+
config;
|
|
16
|
+
bridge;
|
|
17
|
+
storageService;
|
|
18
|
+
allowInsecureAccess;
|
|
19
|
+
cachedPlatformAccessories = [];
|
|
20
|
+
cachedAccessoriesFileLoaded = false;
|
|
21
|
+
publishedExternalAccessories = new Map();
|
|
22
|
+
constructor(api, pluginManager, externalPortService, bridgeOptions, bridgeConfig, config) {
|
|
23
|
+
this.api = api;
|
|
24
|
+
this.pluginManager = pluginManager;
|
|
25
|
+
this.externalPortService = externalPortService;
|
|
26
|
+
this.bridgeOptions = bridgeOptions;
|
|
27
|
+
this.bridgeConfig = bridgeConfig;
|
|
28
|
+
this.config = config;
|
|
29
|
+
this.storageService = new StorageService(this.bridgeOptions.cachedAccessoriesDir);
|
|
30
|
+
this.storageService.initSync();
|
|
31
|
+
// Server is "secure by default", meaning it creates a top-level Bridge accessory that
|
|
32
|
+
// will not allow unauthenticated requests. This matches the behavior of actual HomeKit
|
|
33
|
+
// accessories. However, you can set this to true to allow all requests without authentication,
|
|
34
|
+
// which can be useful for easy hacking. Note that this will expose all functions of your
|
|
35
|
+
// bridged accessories, like changing characteristics (i.e. flipping your lights on and off).
|
|
36
|
+
this.allowInsecureAccess = this.bridgeOptions.insecureAccess || false;
|
|
37
|
+
this.api.on("registerPlatformAccessories" /* InternalAPIEvent.REGISTER_PLATFORM_ACCESSORIES */, this.handleRegisterPlatformAccessories.bind(this));
|
|
38
|
+
this.api.on("updatePlatformAccessories" /* InternalAPIEvent.UPDATE_PLATFORM_ACCESSORIES */, this.handleUpdatePlatformAccessories.bind(this));
|
|
39
|
+
this.api.on("unregisterPlatformAccessories" /* InternalAPIEvent.UNREGISTER_PLATFORM_ACCESSORIES */, this.handleUnregisterPlatformAccessories.bind(this));
|
|
40
|
+
this.api.on("publishExternalAccessories" /* InternalAPIEvent.PUBLISH_EXTERNAL_ACCESSORIES */, this.handlePublishExternalAccessories.bind(this));
|
|
41
|
+
this.bridge = new Bridge(bridgeConfig.name, uuid.generate('HomeBridge'));
|
|
42
|
+
this.bridge.on("characteristic-warning" /* AccessoryEventTypes.CHARACTERISTIC_WARNING */, () => {
|
|
43
|
+
// We register characteristic warning handlers on every bridged accessory (to have a reference to the plugin).
|
|
44
|
+
// For Bridges the warnings will propagate to the main Bridge accessory, thus we need to silence them here.
|
|
45
|
+
// Otherwise, those would be printed twice (by us and HAP-NodeJS as it detects no handlers on the bridge).
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
// characteristic warning event has additional parameter originatorChain: string[] which is currently unused
|
|
49
|
+
static printCharacteristicWriteWarning(plugin, accessory, opts, warning) {
|
|
50
|
+
const wikiInfo = 'See https://homebridge.io/w/JtMGR for more info.';
|
|
51
|
+
switch (warning.type) {
|
|
52
|
+
case "slow-read" /* CharacteristicWarningType.SLOW_READ */:
|
|
53
|
+
case "slow-write" /* CharacteristicWarningType.SLOW_WRITE */:
|
|
54
|
+
if (!opts.ignoreSlow) {
|
|
55
|
+
log.info(getLogPrefix(plugin.getPluginIdentifier()), 'This plugin slows down Homebridge.', warning.message, wikiInfo);
|
|
56
|
+
}
|
|
57
|
+
break;
|
|
58
|
+
case "timeout-read" /* CharacteristicWarningType.TIMEOUT_READ */:
|
|
59
|
+
case "timeout-write" /* CharacteristicWarningType.TIMEOUT_WRITE */:
|
|
60
|
+
log.error(getLogPrefix(plugin.getPluginIdentifier()), 'This plugin slows down Homebridge.', warning.message, wikiInfo);
|
|
61
|
+
break;
|
|
62
|
+
case "warn-message" /* CharacteristicWarningType.WARN_MESSAGE */:
|
|
63
|
+
log.info(getLogPrefix(plugin.getPluginIdentifier()), `This plugin generated a warning from the characteristic '${warning.characteristic.displayName}':`, `${warning.message}.`, wikiInfo);
|
|
64
|
+
break;
|
|
65
|
+
case "error-message" /* CharacteristicWarningType.ERROR_MESSAGE */:
|
|
66
|
+
log.error(getLogPrefix(plugin.getPluginIdentifier()), `This plugin threw an error from the characteristic '${warning.characteristic.displayName}':`, `${warning.message}.`, wikiInfo);
|
|
67
|
+
break;
|
|
68
|
+
case "debug-message" /* CharacteristicWarningType.DEBUG_MESSAGE */:
|
|
69
|
+
log.debug(getLogPrefix(plugin.getPluginIdentifier()), `Characteristic '${warning.characteristic.displayName}':`, `${warning.message}.`, wikiInfo);
|
|
70
|
+
break;
|
|
71
|
+
default: // generic message for yet unknown types
|
|
72
|
+
log.info(getLogPrefix(plugin.getPluginIdentifier()), `This plugin generated a warning from the characteristic '${warning.characteristic.displayName}':`, `${warning.message}.`, wikiInfo);
|
|
73
|
+
break;
|
|
74
|
+
}
|
|
75
|
+
if (warning.stack) {
|
|
76
|
+
log.debug(getLogPrefix(plugin.getPluginIdentifier()), warning.stack);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
publishBridge() {
|
|
80
|
+
const bridgeConfig = this.bridgeConfig;
|
|
81
|
+
const info = this.bridge.getService(Service.AccessoryInformation);
|
|
82
|
+
info.setCharacteristic(Characteristic.Manufacturer, bridgeConfig.manufacturer || 'homebridge.io');
|
|
83
|
+
info.setCharacteristic(Characteristic.Model, bridgeConfig.model || 'homebridge');
|
|
84
|
+
info.setCharacteristic(Characteristic.SerialNumber, bridgeConfig.serialNumber || bridgeConfig.username);
|
|
85
|
+
info.setCharacteristic(Characteristic.FirmwareRevision, bridgeConfig.firmwareRevision || getVersion());
|
|
86
|
+
this.bridge.on("listening" /* AccessoryEventTypes.LISTENING */, (port) => {
|
|
87
|
+
log.success('Homebridge v%s (HAP v%s) (%s) is running on port %s.', getVersion(), HAPLibraryVersion(), bridgeConfig.name, port);
|
|
88
|
+
});
|
|
89
|
+
const publishInfo = {
|
|
90
|
+
username: bridgeConfig.username,
|
|
91
|
+
port: bridgeConfig.port,
|
|
92
|
+
pincode: bridgeConfig.pin,
|
|
93
|
+
category: 2 /* Categories.BRIDGE */,
|
|
94
|
+
bind: bridgeConfig.bind,
|
|
95
|
+
addIdentifyingMaterial: true,
|
|
96
|
+
advertiser: bridgeConfig.advertiser,
|
|
97
|
+
};
|
|
98
|
+
if (bridgeConfig.setupID && bridgeConfig.setupID.length === 4) {
|
|
99
|
+
publishInfo.setupID = bridgeConfig.setupID;
|
|
100
|
+
}
|
|
101
|
+
log.debug('Publishing bridge accessory (name: %s, publishInfo: %o).', this.bridge.displayName, BridgeService.strippingPinCode(publishInfo));
|
|
102
|
+
this.bridge.publish(publishInfo, this.allowInsecureAccess);
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* Attempt to load the cached accessories from disk.
|
|
106
|
+
*/
|
|
107
|
+
async loadCachedPlatformAccessoriesFromDisk() {
|
|
108
|
+
let cachedAccessories = null;
|
|
109
|
+
try {
|
|
110
|
+
cachedAccessories = await this.storageService.getItem(this.bridgeOptions.cachedAccessoriesItemName);
|
|
111
|
+
}
|
|
112
|
+
catch (error) {
|
|
113
|
+
log.error('Failed to load cached accessories from disk:', error.message);
|
|
114
|
+
if (error instanceof SyntaxError) {
|
|
115
|
+
// syntax error probably means invalid json / corrupted file; try and restore from backup
|
|
116
|
+
cachedAccessories = await this.restoreCachedAccessoriesBackup();
|
|
117
|
+
}
|
|
118
|
+
else {
|
|
119
|
+
log.error('Not restoring cached accessories - some accessories may be reset.');
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
if (cachedAccessories) {
|
|
123
|
+
log.info(`Loaded ${cachedAccessories.length} cached accessories from ${this.bridgeOptions.cachedAccessoriesItemName}.`);
|
|
124
|
+
this.cachedPlatformAccessories = cachedAccessories.map((serialized) => {
|
|
125
|
+
return PlatformAccessory.deserialize(serialized);
|
|
126
|
+
});
|
|
127
|
+
if (cachedAccessories.length) {
|
|
128
|
+
// create a backup of the cache file
|
|
129
|
+
await this.createCachedAccessoriesBackup();
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
this.cachedAccessoriesFileLoaded = true;
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
135
|
+
* Return the name of the backup cache file
|
|
136
|
+
*/
|
|
137
|
+
get backupCacheFileName() {
|
|
138
|
+
return `.${this.bridgeOptions.cachedAccessoriesItemName}.bak`;
|
|
139
|
+
}
|
|
140
|
+
/**
|
|
141
|
+
* Create a backup of the cached file
|
|
142
|
+
* This is used if we ever have trouble reading the main cache file
|
|
143
|
+
*/
|
|
144
|
+
async createCachedAccessoriesBackup() {
|
|
145
|
+
try {
|
|
146
|
+
await this.storageService.copyItem(this.bridgeOptions.cachedAccessoriesItemName, this.backupCacheFileName);
|
|
147
|
+
}
|
|
148
|
+
catch (error) {
|
|
149
|
+
log.warn(`Failed to create a backup of the ${this.bridgeOptions.cachedAccessoriesItemName} cached accessories file:`, error.message);
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
/**
|
|
153
|
+
* Restore a cached accessories backup
|
|
154
|
+
* This is used if the main cache file has a JSON syntax error / is corrupted
|
|
155
|
+
*/
|
|
156
|
+
async restoreCachedAccessoriesBackup() {
|
|
157
|
+
try {
|
|
158
|
+
const cachedAccessories = await this.storageService.getItem(this.backupCacheFileName);
|
|
159
|
+
if (cachedAccessories && cachedAccessories.length) {
|
|
160
|
+
log.warn(`Recovered ${cachedAccessories.length} accessories from ${this.bridgeOptions.cachedAccessoriesItemName} cache backup.`);
|
|
161
|
+
}
|
|
162
|
+
return cachedAccessories;
|
|
163
|
+
}
|
|
164
|
+
catch (error) {
|
|
165
|
+
return null;
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
restoreCachedPlatformAccessories() {
|
|
169
|
+
this.cachedPlatformAccessories = this.cachedPlatformAccessories.filter((accessory) => {
|
|
170
|
+
let plugin = this.pluginManager.getPlugin(accessory._associatedPlugin);
|
|
171
|
+
if (!plugin) { // a little explainer here. This section is basically here to resolve plugin name changes of dynamic platform plugins
|
|
172
|
+
try {
|
|
173
|
+
// resolve platform accessories by searching for plugins which registered a dynamic platform for the given name
|
|
174
|
+
plugin = this.pluginManager.getPluginByActiveDynamicPlatform(accessory._associatedPlatform);
|
|
175
|
+
if (plugin) { // if it's undefined the no plugin was found
|
|
176
|
+
// could improve on this by calculating the Levenshtein distance to only allow platform ownership changes
|
|
177
|
+
// when something like a typo happened. Are there other reasons the name could change?
|
|
178
|
+
// And how would we define the threshold?
|
|
179
|
+
log.info(`When searching for the associated plugin of the accessory '${accessory.displayName}' `
|
|
180
|
+
+ `it seems like the plugin name changed from '${accessory._associatedPlugin}' to '${plugin.getPluginIdentifier()}'. Plugin association is now being transformed!`);
|
|
181
|
+
accessory._associatedPlugin = plugin.getPluginIdentifier(); // update the associated plugin to the new one
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
catch (error) { // error is thrown if multiple plugins where found for the given platform name
|
|
185
|
+
log.info(`Could not find the associated plugin for the accessory '${accessory.displayName}'. `
|
|
186
|
+
+ `Tried to find the plugin by the platform name but ${error.message}`);
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
const platformPlugins = plugin && plugin.getActiveDynamicPlatform(accessory._associatedPlatform);
|
|
190
|
+
if (plugin) {
|
|
191
|
+
accessory._associatedHAPAccessory.on("characteristic-warning" /* AccessoryEventTypes.CHARACTERISTIC_WARNING */, BridgeService.printCharacteristicWriteWarning.bind(this, plugin, accessory._associatedHAPAccessory, {}));
|
|
192
|
+
}
|
|
193
|
+
if (!platformPlugins) {
|
|
194
|
+
log.info(`Failed to find plugin to handle accessory ${accessory._associatedHAPAccessory.displayName}`);
|
|
195
|
+
if (!this.bridgeOptions.keepOrphanedCachedAccessories) {
|
|
196
|
+
log.info(`Removing orphaned accessory ${accessory._associatedHAPAccessory.displayName}`);
|
|
197
|
+
return false; // filter it from the list
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
else {
|
|
201
|
+
// We set a placeholder for FirmwareRevision before configureAccessory is called so the plugin has the opportunity to override it.
|
|
202
|
+
accessory.getService(Service.AccessoryInformation)?.setCharacteristic(Characteristic.FirmwareRevision, '0');
|
|
203
|
+
platformPlugins.configureAccessory(accessory);
|
|
204
|
+
}
|
|
205
|
+
try {
|
|
206
|
+
this.bridge.addBridgedAccessory(accessory._associatedHAPAccessory);
|
|
207
|
+
}
|
|
208
|
+
catch (error) {
|
|
209
|
+
log.warn(`${accessory._associatedPlugin ? getLogPrefix(accessory._associatedPlugin) : ''} Could not restore cached accessory '${accessory._associatedHAPAccessory.displayName}':`, error.message);
|
|
210
|
+
return false; // filter it from the list
|
|
211
|
+
}
|
|
212
|
+
return true; // keep it in the list
|
|
213
|
+
});
|
|
214
|
+
}
|
|
215
|
+
/**
|
|
216
|
+
* Save the cached accessories back to disk.
|
|
217
|
+
*/
|
|
218
|
+
saveCachedPlatformAccessoriesOnDisk() {
|
|
219
|
+
try {
|
|
220
|
+
// only save the cache file back to disk if we have already attempted to load it
|
|
221
|
+
// this should prevent the cache being deleted should homebridge be shutdown before it has finished launching
|
|
222
|
+
if (this.cachedAccessoriesFileLoaded) {
|
|
223
|
+
const serializedAccessories = this.cachedPlatformAccessories.map(accessory => PlatformAccessory.serialize(accessory));
|
|
224
|
+
this.storageService.setItemSync(this.bridgeOptions.cachedAccessoriesItemName, serializedAccessories);
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
catch (error) {
|
|
228
|
+
log.error('Failed to save cached accessories to disk:', error.message);
|
|
229
|
+
log.error('Your accessories will not persist between restarts until this issue is resolved.');
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
handleRegisterPlatformAccessories(accessories) {
|
|
233
|
+
const hapAccessories = accessories.map((accessory) => {
|
|
234
|
+
this.cachedPlatformAccessories.push(accessory);
|
|
235
|
+
const plugin = this.pluginManager.getPlugin(accessory._associatedPlugin);
|
|
236
|
+
if (plugin) {
|
|
237
|
+
const platforms = plugin.getActiveDynamicPlatform(accessory._associatedPlatform);
|
|
238
|
+
if (!platforms) {
|
|
239
|
+
log.warn('The plugin \'%s\' registered a new accessory for the platform \'%s\'. The platform couldn\'t be found though!', accessory._associatedPlugin, accessory._associatedPlatform);
|
|
240
|
+
}
|
|
241
|
+
accessory._associatedHAPAccessory.on("characteristic-warning" /* AccessoryEventTypes.CHARACTERISTIC_WARNING */, BridgeService.printCharacteristicWriteWarning.bind(this, plugin, accessory._associatedHAPAccessory, {}));
|
|
242
|
+
}
|
|
243
|
+
else {
|
|
244
|
+
log.warn('A platform configured a new accessory under the plugin name \'%s\'. However no loaded plugin could be found for the name!', accessory._associatedPlugin);
|
|
245
|
+
}
|
|
246
|
+
return accessory._associatedHAPAccessory;
|
|
247
|
+
});
|
|
248
|
+
this.bridge.addBridgedAccessories(hapAccessories);
|
|
249
|
+
this.saveCachedPlatformAccessoriesOnDisk();
|
|
250
|
+
}
|
|
251
|
+
handleUpdatePlatformAccessories(accessories) {
|
|
252
|
+
if (!Array.isArray(accessories)) {
|
|
253
|
+
// This could be quite destructive if a non-array is passed in, so we'll just ignore it.
|
|
254
|
+
return;
|
|
255
|
+
}
|
|
256
|
+
const nonUpdatedPlugins = this.cachedPlatformAccessories.filter(cachedPlatformAccessory => (accessories.find(accessory => accessory.UUID === cachedPlatformAccessory._associatedHAPAccessory.UUID) === undefined));
|
|
257
|
+
this.cachedPlatformAccessories = [...nonUpdatedPlugins, ...accessories];
|
|
258
|
+
// Update persisted accessories
|
|
259
|
+
this.saveCachedPlatformAccessoriesOnDisk();
|
|
260
|
+
}
|
|
261
|
+
handleUnregisterPlatformAccessories(accessories) {
|
|
262
|
+
const hapAccessories = accessories.map((accessory) => {
|
|
263
|
+
const index = this.cachedPlatformAccessories.indexOf(accessory);
|
|
264
|
+
if (index >= 0) {
|
|
265
|
+
this.cachedPlatformAccessories.splice(index, 1);
|
|
266
|
+
}
|
|
267
|
+
return accessory._associatedHAPAccessory;
|
|
268
|
+
});
|
|
269
|
+
this.bridge.removeBridgedAccessories(hapAccessories);
|
|
270
|
+
this.saveCachedPlatformAccessoriesOnDisk();
|
|
271
|
+
}
|
|
272
|
+
async handlePublishExternalAccessories(accessories) {
|
|
273
|
+
const accessoryPin = this.bridgeConfig.pin;
|
|
274
|
+
for (const accessory of accessories) {
|
|
275
|
+
const hapAccessory = accessory._associatedHAPAccessory;
|
|
276
|
+
const advertiseAddress = generate(hapAccessory.UUID);
|
|
277
|
+
// get external port allocation
|
|
278
|
+
const accessoryPort = await this.externalPortService.requestPort(advertiseAddress);
|
|
279
|
+
if (this.publishedExternalAccessories.has(advertiseAddress)) {
|
|
280
|
+
throw new Error(`Accessory ${hapAccessory.displayName} experienced an address collision.`);
|
|
281
|
+
}
|
|
282
|
+
else {
|
|
283
|
+
this.publishedExternalAccessories.set(advertiseAddress, accessory);
|
|
284
|
+
}
|
|
285
|
+
const plugin = this.pluginManager.getPlugin(accessory._associatedPlugin);
|
|
286
|
+
if (plugin) {
|
|
287
|
+
hapAccessory.on("characteristic-warning" /* AccessoryEventTypes.CHARACTERISTIC_WARNING */, BridgeService.printCharacteristicWriteWarning.bind(this, plugin, hapAccessory, { ignoreSlow: true }));
|
|
288
|
+
}
|
|
289
|
+
else if (PluginManager.isQualifiedPluginIdentifier(accessory._associatedPlugin)) {
|
|
290
|
+
// we did already complain in api.ts if it wasn't a qualified name
|
|
291
|
+
log.warn('A platform configured a external accessory under the plugin name \'%s\'. However no loaded plugin could be found for the name!', accessory._associatedPlugin);
|
|
292
|
+
}
|
|
293
|
+
hapAccessory.on("listening" /* AccessoryEventTypes.LISTENING */, (port) => {
|
|
294
|
+
log.success('%s is running on port %s.', hapAccessory.displayName, port);
|
|
295
|
+
log.info('Please add [%s] manually in Home app. Setup Code: %s', hapAccessory.displayName, accessoryPin);
|
|
296
|
+
});
|
|
297
|
+
const publishInfo = {
|
|
298
|
+
username: advertiseAddress,
|
|
299
|
+
pincode: accessoryPin,
|
|
300
|
+
category: accessory.category,
|
|
301
|
+
port: accessoryPort,
|
|
302
|
+
bind: this.bridgeConfig.bind,
|
|
303
|
+
addIdentifyingMaterial: true,
|
|
304
|
+
advertiser: this.bridgeConfig.advertiser,
|
|
305
|
+
};
|
|
306
|
+
log.debug('Publishing external accessory (name: %s, publishInfo: %o).', hapAccessory.displayName, BridgeService.strippingPinCode(publishInfo));
|
|
307
|
+
hapAccessory.publish(publishInfo, this.allowInsecureAccess);
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
createHAPAccessory(plugin, accessoryInstance, displayName, accessoryType, uuidBase) {
|
|
311
|
+
const services = (accessoryInstance.getServices() || [])
|
|
312
|
+
.filter(service => !!service); // filter out undefined values; a common mistake
|
|
313
|
+
const controllers = ((accessoryInstance.getControllers && accessoryInstance.getControllers()) || [])
|
|
314
|
+
.filter(controller => !!controller);
|
|
315
|
+
if (services.length === 0 && controllers.length === 0) { // check that we only add valid accessory with at least one service
|
|
316
|
+
return undefined;
|
|
317
|
+
}
|
|
318
|
+
// The returned "services" for this accessory are simply an array of new-API-style
|
|
319
|
+
// Service instances which we can add to a created HAP-NodeJS Accessory directly.
|
|
320
|
+
const accessoryUUID = uuid.generate(`${accessoryType}:${uuidBase || displayName}`);
|
|
321
|
+
const accessory = new Accessory(displayName, accessoryUUID);
|
|
322
|
+
// listen for the identify event if the accessory instance has defined an identify() method
|
|
323
|
+
if (accessoryInstance.identify) {
|
|
324
|
+
accessory.on("identify" /* AccessoryEventTypes.IDENTIFY */, (paired, callback) => {
|
|
325
|
+
// @ts-expect-error: empty callback for backwards compatibility
|
|
326
|
+
accessoryInstance.identify(() => { });
|
|
327
|
+
callback();
|
|
328
|
+
});
|
|
329
|
+
}
|
|
330
|
+
const informationService = accessory.getService(Service.AccessoryInformation);
|
|
331
|
+
services.forEach((service) => {
|
|
332
|
+
// if you returned an AccessoryInformation service, merge its values with ours
|
|
333
|
+
if (service instanceof Service.AccessoryInformation) {
|
|
334
|
+
service.setCharacteristic(Characteristic.Name, displayName); // ensure display name is set
|
|
335
|
+
// ensure the plugin has not hooked already some listeners (some weird ones do).
|
|
336
|
+
// Otherwise, they would override our identify listener registered by the HAP-NodeJS accessory
|
|
337
|
+
service.getCharacteristic(Characteristic.Identify).removeAllListeners("set" /* CharacteristicEventTypes.SET */);
|
|
338
|
+
// pull out any values and listeners (get and set) you may have defined
|
|
339
|
+
informationService.replaceCharacteristicsFromService(service);
|
|
340
|
+
}
|
|
341
|
+
else {
|
|
342
|
+
accessory.addService(service);
|
|
343
|
+
}
|
|
344
|
+
});
|
|
345
|
+
accessory.on("characteristic-warning" /* AccessoryEventTypes.CHARACTERISTIC_WARNING */, BridgeService.printCharacteristicWriteWarning.bind(this, plugin, accessory, {}));
|
|
346
|
+
controllers.forEach((controller) => {
|
|
347
|
+
accessory.configureController(controller);
|
|
348
|
+
});
|
|
349
|
+
return accessory;
|
|
350
|
+
}
|
|
351
|
+
async loadPlatformAccessories(plugin, platformInstance, platformType, logger) {
|
|
352
|
+
// Plugin 1.0, load accessories
|
|
353
|
+
return new Promise((resolve) => {
|
|
354
|
+
// warn the user if the static platform is blocking the startup of Homebridge for to long
|
|
355
|
+
const loadDelayWarningInterval = setInterval(() => {
|
|
356
|
+
log.warn(getLogPrefix(plugin.getPluginIdentifier()), 'This plugin is taking long time to load and preventing Homebridge from starting. See https://homebridge.io/w/JtMGR for more info.');
|
|
357
|
+
}, 20000);
|
|
358
|
+
platformInstance.accessories(once((accessories) => {
|
|
359
|
+
// clear the load delay warning interval
|
|
360
|
+
clearInterval(loadDelayWarningInterval);
|
|
361
|
+
// loop through accessories adding them to the list and registering them
|
|
362
|
+
accessories.forEach((accessoryInstance, index) => {
|
|
363
|
+
// @ts-expect-error: assume this property was set
|
|
364
|
+
const accessoryName = accessoryInstance.name;
|
|
365
|
+
// @ts-expect-error: optional base uuid
|
|
366
|
+
const uuidBase = accessoryInstance.uuid_base;
|
|
367
|
+
log.info('Initializing platform accessory \'%s\'...', accessoryName);
|
|
368
|
+
const accessory = this.createHAPAccessory(plugin, accessoryInstance, accessoryName, platformType, uuidBase);
|
|
369
|
+
if (accessory) {
|
|
370
|
+
this.bridge.addBridgedAccessory(accessory);
|
|
371
|
+
}
|
|
372
|
+
else {
|
|
373
|
+
logger('Platform %s returned an accessory at index %d with an empty set of services. Won\'t adding it to the bridge!', platformType, index);
|
|
374
|
+
}
|
|
375
|
+
});
|
|
376
|
+
resolve();
|
|
377
|
+
}));
|
|
378
|
+
});
|
|
379
|
+
}
|
|
380
|
+
teardown() {
|
|
381
|
+
this.bridge.unpublish();
|
|
382
|
+
for (const accessory of this.publishedExternalAccessories.values()) {
|
|
383
|
+
accessory._associatedHAPAccessory.unpublish();
|
|
384
|
+
}
|
|
385
|
+
this.saveCachedPlatformAccessoriesOnDisk();
|
|
386
|
+
this.api.signalShutdown();
|
|
387
|
+
}
|
|
388
|
+
static strippingPinCode(publishInfo) {
|
|
389
|
+
const info = {
|
|
390
|
+
...publishInfo,
|
|
391
|
+
};
|
|
392
|
+
info.pincode = '***-**-***';
|
|
393
|
+
return info;
|
|
394
|
+
}
|
|
395
|
+
}
|
|
396
|
+
//# sourceMappingURL=bridgeService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bridgeService.js","sourceRoot":"","sources":["../src/bridgeService.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import type { MacAddress } from 'hap-nodejs';
|
|
2
|
+
import type { ChildProcessLoadEventData, ChildProcessPortAllocatedEventData } from './childBridgeService.js';
|
|
3
|
+
import { ChildProcessMessageEventType } from './childBridgeService.js';
|
|
4
|
+
import 'source-map-support/register.js';
|
|
5
|
+
export declare class ChildBridgeFork {
|
|
6
|
+
private bridgeService;
|
|
7
|
+
private api;
|
|
8
|
+
private pluginManager;
|
|
9
|
+
private externalPortService;
|
|
10
|
+
private type;
|
|
11
|
+
private plugin;
|
|
12
|
+
private identifier;
|
|
13
|
+
private pluginConfig;
|
|
14
|
+
private bridgeConfig;
|
|
15
|
+
private bridgeOptions;
|
|
16
|
+
private homebridgeConfig;
|
|
17
|
+
private portRequestCallback;
|
|
18
|
+
constructor();
|
|
19
|
+
sendMessage<T = unknown>(type: ChildProcessMessageEventType, data?: T): void;
|
|
20
|
+
loadPlugin(data: ChildProcessLoadEventData): Promise<void>;
|
|
21
|
+
startBridge(): Promise<void>;
|
|
22
|
+
/**
|
|
23
|
+
* Request the next available external port from the parent process
|
|
24
|
+
* @param username
|
|
25
|
+
*/
|
|
26
|
+
requestExternalPort(username: MacAddress): Promise<number | undefined>;
|
|
27
|
+
/**
|
|
28
|
+
* Handles the port allocation response message from the parent process
|
|
29
|
+
* @param data
|
|
30
|
+
*/
|
|
31
|
+
handleExternalResponse(data: ChildProcessPortAllocatedEventData): void;
|
|
32
|
+
/**
|
|
33
|
+
* Sends the current pairing status of the child bridge to the parent process
|
|
34
|
+
*/
|
|
35
|
+
sendPairedStatusEvent(): void;
|
|
36
|
+
shutdown(): void;
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=childBridgeFork.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"childBridgeFork.d.ts","sourceRoot":"","sources":["../src/childBridgeFork.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,YAAY,CAAA;AAU5C,OAAO,KAAK,EAEV,yBAAyB,EAGzB,kCAAkC,EAEnC,MAAM,yBAAyB,CAAA;AAShC,OAAO,EAAE,4BAA4B,EAAE,MAAM,yBAAyB,CAAA;AAMtE,OAAO,gCAAgC,CAAA;AAQvC,qBAAa,eAAe;IAC1B,OAAO,CAAC,aAAa,CAAgB;IACrC,OAAO,CAAC,GAAG,CAAgB;IAC3B,OAAO,CAAC,aAAa,CAAgB;IACrC,OAAO,CAAC,mBAAmB,CAAiC;IAE5D,OAAO,CAAC,IAAI,CAAa;IACzB,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,YAAY,CAA0C;IAC9D,OAAO,CAAC,YAAY,CAAsB;IAC1C,OAAO,CAAC,aAAa,CAAgB;IACrC,OAAO,CAAC,gBAAgB,CAAmB;IAE3C,OAAO,CAAC,mBAAmB,CAAiE;;IAO5F,WAAW,CAAC,CAAC,GAAG,OAAO,EAAE,IAAI,EAAE,4BAA4B,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,IAAI;IAStE,UAAU,CAAC,IAAI,EAAE,yBAAyB,GAAG,OAAO,CAAC,IAAI,CAAC;IAoD1D,WAAW,IAAI,OAAO,CAAC,IAAI,CAAC;IA8ElC;;;OAGG;IACU,mBAAmB,CAAC,QAAQ,EAAE,UAAU,GAAG,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC;IAoBnF;;;OAGG;IACI,sBAAsB,CAAC,IAAI,EAAE,kCAAkC,GAAG,IAAI;IAO7E;;OAEG;IACI,qBAAqB;IAO5B,QAAQ,IAAI,IAAI;CAGjB"}
|