zigbee-herdsman-converters
Version:
Collection of device converters to be used with zigbee-herdsman
437 lines • 14.6 kB
TypeScript
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