UNPKG

zigbee-herdsman

Version:

An open source ZigBee gateway solution with node.js.

155 lines 8.8 kB
"use strict"; //------------------------------------------------------------------------------------------------- // General Object.defineProperty(exports, "__esModule", { value: true }); exports.MANUFACTURING_STRING_SIZE = exports.INTERPAN_APS_FRAME_SECURITY = exports.INTERPAN_APS_FRAME_DELIVERY_MODE_MASK = exports.INTERPAN_APS_FRAME_CONTROL_NO_DELIVERY_MODE = exports.INTERPAN_APS_FRAME_TYPE_MASK = exports.INTERPAN_APS_FRAME_TYPE = exports.MIN_STUB_APS_SIZE = exports.MAX_STUB_APS_SIZE = exports.INTERPAN_APS_MULTICAST_SIZE = exports.INTERPAN_APS_UNICAST_BROADCAST_SIZE = exports.STUB_NWK_FRAME_CONTROL = exports.STUB_NWK_SIZE = exports.MAC_ACK_REQUIRED = exports.LONG_DEST_FRAME_CONTROL = exports.SHORT_DEST_FRAME_CONTROL = exports.MAXIMUM_INTERPAN_LENGTH = exports.GP_SIZE_OF_SINK_LIST_ENTRIES_OCTET_STRING = exports.GP_SINK_LIST_ENTRIES = exports.ZIGBEE_PROFILE_INTEROPERABILITY_LINK_KEY = exports.SECURITY_LEVEL_Z3 = exports.STACK_PROFILE_ZIGBEE_PRO = exports.ZB_PSA_ALG = exports.EMBER_TRUST_CENTER_NODE_ID = exports.EMBER_HIGH_RAM_CONCENTRATOR = exports.EMBER_LOW_RAM_CONCENTRATOR = exports.EMBER_INACTIVE_CONCENTRATOR = exports.APS_FRAGMENTATION_OVERHEAD = exports.APS_ENCRYPTION_OVERHEAD = exports.MAXIMUM_APS_PAYLOAD_LENGTH = exports.SOURCE_ROUTING_RESERVED_PAYLOAD_LENGTH = exports.NWK_SOURCE_ROUTE_OVERHEAD = exports.EMBER_MIN_BROADCAST_ADDRESS = exports.SOURCE_ROUTE_OVERHEAD_UNKNOWN = exports.EMBER_NULL_ADDRESS_TABLE_INDEX = exports.EMBER_DISCOVERY_ACTIVE_NODE_ID = exports.EMBER_UNKNOWN_NODE_ID = exports.EMBER_MULTICAST_NODE_ID = exports.INVALID_RADIO_CHANNEL = exports.INVALID_CONFIG_VALUE = void 0; /** Serves to initialize cache for config IDs */ exports.INVALID_CONFIG_VALUE = 0xffff; /** Serves to initialize cache */ exports.INVALID_RADIO_CHANNEL = 0xff; /** * A distinguished network ID that will never be assigned to any node. * This value is returned when getting the remote node ID from the binding table and the given binding table index refers * to a multicast binding entry. */ exports.EMBER_MULTICAST_NODE_ID = 0xfffe; /** * A distinguished network ID that will never be assigned * to any node. This value is used when getting the remote node ID * from the address or binding tables. It indicates that the address * or binding table entry is currently in use but the node ID * corresponding to the EUI64 in the table is currently unknown. */ exports.EMBER_UNKNOWN_NODE_ID = 0xfffd; /** * A distinguished network ID that will never be assigned * to any node. This value is used when getting the remote node ID * from the address or binding tables. It indicates that the address * or binding table entry is currently in use and network address * discovery is underway. */ exports.EMBER_DISCOVERY_ACTIVE_NODE_ID = 0xfffc; /** A distinguished address table index used to indicate the absence of an address table entry. */ exports.EMBER_NULL_ADDRESS_TABLE_INDEX = 0xff; /** Invalidates cached information */ exports.SOURCE_ROUTE_OVERHEAD_UNKNOWN = 0xff; //------------------------------------------------------------------------------------------------- // Network // From table 3.51 of 053474r14 // When sending many-to-one route requests, the following // addresses are used // 0xFFF9 indicates a non-memory-constrained many-to-one route request // 0xFFF8 indicates a memory-constrained many-to-one route request exports.EMBER_MIN_BROADCAST_ADDRESS = 0xfff8; /** * The additional overhead required for network source routing (relay count = 1, relay index = 1). * This does not include the size of the relay list itself. */ exports.NWK_SOURCE_ROUTE_OVERHEAD = 2; exports.SOURCE_ROUTING_RESERVED_PAYLOAD_LENGTH = 0; /** * The maximum APS payload, not including any APS options. * This value is also available from emberMaximumApsPayloadLength() or ezspMaximumPayloadLength(). * See http://portal.ember.com/faq/payload for more information. */ exports.MAXIMUM_APS_PAYLOAD_LENGTH = 82 - exports.SOURCE_ROUTING_RESERVED_PAYLOAD_LENGTH; // export const MAXIMUM_APS_PAYLOAD_LENGTH_SECURITY_NONE = (100 - SOURCE_ROUTING_RESERVED_PAYLOAD_LENGTH); /** The additional overhead required for APS encryption (security = 5, MIC = 4). */ exports.APS_ENCRYPTION_OVERHEAD = 9; /** The additional overhead required for APS fragmentation. */ exports.APS_FRAGMENTATION_OVERHEAD = 2; /** An inactive concentrator. */ exports.EMBER_INACTIVE_CONCENTRATOR = 0xffff; /** * A concentrator with insufficient memory to store source routes for the entire network. * Route records are sent to the concentrator prior to every inbound APS unicast. */ exports.EMBER_LOW_RAM_CONCENTRATOR = 0xfff8; /** * A concentrator with sufficient memory to store source routes for the entire network. * Remote nodes stop sending route records once the concentrator has successfully received one. */ exports.EMBER_HIGH_RAM_CONCENTRATOR = 0xfff9; //------------------------------------------------------------------------------------------------- // Security /** The short address of the trust center. This address never changes dynamically. */ exports.EMBER_TRUST_CENTER_NODE_ID = 0x0000; /** * Default value for context's PSA algorithm permission (CCM* with 4 byte tag). * Only used by NCPs with secure key storage; define is mirrored here to allow * host code to initialize the context itself rather than needing a new EZSP frame. */ exports.ZB_PSA_ALG = 0x05440100; exports.STACK_PROFILE_ZIGBEE_PRO = 0x02; exports.SECURITY_LEVEL_Z3 = 0x05; /** This key is "ZigBeeAlliance09" */ exports.ZIGBEE_PROFILE_INTEROPERABILITY_LINK_KEY = [ 0x5a, 0x69, 0x67, 0x42, 0x65, 0x65, 0x41, 0x6c, 0x6c, 0x69, 0x61, 0x6e, 0x63, 0x65, 0x30, 0x39, ]; //------------------------------------------------------------------------------------------------- // Zigbee Green Power types and defines. /** Number of GP sink list entries. Minimum is 2 sink list entries. */ exports.GP_SINK_LIST_ENTRIES = 2; /** The size of the SinkList entries in sink table in format of octet string that has a format of {<1 byte length>, <n bytes for sink groups>} */ exports.GP_SIZE_OF_SINK_LIST_ENTRIES_OCTET_STRING = 1 + exports.GP_SINK_LIST_ENTRIES * 4; // sizeof(EmberGpSinkGroup) === uint16_t * 2 //------------------------------------------------------------------------------------------------- //-- InterPAN // Max PHY size = 128 // -1 byte for PHY length // -2 bytes for MAC CRC exports.MAXIMUM_INTERPAN_LENGTH = 125; // MAC frame control // Bits: // | 0-2 | 3 | 4 | 5 | 6 | 7-9 | 10-11 | 12-13 | 14-15 | // | Frame | Security | Frame | Ack | Intra | Reserved | Dest. | Reserved | Src | // | Type | Enabled | Pending | Req | PAN | | Addr. | | Adrr. | // | | | | | | | Mode | | Mode | // Frame Type // 000 = Beacon // 001 = Data // 010 = Acknwoledgement // 011 = MAC Command // 100 - 111 = Reserved // Addressing Mode // 00 - PAN ID and address field are not present // 01 - Reserved // 10 - Address field contains a 16-bit short address // 11 - Address field contains a 64-bit extended address const MAC_FRAME_TYPE_DATA = 0x0001; // const MAC_FRAME_SOURCE_MODE_SHORT = 0x8000; const MAC_FRAME_SOURCE_MODE_LONG = 0xc000; const MAC_FRAME_DESTINATION_MODE_SHORT = 0x0800; const MAC_FRAME_DESTINATION_MODE_LONG = 0x0c00; // The two possible incoming MAC frame controls. // Using short source address is not allowed. exports.SHORT_DEST_FRAME_CONTROL = MAC_FRAME_TYPE_DATA | MAC_FRAME_DESTINATION_MODE_SHORT | MAC_FRAME_SOURCE_MODE_LONG; exports.LONG_DEST_FRAME_CONTROL = MAC_FRAME_TYPE_DATA | MAC_FRAME_DESTINATION_MODE_LONG | MAC_FRAME_SOURCE_MODE_LONG; exports.MAC_ACK_REQUIRED = 0x0020; /** NWK stub frame has two control bytes. */ exports.STUB_NWK_SIZE = 2; exports.STUB_NWK_FRAME_CONTROL = 0x000b; /** * Interpan APS Unicast, same for Broadcast. * - Frame Control (1-byte) * - Cluster ID (2-bytes) * - Profile ID (2-bytes) */ exports.INTERPAN_APS_UNICAST_BROADCAST_SIZE = 5; /** * Interpan APS Multicast * - Frame Control (1-byte) * - Group ID (2-bytes) * - Cluster ID (2-bytes) * - Profile ID (2-bytes) */ exports.INTERPAN_APS_MULTICAST_SIZE = 7; exports.MAX_STUB_APS_SIZE = exports.INTERPAN_APS_MULTICAST_SIZE; exports.MIN_STUB_APS_SIZE = exports.INTERPAN_APS_UNICAST_BROADCAST_SIZE; exports.INTERPAN_APS_FRAME_TYPE = 0x03; exports.INTERPAN_APS_FRAME_TYPE_MASK = 0x03; /** The only allowed APS FC value (without the delivery mode subfield) */ exports.INTERPAN_APS_FRAME_CONTROL_NO_DELIVERY_MODE = exports.INTERPAN_APS_FRAME_TYPE; exports.INTERPAN_APS_FRAME_DELIVERY_MODE_MASK = 0x0c; exports.INTERPAN_APS_FRAME_SECURITY = 0x20; exports.MANUFACTURING_STRING_SIZE = 16; //# sourceMappingURL=consts.js.map