UNPKG

@homebridge-plugins/homebridge-cloudflared-tunnel

Version:

The Cloudflared Tunnel plugin allows you to run a Cloudflare-Tunnel for exposing your homebridge instance for remote access.

69 lines 3.18 kB
import type { API, DynamicPlatformPlugin, HAP, Logging, PlatformAccessory } from 'homebridge'; import type { CloudflaredTunnelPlatformConfig } from './settings.js'; /** * HomebridgePlatform * This class is the main constructor for your plugin, this is where you should * parse the user config and discover/register accessories with Homebridge. */ export declare class CloudflaredTunnelPlatform implements DynamicPlatformPlugin { accessories: PlatformAccessory[]; readonly api: API; readonly log: Logging; protected readonly hap: HAP; config: CloudflaredTunnelPlatformConfig; platformConfig: CloudflaredTunnelPlatformConfig; platformLogging: CloudflaredTunnelPlatformConfig['logging']; platformRefreshRate: CloudflaredTunnelPlatformConfig['refreshRate']; platformUpdateRate: CloudflaredTunnelPlatformConfig['updateRate']; platformPushRate: CloudflaredTunnelPlatformConfig['pushRate']; debugMode: boolean; version: string; constructor(log: Logging, config: CloudflaredTunnelPlatformConfig, api: API); /** * This function is invoked when homebridge restores cached accessories from disk at startup. * It should be used to setup event handlers for characteristics and update respective values. */ configureAccessory(accessory: PlatformAccessory): void; /** * Verify the config passed to the plugin is valid */ verifyConfig(): Promise<void>; existingTunnel(): Promise<void>; createTunnel(): Promise<void>; getPlatformLogSettings(): Promise<void>; getPlatformRateSettings(): Promise<void>; getPlatformConfigSettings(): Promise<void>; /** * Asynchronously retrieves the version of the plugin from the package.json file. * * This method reads the package.json file located in the parent directory, * parses its content to extract the version, and logs the version using the debug logger. * The extracted version is then assigned to the `version` property of the class. * * @returns {Promise<void>} A promise that resolves when the version has been retrieved and logged. */ getVersion(): Promise<void>; /** * Validate and clean a string value for a Name Characteristic. * @param displayName - The display name of the accessory. * @param name - The name of the characteristic. * @param value - The value to be validated and cleaned. * @returns The cleaned string value. */ validateAndCleanDisplayName(displayName: string, name: string, value: string): Promise<string>; /** * If device level logging is turned on, log to log.warn * Otherwise send debug logs to log.debug */ infoLog(...log: any[]): Promise<void>; successLog(...log: any[]): Promise<void>; debugSuccessLog(...log: any[]): Promise<void>; warnLog(...log: any[]): Promise<void>; debugWarnLog(...log: any[]): Promise<void>; errorLog(...log: any[]): Promise<void>; debugErrorLog(...log: any[]): Promise<void>; debugLog(...log: any[]): Promise<void>; loggingIsDebug(): Promise<boolean>; enablingPlatformLogging(): Promise<boolean>; } //# sourceMappingURL=platform.d.ts.map