homebridge
Version:
HomeKit support for the impatient
129 lines • 5.42 kB
TypeScript
import type { CharacteristicWarning, InterfaceName, IPAddress, MacAddress, MDNSAdvertiser } from '@homebridge/hap-nodejs';
import type { AccessoryIdentifier, AccessoryName, AccessoryPlugin, HomebridgeAPI, PlatformIdentifier, PlatformName, PluginIdentifier, StaticPlatformPlugin } from './api.js';
import type { ExternalPortsConfiguration, ExternalPortService } from './externalPortService.js';
import type { Logging } from './logger.js';
import type { MatterConfig } from './matter/index.js';
import type { Plugin } from './plugin.js';
import type { HomebridgeOptions } from './server.js';
import { Accessory, Bridge } from '@homebridge/hap-nodejs';
import { PlatformAccessory } from './platformAccessory.js';
import { PluginManager } from './pluginManager.js';
export declare const DEFAULT_BRIDGE_DEFAULTS: {
readonly vendorName: "Homebridge";
readonly manufacturer: "homebridge.io";
readonly model: "homebridge";
};
export interface BridgeConfiguration {
name: string;
username: MacAddress;
pin: string;
advertiser?: MDNSAdvertiser;
port?: number;
bind?: (InterfaceName | IPAddress) | (InterfaceName | IPAddress)[];
/** 4-character HomeKit setup ID (alphanumeric, e.g. "ABCD"). Validated at runtime. */
setupID?: string;
manufacturer?: string;
model?: string;
disableIpc?: boolean;
firmwareRevision?: string;
serialNumber?: string;
debugModeEnabled?: boolean;
/**
* When `false`, this bridge will not publish HAP. Useful for Matter-only
* bridges where the user does not want to expose a HomeKit bridge accessory.
* Default: `true` (HAP is published).
*
* Note: at least one of `hap` or `matter` must be enabled per bridge —
* setting `hap: false` without a `matter` configuration is rejected.
*/
hap?: boolean;
matter?: MatterConfig;
env?: {
DEBUG?: string;
NODE_OPTIONS?: string;
};
}
export interface AccessoryConfig extends Record<string, any> {
accessory: AccessoryName | AccessoryIdentifier;
name: string;
uuid_base?: string;
_bridge?: BridgeConfiguration;
}
export interface PlatformConfig extends Record<string, any> {
platform: PlatformName | PlatformIdentifier;
name?: string;
_bridge?: BridgeConfiguration;
}
export interface HomebridgeConfig {
bridge: BridgeConfiguration;
/**
* @deprecated
*/
mdns?: any;
accessories: AccessoryConfig[];
platforms: PlatformConfig[];
plugins?: PluginIdentifier[];
/**
* Array of disabled plugins.
* Unlike the plugins[] config which prevents plugins from being initialized at all, disabled plugins still have their alias loaded, so
* we can match config blocks of disabled plugins and show an appropriate message in the logs.
*/
disabledPlugins?: PluginIdentifier[];
ports?: ExternalPortsConfiguration;
matterPorts?: ExternalPortsConfiguration;
}
export interface BridgeOptions extends HomebridgeOptions {
cachedAccessoriesDir: string;
cachedAccessoriesItemName: string;
}
export interface CharacteristicWarningOpts {
ignoreSlow?: boolean;
}
export declare class BridgeService {
private api;
private pluginManager;
private externalPortService;
private bridgeOptions;
private bridgeConfig;
bridge: Bridge;
private storageService;
private readonly allowInsecureAccess;
private cachedPlatformAccessories;
private cachedAccessoriesFileLoaded;
private readonly publishedExternalAccessories;
constructor(api: HomebridgeAPI, pluginManager: PluginManager, externalPortService: ExternalPortService, bridgeOptions: BridgeOptions, bridgeConfig: BridgeConfiguration);
static printCharacteristicWriteWarning(plugin: Plugin, accessory: Accessory, opts: CharacteristicWarningOpts, warning: CharacteristicWarning): void;
publishBridge(): void;
/**
* Attempt to load the cached accessories from disk.
*/
loadCachedPlatformAccessoriesFromDisk(): Promise<void>;
/**
* Return the name of the backup cache file
*/
private get backupCacheFileName();
/**
* Create a backup of the cached file
* This is used if we ever have trouble reading the main cache file
*/
private createCachedAccessoriesBackup;
/**
* Restore a cached accessories backup
* This is used if the main cache file has a JSON syntax error / is corrupted
*/
private restoreCachedAccessoriesBackup;
restoreCachedPlatformAccessories(): void;
/**
* Save the cached accessories back to disk.
*/
saveCachedPlatformAccessoriesOnDisk(): void;
handleRegisterPlatformAccessories(accessories: PlatformAccessory[]): void;
handleUpdatePlatformAccessories(accessories: PlatformAccessory[]): void;
handleUnregisterPlatformAccessories(accessories: PlatformAccessory[]): void;
handlePublishExternalAccessories(accessories: PlatformAccessory[]): Promise<void>;
createHAPAccessory(plugin: Plugin, accessoryInstance: AccessoryPlugin, displayName: string, accessoryType: AccessoryName | AccessoryIdentifier, uuidBase?: string): Accessory | undefined;
loadPlatformAccessories(plugin: Plugin, platformInstance: StaticPlatformPlugin, platformType: PlatformName | PlatformIdentifier, logger: Logging): Promise<void>;
teardown(): void;
private static strippingPinCode;
}
//# sourceMappingURL=bridgeService.d.ts.map