/**
 * This file contains the class MatterbridgeEndpoint that extends the Endpoint class from the Matter.js library.
 *
 * @file matterbridgeEndpoint.ts
 * @author Luca Liguori
 * @date 2024-10-01
 * @version 2.0.0
 *
 * Copyright 2024, 2025, 2026 Luca Liguori.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License. *
 */
import { AnsiLogger, LogLevel } from './logger/export.js';
import { DeviceTypeDefinition, MatterbridgeEndpointOptions } from './matterbridgeDeviceTypes.js';
import { AtLeastOne, Behavior, ClusterId, Endpoint, EndpointNumber, HandlerFunction, NamedHandler } from '@matter/main';
import { ClusterType, Semtag } from '@matter/main/types';
import { PowerSource } from '@matter/main/clusters/power-source';
import { Identify } from '@matter/main/clusters/identify';
import { OnOff } from '@matter/main/clusters/on-off';
import { ColorControl } from '@matter/main/clusters/color-control';
import { WindowCovering } from '@matter/main/clusters/window-covering';
import { FanControl } from '@matter/main/clusters/fan-control';
import { DoorLock } from '@matter/main/clusters/door-lock';
import { ModeSelect } from '@matter/main/clusters/mode-select';
import { ValveConfigurationAndControl } from '@matter/main/clusters/valve-configuration-and-control';
import { PumpConfigurationAndControl } from '@matter/main/clusters/pump-configuration-and-control';
import { SmokeCoAlarm } from '@matter/main/clusters/smoke-co-alarm';
import { AirQuality } from '@matter/main/clusters/air-quality';
import { ConcentrationMeasurement } from '@matter/main/clusters/concentration-measurement';
export interface MatterbridgeEndpointCommands {
    identify: HandlerFunction;
    triggerEffect: HandlerFunction;
    on: HandlerFunction;
    off: HandlerFunction;
    toggle: HandlerFunction;
    offWithEffect: HandlerFunction;
    moveToLevel: HandlerFunction;
    moveToLevelWithOnOff: HandlerFunction;
    moveToColor: HandlerFunction;
    moveColor: HandlerFunction;
    stepColor: HandlerFunction;
    moveToHue: HandlerFunction;
    moveHue: HandlerFunction;
    stepHue: HandlerFunction;
    moveToSaturation: HandlerFunction;
    moveSaturation: HandlerFunction;
    stepSaturation: HandlerFunction;
    moveToHueAndSaturation: HandlerFunction;
    moveToColorTemperature: HandlerFunction;
    upOrOpen: HandlerFunction;
    downOrClose: HandlerFunction;
    stopMotion: HandlerFunction;
    goToLiftPercentage: HandlerFunction;
    lockDoor: HandlerFunction;
    unlockDoor: HandlerFunction;
    setpointRaiseLower: HandlerFunction;
    step: HandlerFunction;
    changeToMode: HandlerFunction;
    open: HandlerFunction;
    close: HandlerFunction;
    suppressAlarm: HandlerFunction;
    enableDisableAlarm: HandlerFunction;
    selfTestRequest: HandlerFunction;
    resetCounts: HandlerFunction;
    setUtcTime: HandlerFunction;
    setTimeZone: HandlerFunction;
    setDstOffset: HandlerFunction;
    pauseRequest: HandlerFunction;
    resumeRequest: HandlerFunction;
}
export interface SerializedMatterbridgeEndpoint {
    pluginName: string;
    deviceName: string;
    serialNumber: string;
    uniqueId: string;
    productId?: number;
    productName?: string;
    vendorId?: number;
    vendorName?: string;
    deviceTypes: DeviceTypeDefinition[];
    endpoint: EndpointNumber | undefined;
    endpointName: string;
    clusterServersId: ClusterId[];
}
export declare class MatterbridgeEndpoint extends Endpoint {
    static bridgeMode: string;
    static logLevel: LogLevel;
    log: AnsiLogger;
    plugin: string | undefined;
    configUrl: string | undefined;
    deviceName: string | undefined;
    serialNumber: string | undefined;
    uniqueId: string | undefined;
    vendorId: number | undefined;
    vendorName: string | undefined;
    productId: number | undefined;
    productName: string | undefined;
    softwareVersion: number | undefined;
    softwareVersionString: string | undefined;
    hardwareVersion: number | undefined;
    hardwareVersionString: string | undefined;
    productUrl: string;
    name: string | undefined;
    deviceType: number;
    uniqueStorageKey: string | undefined;
    tagList?: Semtag[];
    readonly deviceTypes: Map<number, DeviceTypeDefinition>;
    readonly commandHandler: NamedHandler<MatterbridgeEndpointCommands>;
    /**
     * Represents a MatterbridgeEndpoint.
     * @constructor
     * @param {DeviceTypeDefinition | AtLeastOne<DeviceTypeDefinition>} definition - The DeviceTypeDefinition(s) of the endpoint.
     * @param {MatterbridgeEndpointOptions} [options={}] - The options for the device.
     * @param {boolean} [debug=false] - Debug flag.
     */
    constructor(definition: DeviceTypeDefinition | AtLeastOne<DeviceTypeDefinition>, options?: MatterbridgeEndpointOptions, debug?: boolean);
    /**
     * Loads an instance of the MatterbridgeEndpoint class.
     *
     * @param {DeviceTypeDefinition | AtLeastOne<DeviceTypeDefinition>} definition - The DeviceTypeDefinition(s) of the device.
     * @param {MatterbridgeEndpointOptions} [options={}] - The options for the device.
     * @param {boolean} [debug=false] - Debug flag.
     * @returns {Promise<MatterbridgeEndpoint>} MatterbridgeEndpoint instance.
     */
    static loadInstance(definition: DeviceTypeDefinition | AtLeastOne<DeviceTypeDefinition>, options?: MatterbridgeEndpointOptions, debug?: boolean): Promise<MatterbridgeEndpoint>;
    /**
     * Get all the device types of this endpoint.
     *
     * @returns {DeviceTypeDefinition[]} The device types of this endpoint.
     */
    getDeviceTypes(): DeviceTypeDefinition[];
    /**
     * Checks if the provided cluster server is supported by this endpoint.
     *
     * @param {Behavior.Type | ClusterType | ClusterId | string} cluster - The cluster to check.
     * @returns {boolean} True if the cluster server is supported, false otherwise.
     */
    hasClusterServer(cluster: Behavior.Type | ClusterType | ClusterId | string): boolean;
    /**
     * Checks if the provided attribute server is supported for a given cluster of this endpoint.
     *
     * @param {Behavior.Type | ClusterType | ClusterId | string} cluster - The cluster to check.
     * @param {string} attribute - The attribute name to check.
     * @returns {boolean} True if the attribute server is supported, false otherwise.
     */
    hasAttributeServer(cluster: Behavior.Type | ClusterType | ClusterId | string, attribute: string): boolean;
    /**
     * Retrieves the initial options for the provided cluster server.
     *
     * @param {Behavior.Type | ClusterType | ClusterId | string} cluster - The cluster to get options for.
     * @returns {Record<string, boolean | number | bigint | string | object | null> | undefined} The options for the provided cluster server, or undefined if the cluster is not supported.
     */
    getClusterServerOptions(cluster: Behavior.Type | ClusterType | ClusterId | string): Record<string, string | number | bigint | boolean | object | null> | undefined;
    /**
     * Retrieves the value of the provided attribute from the given cluster.
     *
     * @param {Behavior.Type | ClusterType | ClusterId | string} cluster - The cluster to retrieve the attribute from.
     * @param {string} attribute - The name of the attribute to retrieve.
     * @param {AnsiLogger} [log] - Optional logger for error and info messages.
     * @returns {any} The value of the attribute, or undefined if the attribute is not found.
     */
    getAttribute(cluster: Behavior.Type | ClusterType | ClusterId | string, attribute: string, log?: AnsiLogger): any;
    /**
     * Sets the value of an attribute on a cluster server.
     *
     * @param {Behavior.Type | ClusterType | ClusterId | string} clusterId - The ID of the cluster.
     * @param {string} attribute - The name of the attribute.
     * @param {boolean | number | bigint | string | object | null} value - The value to set for the attribute.
     * @param {AnsiLogger} [log] - (Optional) The logger to use for logging errors and information.
     * @returns {Promise<boolean>} - A promise that resolves to a boolean indicating whether the attribute was successfully set.
     */
    setAttribute(clusterId: Behavior.Type | ClusterType | ClusterId | string, attribute: string, value: boolean | number | bigint | string | object | null, log?: AnsiLogger): Promise<boolean>;
    /**
     * Update the value of an attribute on a cluster server only if the value is different.
     *
     * @param {Behavior.Type | ClusterType | ClusterId | string} cluster - The cluster to set the attribute on.
     * @param {string} attribute - The name of the attribute.
     * @param {boolean | number | bigint | string | object | null} value - The value to set for the attribute.
     * @param {AnsiLogger} [log] - (Optional) The logger to use for logging the update. Errors are logged to the endpoint logger.
     * @returns {Promise<boolean>} - A promise that resolves to a boolean indicating whether the attribute was successfully set.
     */
    updateAttribute(cluster: Behavior.Type | ClusterType | ClusterId | string, attribute: string, value: boolean | number | bigint | string | object | null, log?: AnsiLogger): Promise<boolean>;
    /**
     * Subscribes to the provided attribute on a cluster.
     *
     * @param {Behavior.Type | ClusterType | ClusterId | string} cluster - The cluster to subscribe the attribute to.
     * @param {string} attribute - The name of the attribute to subscribe to.
     * @param {(newValue: any, oldValue: any) => void} listener - A callback function that will be called when the attribute value changes.
     * @param {AnsiLogger} [log] - Optional logger for logging errors and information.
     * @returns {Promise<boolean>} - A boolean indicating whether the subscription was successful.
     */
    subscribeAttribute(cluster: Behavior.Type | ClusterType | ClusterId | string, attribute: string, listener: (newValue: any, oldValue: any) => void, log?: AnsiLogger): Promise<boolean>;
    /**
     * Triggers an event on the specified cluster.
     *
     * @param {ClusterId} clusterId - The ID of the cluster.
     * @param {string} event - The name of the event to trigger.
     * @param {Record<string, boolean | number | bigint | string | object | undefined | null>} payload - The payload to pass to the event.
     * @param {AnsiLogger} [log] - Optional logger for logging information.
     * @returns {Promise<boolean>} - A promise that resolves to a boolean indicating whether the event was successfully triggered.
     */
    triggerEvent(clusterId: ClusterId, event: string, payload: Record<string, boolean | number | bigint | string | object | undefined | null>, log?: AnsiLogger): Promise<boolean>;
    /**
     * Adds cluster servers from the provided server list.
     *
     * @param {ClusterId[]} serverList - The list of cluster IDs to add.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    addClusterServers(serverList: ClusterId[]): this;
    /**
     * Adds a fixed label to the FixedLabel cluster. If the cluster server is not present, it will be added.
     *
     * @param {string} label - The label to add.
     * @param {string} value - The value of the label.
     * @returns {Promise<this>} The current MatterbridgeEndpoint instance for chaining.
     */
    addFixedLabel(label: string, value: string): Promise<this>;
    /**
     * Adds a user label to the UserLabel cluster. If the cluster server is not present, it will be added.
     *
     * @param {string} label - The label to add.
     * @param {string} value - The value of the label.
     * @returns {Promise<this>} The current MatterbridgeEndpoint instance for chaining.
     */
    addUserLabel(label: string, value: string): Promise<this>;
    /**
     * Adds a command handler for the specified command.
     *
     * @param {keyof MatterbridgeEndpointCommands} command - The command to add the handler for.
     * @param {HandlerFunction} handler - The handler function to execute when the command is received.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    addCommandHandler(command: keyof MatterbridgeEndpointCommands, handler: HandlerFunction): this;
    /**
     * Execute the command handler for the specified command. Mainly used in Jest tests.
     *
     * @param {keyof MatterbridgeEndpointCommands} command - The command to execute.
     * @param {Record<string, boolean | number | bigint | string | object | null>} request - The optional request to pass to the handler function.
     * @returns {Promise<void>} A promise that resolves when the command handler has been executed
     */
    executeCommandHandler(command: keyof MatterbridgeEndpointCommands, request?: Record<string, boolean | number | bigint | string | object | null>): Promise<void>;
    /**
     * Adds the required cluster servers (only if they are not present) for the device types of the specified endpoint.
     *
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    addRequiredClusterServers(): MatterbridgeEndpoint;
    /**
     * Adds the optional cluster servers (only if they are not present) for the device types of the specified endpoint.
     *
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    addOptionalClusterServers(): MatterbridgeEndpoint;
    /**
     * Retrieves all cluster servers.
     *
     * @returns {Behavior.Type[]} An array of all cluster servers.
     */
    getAllClusterServers(): Behavior.Type[];
    /**
     * Retrieves the names of all cluster servers.
     *
     * @returns {string[]} An array of all cluster server names.
     */
    getAllClusterServerNames(): string[];
    /**
     * Iterates over each attribute of each cluster server of the device state and calls the provided callback function.
     *
     * @param {Function} callback - The callback function to call with the cluster name, cluster id, attribute name, attribute id and attribute value.
     */
    forEachAttribute(callback: (clusterName: string, clusterId: number, attributeName: string, attributeId: number, attributeValue: boolean | number | bigint | string | object | null | undefined) => void): void;
    /**
     * Adds a child endpoint with the specified device types and options.
     * If the child endpoint is not already present, it will be created and added.
     * If the child endpoint is already present, the existing child endpoint will be returned.
     *
     * @param {string} endpointName - The name of the new endpoint to add.
     * @param {DeviceTypeDefinition | AtLeastOne<DeviceTypeDefinition>} definition - The device types to add.
     * @param {MatterbridgeEndpointOptions} [options={}] - The options for the endpoint.
     * @param {boolean} [debug=false] - Whether to enable debug logging.
     * @returns {MatterbridgeEndpoint} - The child endpoint that was found or added.
     *
     * @example
     * ```typescript
     * const endpoint = device.addChildDeviceType('Temperature', [temperatureSensor], { tagList: [{ mfgCode: null, namespaceId: LocationTag.Indoor.namespaceId, tag: LocationTag.Indoor.tag, label: null }] }, true);
     * ```
     */
    addChildDeviceType(endpointName: string, definition: DeviceTypeDefinition | AtLeastOne<DeviceTypeDefinition>, options?: MatterbridgeEndpointOptions, debug?: boolean): MatterbridgeEndpoint;
    /**
     * Adds a child endpoint with one or more device types with the required cluster servers and the specified cluster servers.
     * If the child endpoint is not already present in the childEndpoints, it will be added.
     * If the child endpoint is already present in the childEndpoints, the device types and cluster servers will be added to the existing child endpoint.
     *
     * @param {string} endpointName - The name of the new enpoint to add.
     * @param {DeviceTypeDefinition | AtLeastOne<DeviceTypeDefinition>} definition - The device types to add.
     * @param {ClusterId[]} [serverList=[]] - The list of cluster IDs to include.
     * @param {MatterbridgeEndpointOptions} [options={}] - The options for the device.
     * @param {boolean} [debug=false] - Whether to enable debug logging.
     * @returns {MatterbridgeEndpoint} - The child endpoint that was found or added.
     *
     * @example
     * ```typescript
     * const endpoint = device.addChildDeviceTypeWithClusterServer('Temperature', [temperatureSensor], [], { tagList: [{ mfgCode: null, namespaceId: LocationTag.Indoor.namespaceId, tag: LocationTag.Indoor.tag, label: null }] }, true);
     * ```
     */
    addChildDeviceTypeWithClusterServer(endpointName: string, definition: DeviceTypeDefinition | AtLeastOne<DeviceTypeDefinition>, serverList?: ClusterId[], options?: MatterbridgeEndpointOptions, debug?: boolean): MatterbridgeEndpoint;
    /**
     * Retrieves a child endpoint by its name.
     *
     * @param {string} endpointName - The name of the endpoint to retrieve.
     * @returns {Endpoint | undefined} The child endpoint with the specified name, or undefined if not found.
     */
    getChildEndpointByName(endpointName: string): MatterbridgeEndpoint | undefined;
    /**
     * Retrieves a child endpoint by its EndpointNumber.
     *
     * @param {EndpointNumber} endpointNumber - The EndpointNumber of the endpoint to retrieve.
     * @returns {MatterbridgeEndpoint | undefined} The child endpoint with the specified EndpointNumber, or undefined if not found.
     */
    getChildEndpoint(endpointNumber: EndpointNumber): MatterbridgeEndpoint | undefined;
    /**
     * Get all the child endpoints of this endpoint.
     *
     * @returns {MatterbridgeEndpoint[]} The child endpoints.
     */
    getChildEndpoints(): MatterbridgeEndpoint[];
    /**
     * Serializes the Matterbridge device into a serialized object.
     *
     * @param pluginName - The name of the plugin.
     * @returns The serialized Matterbridge device object.
     */
    static serialize(device: MatterbridgeEndpoint): SerializedMatterbridgeEndpoint | undefined;
    /**
     * Deserializes the device into a serialized object.
     *
     * @returns The deserialized MatterbridgeDevice.
     */
    static deserialize(serializedDevice: SerializedMatterbridgeEndpoint): MatterbridgeEndpoint | undefined;
    /**
     * Creates a default power source wired cluster server.
     *
     * @param wiredCurrentType - The type of wired current (default: PowerSource.WiredCurrentType.Ac)
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultPowerSourceWiredClusterServer(wiredCurrentType?: PowerSource.WiredCurrentType): this;
    /**
     * Creates a default power source replaceable battery cluster server.
     *
     * @param batPercentRemaining - The remaining battery percentage (default: 100).
     * @param batChargeLevel - The battery charge level (default: PowerSource.BatChargeLevel.Ok).
     * @param batVoltage - The battery voltage (default: 1500).
     * @param batReplacementDescription - The battery replacement description (default: 'Battery type').
     * @param batQuantity - The battery quantity (default: 1).
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultPowerSourceReplaceableBatteryClusterServer(batPercentRemaining?: number, batChargeLevel?: PowerSource.BatChargeLevel, batVoltage?: number, batReplacementDescription?: string, batQuantity?: number): this;
    /**
     * Creates a default power source rechargeable battery cluster server.
     *
     * @param batPercentRemaining - The remaining battery percentage (default: 100).
     * @param batChargeLevel - The battery charge level (default: PowerSource.BatChargeLevel.Ok).
     * @param batVoltage - The battery voltage (default: 1500).
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultPowerSourceRechargeableBatteryClusterServer(batPercentRemaining?: number, batChargeLevel?: PowerSource.BatChargeLevel, batVoltage?: number): this;
    /**
     * Creates a default Basic Information Cluster Server for the server node.
     *
     * @param deviceName - The name of the device.
     * @param serialNumber - The serial number of the device.
     * @param vendorId - The vendor ID of the device.
     * @param vendorName - The vendor name of the device.
     * @param productId - The product ID of the device.
     * @param productName - The product name of the device.
     * @param softwareVersion - The software version of the device. Default is 1.
     * @param softwareVersionString - The software version string of the device. Default is 'v.1.0.0'.
     * @param hardwareVersion - The hardware version of the device. Default is 1.
     * @param hardwareVersionString - The hardware version string of the device. Default is 'v.1.0.0'.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultBasicInformationClusterServer(deviceName: string, serialNumber: string, vendorId: number, vendorName: string, productId: number, productName: string, softwareVersion?: number, softwareVersionString?: string, hardwareVersion?: number, hardwareVersionString?: string): this;
    /**
     * Creates a default BridgedDeviceBasicInformationClusterServer for the aggregator endpoints.
     *
     * @param deviceName - The name of the device.
     * @param serialNumber - The serial number of the device.
     * @param vendorId - The vendor ID of the device.
     * @param vendorName - The name of the vendor.
     * @param productName - The name of the product.
     * @param softwareVersion - The software version of the device. Default is 1.
     * @param softwareVersionString - The software version string of the device. Default is 'v.1.0.0'.
     * @param hardwareVersion - The hardware version of the device. Default is 1.
     * @param hardwareVersionString - The hardware version string of the device. Default is 'v.1.0.0'.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultBridgedDeviceBasicInformationClusterServer(deviceName: string, serialNumber: string, vendorId: number, vendorName: string, productName: string, softwareVersion?: number, softwareVersionString?: string, hardwareVersion?: number, hardwareVersionString?: string): this;
    /**
     * Creates a default identify cluster server with the specified identify time and type.
     *
     * @param {number} [identifyTime=0] - The time to identify the server. Defaults to 0.
     * @param {Identify.IdentifyType} [identifyType=Identify.IdentifyType.None] - The type of identification. Defaults to Identify.IdentifyType.None.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultIdentifyClusterServer(identifyTime?: number, identifyType?: Identify.IdentifyType): this;
    /**
     * Creates a default groups cluster server.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultGroupsClusterServer(): this;
    /**
     * Creates a default scenes management cluster server.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultScenesClusterServer(): this;
    /**
     * Creates a default OnOff cluster server for light devices.
     *
     * @param {boolean} [onOff=false] - The initial state of the OnOff cluster.
     * @param {boolean} [globalSceneControl=false] - The global scene control state.
     * @param {number} [onTime=0] - The on time value.
     * @param {number} [offWaitTime=0] - The off wait time value.
     * @param {OnOff.StartUpOnOff | null} [startUpOnOff=null] - The start-up OnOff state. Null means previous state.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultOnOffClusterServer(onOff?: boolean, globalSceneControl?: boolean, onTime?: number, offWaitTime?: number, startUpOnOff?: OnOff.StartUpOnOff | null): this;
    /**
     * Creates an OnOff cluster server without features.
     *
     * @param {boolean} [onOff=false] - The initial state of the OnOff cluster.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createOnOffClusterServer(onOff?: boolean): this;
    /**
     * Creates a DeadFront OnOff cluster server.
     *
     * @param {boolean} [onOff=false] - The initial state of the OnOff cluster.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDeadFrontOnOffClusterServer(onOff?: boolean): this;
    /**
     * Creates a default level control cluster server for light devices.
     *
     * @param {number} [currentLevel=254] - The current level (default: 254).
     * @param {number} [minLevel=1] - The minimum level (default: 1).
     * @param {number} [maxLevel=254] - The maximum level (default: 254).
     * @param {number | null} [onLevel=null] - The on level (default: null).
     * @param {number | null} [startUpCurrentLevel=null] - The startUp on level (default: null).
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultLevelControlClusterServer(currentLevel?: number, minLevel?: number, maxLevel?: number, onLevel?: number | null, startUpCurrentLevel?: number | null): this;
    /**
     * Creates a default color control cluster server with Xy, HueSaturation and ColorTemperature.
     *
     * @param currentX - The current X value.
     * @param currentY - The current Y value.
     * @param currentHue - The current hue value.
     * @param currentSaturation - The current saturation value.
     * @param colorTemperatureMireds - The color temperature in mireds.
     * @param colorTempPhysicalMinMireds - The physical minimum color temperature in mireds.
     * @param colorTempPhysicalMaxMireds - The physical maximum color temperature in mireds.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultColorControlClusterServer(currentX?: number, currentY?: number, currentHue?: number, currentSaturation?: number, colorTemperatureMireds?: number, colorTempPhysicalMinMireds?: number, colorTempPhysicalMaxMireds?: number): this;
    /**
     * Creates a Xy color control cluster server with Xy and ColorTemperature.
     *
     * @param currentX - The current X value.
     * @param currentY - The current Y value.
     * @param colorTemperatureMireds - The color temperature in mireds.
     * @param colorTempPhysicalMinMireds - The physical minimum color temperature in mireds.
     * @param colorTempPhysicalMaxMireds - The physical maximum color temperature in mireds.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     *
     * @remarks
     * From zigbee to matter = Math.max(Math.min(Math.round(x * 65536), 65279), 0)
     */
    createXyColorControlClusterServer(currentX?: number, currentY?: number, colorTemperatureMireds?: number, colorTempPhysicalMinMireds?: number, colorTempPhysicalMaxMireds?: number): this;
    /**
     * Creates a default hue and saturation control cluster server with HueSaturation and ColorTemperature.
     *
     * @param currentHue - The current hue value.
     * @param currentSaturation - The current saturation value.
     * @param colorTemperatureMireds - The color temperature in mireds.
     * @param colorTempPhysicalMinMireds - The physical minimum color temperature in mireds.
     * @param colorTempPhysicalMaxMireds - The physical maximum color temperature in mireds.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createHsColorControlClusterServer(currentHue?: number, currentSaturation?: number, colorTemperatureMireds?: number, colorTempPhysicalMinMireds?: number, colorTempPhysicalMaxMireds?: number): this;
    /**
     * Creates a color temperature color control cluster server.
     *
     * @param colorTemperatureMireds - The color temperature in mireds.
     * @param colorTempPhysicalMinMireds - The physical minimum color temperature in mireds.
     * @param colorTempPhysicalMaxMireds - The physical maximum color temperature in mireds.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createCtColorControlClusterServer(colorTemperatureMireds?: number, colorTempPhysicalMinMireds?: number, colorTempPhysicalMaxMireds?: number): this;
    /**
     * Configures the color control mode for the device.
     *
     * @param {ColorControl.ColorMode} colorMode - The color mode to set.
     */
    configureColorControlMode(colorMode: ColorControl.ColorMode): Promise<void>;
    /**
     * Creates a default window covering cluster server (Lift and PositionAwareLift).
     *
     * @param positionPercent100ths - The position percentage in 100ths (0-10000). Defaults to 0. Matter uses 10000 = fully closed 0 = fully opened.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultWindowCoveringClusterServer(positionPercent100ths?: number): this;
    /**
     * Sets the window covering target position as the current position and stops the movement.
     *
     */
    setWindowCoveringTargetAsCurrentAndStopped(): Promise<void>;
    /**
     * Sets the current and target status of a window covering.
     * @param {number} current - The current position of the window covering.
     * @param {number} target - The target position of the window covering.
     * @param {WindowCovering.MovementStatus} status - The movement status of the window covering.
     */
    setWindowCoveringCurrentTargetStatus(current: number, target: number, status: WindowCovering.MovementStatus): Promise<void>;
    /**
     * Sets the status of the window covering.
     * @param {WindowCovering.MovementStatus} status - The movement status to set.
     */
    setWindowCoveringStatus(status: WindowCovering.MovementStatus): Promise<void>;
    /**
     * Retrieves the status of the window covering.
     *
     * @returns The global operational status of the window covering or undefined.
     */
    getWindowCoveringStatus(): WindowCovering.MovementStatus | undefined;
    /**
     * Sets the target and current position of the window covering.
     *
     * @param position - The position to set, specified as a number.
     */
    setWindowCoveringTargetAndCurrentPosition(position: number): Promise<void>;
    /**
     * Creates a default thermostat cluster server with Thermostat.Feature.Heating, Thermostat.Feature.Cooling, Thermostat.Feature.AutoMode.
     *
     * @param {number} [localTemperature=23] - The local temperature value in degrees Celsius. Defaults to 23°.
     * @param {number} [occupiedHeatingSetpoint=21] - The occupied heating setpoint value in degrees Celsius. Defaults to 21°.
     * @param {number} [occupiedCoolingSetpoint=25] - The occupied cooling setpoint value in degrees Celsius. Defaults to 25°.
     * @param {number} [minSetpointDeadBand=1] - The minimum setpoint dead band value. Defaults to 1°.
     * @param {number} [minHeatSetpointLimit=0] - The minimum heat setpoint limit value. Defaults to 0°.
     * @param {number} [maxHeatSetpointLimit=50] - The maximum heat setpoint limit value. Defaults to 50°.
     * @param {number} [minCoolSetpointLimit=0] - The minimum cool setpoint limit value. Defaults to 0°.
     * @param {number} [maxCoolSetpointLimit=50] - The maximum cool setpoint limit value. Defaults to 50°.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultThermostatClusterServer(localTemperature?: number, occupiedHeatingSetpoint?: number, occupiedCoolingSetpoint?: number, minSetpointDeadBand?: number, minHeatSetpointLimit?: number, maxHeatSetpointLimit?: number, minCoolSetpointLimit?: number, maxCoolSetpointLimit?: number): this;
    /**
     * Creates a default heating thermostat cluster server with Thermostat.Feature.Heating.
     * @param {number} [localTemperature] - The local temperature value in degrees Celsius. Defaults to 23°.
     * @param {number} [occupiedHeatingSetpoint] - The occupied heating setpoint value in degrees Celsius. Defaults to 21°.
     * @param {number} [minHeatSetpointLimit] - The minimum heat setpoint limit value. Defaults to 0°.
     * @param {number} [maxHeatSetpointLimit] - The maximum heat setpoint limit value. Defaults to 50°.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultHeatingThermostatClusterServer(localTemperature?: number, occupiedHeatingSetpoint?: number, minHeatSetpointLimit?: number, maxHeatSetpointLimit?: number): this;
    /**
     * Creates a default cooling thermostat cluster server with Thermostat.Feature.Cooling.
     * @param {number} [localTemperature] - The local temperature value in degrees Celsius. Defaults to 23°.
     * @param {number} [occupiedCoolingSetpoint] - The occupied cooling setpoint value in degrees Celsius. Defaults to 25°.
     * @param {number} [minCoolSetpointLimit] - The minimum cool setpoint limit value. Defaults to 0°.
     * @param {number} [maxCoolSetpointLimit] - The maximum cool setpoint limit value. Defaults to 50°.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultCoolingThermostatClusterServer(localTemperature?: number, occupiedCoolingSetpoint?: number, minCoolSetpointLimit?: number, maxCoolSetpointLimit?: number): this;
    /**
     * Creates a default fan control cluster server.
     *
     * @param fanMode The fan mode to set. Defaults to `FanControl.FanMode.Off`.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultFanControlClusterServer(fanMode?: FanControl.FanMode): this;
    /**
     * Creates a default door lock cluster server.
     *
     * @param {DoorLock.LockState} [lockState=DoorLock.LockState.Locked] - The initial state of the lock (default: Locked).
     * @param {DoorLock.LockType} [lockType=DoorLock.LockType.DeadBolt] - The type of the lock (default: DeadBolt).
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     *
     * @remarks
     * All operating modes NOT supported by a lock SHALL be set to one. The value of the OperatingMode enumeration defines the related bit to be set.
     */
    createDefaultDoorLockClusterServer(lockState?: DoorLock.LockState, lockType?: DoorLock.LockType): this;
    /**
     * Creates a default Mode Select cluster server.
     *
     * @param {string} description - The description of the mode select cluster.
     * @param {ModeSelect.ModeOption[]} supportedModes - The list of supported modes.
     * @param {number} [currentMode=0] - The current mode (default: 0).
     * @param {number} [startUpMode=0] - The startup mode (default: 0).
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     *
     * @remarks
     * endpoint.createDefaultModeSelectClusterServer('Night mode', [{ label: 'Led ON', mode: 0, semanticTags: [] }, { label: 'Led OFF', mode: 1, semanticTags: [] }], 0, 0);
     */
    createDefaultModeSelectClusterServer(description: string, supportedModes: ModeSelect.ModeOption[], currentMode?: number, startUpMode?: number): this;
    /**
     * Creates the default Valve Configuration And Control cluster server.
     *
     * @param {ValveConfigurationAndControl.ValveState} [valveState=ValveConfigurationAndControl.ValveState.Closed] - The valve state to set. Defaults to `ValveConfigurationAndControl.ValveState.Closed`.
     * @param {number} [valveLevel=0] - The valve level to set. Defaults to 0.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultValveConfigurationAndControlClusterServer(valveState?: ValveConfigurationAndControl.ValveState, valveLevel?: number): this;
    /**
     * Creates the default PumpConfigurationAndControl cluster server.
     *
     * @param {PumpConfigurationAndControl.OperationMode} [pumpMode=PumpConfigurationAndControl.OperationMode.Normal] - The pump mode to set. Defaults to `PumpConfigurationAndControl.OperationMode.Normal`.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultPumpConfigurationAndControlClusterServer(pumpMode?: PumpConfigurationAndControl.OperationMode): this;
    /**
     * Creates the default SmokeCOAlarm Cluster Server.
     *
     * @param {SmokeCoAlarm.AlarmState} smokeState - The state of the smoke alarm. Defaults to SmokeCoAlarm.AlarmState.Normal.
     * @param {SmokeCoAlarm.AlarmState} coState - The state of the CO alarm. Defaults to SmokeCoAlarm.AlarmState.Normal.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultSmokeCOAlarmClusterServer(smokeState?: SmokeCoAlarm.AlarmState, coState?: SmokeCoAlarm.AlarmState): this;
    /**
     * Creates a smoke only SmokeCOAlarm Cluster Server.
     *
     * @param {SmokeCoAlarm.AlarmState} smokeState - The state of the smoke alarm. Defaults to SmokeCoAlarm.AlarmState.Normal.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createSmokeOnlySmokeCOAlarmClusterServer(smokeState?: SmokeCoAlarm.AlarmState): this;
    /**
     * Creates a co only SmokeCOAlarm Cluster Server.
     *
     * @param {SmokeCoAlarm.AlarmState} coState - The state of the CO alarm. Defaults to SmokeCoAlarm.AlarmState.Normal.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createCoOnlySmokeCOAlarmClusterServer(coState?: SmokeCoAlarm.AlarmState): this;
    /**
     * Creates a default momentary switch cluster server.
     *
     * @remarks
     * This method adds a cluster server with default momentary switch features and configuration suitable for (AppleHome) Single Double Long automations.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultSwitchClusterServer(): this;
    /**
     * Creates a default latching switch cluster server.
     *
     * @remarks
     * This method adds a cluster server with default latching switch features and configuration suitable for a latching switch with 2 positions.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultLatchingSwitchClusterServer(): this;
    /**
     * Triggers a switch event on the specified endpoint.
     *
     * @param {string} event - The type of event to trigger. Possible values are 'Single', 'Double', 'Long' for momentarySwitch and 'Press', 'Release' for latchingSwitch.
     * @param {Endpoint} endpoint - The endpoint on which to trigger the event (default the device endpoint).
     * @returns {boolean} - A boolean indicating whether the event was successfully triggered.
     */
    triggerSwitchEvent(event: 'Single' | 'Double' | 'Long' | 'Press' | 'Release', log?: AnsiLogger): Promise<boolean>;
    /**
     * Creates a default boolean state cluster server.
     *
     * @param {boolean} contact - The state of the cluster. Defaults to true (true = contact).
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultBooleanStateClusterServer(contact?: boolean): this;
    /**
     * Creates a default boolean state configuration cluster server to be used with the waterFreezeDetector, waterLeakDetector, and rainSensor device types.
     *
     * @remarks Supports the enableDisableAlarm command.
     *
     * @param {boolean} [sensorFault=false] - Optional boolean value indicating the sensor fault state. Defaults to `false` if not provided.
     * @param {number} [currentSensitivityLevel=0] - The current sensitivity level. Defaults to `0` if not provided.
     * @param {number} [supportedSensitivityLevels=2] - The number of supported sensitivity levels. Defaults to `2` if not provided (min 2, max 10).
     * @param {number} [defaultSensitivityLevel=0] - The default sensitivity level. Defaults to `0` if not provided.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultBooleanStateConfigurationClusterServer(sensorFault?: boolean, currentSensitivityLevel?: number, supportedSensitivityLevels?: number, defaultSensitivityLevel?: number): this;
    /**
     * Creates a default Power Topology Cluster Server with feature TreeTopology. Only needed for an electricalSensor device type.
     *
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultPowerTopologyClusterServer(): this;
    /**
     * Creates a default Electrical Energy Measurement Cluster Server.
     *
     * @param {number} energy - The total consumption value in mW/h.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultElectricalEnergyMeasurementClusterServer(energy?: number | bigint | null): this;
    /**
     * Creates a default Electrical Power Measurement Cluster Server.
     *
     * @param {number} voltage - The voltage value in millivolts.
     * @param {number} current - The current value in milliamperes.
     * @param {number} power - The power value in milliwatts.
     * @param {number} frequency - The frequency value in millihertz.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultElectricalPowerMeasurementClusterServer(voltage?: number | bigint | null, current?: number | bigint | null, power?: number | bigint | null, frequency?: number | bigint | null): this;
    /**
     * Creates a default TemperatureMeasurement cluster server.
     *
     * @param {number} measuredValue - The measured value of the temperature x 100.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultTemperatureMeasurementClusterServer(measuredValue?: number): this;
    /**
     * Creates a default RelativeHumidityMeasurement cluster server.
     *
     * @param {number} measuredValue - The measured value of the relative humidity x 100.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultRelativeHumidityMeasurementClusterServer(measuredValue?: number): this;
    /**
     * Creates a default PressureMeasurement cluster server.
     *
     * @param {number} measuredValue - The measured value for the pressure.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultPressureMeasurementClusterServer(measuredValue?: number): this;
    /**
     * Creates a default IlluminanceMeasurement cluster server.
     *
     * @param {number} measuredValue - The measured value of illuminance.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     *
     * @remarks
     * Lux to matter = Math.round(Math.max(Math.min(10000 * Math.log10(lux), 0xfffe), 0))
     * Matter to Lux = Math.round(Math.max(Math.pow(10, value / 10000), 0))
     */
    createDefaultIlluminanceMeasurementClusterServer(measuredValue?: number): this;
    /**
     * Creates a default FlowMeasurement cluster server.
     *
     * @param {number} measuredValue - The measured value of the flow in 10 x m/h.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultFlowMeasurementClusterServer(measuredValue?: number): this;
    /**
     * Creates a default OccupancySensing cluster server.
     *
     * @param {boolean} occupied - A boolean indicating whether the occupancy is occupied or not. Default is false.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultOccupancySensingClusterServer(occupied?: boolean): this;
    /**
     * Creates a default AirQuality cluster server.
     *
     * @param {AirQuality.AirQualityEnum} airQuality The air quality level. Defaults to `AirQuality.AirQualityType.Unknown`.
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultAirQualityClusterServer(airQuality?: AirQuality.AirQualityEnum): this;
    /**
     * Creates a default TotalVolatileOrganicCompoundsConcentrationMeasurement cluster server.
     *
     * @param {number} measuredValue - The measured value of the concentration.
     * @param {ConcentrationMeasurement.MeasurementUnit} measurementUnit - The unit of measurement (default to ConcentrationMeasurement.MeasurementUnit.Ppm).
     * @param {ConcentrationMeasurement.MeasurementMedium} measurementMedium - The unit of measurement (default to ConcentrationMeasurement.MeasurementMedium.Air).
     * @returns {this} The current MatterbridgeEndpoint instance for chaining.
     */
    createDefaultTvocMeasurementClusterServer(measuredValue?: number, measurementUnit?: ConcentrationMeasurement.MeasurementUnit, measurementMedium?: ConcentrationMeasurement.MeasurementMedium): this;
    /**
     * Create a default CarbonMonoxideConcentrationMeasurement cluster server.
     *
     * @param {number} measuredValue - The measured value of the concentration.
     * @param {ConcentrationMeasurement.MeasurementUnit} measurementUnit - The unit of measurement (default to ConcentrationMeasurement.MeasurementUnit.Ppm).
     * @param {ConcentrationMeasurement.MeasurementMedium} measurementMedium - The unit of measurement (default to ConcentrationMeasurement.MeasurementMedium.Air).
     */
    createDefaultCarbonMonoxideConcentrationMeasurementClusterServer(measuredValue?: number, measurementUnit?: ConcentrationMeasurement.MeasurementUnit, measurementMedium?: ConcentrationMeasurement.MeasurementMedium): this;
    /**
     * Create a default CarbonDioxideConcentrationMeasurement cluster server.
     *
     * @param {number} measuredValue - The measured value of the concentration.
     * @param {ConcentrationMeasurement.MeasurementUnit} measurementUnit - The unit of measurement (default to ConcentrationMeasurement.MeasurementUnit.Ppm).
     * @param {ConcentrationMeasurement.MeasurementMedium} measurementMedium - The unit of measurement (default to ConcentrationMeasurement.MeasurementMedium.Air).
     */
    createDefaultCarbonDioxideConcentrationMeasurementClusterServer(measuredValue?: number, measurementUnit?: ConcentrationMeasurement.MeasurementUnit, measurementMedium?: ConcentrationMeasurement.MeasurementMedium): this;
    /**
     * Create a default FormaldehydeConcentrationMeasurement cluster server.
     *
     * @param {number} measuredValue - The measured value of the concentration.
     * @param {ConcentrationMeasurement.MeasurementUnit} measurementUnit - The unit of measurement (default to ConcentrationMeasurement.MeasurementUnit.Ppm).
     * @param {ConcentrationMeasurement.MeasurementMedium} measurementMedium - The unit of measurement (default to ConcentrationMeasurement.MeasurementMedium.Air).
     */
    createDefaultFormaldehydeConcentrationMeasurementClusterServer(measuredValue?: number, measurementUnit?: ConcentrationMeasurement.MeasurementUnit, measurementMedium?: ConcentrationMeasurement.MeasurementMedium): this;
    /**
     * Create a default Pm1ConcentrationMeasurement cluster server.
     *
     * @param {number} measuredValue - The measured value of the concentration.
     * @param {ConcentrationMeasurement.MeasurementUnit} measurementUnit - The unit of measurement (default to ConcentrationMeasurement.MeasurementUnit.Ppm).
     * @param {ConcentrationMeasurement.MeasurementMedium} measurementMedium - The unit of measurement (default to ConcentrationMeasurement.MeasurementMedium.Air).
     */
    createDefaultPm1ConcentrationMeasurementClusterServer(measuredValue?: number, measurementUnit?: ConcentrationMeasurement.MeasurementUnit, measurementMedium?: ConcentrationMeasurement.MeasurementMedium): this;
    /**
     * Create a default Pm25ConcentrationMeasurement cluster server.
     *
     * @param {number} measuredValue - The measured value of the concentration.
     * @param {ConcentrationMeasurement.MeasurementUnit} measurementUnit - The unit of measurement (default to ConcentrationMeasurement.MeasurementUnit.Ppm).
     * @param {ConcentrationMeasurement.MeasurementMedium} measurementMedium - The unit of measurement (default to ConcentrationMeasurement.MeasurementMedium.Air).
     */
    createDefaultPm25ConcentrationMeasurementClusterServer(measuredValue?: number, measurementUnit?: ConcentrationMeasurement.MeasurementUnit, measurementMedium?: ConcentrationMeasurement.MeasurementMedium): this;
    /**
     * Create a default Pm10ConcentrationMeasurement cluster server.
     *
     * @param {number} measuredValue - The measured value of the concentration.
     * @param {ConcentrationMeasurement.MeasurementUnit} measurementUnit - The unit of measurement (default to ConcentrationMeasurement.MeasurementUnit.Ppm).
     * @param {ConcentrationMeasurement.MeasurementMedium} measurementMedium - The unit of measurement (default to ConcentrationMeasurement.MeasurementMedium.Air).
     */
    createDefaultPm10ConcentrationMeasurementClusterServer(measuredValue?: number, measurementUnit?: ConcentrationMeasurement.MeasurementUnit, measurementMedium?: ConcentrationMeasurement.MeasurementMedium): this;
    /**
     * Create a default OzoneConcentrationMeasurement cluster server.
     *
     * @param {number} measuredValue - The measured value of the concentration.
     * @param {ConcentrationMeasurement.MeasurementUnit} measurementUnit - The unit of measurement (default to ConcentrationMeasurement.MeasurementUnit.Ugm3).
     * @param {ConcentrationMeasurement.MeasurementMedium} measurementMedium - The unit of measurement (default to ConcentrationMeasurement.MeasurementMedium.Air).
     */
    createDefaultOzoneConcentrationMeasurementClusterServer(measuredValue?: number, measurementUnit?: ConcentrationMeasurement.MeasurementUnit, measurementMedium?: ConcentrationMeasurement.MeasurementMedium): this;
    /**
     * Create a default RadonConcentrationMeasurement cluster server.
     *
     * @param {number} measuredValue - The measured value of the concentration.
     * @param {ConcentrationMeasurement.MeasurementUnit} measurementUnit - The unit of measurement (default to ConcentrationMeasurement.MeasurementUnit.Ppm).
     * @param {ConcentrationMeasurement.MeasurementMedium} measurementMedium - The unit of measurement (default to ConcentrationMeasurement.MeasurementMedium.Air).
     */
    createDefaultRadonConcentrationMeasurementClusterServer(measuredValue?: number, measurementUnit?: ConcentrationMeasurement.MeasurementUnit, measurementMedium?: ConcentrationMeasurement.MeasurementMedium): this;
    /**
     * Create a default NitrogenDioxideConcentrationMeasurement cluster server.
     *
     * @param {number} measuredValue - The measured value of the concentration.
     * @param {ConcentrationMeasurement.MeasurementUnit} measurementUnit - The unit of measurement (default to ConcentrationMeasurement.MeasurementUnit.Ugm3).
     * @param {ConcentrationMeasurement.MeasurementMedium} measurementMedium - The unit of measurement (default to ConcentrationMeasurement.MeasurementMedium.Air).
     */
    createDefaultNitrogenDioxideConcentrationMeasurementClusterServer(measuredValue?: number, measurementUnit?: ConcentrationMeasurement.MeasurementUnit, measurementMedium?: ConcentrationMeasurement.MeasurementMedium): this;
}
//# sourceMappingURL=matterbridgeEndpoint.d.ts.map