UNPKG

zigbee-herdsman-converters

Version:

Collection of device converters to be used with zigbee-herdsman

437 lines • 14.6 kB
import type { Models as ZHModels } from "zigbee-herdsman"; import type { Header as ZHZclHeader } from "zigbee-herdsman/dist/zspec/zcl"; import type { FrameControl } from "zigbee-herdsman/dist/zspec/zcl/definition/tstype"; import type * as exposes from "./exposes"; export interface Logger { debug: (messageOrLambda: string | (() => string), namespace: string) => void; info: (messageOrLambda: string | (() => string), namespace: string) => void; warning: (messageOrLambda: string | (() => string), namespace: string) => void; error: (messageOrLambda: string | (() => string), namespace: string) => void; } export type Range = [number, number]; export interface KeyValue { [s: string]: unknown; } export interface KeyValueString { [s: string]: string; } export interface KeyValueNumberString { [s: number]: string; } export interface KeyValueAny { [s: string]: any; } export type Publish = (payload: KeyValue) => void; export type OnEventType = "start" | "stop" | "message" | "deviceJoined" | "deviceInterview" | "deviceAnnounce" | "deviceNetworkAddressChanged" | "deviceOptionsChanged"; export type Access = 0b001 | 0b010 | 0b100 | 0b011 | 0b101 | 0b111; export type Expose = exposes.Numeric | exposes.Binary | exposes.Enum | exposes.Composite | exposes.List | exposes.Light | exposes.Switch | exposes.Lock | exposes.Cover | exposes.Climate | exposes.Fan | exposes.Text; export type Option = exposes.Numeric | exposes.Binary | exposes.Composite | exposes.Enum | exposes.List | exposes.Text; export interface Fingerprint { applicationVersion?: number; manufacturerID?: number; type?: "EndDevice" | "Router"; dateCode?: string; hardwareVersion?: number; manufacturerName?: string; modelID?: string; powerSource?: "Battery" | "Mains (single phase)"; softwareBuildID?: string; stackVersion?: number; zclVersion?: number; ieeeAddr?: RegExp; endpoints?: { ID?: number; profileID?: number; deviceID?: number; inputClusters?: number[]; outputClusters?: number[]; }[]; priority?: number; } export type WhiteLabel = { vendor: string; model: string; description: string; fingerprint: Fingerprint[]; } | { vendor: string; model: string; description?: string; }; export interface MockProperty { property: string; value: KeyValue | string; } export interface DiscoveryEntry { mockProperties: MockProperty[]; type: string; object_id: string; discovery_payload: KeyValue; } export type BatteryLinearVoltage = { min: number; max: number; vOffset?: number; }; export type BatteryNonLinearVoltage = "3V_2100" | "3V_1500_2800"; export interface DefinitionMeta { separateWhite?: boolean; /** * Enables the multi endpoint functionality in e.g. `fromZigbee.on_off`, example: normally this converter would return `{"state": "OFF"}`, when * multiEndpoint is enabled the `endpoint` method of the device definition will be called to determine the endpoint name which is then used as ke * y e.g. `{"state_left": "OFF"}`. Only needed when device sends the same attribute from multiple endpoints. * * @defaultValue false */ multiEndpoint?: boolean; /** * enforce a certain endpoint for an attribute, e.g. `{"power": 4}` see `utils.enforceEndpoint()` */ multiEndpointEnforce?: { [s: string]: number; }; /** * Attributes to not suffix with the endpoint name */ multiEndpointSkip?: string[]; publishDuplicateTransaction?: boolean; tuyaDatapoints?: Tuya.MetaTuyaDataPoints; /** * used by toZigbee converters to disable the default response of some devices as they don't provide one. * * @defaultValue false */ disableDefaultResponse?: boolean | ((entity: Zh.Endpoint) => boolean); /** * Amount of pincodes the lock can handle */ pinCodeCount?: number; /** * Set to true for cover controls that report position=100 as open. * * @defaultValue false */ coverInverted?: boolean; /** * timeout for commands to this device used in toZigbee. * * @defaultValue 10000 */ timeout?: number; tuyaSendCommand?: "sendData" | "dataRequest"; /** * Set cover state based on tilt */ coverStateFromTilt?: boolean; /** * see e.g. HT-08 definition */ thermostat?: { weeklyScheduleMaxTransitions?: number; weeklyScheduleSupportedModes?: number[]; weeklyScheduleFirstDayDpId?: number; weeklyScheduleConversion?: string; /** * Do not map `pIHeatingDemand`/`pICoolingDemand` from 0-255 -\> 0-100, see `fromZigbee.thermostat` * * @defaultValue false */ dontMapPIHeatingDemand?: boolean; }; battery?: { /** * convert voltage to percentage using specified option. See `utils.batteryVoltageToPercentage()` * * @example '3V_2100' * @defaultValue null */ voltageToPercentage?: BatteryNonLinearVoltage | BatteryLinearVoltage; /** * Prevents batteryPercentageRemaining from being divided (ZCL 200=100%, but some report 100=100%) * * @defaultValue false */ dontDividePercentage?: boolean; }; /** * see `toZigbee.light_color` * * @defaultValue false */ applyRedFix?: boolean; /** * Indicates light turns off when brightness 1 is set * * @defaultValue false */ turnsOffAtBrightness1?: boolean; tuyaThermostatPreset?: { [s: number]: string; }; /** Tuya specific thermostat options */ tuyaThermostatSystemMode?: { [s: number]: string; }; /** Tuya specific thermostat options */ tuyaThermostatPresetToSystemMode?: { [s: number]: string; }; /** * see `toZigbee.light_color` * * @defaultValue true */ supportsEnhancedHue?: boolean | ((entity: Zh.Endpoint) => boolean); /** * Prevents some converters adding the `action_group` to the payload. * * @defaultValue false */ disableActionGroup?: boolean; /** * see `toZigbee.light_color`, usually set by `light_*` extends via options. * * @defaultValue true */ supportsHueAndSaturation?: boolean; /** * Do not set `position` or `tilt` to target value on /set. See `toZigbee.cover_position_tilt` * * @defaultValue false */ coverPositionTiltDisableReport?: boolean; /** * Override the Home Assistant discovery payload using a custom function. */ overrideHaDiscoveryPayload?(payload: KeyValueAny): void; /** * Never use a transition when transitioning to off (even when specified) */ noOffTransitionWhenOff?: boolean | ((entity: Zh.Endpoint) => boolean); } export type Configure = (device: Zh.Device, coordinatorEndpoint: Zh.Endpoint, definition: Definition) => Promise<void> | void; export interface OnEventMeta { deviceExposesChanged: () => void; } export type OnEvent = (type: OnEventType, data: OnEventData, device: Zh.Device, settings: KeyValue, state: KeyValue, meta?: OnEventMeta) => Promise<void> | void; export interface ModernExtend { fromZigbee?: Definition["fromZigbee"]; toZigbee?: Definition["toZigbee"]; exposes?: (Expose | DefinitionExposesFunction)[]; configure?: Definition["configure"][]; meta?: Definition["meta"]; ota?: Definition["ota"]; onEvent?: Definition["onEvent"][]; endpoint?: Definition["endpoint"]; isModernExtend: true; } export interface OnEventData { endpoint?: Zh.Endpoint; meta?: { zclTransactionSequenceNumber?: number; manufacturerCode?: number; }; cluster?: string; type?: string; data?: KeyValueAny; } export type DefinitionExposesFunction = (device: Zh.Device | undefined, options: KeyValue | undefined) => Expose[]; export type DefinitionExposes = Expose[] | DefinitionExposesFunction; type DefinitionMatcher = { zigbeeModel: string[]; fingerprint?: Fingerprint[]; } | { zigbeeModel?: string[]; fingerprint: Fingerprint[]; }; type DefinitionBase = { model: string; vendor: string; description: string; whiteLabel?: WhiteLabel[]; generated?: true; externalConverterName?: string; }; type DefinitionConfig = { endpoint?: (device: Zh.Device) => { [s: string]: number; }; configure?: Configure; options?: Option[]; meta?: DefinitionMeta; onEvent?: OnEvent; ota?: boolean | Ota.ExtraMetas; }; type DefinitionFeatures = { fromZigbee: Fz.Converter[]; toZigbee: Tz.Converter[]; exposes: DefinitionExposes; }; export type Definition = DefinitionMatcher & DefinitionBase & DefinitionConfig & DefinitionFeatures; export type DefinitionWithExtend = DefinitionMatcher & DefinitionBase & DefinitionConfig & (({ extend: ModernExtend[]; } & Partial<DefinitionFeatures>) | DefinitionFeatures); export type ExternalDefinitionWithExtend = DefinitionWithExtend & { externalConverterName: string; }; export declare namespace Fz { interface Message { data: any; endpoint: Zh.Endpoint; device: Zh.Device; meta: { zclTransactionSequenceNumber?: number; manufacturerCode?: number; frameControl?: FrameControl; }; groupID: number; type: string; cluster: string | number; linkquality: number; } interface Meta { state: KeyValue; device: Zh.Device; deviceExposesChanged: () => void; } interface Converter { cluster: string | number; type: string[] | string; options?: Option[] | ((definition: Definition) => Option[]); convert: (model: Definition, msg: Message, publish: Publish, options: KeyValue, meta: Fz.Meta) => KeyValueAny | void | Promise<void>; } } export declare namespace Tz { interface Meta { message: KeyValue; device: Zh.Device | undefined; mapped: Definition | Definition[]; options: KeyValue; state: KeyValue; endpoint_name: string | undefined; membersState?: { [s: string]: KeyValue; }; publish: Publish; } type ConvertSetResult = { state?: KeyValue; membersState?: { [s: string]: KeyValue; }; } | void; interface Converter { key?: string[]; options?: Option[] | ((definition: Definition) => Option[]); endpoints?: string[]; convertSet?: (entity: Zh.Endpoint | Zh.Group, key: string, value: unknown, meta: Tz.Meta) => Promise<ConvertSetResult> | ConvertSetResult; convertGet?: (entity: Zh.Endpoint | Zh.Group, key: string, meta: Tz.Meta) => Promise<void>; } } export declare namespace Zh { type Endpoint = ZHModels.Endpoint; type Device = ZHModels.Device; type Group = ZHModels.Group; type ZclHeader = ZHZclHeader; } export declare namespace Tuya { interface DpValue { dp: number; datatype: number; data: Buffer | number[]; } interface ValueConverterSingle { to?: (value: any, meta?: Tz.Meta) => unknown; from?: (value: any, meta?: Fz.Meta, options?: KeyValue, publish?: Publish, msg?: Fz.Message) => number | string | boolean | KeyValue | null; } interface MetaTuyaDataPointsMeta { skip?: (meta: Tz.Meta) => boolean; optimistic?: boolean; } type MetaTuyaDataPointsSingle = [number, string, ValueConverterSingle, MetaTuyaDataPointsMeta?]; type MetaTuyaDataPoints = MetaTuyaDataPointsSingle[]; } export declare namespace Ota { type OnProgress = (progress: number, remaining?: number) => void; interface Settings { dataDir: string; overrideIndexLocation?: string; imageBlockResponseDelay?: number; defaultMaximumDataSize?: number; } interface UpdateAvailableResult { available: boolean; currentFileVersion: number; otaFileVersion: number; } interface Version { imageType: number; manufacturerCode: number; fileVersion: number; } interface ImageHeader { otaUpgradeFileIdentifier: Buffer; otaHeaderVersion: number; otaHeaderLength: number; otaHeaderFieldControl: number; manufacturerCode: number; imageType: number; fileVersion: number; zigbeeStackVersion: number; otaHeaderString: string; totalImageSize: number; securityCredentialVersion?: number; upgradeFileDestination?: Buffer; minimumHardwareVersion?: number; maximumHardwareVersion?: number; } interface ImageElement { tagID: number; length: number; data: Buffer; } interface Image { header: ImageHeader; elements: ImageElement[]; raw: Buffer; } interface ImageInfo { imageType: ImageHeader["imageType"]; fileVersion: ImageHeader["fileVersion"]; manufacturerCode: ImageHeader["manufacturerCode"]; hardwareVersion?: number; } interface ImageMeta { fileVersion: ImageHeader["fileVersion"]; fileSize?: ImageHeader["totalImageSize"]; url: string; force?: boolean; sha512?: string; otaHeaderString?: ImageHeader["otaHeaderString"]; hardwareVersionMin?: ImageHeader["minimumHardwareVersion"]; hardwareVersionMax?: ImageHeader["maximumHardwareVersion"]; } interface ZigbeeOTAImageMeta extends ImageInfo, ImageMeta { fileName: string; modelId?: string; manufacturerName?: string[]; minFileVersion?: ImageHeader["fileVersion"]; maxFileVersion?: ImageHeader["fileVersion"]; originalUrl?: string; releaseNotes?: string; } type ExtraMetas = Pick<ZigbeeOTAImageMeta, "modelId" | "otaHeaderString" | "hardwareVersionMin" | "hardwareVersionMax"> & { manufacturerName?: string; suppressElementImageParseFailure?: boolean; }; } export declare namespace Reporting { interface Override { min?: number; max?: number; change?: number; } } export type LevelConfigFeatures = ("on_off_transition_time" | "on_transition_time" | "off_transition_time" | "execute_if_off" | "on_level" | "current_level_startup")[]; export {}; //# sourceMappingURL=types.d.ts.map