@willieee802/zigbee-herdsman 0.48.3 → 0.49.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.github/ISSUE_TEMPLATE/config.yml +5 -0
- package/.github/copilot-instructions.md +689 -0
- package/.github/dependabot.yml +22 -0
- package/.github/prompts/copilot-instructions-blueprint-generator.prompt.md +294 -0
- package/.github/prompts/create-agentsmd.prompt.md +249 -0
- package/.github/prompts/create-specification.prompt.md +127 -0
- package/.github/prompts/review-and-refactor.prompt.md +15 -0
- package/.github/prompts/update-specification.prompt.md +127 -0
- package/.github/workflows/ci.yml +70 -0
- package/.github/workflows/release-please.yml +18 -0
- package/.github/workflows/stale.yml +20 -0
- package/.github/workflows/typedoc.yaml +47 -0
- package/.release-please-manifest.json +2 -2
- package/.vscode/extensions.json +3 -0
- package/.vscode/settings.json +11 -0
- package/AGENTS.md +441 -0
- package/CHANGELOG.md +1245 -0
- package/README.md +1 -1
- package/biome.json +103 -0
- package/examples/join-and-log.js +18 -18
- package/package.json +83 -70
- package/release-please-config.json +8 -8
- package/scripts/check-clusters-changes.ts +328 -0
- package/scripts/clusters-changes.log +584 -0
- package/scripts/clusters-typegen.ts +608 -0
- package/scripts/utils.ts +88 -0
- package/scripts/zap-update-clusters-report.json +303 -0
- package/scripts/zap-update-clusters.ts +1520 -0
- package/scripts/zap-update-types.ts +707 -0
- package/scripts/zap-xml-clusters-overrides-data.ts +52 -0
- package/scripts/zap-xml-clusters-overrides.ts +400 -0
- package/scripts/zap-xml-types.ts +146 -0
- package/src/adapter/adapter.ts +210 -0
- package/src/adapter/adapterDiscovery.ts +736 -0
- package/src/adapter/const.ts +12 -0
- package/src/adapter/deconz/adapter/deconzAdapter.ts +888 -0
- package/src/adapter/deconz/driver/constants.ts +246 -0
- package/src/adapter/deconz/driver/driver.ts +1528 -0
- package/src/adapter/deconz/driver/frame.ts +11 -0
- package/src/adapter/deconz/driver/frameParser.ts +766 -0
- package/src/adapter/deconz/driver/parser.ts +45 -0
- package/src/adapter/deconz/driver/writer.ts +22 -0
- package/src/adapter/deconz/types.d.ts +13 -0
- package/src/adapter/ember/adapter/emberAdapter.ts +2262 -0
- package/src/adapter/ember/adapter/endpoints.ts +86 -0
- package/src/adapter/ember/adapter/oneWaitress.ts +324 -0
- package/src/adapter/ember/adapter/tokensManager.ts +780 -0
- package/src/adapter/ember/consts.ts +178 -0
- package/src/adapter/ember/enums.ts +1746 -0
- package/src/adapter/ember/ezsp/buffalo.ts +1392 -0
- package/src/adapter/ember/ezsp/consts.ts +148 -0
- package/src/adapter/ember/ezsp/enums.ts +1114 -0
- package/src/adapter/ember/ezsp/ezsp.ts +9073 -0
- package/src/adapter/ember/ezspError.ts +10 -0
- package/src/adapter/ember/types.ts +866 -0
- package/src/adapter/ember/uart/ash.ts +1933 -0
- package/src/adapter/ember/uart/consts.ts +109 -0
- package/src/adapter/ember/uart/enums.ts +192 -0
- package/src/adapter/ember/uart/parser.ts +42 -0
- package/src/adapter/ember/uart/queues.ts +247 -0
- package/src/adapter/ember/uart/writer.ts +50 -0
- package/src/adapter/ember/utils/initters.ts +58 -0
- package/src/adapter/ember/utils/math.ts +71 -0
- package/src/adapter/events.ts +21 -0
- package/src/adapter/ezsp/adapter/backup.ts +100 -0
- package/src/adapter/ezsp/adapter/ezspAdapter.ts +632 -0
- package/src/adapter/ezsp/driver/commands.ts +2497 -0
- package/src/adapter/ezsp/driver/consts.ts +11 -0
- package/src/adapter/ezsp/driver/driver.ts +1002 -0
- package/src/adapter/ezsp/driver/ezsp.ts +802 -0
- package/src/adapter/ezsp/driver/frame.ts +101 -0
- package/src/adapter/ezsp/driver/index.ts +4 -0
- package/src/adapter/ezsp/driver/multicast.ts +78 -0
- package/src/adapter/ezsp/driver/parser.ts +81 -0
- package/src/adapter/ezsp/driver/types/basic.ts +201 -0
- package/src/adapter/ezsp/driver/types/index.ts +239 -0
- package/src/adapter/ezsp/driver/types/named.ts +2330 -0
- package/src/adapter/ezsp/driver/types/struct.ts +844 -0
- package/src/adapter/ezsp/driver/uart.ts +460 -0
- package/src/adapter/ezsp/driver/utils/crc16ccitt.ts +44 -0
- package/src/adapter/ezsp/driver/utils/index.ts +32 -0
- package/src/adapter/ezsp/driver/writer.ts +64 -0
- package/src/adapter/index.ts +3 -0
- package/src/adapter/serialPort.ts +58 -0
- package/src/adapter/tstype.ts +57 -0
- package/src/adapter/utils.ts +41 -0
- package/src/adapter/z-stack/adapter/adapter-backup.ts +509 -0
- package/src/adapter/z-stack/adapter/adapter-nv-memory.ts +457 -0
- package/src/adapter/z-stack/adapter/endpoints.ts +60 -0
- package/src/adapter/z-stack/adapter/manager.ts +543 -0
- package/src/adapter/z-stack/adapter/tstype.ts +6 -0
- package/src/adapter/z-stack/adapter/zStackAdapter.ts +1350 -0
- package/src/adapter/z-stack/constants/af.ts +27 -0
- package/src/adapter/z-stack/constants/common.ts +285 -0
- package/src/adapter/z-stack/constants/dbg.ts +23 -0
- package/src/adapter/z-stack/constants/index.ts +11 -0
- package/src/adapter/z-stack/constants/mac.ts +128 -0
- package/src/adapter/z-stack/constants/sapi.ts +25 -0
- package/src/adapter/z-stack/constants/sys.ts +72 -0
- package/src/adapter/z-stack/constants/util.ts +82 -0
- package/src/adapter/z-stack/constants/utils.ts +14 -0
- package/src/adapter/z-stack/constants/zdo.ts +103 -0
- package/src/adapter/z-stack/models/startup-options.ts +13 -0
- package/src/adapter/z-stack/structs/entries/address-manager-entry.ts +44 -0
- package/src/adapter/z-stack/structs/entries/address-manager-table.ts +19 -0
- package/src/adapter/z-stack/structs/entries/aps-link-key-data-entry.ts +12 -0
- package/src/adapter/z-stack/structs/entries/aps-link-key-data-table.ts +21 -0
- package/src/adapter/z-stack/structs/entries/aps-tc-link-key-entry.ts +19 -0
- package/src/adapter/z-stack/structs/entries/aps-tc-link-key-table.ts +21 -0
- package/src/adapter/z-stack/structs/entries/channel-list.ts +8 -0
- package/src/adapter/z-stack/structs/entries/has-configured.ts +16 -0
- package/src/adapter/z-stack/structs/entries/index.ts +16 -0
- package/src/adapter/z-stack/structs/entries/nib.ts +66 -0
- package/src/adapter/z-stack/structs/entries/nwk-key-descriptor.ts +15 -0
- package/src/adapter/z-stack/structs/entries/nwk-key.ts +13 -0
- package/src/adapter/z-stack/structs/entries/nwk-pan-id.ts +8 -0
- package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.ts +20 -0
- package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.ts +19 -0
- package/src/adapter/z-stack/structs/entries/security-manager-entry.ts +33 -0
- package/src/adapter/z-stack/structs/entries/security-manager-table.ts +22 -0
- package/src/adapter/z-stack/structs/index.ts +4 -0
- package/src/adapter/z-stack/structs/serializable-memory-object.ts +14 -0
- package/src/adapter/z-stack/structs/struct.ts +367 -0
- package/src/adapter/z-stack/structs/table.ts +198 -0
- package/src/adapter/z-stack/unpi/constants.ts +33 -0
- package/src/adapter/z-stack/unpi/frame.ts +62 -0
- package/src/adapter/z-stack/unpi/index.ts +4 -0
- package/src/adapter/z-stack/unpi/parser.ts +67 -0
- package/src/adapter/z-stack/unpi/writer.ts +37 -0
- package/src/adapter/z-stack/utils/channel-list.ts +40 -0
- package/src/adapter/z-stack/utils/index.ts +2 -0
- package/src/adapter/z-stack/utils/network-options.ts +26 -0
- package/src/adapter/z-stack/znp/buffaloZnp.ts +175 -0
- package/src/adapter/z-stack/znp/definition.ts +2713 -0
- package/src/adapter/z-stack/znp/index.ts +2 -0
- package/src/adapter/z-stack/znp/parameterType.ts +22 -0
- package/src/adapter/z-stack/znp/tstype.ts +44 -0
- package/src/adapter/z-stack/znp/utils.ts +10 -0
- package/src/adapter/z-stack/znp/znp.ts +345 -0
- package/src/adapter/z-stack/znp/zpiObject.ts +148 -0
- package/src/adapter/zboss/adapter/zbossAdapter.ts +535 -0
- package/src/adapter/zboss/commands.ts +1184 -0
- package/src/adapter/zboss/consts.ts +9 -0
- package/src/adapter/zboss/driver.ts +422 -0
- package/src/adapter/zboss/enums.ts +360 -0
- package/src/adapter/zboss/frame.ts +227 -0
- package/src/adapter/zboss/reader.ts +65 -0
- package/src/adapter/zboss/types.ts +0 -0
- package/src/adapter/zboss/uart.ts +428 -0
- package/src/adapter/zboss/utils.ts +58 -0
- package/src/adapter/zboss/writer.ts +49 -0
- package/src/adapter/zigate/adapter/patchZdoBuffaloBE.ts +25 -0
- package/src/adapter/zigate/adapter/zigateAdapter.ts +633 -0
- package/src/adapter/zigate/driver/LICENSE +17 -0
- package/src/adapter/zigate/driver/buffaloZiGate.ts +210 -0
- package/src/adapter/zigate/driver/commandType.ts +418 -0
- package/src/adapter/zigate/driver/constants.ts +150 -0
- package/src/adapter/zigate/driver/frame.ts +197 -0
- package/src/adapter/zigate/driver/messageType.ts +287 -0
- package/src/adapter/zigate/driver/parameterType.ts +32 -0
- package/src/adapter/zigate/driver/ziGateObject.ts +146 -0
- package/src/adapter/zigate/driver/zigate.ts +422 -0
- package/src/adapter/zoh/adapter/utils.ts +27 -0
- package/src/adapter/zoh/adapter/zohAdapter.ts +931 -0
- package/src/buffalo/buffalo.ts +336 -0
- package/src/buffalo/index.ts +1 -0
- package/src/controller/controller.ts +1159 -0
- package/src/controller/database.ts +148 -0
- package/src/controller/events.ts +52 -0
- package/src/controller/greenPower.ts +613 -0
- package/src/controller/helpers/index.ts +1 -0
- package/src/controller/helpers/installCodes.ts +107 -0
- package/src/controller/helpers/ota.ts +575 -0
- package/src/controller/helpers/request.ts +96 -0
- package/src/controller/helpers/requestQueue.ts +126 -0
- package/src/controller/helpers/zclFrameConverter.ts +64 -0
- package/src/controller/helpers/zclTransactionSequenceNumber.ts +15 -0
- package/src/controller/index.ts +6 -0
- package/src/controller/model/device.ts +1791 -0
- package/src/controller/model/endpoint.ts +1235 -0
- package/src/controller/model/entity.ts +43 -0
- package/src/controller/model/group.ts +446 -0
- package/src/controller/model/index.ts +5 -0
- package/src/controller/model/konnextConfig.ts +6 -0
- package/src/controller/model/zigbeeEntity.ts +30 -0
- package/src/controller/touchlink.ts +195 -0
- package/src/controller/tstype.ts +374 -0
- package/src/index.ts +14 -0
- package/src/models/backup-storage-legacy.ts +48 -0
- package/src/models/backup-storage-unified.ts +47 -0
- package/src/models/backup.ts +37 -0
- package/src/models/index.ts +5 -0
- package/src/models/network-options.ts +11 -0
- package/src/utils/aes.ts +218 -0
- package/src/utils/async-mutex.ts +31 -0
- package/src/utils/backup.ts +152 -0
- package/src/utils/index.ts +5 -0
- package/src/utils/logger.ts +20 -0
- package/src/utils/patchBigIntSerialization.ts +8 -0
- package/src/utils/queue.ts +79 -0
- package/src/utils/timeService.ts +139 -0
- package/src/utils/utils.ts +19 -0
- package/src/utils/wait.ts +5 -0
- package/src/utils/waitress.ts +96 -0
- package/src/zspec/consts.ts +89 -0
- package/src/zspec/enums.ts +22 -0
- package/src/zspec/index.ts +3 -0
- package/src/zspec/tstypes.ts +18 -0
- package/src/zspec/utils.ts +247 -0
- package/src/zspec/zcl/buffaloZcl.ts +1073 -0
- package/src/zspec/zcl/definition/cluster.ts +7845 -0
- package/src/zspec/zcl/definition/clusters-types.ts +8577 -0
- package/src/zspec/zcl/definition/consts.ts +24 -0
- package/src/zspec/zcl/definition/datatypes.ts +2454 -0
- package/src/zspec/zcl/definition/enums.ts +224 -0
- package/src/zspec/zcl/definition/foundation.ts +342 -0
- package/src/zspec/zcl/definition/manufacturerCode.ts +730 -0
- package/src/zspec/zcl/definition/status.ts +69 -0
- package/src/zspec/zcl/definition/tstype.ts +446 -0
- package/src/zspec/zcl/index.ts +11 -0
- package/src/zspec/zcl/utils.ts +521 -0
- package/src/zspec/zcl/zclFrame.ts +383 -0
- package/src/zspec/zcl/zclHeader.ts +102 -0
- package/src/zspec/zcl/zclStatusError.ts +10 -0
- package/src/zspec/zdo/buffaloZdo.ts +2336 -0
- package/src/zspec/zdo/definition/clusters.ts +722 -0
- package/src/zspec/zdo/definition/consts.ts +16 -0
- package/src/zspec/zdo/definition/enums.ts +99 -0
- package/src/zspec/zdo/definition/status.ts +105 -0
- package/src/zspec/zdo/definition/tstypes.ts +1062 -0
- package/src/zspec/zdo/index.ts +7 -0
- package/src/zspec/zdo/utils.ts +76 -0
- package/src/zspec/zdo/zdoStatusError.ts +10 -0
- package/test/adapter/adapter.test.ts +1276 -0
- package/test/adapter/ember/ash.test.ts +337 -0
- package/test/adapter/ember/consts.ts +131 -0
- package/test/adapter/ember/emberAdapter.test.ts +3447 -0
- package/test/adapter/ember/ezsp.test.ts +389 -0
- package/test/adapter/ember/ezspBuffalo.test.ts +93 -0
- package/test/adapter/ember/ezspError.test.ts +12 -0
- package/test/adapter/ember/math.test.ts +190 -0
- package/test/adapter/ezsp/frame.test.ts +30 -0
- package/test/adapter/ezsp/uart.test.ts +181 -0
- package/test/adapter/z-stack/adapter.test.ts +4260 -0
- package/test/adapter/z-stack/constants.test.ts +33 -0
- package/test/adapter/z-stack/structs.test.ts +115 -0
- package/test/adapter/z-stack/unpi.test.ts +213 -0
- package/test/adapter/z-stack/znp.test.ts +1288 -0
- package/test/adapter/zboss/fixZdoResponse.test.ts +179 -0
- package/test/adapter/zigate/patchZdoBuffaloBE.test.ts +81 -0
- package/test/adapter/zigate/zdo.test.ts +187 -0
- package/test/adapter/zoh/utils.test.ts +36 -0
- package/test/adapter/zoh/zohAdapter.test.ts +1451 -0
- package/test/benchOptions.ts +14 -0
- package/test/buffalo.test.ts +431 -0
- package/test/controller.bench.ts +215 -0
- package/test/controller.test.ts +10030 -0
- package/test/data/integrity-code-1166-012B-24031511-upgradeMe-RB 249 T.zigbee +0 -0
- package/test/data/manuf-tags-tradfri-cv-cct-unified_release_prod_v587757105_33e34452-9267-4665-bc5a-844c8f61f063.ota +0 -0
- package/test/data/padded-tretakt_smart_plug_soc-0x1100-2.4.25-prod.ota.ota.signed +0 -0
- package/test/data/telink-aes-A60_RGBW_T-0x00B6-0x03483712-MF_DIS.OTA +0 -0
- package/test/data/zbminir2_v1.0.8.ota +0 -0
- package/test/device-ota.test.ts +3332 -0
- package/test/greenpower.test.ts +1409 -0
- package/test/mockAdapters.ts +95 -0
- package/test/mockDevices.ts +623 -0
- package/test/requests.bench.ts +321 -0
- package/test/testUtils.ts +20 -0
- package/test/timeService.test.ts +214 -0
- package/test/tsconfig.json +9 -0
- package/test/utils/math.ts +19 -0
- package/test/utils.test.ts +352 -0
- package/test/vitest.config.mts +28 -0
- package/test/vitest.ts +9 -0
- package/test/zcl.test.ts +2858 -0
- package/test/zspec/utils.test.ts +68 -0
- package/test/zspec/zcl/buffalo.test.ts +1316 -0
- package/test/zspec/zcl/frame.test.ts +1056 -0
- package/test/zspec/zcl/utils.test.ts +650 -0
- package/test/zspec/zdo/buffalo.test.ts +1850 -0
- package/test/zspec/zdo/utils.test.ts +241 -0
- package/tsconfig.json +8 -10
- package/.babelrc.js +0 -6
- package/.eslintignore +0 -3
- package/dist/adapter/adapter.d.ts +0 -64
- package/dist/adapter/adapter.d.ts.map +0 -1
- package/dist/adapter/adapter.js +0 -157
- package/dist/adapter/adapter.js.map +0 -1
- package/dist/adapter/deconz/adapter/deconzAdapter.d.ts +0 -71
- package/dist/adapter/deconz/adapter/deconzAdapter.d.ts.map +0 -1
- package/dist/adapter/deconz/adapter/deconzAdapter.js +0 -1072
- package/dist/adapter/deconz/adapter/deconzAdapter.js.map +0 -1
- package/dist/adapter/deconz/adapter/index.d.ts +0 -3
- package/dist/adapter/deconz/adapter/index.d.ts.map +0 -1
- package/dist/adapter/deconz/adapter/index.js +0 -11
- package/dist/adapter/deconz/adapter/index.js.map +0 -1
- package/dist/adapter/deconz/driver/constants.d.ts +0 -105
- package/dist/adapter/deconz/driver/constants.d.ts.map +0 -1
- package/dist/adapter/deconz/driver/constants.js +0 -56
- package/dist/adapter/deconz/driver/constants.js.map +0 -1
- package/dist/adapter/deconz/driver/driver.d.ts +0 -82
- package/dist/adapter/deconz/driver/driver.d.ts.map +0 -1
- package/dist/adapter/deconz/driver/driver.js +0 -751
- package/dist/adapter/deconz/driver/driver.js.map +0 -1
- package/dist/adapter/deconz/driver/frame.d.ts +0 -7
- package/dist/adapter/deconz/driver/frame.d.ts.map +0 -1
- package/dist/adapter/deconz/driver/frame.js +0 -14
- package/dist/adapter/deconz/driver/frame.js.map +0 -1
- package/dist/adapter/deconz/driver/frameParser.d.ts +0 -3
- package/dist/adapter/deconz/driver/frameParser.d.ts.map +0 -1
- package/dist/adapter/deconz/driver/frameParser.js +0 -444
- package/dist/adapter/deconz/driver/frameParser.js.map +0 -1
- package/dist/adapter/deconz/driver/parser.d.ts +0 -13
- package/dist/adapter/deconz/driver/parser.d.ts.map +0 -1
- package/dist/adapter/deconz/driver/parser.js +0 -64
- package/dist/adapter/deconz/driver/parser.js.map +0 -1
- package/dist/adapter/deconz/driver/writer.d.ts +0 -9
- package/dist/adapter/deconz/driver/writer.d.ts.map +0 -1
- package/dist/adapter/deconz/driver/writer.js +0 -45
- package/dist/adapter/deconz/driver/writer.js.map +0 -1
- package/dist/adapter/ember/adapter/emberAdapter.d.ts +0 -806
- package/dist/adapter/ember/adapter/emberAdapter.d.ts.map +0 -1
- package/dist/adapter/ember/adapter/emberAdapter.js +0 -2942
- package/dist/adapter/ember/adapter/emberAdapter.js.map +0 -1
- package/dist/adapter/ember/adapter/endpoints.d.ts +0 -27
- package/dist/adapter/ember/adapter/endpoints.d.ts.map +0 -1
- package/dist/adapter/ember/adapter/endpoints.js +0 -68
- package/dist/adapter/ember/adapter/endpoints.js.map +0 -1
- package/dist/adapter/ember/adapter/index.d.ts +0 -3
- package/dist/adapter/ember/adapter/index.d.ts.map +0 -1
- package/dist/adapter/ember/adapter/index.js +0 -6
- package/dist/adapter/ember/adapter/index.js.map +0 -1
- package/dist/adapter/ember/adapter/oneWaitress.d.ts +0 -108
- package/dist/adapter/ember/adapter/oneWaitress.d.ts.map +0 -1
- package/dist/adapter/ember/adapter/oneWaitress.js +0 -241
- package/dist/adapter/ember/adapter/oneWaitress.js.map +0 -1
- package/dist/adapter/ember/adapter/requestQueue.d.ts +0 -57
- package/dist/adapter/ember/adapter/requestQueue.d.ts.map +0 -1
- package/dist/adapter/ember/adapter/requestQueue.js +0 -139
- package/dist/adapter/ember/adapter/requestQueue.js.map +0 -1
- package/dist/adapter/ember/adapter/tokensManager.d.ts +0 -69
- package/dist/adapter/ember/adapter/tokensManager.d.ts.map +0 -1
- package/dist/adapter/ember/adapter/tokensManager.js +0 -688
- package/dist/adapter/ember/adapter/tokensManager.js.map +0 -1
- package/dist/adapter/ember/consts.d.ts +0 -191
- package/dist/adapter/ember/consts.d.ts.map +0 -1
- package/dist/adapter/ember/consts.js +0 -246
- package/dist/adapter/ember/consts.js.map +0 -1
- package/dist/adapter/ember/enums.d.ts +0 -2172
- package/dist/adapter/ember/enums.d.ts.map +0 -1
- package/dist/adapter/ember/enums.js +0 -2375
- package/dist/adapter/ember/enums.js.map +0 -1
- package/dist/adapter/ember/ezsp/buffalo.d.ts +0 -156
- package/dist/adapter/ember/ezsp/buffalo.d.ts.map +0 -1
- package/dist/adapter/ember/ezsp/buffalo.js +0 -1033
- package/dist/adapter/ember/ezsp/buffalo.js.map +0 -1
- package/dist/adapter/ember/ezsp/consts.d.ts +0 -116
- package/dist/adapter/ember/ezsp/consts.d.ts.map +0 -1
- package/dist/adapter/ember/ezsp/consts.js +0 -128
- package/dist/adapter/ember/ezsp/consts.js.map +0 -1
- package/dist/adapter/ember/ezsp/enums.d.ts +0 -879
- package/dist/adapter/ember/ezsp/enums.d.ts.map +0 -1
- package/dist/adapter/ember/ezsp/enums.js +0 -948
- package/dist/adapter/ember/ezsp/enums.js.map +0 -1
- package/dist/adapter/ember/ezsp/ezsp.d.ts +0 -2662
- package/dist/adapter/ember/ezsp/ezsp.d.ts.map +0 -1
- package/dist/adapter/ember/ezsp/ezsp.js +0 -6454
- package/dist/adapter/ember/ezsp/ezsp.js.map +0 -1
- package/dist/adapter/ember/types.d.ts +0 -733
- package/dist/adapter/ember/types.d.ts.map +0 -1
- package/dist/adapter/ember/types.js +0 -3
- package/dist/adapter/ember/types.js.map +0 -1
- package/dist/adapter/ember/uart/ash.d.ts +0 -464
- package/dist/adapter/ember/uart/ash.d.ts.map +0 -1
- package/dist/adapter/ember/uart/ash.js +0 -1633
- package/dist/adapter/ember/uart/ash.js.map +0 -1
- package/dist/adapter/ember/uart/consts.d.ts +0 -91
- package/dist/adapter/ember/uart/consts.d.ts.map +0 -1
- package/dist/adapter/ember/uart/consts.js +0 -100
- package/dist/adapter/ember/uart/consts.js.map +0 -1
- package/dist/adapter/ember/uart/enums.d.ts +0 -191
- package/dist/adapter/ember/uart/enums.d.ts.map +0 -1
- package/dist/adapter/ember/uart/enums.js +0 -197
- package/dist/adapter/ember/uart/enums.js.map +0 -1
- package/dist/adapter/ember/uart/parser.d.ts +0 -10
- package/dist/adapter/ember/uart/parser.d.ts.map +0 -1
- package/dist/adapter/ember/uart/parser.js +0 -37
- package/dist/adapter/ember/uart/parser.js.map +0 -1
- package/dist/adapter/ember/uart/queues.d.ts +0 -85
- package/dist/adapter/ember/uart/queues.d.ts.map +0 -1
- package/dist/adapter/ember/uart/queues.js +0 -214
- package/dist/adapter/ember/uart/queues.js.map +0 -1
- package/dist/adapter/ember/uart/writer.d.ts +0 -15
- package/dist/adapter/ember/uart/writer.d.ts.map +0 -1
- package/dist/adapter/ember/uart/writer.js +0 -46
- package/dist/adapter/ember/uart/writer.js.map +0 -1
- package/dist/adapter/ember/utils/initters.d.ts +0 -20
- package/dist/adapter/ember/utils/initters.d.ts.map +0 -1
- package/dist/adapter/ember/utils/initters.js +0 -58
- package/dist/adapter/ember/utils/initters.js.map +0 -1
- package/dist/adapter/ember/utils/math.d.ts +0 -51
- package/dist/adapter/ember/utils/math.d.ts.map +0 -1
- package/dist/adapter/ember/utils/math.js +0 -102
- package/dist/adapter/ember/utils/math.js.map +0 -1
- package/dist/adapter/ember/zdo.d.ts +0 -925
- package/dist/adapter/ember/zdo.d.ts.map +0 -1
- package/dist/adapter/ember/zdo.js +0 -723
- package/dist/adapter/ember/zdo.js.map +0 -1
- package/dist/adapter/events.d.ts +0 -42
- package/dist/adapter/events.d.ts.map +0 -1
- package/dist/adapter/events.js +0 -13
- package/dist/adapter/events.js.map +0 -1
- package/dist/adapter/ezsp/adapter/backup.d.ts +0 -13
- package/dist/adapter/ezsp/adapter/backup.d.ts.map +0 -1
- package/dist/adapter/ezsp/adapter/backup.js +0 -101
- package/dist/adapter/ezsp/adapter/backup.js.map +0 -1
- package/dist/adapter/ezsp/adapter/ezspAdapter.d.ts +0 -65
- package/dist/adapter/ezsp/adapter/ezspAdapter.d.ts.map +0 -1
- package/dist/adapter/ezsp/adapter/ezspAdapter.js +0 -634
- package/dist/adapter/ezsp/adapter/ezspAdapter.js.map +0 -1
- package/dist/adapter/ezsp/adapter/index.d.ts +0 -3
- package/dist/adapter/ezsp/adapter/index.d.ts.map +0 -1
- package/dist/adapter/ezsp/adapter/index.js +0 -11
- package/dist/adapter/ezsp/adapter/index.js.map +0 -1
- package/dist/adapter/ezsp/driver/commands.d.ts +0 -37
- package/dist/adapter/ezsp/driver/commands.d.ts.map +0 -1
- package/dist/adapter/ezsp/driver/commands.js +0 -2387
- package/dist/adapter/ezsp/driver/commands.js.map +0 -1
- package/dist/adapter/ezsp/driver/consts.d.ts +0 -11
- package/dist/adapter/ezsp/driver/consts.d.ts.map +0 -1
- package/dist/adapter/ezsp/driver/consts.js +0 -14
- package/dist/adapter/ezsp/driver/consts.js.map +0 -1
- package/dist/adapter/ezsp/driver/driver.d.ts +0 -109
- package/dist/adapter/ezsp/driver/driver.d.ts.map +0 -1
- package/dist/adapter/ezsp/driver/driver.js +0 -796
- package/dist/adapter/ezsp/driver/driver.js.map +0 -1
- package/dist/adapter/ezsp/driver/ezsp.d.ts +0 -106
- package/dist/adapter/ezsp/driver/ezsp.d.ts.map +0 -1
- package/dist/adapter/ezsp/driver/ezsp.js +0 -664
- package/dist/adapter/ezsp/driver/ezsp.js.map +0 -1
- package/dist/adapter/ezsp/driver/frame.d.ts +0 -40
- package/dist/adapter/ezsp/driver/frame.d.ts.map +0 -1
- package/dist/adapter/ezsp/driver/frame.js +0 -101
- package/dist/adapter/ezsp/driver/frame.js.map +0 -1
- package/dist/adapter/ezsp/driver/index.d.ts +0 -4
- package/dist/adapter/ezsp/driver/index.d.ts.map +0 -1
- package/dist/adapter/ezsp/driver/index.js +0 -9
- package/dist/adapter/ezsp/driver/index.js.map +0 -1
- package/dist/adapter/ezsp/driver/multicast.d.ts +0 -13
- package/dist/adapter/ezsp/driver/multicast.d.ts.map +0 -1
- package/dist/adapter/ezsp/driver/multicast.js +0 -74
- package/dist/adapter/ezsp/driver/multicast.js.map +0 -1
- package/dist/adapter/ezsp/driver/parser.d.ts +0 -12
- package/dist/adapter/ezsp/driver/parser.d.ts.map +0 -1
- package/dist/adapter/ezsp/driver/parser.js +0 -105
- package/dist/adapter/ezsp/driver/parser.js.map +0 -1
- package/dist/adapter/ezsp/driver/types/basic.d.ts +0 -63
- package/dist/adapter/ezsp/driver/types/basic.d.ts.map +0 -1
- package/dist/adapter/ezsp/driver/types/basic.js +0 -209
- package/dist/adapter/ezsp/driver/types/basic.js.map +0 -1
- package/dist/adapter/ezsp/driver/types/index.d.ts +0 -10
- package/dist/adapter/ezsp/driver/types/index.d.ts.map +0 -1
- package/dist/adapter/ezsp/driver/types/index.js +0 -139
- package/dist/adapter/ezsp/driver/types/index.js.map +0 -1
- package/dist/adapter/ezsp/driver/types/named.d.ts +0 -1288
- package/dist/adapter/ezsp/driver/types/named.d.ts.map +0 -1
- package/dist/adapter/ezsp/driver/types/named.js +0 -2330
- package/dist/adapter/ezsp/driver/types/named.js.map +0 -1
- package/dist/adapter/ezsp/driver/types/struct.d.ts +0 -271
- package/dist/adapter/ezsp/driver/types/struct.d.ts.map +0 -1
- package/dist/adapter/ezsp/driver/types/struct.js +0 -804
- package/dist/adapter/ezsp/driver/types/struct.js.map +0 -1
- package/dist/adapter/ezsp/driver/uart.d.ts +0 -49
- package/dist/adapter/ezsp/driver/uart.d.ts.map +0 -1
- package/dist/adapter/ezsp/driver/uart.js +0 -383
- package/dist/adapter/ezsp/driver/uart.js.map +0 -1
- package/dist/adapter/ezsp/driver/utils/crc16ccitt.d.ts +0 -3
- package/dist/adapter/ezsp/driver/utils/crc16ccitt.d.ts.map +0 -1
- package/dist/adapter/ezsp/driver/utils/crc16ccitt.js +0 -56
- package/dist/adapter/ezsp/driver/utils/crc16ccitt.js.map +0 -1
- package/dist/adapter/ezsp/driver/utils/index.d.ts +0 -20
- package/dist/adapter/ezsp/driver/utils/index.d.ts.map +0 -1
- package/dist/adapter/ezsp/driver/utils/index.js +0 -73
- package/dist/adapter/ezsp/driver/utils/index.js.map +0 -1
- package/dist/adapter/ezsp/driver/writer.d.ts +0 -14
- package/dist/adapter/ezsp/driver/writer.d.ts.map +0 -1
- package/dist/adapter/ezsp/driver/writer.js +0 -83
- package/dist/adapter/ezsp/driver/writer.js.map +0 -1
- package/dist/adapter/index.d.ts +0 -5
- package/dist/adapter/index.d.ts.map +0 -1
- package/dist/adapter/index.js +0 -36
- package/dist/adapter/index.js.map +0 -1
- package/dist/adapter/serialPort.d.ts +0 -14
- package/dist/adapter/serialPort.d.ts.map +0 -1
- package/dist/adapter/serialPort.js +0 -47
- package/dist/adapter/serialPort.js.map +0 -1
- package/dist/adapter/serialPortUtils.d.ts +0 -13
- package/dist/adapter/serialPortUtils.d.ts.map +0 -1
- package/dist/adapter/serialPortUtils.js +0 -19
- package/dist/adapter/serialPortUtils.js.map +0 -1
- package/dist/adapter/socketPortUtils.d.ts +0 -11
- package/dist/adapter/socketPortUtils.d.ts.map +0 -1
- package/dist/adapter/socketPortUtils.js +0 -17
- package/dist/adapter/socketPortUtils.js.map +0 -1
- package/dist/adapter/tstype.d.ts +0 -86
- package/dist/adapter/tstype.d.ts.map +0 -1
- package/dist/adapter/tstype.js +0 -3
- package/dist/adapter/tstype.js.map +0 -1
- package/dist/adapter/z-stack/adapter/adapter-backup.d.ts +0 -62
- package/dist/adapter/z-stack/adapter/adapter-backup.d.ts.map +0 -1
- package/dist/adapter/z-stack/adapter/adapter-backup.js +0 -459
- package/dist/adapter/z-stack/adapter/adapter-backup.js.map +0 -1
- package/dist/adapter/z-stack/adapter/adapter-nv-memory.d.ts +0 -151
- package/dist/adapter/z-stack/adapter/adapter-nv-memory.d.ts.map +0 -1
- package/dist/adapter/z-stack/adapter/adapter-nv-memory.js +0 -259
- package/dist/adapter/z-stack/adapter/adapter-nv-memory.js.map +0 -1
- package/dist/adapter/z-stack/adapter/endpoints.d.ts +0 -12
- package/dist/adapter/z-stack/adapter/endpoints.d.ts.map +0 -1
- package/dist/adapter/z-stack/adapter/endpoints.js +0 -74
- package/dist/adapter/z-stack/adapter/endpoints.js.map +0 -1
- package/dist/adapter/z-stack/adapter/index.d.ts +0 -3
- package/dist/adapter/z-stack/adapter/index.d.ts.map +0 -1
- package/dist/adapter/z-stack/adapter/index.js +0 -9
- package/dist/adapter/z-stack/adapter/index.js.map +0 -1
- package/dist/adapter/z-stack/adapter/manager.d.ts +0 -84
- package/dist/adapter/z-stack/adapter/manager.d.ts.map +0 -1
- package/dist/adapter/z-stack/adapter/manager.js +0 -474
- package/dist/adapter/z-stack/adapter/manager.js.map +0 -1
- package/dist/adapter/z-stack/adapter/tstype.d.ts +0 -7
- package/dist/adapter/z-stack/adapter/tstype.d.ts.map +0 -1
- package/dist/adapter/z-stack/adapter/tstype.js +0 -10
- package/dist/adapter/z-stack/adapter/tstype.js.map +0 -1
- package/dist/adapter/z-stack/adapter/zStackAdapter.d.ts +0 -86
- package/dist/adapter/z-stack/adapter/zStackAdapter.d.ts.map +0 -1
- package/dist/adapter/z-stack/adapter/zStackAdapter.js +0 -912
- package/dist/adapter/z-stack/adapter/zStackAdapter.js.map +0 -1
- package/dist/adapter/z-stack/constants/af.d.ts +0 -24
- package/dist/adapter/z-stack/constants/af.d.ts.map +0 -1
- package/dist/adapter/z-stack/constants/af.js +0 -28
- package/dist/adapter/z-stack/constants/af.js.map +0 -1
- package/dist/adapter/z-stack/constants/common.d.ts +0 -279
- package/dist/adapter/z-stack/constants/common.d.ts.map +0 -1
- package/dist/adapter/z-stack/constants/common.js +0 -293
- package/dist/adapter/z-stack/constants/common.js.map +0 -1
- package/dist/adapter/z-stack/constants/dbg.d.ts +0 -23
- package/dist/adapter/z-stack/constants/dbg.d.ts.map +0 -1
- package/dist/adapter/z-stack/constants/dbg.js +0 -25
- package/dist/adapter/z-stack/constants/dbg.js.map +0 -1
- package/dist/adapter/z-stack/constants/index.d.ts +0 -11
- package/dist/adapter/z-stack/constants/index.d.ts.map +0 -1
- package/dist/adapter/z-stack/constants/index.js +0 -48
- package/dist/adapter/z-stack/constants/index.js.map +0 -1
- package/dist/adapter/z-stack/constants/mac.d.ts +0 -128
- package/dist/adapter/z-stack/constants/mac.d.ts.map +0 -1
- package/dist/adapter/z-stack/constants/mac.js +0 -130
- package/dist/adapter/z-stack/constants/mac.js.map +0 -1
- package/dist/adapter/z-stack/constants/sapi.d.ts +0 -25
- package/dist/adapter/z-stack/constants/sapi.d.ts.map +0 -1
- package/dist/adapter/z-stack/constants/sapi.js +0 -27
- package/dist/adapter/z-stack/constants/sapi.js.map +0 -1
- package/dist/adapter/z-stack/constants/sys.d.ts +0 -72
- package/dist/adapter/z-stack/constants/sys.d.ts.map +0 -1
- package/dist/adapter/z-stack/constants/sys.js +0 -74
- package/dist/adapter/z-stack/constants/sys.js.map +0 -1
- package/dist/adapter/z-stack/constants/util.d.ts +0 -82
- package/dist/adapter/z-stack/constants/util.d.ts.map +0 -1
- package/dist/adapter/z-stack/constants/util.js +0 -84
- package/dist/adapter/z-stack/constants/util.js.map +0 -1
- package/dist/adapter/z-stack/constants/utils.d.ts +0 -5
- package/dist/adapter/z-stack/constants/utils.d.ts.map +0 -1
- package/dist/adapter/z-stack/constants/utils.js +0 -15
- package/dist/adapter/z-stack/constants/utils.js.map +0 -1
- package/dist/adapter/z-stack/constants/zdo.d.ts +0 -103
- package/dist/adapter/z-stack/constants/zdo.d.ts.map +0 -1
- package/dist/adapter/z-stack/constants/zdo.js +0 -105
- package/dist/adapter/z-stack/constants/zdo.js.map +0 -1
- package/dist/adapter/z-stack/models/index.d.ts +0 -2
- package/dist/adapter/z-stack/models/index.d.ts.map +0 -1
- package/dist/adapter/z-stack/models/index.js +0 -18
- package/dist/adapter/z-stack/models/index.js.map +0 -1
- package/dist/adapter/z-stack/models/startup-options.d.ts +0 -13
- package/dist/adapter/z-stack/models/startup-options.d.ts.map +0 -1
- package/dist/adapter/z-stack/models/startup-options.js +0 -3
- package/dist/adapter/z-stack/models/startup-options.js.map +0 -1
- package/dist/adapter/z-stack/structs/entries/address-manager-entry.d.ts +0 -24
- package/dist/adapter/z-stack/structs/entries/address-manager-entry.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/entries/address-manager-entry.js +0 -46
- package/dist/adapter/z-stack/structs/entries/address-manager-entry.js.map +0 -1
- package/dist/adapter/z-stack/structs/entries/address-manager-table.d.ts +0 -11
- package/dist/adapter/z-stack/structs/entries/address-manager-table.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/entries/address-manager-table.js +0 -23
- package/dist/adapter/z-stack/structs/entries/address-manager-table.js.map +0 -1
- package/dist/adapter/z-stack/structs/entries/aps-link-key-data-entry.d.ts +0 -11
- package/dist/adapter/z-stack/structs/entries/aps-link-key-data-entry.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/entries/aps-link-key-data-entry.js +0 -22
- package/dist/adapter/z-stack/structs/entries/aps-link-key-data-entry.js.map +0 -1
- package/dist/adapter/z-stack/structs/entries/aps-link-key-data-table.d.ts +0 -11
- package/dist/adapter/z-stack/structs/entries/aps-link-key-data-table.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/entries/aps-link-key-data-table.js +0 -24
- package/dist/adapter/z-stack/structs/entries/aps-link-key-data-table.js.map +0 -1
- package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-entry.d.ts +0 -11
- package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-entry.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-entry.js +0 -25
- package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-entry.js.map +0 -1
- package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-table.d.ts +0 -11
- package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-table.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-table.js +0 -24
- package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-table.js.map +0 -1
- package/dist/adapter/z-stack/structs/entries/channel-list.d.ts +0 -9
- package/dist/adapter/z-stack/structs/entries/channel-list.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/entries/channel-list.js +0 -16
- package/dist/adapter/z-stack/structs/entries/channel-list.js.map +0 -1
- package/dist/adapter/z-stack/structs/entries/has-configured.d.ts +0 -9
- package/dist/adapter/z-stack/structs/entries/has-configured.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/entries/has-configured.js +0 -17
- package/dist/adapter/z-stack/structs/entries/has-configured.js.map +0 -1
- package/dist/adapter/z-stack/structs/entries/index.d.ts +0 -17
- package/dist/adapter/z-stack/structs/entries/index.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/entries/index.js +0 -33
- package/dist/adapter/z-stack/structs/entries/index.js.map +0 -1
- package/dist/adapter/z-stack/structs/entries/nib.d.ts +0 -11
- package/dist/adapter/z-stack/structs/entries/nib.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/entries/nib.js +0 -69
- package/dist/adapter/z-stack/structs/entries/nib.js.map +0 -1
- package/dist/adapter/z-stack/structs/entries/nwk-key-descriptor.d.ts +0 -11
- package/dist/adapter/z-stack/structs/entries/nwk-key-descriptor.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/entries/nwk-key-descriptor.js +0 -19
- package/dist/adapter/z-stack/structs/entries/nwk-key-descriptor.js.map +0 -1
- package/dist/adapter/z-stack/structs/entries/nwk-key.d.ts +0 -9
- package/dist/adapter/z-stack/structs/entries/nwk-key.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/entries/nwk-key.js +0 -16
- package/dist/adapter/z-stack/structs/entries/nwk-key.js.map +0 -1
- package/dist/adapter/z-stack/structs/entries/nwk-pan-id.d.ts +0 -9
- package/dist/adapter/z-stack/structs/entries/nwk-pan-id.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/entries/nwk-pan-id.js +0 -16
- package/dist/adapter/z-stack/structs/entries/nwk-pan-id.js.map +0 -1
- package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.d.ts +0 -14
- package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.js +0 -24
- package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.js.map +0 -1
- package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.d.ts +0 -11
- package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.js +0 -23
- package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.js.map +0 -1
- package/dist/adapter/z-stack/structs/entries/security-manager-entry.d.ts +0 -21
- package/dist/adapter/z-stack/structs/entries/security-manager-entry.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/entries/security-manager-entry.js +0 -37
- package/dist/adapter/z-stack/structs/entries/security-manager-entry.js.map +0 -1
- package/dist/adapter/z-stack/structs/entries/security-manager-table.d.ts +0 -11
- package/dist/adapter/z-stack/structs/entries/security-manager-table.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/entries/security-manager-table.js +0 -25
- package/dist/adapter/z-stack/structs/entries/security-manager-table.js.map +0 -1
- package/dist/adapter/z-stack/structs/index.d.ts +0 -5
- package/dist/adapter/z-stack/structs/index.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/index.js +0 -21
- package/dist/adapter/z-stack/structs/index.js.map +0 -1
- package/dist/adapter/z-stack/structs/serializable-memory-object.d.ts +0 -14
- package/dist/adapter/z-stack/structs/serializable-memory-object.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/serializable-memory-object.js +0 -3
- package/dist/adapter/z-stack/structs/serializable-memory-object.js.map +0 -1
- package/dist/adapter/z-stack/structs/struct.d.ts +0 -100
- package/dist/adapter/z-stack/structs/struct.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/struct.js +0 -297
- package/dist/adapter/z-stack/structs/struct.js.map +0 -1
- package/dist/adapter/z-stack/structs/table.d.ts +0 -95
- package/dist/adapter/z-stack/structs/table.d.ts.map +0 -1
- package/dist/adapter/z-stack/structs/table.js +0 -164
- package/dist/adapter/z-stack/structs/table.js.map +0 -1
- package/dist/adapter/z-stack/unpi/constants.d.ts +0 -29
- package/dist/adapter/z-stack/unpi/constants.d.ts.map +0 -1
- package/dist/adapter/z-stack/unpi/constants.js +0 -40
- package/dist/adapter/z-stack/unpi/constants.js.map +0 -1
- package/dist/adapter/z-stack/unpi/frame.d.ts +0 -17
- package/dist/adapter/z-stack/unpi/frame.d.ts.map +0 -1
- package/dist/adapter/z-stack/unpi/frame.js +0 -55
- package/dist/adapter/z-stack/unpi/frame.js.map +0 -1
- package/dist/adapter/z-stack/unpi/index.d.ts +0 -6
- package/dist/adapter/z-stack/unpi/index.d.ts.map +0 -1
- package/dist/adapter/z-stack/unpi/index.js +0 -38
- package/dist/adapter/z-stack/unpi/index.js.map +0 -1
- package/dist/adapter/z-stack/unpi/parser.d.ts +0 -13
- package/dist/adapter/z-stack/unpi/parser.d.ts.map +0 -1
- package/dist/adapter/z-stack/unpi/parser.js +0 -86
- package/dist/adapter/z-stack/unpi/parser.js.map +0 -1
- package/dist/adapter/z-stack/unpi/writer.d.ts +0 -12
- package/dist/adapter/z-stack/unpi/writer.d.ts.map +0 -1
- package/dist/adapter/z-stack/unpi/writer.js +0 -55
- package/dist/adapter/z-stack/unpi/writer.js.map +0 -1
- package/dist/adapter/z-stack/utils/channel-list.d.ts +0 -21
- package/dist/adapter/z-stack/utils/channel-list.d.ts.map +0 -1
- package/dist/adapter/z-stack/utils/channel-list.js +0 -41
- package/dist/adapter/z-stack/utils/channel-list.js.map +0 -1
- package/dist/adapter/z-stack/utils/index.d.ts +0 -3
- package/dist/adapter/z-stack/utils/index.d.ts.map +0 -1
- package/dist/adapter/z-stack/utils/index.js +0 -19
- package/dist/adapter/z-stack/utils/index.js.map +0 -1
- package/dist/adapter/z-stack/utils/network-options.d.ts +0 -9
- package/dist/adapter/z-stack/utils/network-options.d.ts.map +0 -1
- package/dist/adapter/z-stack/utils/network-options.js +0 -23
- package/dist/adapter/z-stack/utils/network-options.js.map +0 -1
- package/dist/adapter/z-stack/znp/buffaloZnp.d.ts +0 -14
- package/dist/adapter/z-stack/znp/buffaloZnp.d.ts.map +0 -1
- package/dist/adapter/z-stack/znp/buffaloZnp.js +0 -243
- package/dist/adapter/z-stack/znp/buffaloZnp.js.map +0 -1
- package/dist/adapter/z-stack/znp/definition.d.ts +0 -6
- package/dist/adapter/z-stack/znp/definition.d.ts.map +0 -1
- package/dist/adapter/z-stack/znp/definition.js +0 -3052
- package/dist/adapter/z-stack/znp/definition.js.map +0 -1
- package/dist/adapter/z-stack/znp/index.d.ts +0 -4
- package/dist/adapter/z-stack/znp/index.d.ts.map +0 -1
- package/dist/adapter/z-stack/znp/index.js +0 -11
- package/dist/adapter/z-stack/znp/index.js.map +0 -1
- package/dist/adapter/z-stack/znp/parameterType.d.ts +0 -23
- package/dist/adapter/z-stack/znp/parameterType.d.ts.map +0 -1
- package/dist/adapter/z-stack/znp/parameterType.js +0 -26
- package/dist/adapter/z-stack/znp/parameterType.js.map +0 -1
- package/dist/adapter/z-stack/znp/tstype.d.ts +0 -23
- package/dist/adapter/z-stack/znp/tstype.d.ts.map +0 -1
- package/dist/adapter/z-stack/znp/tstype.js +0 -3
- package/dist/adapter/z-stack/znp/tstype.js.map +0 -1
- package/dist/adapter/z-stack/znp/znp.d.ts +0 -47
- package/dist/adapter/z-stack/znp/znp.d.ts.map +0 -1
- package/dist/adapter/z-stack/znp/znp.js +0 -322
- package/dist/adapter/z-stack/znp/znp.js.map +0 -1
- package/dist/adapter/z-stack/znp/zpiObject.d.ts +0 -20
- package/dist/adapter/z-stack/znp/zpiObject.d.ts.map +0 -1
- package/dist/adapter/z-stack/znp/zpiObject.js +0 -103
- package/dist/adapter/z-stack/znp/zpiObject.js.map +0 -1
- package/dist/adapter/zigate/adapter/index.d.ts +0 -3
- package/dist/adapter/zigate/adapter/index.d.ts.map +0 -1
- package/dist/adapter/zigate/adapter/index.js +0 -11
- package/dist/adapter/zigate/adapter/index.js.map +0 -1
- package/dist/adapter/zigate/adapter/zigateAdapter.d.ts +0 -72
- package/dist/adapter/zigate/adapter/zigateAdapter.d.ts.map +0 -1
- package/dist/adapter/zigate/adapter/zigateAdapter.js +0 -681
- package/dist/adapter/zigate/adapter/zigateAdapter.js.map +0 -1
- package/dist/adapter/zigate/driver/buffaloZiGate.d.ts +0 -18
- package/dist/adapter/zigate/driver/buffaloZiGate.d.ts.map +0 -1
- package/dist/adapter/zigate/driver/buffaloZiGate.js +0 -190
- package/dist/adapter/zigate/driver/buffaloZiGate.js.map +0 -1
- package/dist/adapter/zigate/driver/commandType.d.ts +0 -43
- package/dist/adapter/zigate/driver/commandType.d.ts.map +0 -1
- package/dist/adapter/zigate/driver/commandType.js +0 -390
- package/dist/adapter/zigate/driver/commandType.js.map +0 -1
- package/dist/adapter/zigate/driver/constants.d.ts +0 -277
- package/dist/adapter/zigate/driver/constants.d.ts.map +0 -1
- package/dist/adapter/zigate/driver/constants.js +0 -372
- package/dist/adapter/zigate/driver/constants.js.map +0 -1
- package/dist/adapter/zigate/driver/frame.d.ts +0 -27
- package/dist/adapter/zigate/driver/frame.d.ts.map +0 -1
- package/dist/adapter/zigate/driver/frame.js +0 -173
- package/dist/adapter/zigate/driver/frame.js.map +0 -1
- package/dist/adapter/zigate/driver/messageType.d.ts +0 -13
- package/dist/adapter/zigate/driver/messageType.d.ts.map +0 -1
- package/dist/adapter/zigate/driver/messageType.js +0 -284
- package/dist/adapter/zigate/driver/messageType.js.map +0 -1
- package/dist/adapter/zigate/driver/parameterType.d.ts +0 -28
- package/dist/adapter/zigate/driver/parameterType.d.ts.map +0 -1
- package/dist/adapter/zigate/driver/parameterType.js +0 -33
- package/dist/adapter/zigate/driver/parameterType.js.map +0 -1
- package/dist/adapter/zigate/driver/ziGateObject.d.ts +0 -24
- package/dist/adapter/zigate/driver/ziGateObject.d.ts.map +0 -1
- package/dist/adapter/zigate/driver/ziGateObject.js +0 -111
- package/dist/adapter/zigate/driver/ziGateObject.js.map +0 -1
- package/dist/adapter/zigate/driver/zigate.d.ts +0 -50
- package/dist/adapter/zigate/driver/zigate.d.ts.map +0 -1
- package/dist/adapter/zigate/driver/zigate.js +0 -289
- package/dist/adapter/zigate/driver/zigate.js.map +0 -1
- package/dist/buffalo/buffalo.d.ts +0 -55
- package/dist/buffalo/buffalo.d.ts.map +0 -1
- package/dist/buffalo/buffalo.js +0 -230
- package/dist/buffalo/buffalo.js.map +0 -1
- package/dist/buffalo/index.d.ts +0 -3
- package/dist/buffalo/index.d.ts.map +0 -1
- package/dist/buffalo/index.js +0 -9
- package/dist/buffalo/index.js.map +0 -1
- package/dist/controller/controller.d.ts +0 -119
- package/dist/controller/controller.d.ts.map +0 -1
- package/dist/controller/controller.js +0 -700
- package/dist/controller/controller.js.map +0 -1
- package/dist/controller/database.d.ts +0 -20
- package/dist/controller/database.d.ts.map +0 -1
- package/dist/controller/database.js +0 -94
- package/dist/controller/database.js.map +0 -1
- package/dist/controller/events.d.ts +0 -59
- package/dist/controller/events.d.ts.map +0 -1
- package/dist/controller/events.js +0 -113
- package/dist/controller/events.js.map +0 -1
- package/dist/controller/greenPower.d.ts +0 -14
- package/dist/controller/greenPower.d.ts.map +0 -1
- package/dist/controller/greenPower.js +0 -216
- package/dist/controller/greenPower.js.map +0 -1
- package/dist/controller/helpers/index.d.ts +0 -3
- package/dist/controller/helpers/index.d.ts.map +0 -1
- package/dist/controller/helpers/index.js +0 -29
- package/dist/controller/helpers/index.js.map +0 -1
- package/dist/controller/helpers/request.d.ts +0 -22
- package/dist/controller/helpers/request.d.ts.map +0 -1
- package/dist/controller/helpers/request.js +0 -78
- package/dist/controller/helpers/request.js.map +0 -1
- package/dist/controller/helpers/requestQueue.d.ts +0 -13
- package/dist/controller/helpers/requestQueue.d.ts.map +0 -1
- package/dist/controller/helpers/requestQueue.js +0 -106
- package/dist/controller/helpers/requestQueue.js.map +0 -1
- package/dist/controller/helpers/zclFrameConverter.d.ts +0 -9
- package/dist/controller/helpers/zclFrameConverter.d.ts.map +0 -1
- package/dist/controller/helpers/zclFrameConverter.js +0 -70
- package/dist/controller/helpers/zclFrameConverter.js.map +0 -1
- package/dist/controller/helpers/zclTransactionSequenceNumber.d.ts +0 -6
- package/dist/controller/helpers/zclTransactionSequenceNumber.d.ts.map +0 -1
- package/dist/controller/helpers/zclTransactionSequenceNumber.js +0 -14
- package/dist/controller/helpers/zclTransactionSequenceNumber.js.map +0 -1
- package/dist/controller/index.d.ts +0 -6
- package/dist/controller/index.d.ts.map +0 -1
- package/dist/controller/index.js +0 -9
- package/dist/controller/index.js.map +0 -1
- package/dist/controller/model/device.d.ts +0 -140
- package/dist/controller/model/device.d.ts.map +0 -1
- package/dist/controller/model/device.js +0 -746
- package/dist/controller/model/device.js.map +0 -1
- package/dist/controller/model/endpoint.d.ts +0 -134
- package/dist/controller/model/endpoint.d.ts.map +0 -1
- package/dist/controller/model/endpoint.js +0 -667
- package/dist/controller/model/endpoint.js.map +0 -1
- package/dist/controller/model/entity.d.ts +0 -15
- package/dist/controller/model/entity.d.ts.map +0 -1
- package/dist/controller/model/entity.js +0 -27
- package/dist/controller/model/entity.js.map +0 -1
- package/dist/controller/model/group.d.ts +0 -39
- package/dist/controller/model/group.d.ts.map +0 -1
- package/dist/controller/model/group.js +0 -226
- package/dist/controller/model/group.js.map +0 -1
- package/dist/controller/model/index.d.ts +0 -6
- package/dist/controller/model/index.d.ts.map +0 -1
- package/dist/controller/model/index.js +0 -15
- package/dist/controller/model/index.js.map +0 -1
- package/dist/controller/model/konnextConfig.d.ts +0 -7
- package/dist/controller/model/konnextConfig.d.ts.map +0 -1
- package/dist/controller/model/konnextConfig.js +0 -3
- package/dist/controller/model/konnextConfig.js.map +0 -1
- package/dist/controller/touchlink.d.ts +0 -20
- package/dist/controller/touchlink.d.ts.map +0 -1
- package/dist/controller/touchlink.js +0 -157
- package/dist/controller/touchlink.js.map +0 -1
- package/dist/controller/tstype.d.ts +0 -21
- package/dist/controller/tstype.d.ts.map +0 -1
- package/dist/controller/tstype.js +0 -9
- package/dist/controller/tstype.js.map +0 -1
- package/dist/index.d.ts +0 -6
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -37
- package/dist/index.js.map +0 -1
- package/dist/models/backup-storage-legacy.d.ts +0 -27
- package/dist/models/backup-storage-legacy.d.ts.map +0 -1
- package/dist/models/backup-storage-legacy.js +0 -3
- package/dist/models/backup-storage-legacy.js.map +0 -1
- package/dist/models/backup-storage-unified.d.ts +0 -50
- package/dist/models/backup-storage-unified.d.ts.map +0 -1
- package/dist/models/backup-storage-unified.js +0 -3
- package/dist/models/backup-storage-unified.js.map +0 -1
- package/dist/models/backup.d.ts +0 -38
- package/dist/models/backup.d.ts.map +0 -1
- package/dist/models/backup.js +0 -3
- package/dist/models/backup.js.map +0 -1
- package/dist/models/index.d.ts +0 -5
- package/dist/models/index.d.ts.map +0 -1
- package/dist/models/index.js +0 -21
- package/dist/models/index.js.map +0 -1
- package/dist/models/network-options.d.ts +0 -13
- package/dist/models/network-options.d.ts.map +0 -1
- package/dist/models/network-options.js +0 -3
- package/dist/models/network-options.js.map +0 -1
- package/dist/utils/aes.d.ts +0 -40
- package/dist/utils/aes.d.ts.map +0 -1
- package/dist/utils/aes.js +0 -198
- package/dist/utils/aes.js.map +0 -1
- package/dist/utils/assertString.d.ts +0 -3
- package/dist/utils/assertString.d.ts.map +0 -1
- package/dist/utils/assertString.js +0 -9
- package/dist/utils/assertString.js.map +0 -1
- package/dist/utils/backup.d.ts +0 -21
- package/dist/utils/backup.d.ts.map +0 -1
- package/dist/utils/backup.js +0 -190
- package/dist/utils/backup.js.map +0 -1
- package/dist/utils/equalsPartial.d.ts +0 -3
- package/dist/utils/equalsPartial.d.ts.map +0 -1
- package/dist/utils/equalsPartial.js +0 -12
- package/dist/utils/equalsPartial.js.map +0 -1
- package/dist/utils/index.d.ts +0 -10
- package/dist/utils/index.d.ts.map +0 -1
- package/dist/utils/index.js +0 -46
- package/dist/utils/index.js.map +0 -1
- package/dist/utils/isNumberArray.d.ts +0 -3
- package/dist/utils/isNumberArray.d.ts.map +0 -1
- package/dist/utils/isNumberArray.js +0 -7
- package/dist/utils/isNumberArray.js.map +0 -1
- package/dist/utils/logger.d.ts +0 -9
- package/dist/utils/logger.d.ts.map +0 -1
- package/dist/utils/logger.js +0 -14
- package/dist/utils/logger.js.map +0 -1
- package/dist/utils/queue.d.ts +0 -12
- package/dist/utils/queue.d.ts.map +0 -1
- package/dist/utils/queue.js +0 -62
- package/dist/utils/queue.js.map +0 -1
- package/dist/utils/realpathSync.d.ts +0 -3
- package/dist/utils/realpathSync.d.ts.map +0 -1
- package/dist/utils/realpathSync.js +0 -13
- package/dist/utils/realpathSync.js.map +0 -1
- package/dist/utils/wait.d.ts +0 -3
- package/dist/utils/wait.d.ts.map +0 -1
- package/dist/utils/wait.js +0 -9
- package/dist/utils/wait.js.map +0 -1
- package/dist/utils/waitress.d.ts +0 -22
- package/dist/utils/waitress.d.ts.map +0 -1
- package/dist/utils/waitress.js +0 -69
- package/dist/utils/waitress.js.map +0 -1
- package/dist/zspec/consts.d.ts +0 -60
- package/dist/zspec/consts.d.ts.map +0 -1
- package/dist/zspec/consts.js +0 -64
- package/dist/zspec/consts.js.map +0 -1
- package/dist/zspec/enums.d.ts +0 -19
- package/dist/zspec/enums.d.ts.map +0 -1
- package/dist/zspec/enums.js +0 -28
- package/dist/zspec/enums.js.map +0 -1
- package/dist/zspec/index.d.ts +0 -4
- package/dist/zspec/index.d.ts.map +0 -1
- package/dist/zspec/index.js +0 -43
- package/dist/zspec/index.js.map +0 -1
- package/dist/zspec/tstypes.d.ts +0 -19
- package/dist/zspec/tstypes.d.ts.map +0 -1
- package/dist/zspec/tstypes.js +0 -3
- package/dist/zspec/tstypes.js.map +0 -1
- package/dist/zspec/utils.d.ts +0 -14
- package/dist/zspec/utils.d.ts.map +0 -1
- package/dist/zspec/utils.js +0 -29
- package/dist/zspec/utils.js.map +0 -1
- package/dist/zspec/zcl/buffaloZcl.d.ts +0 -55
- package/dist/zspec/zcl/buffaloZcl.d.ts.map +0 -1
- package/dist/zspec/zcl/buffaloZcl.js +0 -929
- package/dist/zspec/zcl/buffaloZcl.js.map +0 -1
- package/dist/zspec/zcl/definition/cluster.d.ts +0 -3
- package/dist/zspec/zcl/definition/cluster.d.ts.map +0 -1
- package/dist/zspec/zcl/definition/cluster.js +0 -5500
- package/dist/zspec/zcl/definition/cluster.js.map +0 -1
- package/dist/zspec/zcl/definition/consts.d.ts +0 -9
- package/dist/zspec/zcl/definition/consts.d.ts.map +0 -1
- package/dist/zspec/zcl/definition/consts.js +0 -27
- package/dist/zspec/zcl/definition/consts.js.map +0 -1
- package/dist/zspec/zcl/definition/enums.d.ts +0 -177
- package/dist/zspec/zcl/definition/enums.d.ts.map +0 -1
- package/dist/zspec/zcl/definition/enums.js +0 -187
- package/dist/zspec/zcl/definition/enums.js.map +0 -1
- package/dist/zspec/zcl/definition/foundation.d.ts +0 -11
- package/dist/zspec/zcl/definition/foundation.d.ts.map +0 -1
- package/dist/zspec/zcl/definition/foundation.js +0 -241
- package/dist/zspec/zcl/definition/foundation.js.map +0 -1
- package/dist/zspec/zcl/definition/manufacturerCode.d.ts +0 -727
- package/dist/zspec/zcl/definition/manufacturerCode.d.ts.map +0 -1
- package/dist/zspec/zcl/definition/manufacturerCode.js +0 -733
- package/dist/zspec/zcl/definition/manufacturerCode.js.map +0 -1
- package/dist/zspec/zcl/definition/status.d.ts +0 -69
- package/dist/zspec/zcl/definition/status.d.ts.map +0 -1
- package/dist/zspec/zcl/definition/status.js +0 -74
- package/dist/zspec/zcl/definition/status.js.map +0 -1
- package/dist/zspec/zcl/definition/tstype.d.ts +0 -114
- package/dist/zspec/zcl/definition/tstype.d.ts.map +0 -1
- package/dist/zspec/zcl/definition/tstype.js +0 -4
- package/dist/zspec/zcl/definition/tstype.js.map +0 -1
- package/dist/zspec/zcl/index.d.ts +0 -11
- package/dist/zspec/zcl/index.d.ts.map +0 -1
- package/dist/zspec/zcl/index.js +0 -47
- package/dist/zspec/zcl/index.js.map +0 -1
- package/dist/zspec/zcl/utils.d.ts +0 -7
- package/dist/zspec/zcl/utils.d.ts.map +0 -1
- package/dist/zspec/zcl/utils.js +0 -234
- package/dist/zspec/zcl/utils.js.map +0 -1
- package/dist/zspec/zcl/zclFrame.d.ts +0 -36
- package/dist/zspec/zcl/zclFrame.d.ts.map +0 -1
- package/dist/zspec/zcl/zclFrame.js +0 -304
- package/dist/zspec/zcl/zclFrame.js.map +0 -1
- package/dist/zspec/zcl/zclHeader.d.ts +0 -17
- package/dist/zspec/zcl/zclHeader.d.ts.map +0 -1
- package/dist/zspec/zcl/zclHeader.js +0 -88
- package/dist/zspec/zcl/zclHeader.js.map +0 -1
- package/dist/zspec/zcl/zclStatusError.d.ts +0 -6
- package/dist/zspec/zcl/zclStatusError.d.ts.map +0 -1
- package/dist/zspec/zcl/zclStatusError.js +0 -13
- package/dist/zspec/zcl/zclStatusError.js.map +0 -1
- package/dist/zspec/zdo/buffaloZdo.d.ts +0 -438
- package/dist/zspec/zdo/buffaloZdo.d.ts.map +0 -1
- package/dist/zspec/zdo/buffaloZdo.js +0 -1892
- package/dist/zspec/zdo/buffaloZdo.js.map +0 -1
- package/dist/zspec/zdo/definition/clusters.d.ts +0 -624
- package/dist/zspec/zdo/definition/clusters.d.ts.map +0 -1
- package/dist/zspec/zdo/definition/clusters.js +0 -687
- package/dist/zspec/zdo/definition/clusters.js.map +0 -1
- package/dist/zspec/zdo/definition/consts.d.ts +0 -13
- package/dist/zspec/zdo/definition/consts.d.ts.map +0 -1
- package/dist/zspec/zdo/definition/consts.js +0 -16
- package/dist/zspec/zdo/definition/consts.js.map +0 -1
- package/dist/zspec/zdo/definition/enums.d.ts +0 -75
- package/dist/zspec/zdo/definition/enums.d.ts.map +0 -1
- package/dist/zspec/zdo/definition/enums.js +0 -97
- package/dist/zspec/zdo/definition/enums.js.map +0 -1
- package/dist/zspec/zdo/definition/status.d.ts +0 -99
- package/dist/zspec/zdo/definition/status.d.ts.map +0 -1
- package/dist/zspec/zdo/definition/status.js +0 -109
- package/dist/zspec/zdo/definition/status.js.map +0 -1
- package/dist/zspec/zdo/definition/tstypes.d.ts +0 -787
- package/dist/zspec/zdo/definition/tstypes.d.ts.map +0 -1
- package/dist/zspec/zdo/definition/tstypes.js +0 -3
- package/dist/zspec/zdo/definition/tstypes.js.map +0 -1
- package/dist/zspec/zdo/index.d.ts +0 -7
- package/dist/zspec/zdo/index.d.ts.map +0 -1
- package/dist/zspec/zdo/index.js +0 -39
- package/dist/zspec/zdo/index.js.map +0 -1
- package/dist/zspec/zdo/utils.d.ts +0 -25
- package/dist/zspec/zdo/utils.d.ts.map +0 -1
- package/dist/zspec/zdo/utils.js +0 -75
- package/dist/zspec/zdo/utils.js.map +0 -1
- package/dist/zspec/zdo/zdoStatusError.d.ts +0 -6
- package/dist/zspec/zdo/zdoStatusError.d.ts.map +0 -1
- package/dist/zspec/zdo/zdoStatusError.js +0 -13
- package/dist/zspec/zdo/zdoStatusError.js.map +0 -1
- package/typedoc-tsconfig.json +0 -44
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
import {INSTALL_CODE_CRC_SIZE, INSTALL_CODE_SIZES} from "../../zspec/consts";
|
|
2
|
+
import {crc16X25} from "../../zspec/utils";
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Parse the given code using known formats:
|
|
6
|
+
* - 95 or 91-length
|
|
7
|
+
* - Widely adopted (Ubisys, Danfoss, Inovelli, Ledvance): ...Z:<ieee>$I:<key>...
|
|
8
|
+
* - Pipe-separated (Muller-Licht, Innr): <ieee>|<key>
|
|
9
|
+
* - Aqara: G$M:...$A:<ieee>$I:<key>
|
|
10
|
+
* - Hue: HUE:Z:<key> M:<ieee>...
|
|
11
|
+
* @param installCode
|
|
12
|
+
* @returns
|
|
13
|
+
* - the IEEE address
|
|
14
|
+
* - the raw key
|
|
15
|
+
*/
|
|
16
|
+
export function parseInstallCode(installCode: string): [ieeeAddr: string, key: string] {
|
|
17
|
+
const widelyAdoptedMatch = installCode.match(/Z:([a-zA-Z0-9]{16})\$I:([a-zA-Z0-9]+)/);
|
|
18
|
+
|
|
19
|
+
if (widelyAdoptedMatch) {
|
|
20
|
+
return [`0x${widelyAdoptedMatch[1].toLowerCase()}`, widelyAdoptedMatch[2]];
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
const pipeMatch = installCode.match(/^([a-zA-Z0-9]{16})\|([a-zA-Z0-9]+)$/);
|
|
24
|
+
|
|
25
|
+
if (pipeMatch) {
|
|
26
|
+
return [`0x${pipeMatch[1].toLowerCase()}`, pipeMatch[2]];
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
const aqaraMatch = installCode.match(/^G\$M:.+\$A:([a-zA-Z0-9]{16})\$I:([a-zA-Z0-9]+)$/);
|
|
30
|
+
|
|
31
|
+
if (aqaraMatch) {
|
|
32
|
+
return [`0x${aqaraMatch[1].toLowerCase()}`, aqaraMatch[2]];
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
const hueMatch = installCode.match(/^HUE:Z:([a-zA-Z0-9]+) M:([a-zA-Z0-9]{16})/);
|
|
36
|
+
|
|
37
|
+
if (hueMatch) {
|
|
38
|
+
return [`0x${hueMatch[2].toLowerCase()}`, hueMatch[1]];
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
if (installCode.length === 95 || installCode.length === 91) {
|
|
42
|
+
const keyStart = installCode.length - (installCode.length === 95 ? 36 : 32);
|
|
43
|
+
|
|
44
|
+
return [`0x${installCode.substring(keyStart - 19, keyStart - 3).toLowerCase()}`, installCode.substring(keyStart, installCode.length)];
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
throw new Error(`Unsupported install code, got ${installCode.length} chars, expected 95 or 91 chars, or known format`);
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* Check if install code (little-endian) is valid, and if not, and requested, fix it.
|
|
52
|
+
*
|
|
53
|
+
* WARNING: Due to conflicting sizes between 8-length code with invalid CRC, and 10-length code missing CRC, given 8-length codes are always assumed to be 8-length code with invalid CRC (most probable scenario).
|
|
54
|
+
*
|
|
55
|
+
* @param code The code to check. Reference is not modified by this procedure but is returned when code was valid, as `outCode`.
|
|
56
|
+
* @param adjust If false, throws if the install code is invalid, otherwise try to fix it (CRC)
|
|
57
|
+
* @returns
|
|
58
|
+
* - The adjusted code, or `code` if not adjusted.
|
|
59
|
+
* - If adjust is false, undefined, otherwise, the reason why the code needed adjusting or undefined if not.
|
|
60
|
+
* - Throws when adjust=false and invalid, or cannot fix.
|
|
61
|
+
*/
|
|
62
|
+
export function checkInstallCode(code: Buffer, adjust = true): [outCode: Buffer, adjusted: "invalid CRC" | "missing CRC" | undefined] {
|
|
63
|
+
const crcLowByteIndex = code.length - INSTALL_CODE_CRC_SIZE;
|
|
64
|
+
const crcHighByteIndex = code.length - INSTALL_CODE_CRC_SIZE + 1;
|
|
65
|
+
|
|
66
|
+
for (const codeSize of INSTALL_CODE_SIZES) {
|
|
67
|
+
if (code.length === codeSize) {
|
|
68
|
+
// install code has CRC, check if valid, if not, replace it
|
|
69
|
+
const crc = crc16X25(code.subarray(0, -2));
|
|
70
|
+
const crcHighByte = (crc >> 8) & 0xff;
|
|
71
|
+
const crcLowByte = crc & 0xff;
|
|
72
|
+
|
|
73
|
+
if (code[crcLowByteIndex] !== crcLowByte || code[crcHighByteIndex] !== crcHighByte) {
|
|
74
|
+
// see WARNING above, 8 is smallest valid length, so always ends up here
|
|
75
|
+
if (adjust) {
|
|
76
|
+
const outCode = Buffer.from(code);
|
|
77
|
+
outCode[crcLowByteIndex] = crcLowByte;
|
|
78
|
+
outCode[crcHighByteIndex] = crcHighByte;
|
|
79
|
+
|
|
80
|
+
return [outCode, "invalid CRC"];
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
throw new Error(`Install code ${code.toString("hex")} failed CRC validation`);
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
return [code, undefined];
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
if (code.length === codeSize - INSTALL_CODE_CRC_SIZE) {
|
|
90
|
+
if (adjust) {
|
|
91
|
+
// install code is missing CRC
|
|
92
|
+
const crc = crc16X25(code);
|
|
93
|
+
const outCode = Buffer.alloc(code.length + INSTALL_CODE_CRC_SIZE);
|
|
94
|
+
|
|
95
|
+
code.copy(outCode, 0);
|
|
96
|
+
outCode.writeUInt16LE(crc, code.length);
|
|
97
|
+
|
|
98
|
+
return [outCode, "missing CRC"];
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
throw new Error(`Install code ${code.toString("hex")} failed CRC validation`);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
// never returned from within the above loop
|
|
106
|
+
throw new Error(`Install code ${code.toString("hex")} has invalid size`);
|
|
107
|
+
}
|
|
@@ -0,0 +1,575 @@
|
|
|
1
|
+
import assert from "node:assert";
|
|
2
|
+
import crypto from "node:crypto";
|
|
3
|
+
import {readFileSync} from "node:fs";
|
|
4
|
+
import path from "node:path";
|
|
5
|
+
import {performance} from "node:perf_hooks";
|
|
6
|
+
import {logger} from "../../utils/logger";
|
|
7
|
+
import * as Zcl from "../../zspec/zcl";
|
|
8
|
+
import type {TClusterCommandPayload, TClusterPayload} from "../../zspec/zcl/definition/clusters-types";
|
|
9
|
+
import type {TZclFrame} from "../../zspec/zcl/zclFrame";
|
|
10
|
+
import type Endpoint from "../model/endpoint";
|
|
11
|
+
import type {OtaDataSettings, OtaImage, OtaImageElement, OtaImageHeader, OtaSource, ZigbeeOtaImageMeta} from "../tstype";
|
|
12
|
+
|
|
13
|
+
const NS = "zh:controller:ota";
|
|
14
|
+
|
|
15
|
+
// OTA_HEADER_VERSION_ZIGBEE 0x0100
|
|
16
|
+
|
|
17
|
+
// ZIGBEE_2006_STACK_VERSION 0x0000
|
|
18
|
+
// ZIGBEE_2007_STACK_VERSION 0x0001
|
|
19
|
+
// ZIGBEE_PRO_STACK_VERSION 0x0002
|
|
20
|
+
// ZIGBEE_IP_STACK_VERSION 0x0003
|
|
21
|
+
|
|
22
|
+
// MANUFACTURE_CODE_WILD_CARD 0xFFFF
|
|
23
|
+
|
|
24
|
+
// IMAGE_TYPE_WILD_CARD 0xFFFF
|
|
25
|
+
// IMAGE_TYPE_SECURITY 0xFFC0
|
|
26
|
+
// IMAGE_TYPE_CONFIG 0xFFC1
|
|
27
|
+
// IMAGE_TYPE_LOG 0xFFC2
|
|
28
|
+
|
|
29
|
+
// FILE_VERSION_WILD_CARD 0xFFFFFFFF
|
|
30
|
+
|
|
31
|
+
export enum OtaTagId {
|
|
32
|
+
UpgradeImage = 0x0000,
|
|
33
|
+
/** signer IEEE address (8-byte), signature data (42-byte) */
|
|
34
|
+
ECDSASignatureCryptoSuite1 = 0x0001,
|
|
35
|
+
/** ECDSA certificate (48-byte) */
|
|
36
|
+
ECDSASigningCertificateCryptoSuite1 = 0x0002,
|
|
37
|
+
/** hash value (16-byte) */
|
|
38
|
+
ImageIntegrityCode = 0x0003,
|
|
39
|
+
/** */
|
|
40
|
+
PictureData = 0x0004,
|
|
41
|
+
/** signer IEEE address (8-byte), signature data (72-byte) */
|
|
42
|
+
ECDSASignatureCryptoSuite2 = 0x0005,
|
|
43
|
+
/** ECDSA certificate (74-byte) */
|
|
44
|
+
ECDSASigningCertificateCryptoSuite2 = 0x0006,
|
|
45
|
+
// "Manufacturer Specific Use" = 0xf000 – 0xffff,
|
|
46
|
+
/**
|
|
47
|
+
* 2-byte header before actual `UpgradeImage`
|
|
48
|
+
* see https://github.com/telink-semi/telink_zigbee_sdk/blob/d5bc2f7b0c1f8536fe21c8127ca680ea8214bc8e/tl_zigbee_sdk/zigbee/ota/ota.h#L38
|
|
49
|
+
*/
|
|
50
|
+
TelinkAES = 0xf000,
|
|
51
|
+
// IkeaUnknown1 = 0xffbf, // parse fine as regular tag
|
|
52
|
+
// IkeaUnknown2 = 0xffbe, // parse fine as regular tag (custom ECDSA?)
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
const ZIGBEE_OTA_LATEST_URL = "https://raw.githubusercontent.com/Koenkk/zigbee-OTA/master/index.json";
|
|
56
|
+
const ZIGBEE_OTA_PREVIOUS_URL = "https://raw.githubusercontent.com/Koenkk/zigbee-OTA/master/index1.json";
|
|
57
|
+
|
|
58
|
+
const UPGRADE_END_REQUEST_ID = Zcl.Clusters.genOta.commands.upgradeEndRequest.ID;
|
|
59
|
+
const IMAGE_BLOCK_REQUEST_ID = Zcl.Clusters.genOta.commands.imageBlockRequest.ID;
|
|
60
|
+
const IMAGE_PAGE_REQUEST_ID = Zcl.Clusters.genOta.commands.imagePageRequest.ID;
|
|
61
|
+
|
|
62
|
+
/** uint32 LE */
|
|
63
|
+
export const UPGRADE_FILE_IDENTIFIER = 0x0beef11e;
|
|
64
|
+
export const UPGRADE_FILE_IDENTIFIER_BUF = Buffer.from([0x1e, 0xf1, 0xee, 0x0b]);
|
|
65
|
+
|
|
66
|
+
// #region General Utils
|
|
67
|
+
|
|
68
|
+
let dataDir: string | undefined;
|
|
69
|
+
let overrideIndexLocation: string | undefined;
|
|
70
|
+
|
|
71
|
+
/**
|
|
72
|
+
* Set the dataDir for relative path needs (firmware file, index) as well as override index if any.
|
|
73
|
+
*/
|
|
74
|
+
export function setOtaConfiguration(inDataDir: string, inOverrideIndexLocation: string | undefined): void {
|
|
75
|
+
dataDir = inDataDir;
|
|
76
|
+
|
|
77
|
+
// If the file name is not a full path, then treat it as a relative to the data directory
|
|
78
|
+
overrideIndexLocation =
|
|
79
|
+
inOverrideIndexLocation && !isValidUrl(inOverrideIndexLocation) && !path.isAbsolute(inOverrideIndexLocation)
|
|
80
|
+
? path.join(dataDir, inOverrideIndexLocation)
|
|
81
|
+
: inOverrideIndexLocation;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
function isValidUrl(url: string): boolean {
|
|
85
|
+
try {
|
|
86
|
+
const parsed = new URL(url);
|
|
87
|
+
|
|
88
|
+
return parsed.protocol === "http:" || parsed.protocol === "https:";
|
|
89
|
+
} catch {
|
|
90
|
+
return false;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
async function getJson<T>(pageUrl: string): Promise<T> {
|
|
95
|
+
const response = await fetch(pageUrl);
|
|
96
|
+
|
|
97
|
+
if (!response.ok || !response.body) {
|
|
98
|
+
throw new Error(`Invalid response from ${pageUrl} status=${response.status}`);
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
return (await response.json()) as T;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
/**
|
|
105
|
+
* Validates a firmware file and returns the appropriate buffer (without possible manufacturer-specific header)
|
|
106
|
+
*/
|
|
107
|
+
function validateFirmware(fileBuffer: Buffer, sha512: string | undefined): Buffer {
|
|
108
|
+
const otaIdentifier = fileBuffer.indexOf(UPGRADE_FILE_IDENTIFIER_BUF);
|
|
109
|
+
|
|
110
|
+
assert(otaIdentifier !== -1, "Not a valid OTA file");
|
|
111
|
+
|
|
112
|
+
if (sha512) {
|
|
113
|
+
const hash = crypto.createHash("sha512");
|
|
114
|
+
|
|
115
|
+
hash.update(fileBuffer);
|
|
116
|
+
|
|
117
|
+
assert(hash.digest("hex") === sha512, "File checksum validation failed");
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
return fileBuffer.subarray(otaIdentifier);
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
async function fetchFirmware(url: string, sha512: string | undefined): Promise<Buffer> {
|
|
124
|
+
logger.debug(() => `Downloading firmware image from '${url}'`, NS);
|
|
125
|
+
|
|
126
|
+
const firmwareFileRsp = await fetch(url);
|
|
127
|
+
|
|
128
|
+
if (!firmwareFileRsp.ok || !firmwareFileRsp.body) {
|
|
129
|
+
throw new Error(`Invalid response from ${url} status=${firmwareFileRsp.status}`);
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
const fileBuffer = Buffer.from(await firmwareFileRsp.arrayBuffer());
|
|
133
|
+
|
|
134
|
+
return validateFirmware(fileBuffer, sha512);
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
function readFirmware(filePath: string, sha512: string | undefined): Buffer {
|
|
138
|
+
logger.debug(() => `Reading firmware image from '${filePath}'`, NS);
|
|
139
|
+
|
|
140
|
+
if (dataDir && !path.isAbsolute(filePath)) {
|
|
141
|
+
// If the file name is not a full path, then treat it as a relative to the data directory
|
|
142
|
+
filePath = path.join(dataDir, filePath);
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
const fileBuffer = readFileSync(filePath);
|
|
146
|
+
|
|
147
|
+
return validateFirmware(fileBuffer, sha512);
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
export async function getOtaFirmware(url: string, sha512: string | undefined): Promise<Buffer> {
|
|
151
|
+
return isValidUrl(url) ? await fetchFirmware(url, sha512) : readFirmware(url, sha512);
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
async function getOtaIndexInternal(url: string): Promise<ZigbeeOtaImageMeta[]> {
|
|
155
|
+
return isValidUrl(url) ? await getJson<ZigbeeOtaImageMeta[]>(url) : (JSON.parse(readFileSync(url, "utf-8")) as ZigbeeOtaImageMeta[]);
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
export async function getOtaIndex(source: OtaSource): Promise<ZigbeeOtaImageMeta[]> {
|
|
159
|
+
let mainIndexUrl: string;
|
|
160
|
+
|
|
161
|
+
if (source.url) {
|
|
162
|
+
if (!isValidUrl(source.url) && !path.isAbsolute(source.url)) {
|
|
163
|
+
if (!dataDir) {
|
|
164
|
+
throw new Error("Invalid OTA configuration");
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
mainIndexUrl = path.join(dataDir, source.url);
|
|
168
|
+
} else {
|
|
169
|
+
mainIndexUrl = source.url;
|
|
170
|
+
}
|
|
171
|
+
} else {
|
|
172
|
+
mainIndexUrl = source.downgrade ? ZIGBEE_OTA_PREVIOUS_URL : ZIGBEE_OTA_LATEST_URL;
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
if (overrideIndexLocation) {
|
|
176
|
+
logger.debug(`Loading override index '${overrideIndexLocation}'`, NS);
|
|
177
|
+
|
|
178
|
+
const localIndex = await getOtaIndexInternal(overrideIndexLocation);
|
|
179
|
+
|
|
180
|
+
// Resulting index will have overridden items first
|
|
181
|
+
const mappedLocalIndex = localIndex.map((meta) => {
|
|
182
|
+
// Web-hosted images must come with all fields filled already
|
|
183
|
+
// Nothing to do if needed fields were filled already
|
|
184
|
+
if (isValidUrl(meta.url) || (meta.imageType !== undefined && meta.manufacturerCode !== undefined && meta.fileVersion !== undefined)) {
|
|
185
|
+
return meta;
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
const image = parseOtaImage(readFirmware(meta.url, meta.sha512));
|
|
189
|
+
meta.imageType = image.header.imageType;
|
|
190
|
+
meta.manufacturerCode = image.header.manufacturerCode;
|
|
191
|
+
meta.fileVersion = image.header.fileVersion;
|
|
192
|
+
|
|
193
|
+
return meta;
|
|
194
|
+
});
|
|
195
|
+
|
|
196
|
+
try {
|
|
197
|
+
const mainIndex = await getOtaIndexInternal(mainIndexUrl);
|
|
198
|
+
|
|
199
|
+
logger.debug("Retrieved main index", NS);
|
|
200
|
+
|
|
201
|
+
return mappedLocalIndex.concat(mainIndex);
|
|
202
|
+
} catch {
|
|
203
|
+
logger.info("Failed to download main index, only override index is loaded", NS);
|
|
204
|
+
|
|
205
|
+
return mappedLocalIndex;
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
return await getOtaIndexInternal(mainIndexUrl);
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
// #endregion
|
|
213
|
+
|
|
214
|
+
// #region OTA Utils
|
|
215
|
+
|
|
216
|
+
export function parseOtaHeader(buffer: Buffer): OtaImageHeader {
|
|
217
|
+
const otaUpgradeFileIdentifier = buffer.readUInt32LE(0);
|
|
218
|
+
|
|
219
|
+
assert(UPGRADE_FILE_IDENTIFIER === otaUpgradeFileIdentifier, "Not a valid OTA file");
|
|
220
|
+
|
|
221
|
+
const otaHeaderVersion = buffer.readUInt16LE(4);
|
|
222
|
+
const otaHeaderLength = buffer.readUInt16LE(6);
|
|
223
|
+
const otaHeaderFieldControl = buffer.readUInt16LE(8);
|
|
224
|
+
const manufacturerCode = buffer.readUInt16LE(10);
|
|
225
|
+
const imageType = buffer.readUInt16LE(12);
|
|
226
|
+
const fileVersion = buffer.readUInt32LE(14);
|
|
227
|
+
const zigbeeStackVersion = buffer.readUInt16LE(18);
|
|
228
|
+
const otaHeaderString = buffer.toString("utf8", 20, 52);
|
|
229
|
+
const totalImageSize = buffer.readUInt32LE(52);
|
|
230
|
+
|
|
231
|
+
const header: OtaImageHeader = {
|
|
232
|
+
otaUpgradeFileIdentifier,
|
|
233
|
+
otaHeaderVersion,
|
|
234
|
+
otaHeaderLength,
|
|
235
|
+
otaHeaderFieldControl,
|
|
236
|
+
manufacturerCode,
|
|
237
|
+
imageType,
|
|
238
|
+
fileVersion,
|
|
239
|
+
zigbeeStackVersion,
|
|
240
|
+
otaHeaderString,
|
|
241
|
+
totalImageSize,
|
|
242
|
+
};
|
|
243
|
+
let headerPosition = 56;
|
|
244
|
+
|
|
245
|
+
if (header.otaHeaderFieldControl & 1) {
|
|
246
|
+
header.securityCredentialVersion = buffer.readUInt8(headerPosition);
|
|
247
|
+
headerPosition += 1;
|
|
248
|
+
}
|
|
249
|
+
|
|
250
|
+
if (header.otaHeaderFieldControl & 2) {
|
|
251
|
+
header.upgradeFileDestination = buffer.subarray(headerPosition, headerPosition + 8);
|
|
252
|
+
headerPosition += 8;
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
if (header.otaHeaderFieldControl & 4) {
|
|
256
|
+
header.minimumHardwareVersion = buffer.readUInt16LE(headerPosition);
|
|
257
|
+
headerPosition += 2;
|
|
258
|
+
header.maximumHardwareVersion = buffer.readUInt16LE(headerPosition);
|
|
259
|
+
headerPosition += 2;
|
|
260
|
+
}
|
|
261
|
+
|
|
262
|
+
return header;
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
export function parseOtaSubElement(buffer: Buffer, position: number): [OtaImageElement, metaOffset: number] {
|
|
266
|
+
const tagId = buffer.readUInt16LE(position);
|
|
267
|
+
const length = buffer.readUInt32LE(position + 2);
|
|
268
|
+
|
|
269
|
+
// this is fine for now, no known other uses of this tag
|
|
270
|
+
if (tagId === OtaTagId.TelinkAES) {
|
|
271
|
+
// OTA_FLAG_IMAGE_ELEM_INFO1 (1-byte) + OTA_FLAG_IMAGE_ELEM_INFO2 (1-byte)
|
|
272
|
+
// buffer.subarray(position + 6, position + 8);
|
|
273
|
+
const data = buffer.subarray(position + 8, position + 8 + length);
|
|
274
|
+
|
|
275
|
+
return [{tagId, length, data}, 8];
|
|
276
|
+
}
|
|
277
|
+
|
|
278
|
+
const data = buffer.subarray(position + 6, position + 6 + length);
|
|
279
|
+
|
|
280
|
+
return [{tagId, length, data}, 6];
|
|
281
|
+
}
|
|
282
|
+
|
|
283
|
+
export function parseOtaImage(buffer: Buffer): OtaImage {
|
|
284
|
+
const header = parseOtaHeader(buffer);
|
|
285
|
+
const raw = buffer.subarray(0, header.totalImageSize);
|
|
286
|
+
let position = header.otaHeaderLength;
|
|
287
|
+
const elements = [];
|
|
288
|
+
|
|
289
|
+
while (position < header.totalImageSize) {
|
|
290
|
+
const [element, metaOffset] = parseOtaSubElement(buffer, position);
|
|
291
|
+
position += element.data.length + metaOffset;
|
|
292
|
+
|
|
293
|
+
elements.push(element);
|
|
294
|
+
}
|
|
295
|
+
|
|
296
|
+
assert(position === header.totalImageSize, "Size mismatch");
|
|
297
|
+
|
|
298
|
+
return {header, elements, raw};
|
|
299
|
+
}
|
|
300
|
+
|
|
301
|
+
function buildImageBlockPayload(
|
|
302
|
+
image: OtaImage,
|
|
303
|
+
requestPayload: TClusterCommandPayload<"genOta", "imageBlockRequest" | "imagePageRequest">,
|
|
304
|
+
pageOffset: number,
|
|
305
|
+
pageSize: number,
|
|
306
|
+
baseDataSize: number,
|
|
307
|
+
) {
|
|
308
|
+
let dataSize = baseDataSize;
|
|
309
|
+
|
|
310
|
+
if (requestPayload.manufacturerCode === Zcl.ManufacturerCode.INSTA_GMBH) {
|
|
311
|
+
// Insta devices, OTA only works for data sizes 40 and smaller (= manufacturerCode 4474).
|
|
312
|
+
dataSize = 40;
|
|
313
|
+
}
|
|
314
|
+
|
|
315
|
+
if (requestPayload.manufacturerCode === Zcl.ManufacturerCode.LEGRAND_GROUP) {
|
|
316
|
+
// Legrand devices (newer firmware) require up to 64 bytes (= manufacturerCode 4129), let it drive the size
|
|
317
|
+
dataSize = requestPayload.maximumDataSize;
|
|
318
|
+
}
|
|
319
|
+
|
|
320
|
+
if (Number.isFinite(requestPayload.maximumDataSize)) {
|
|
321
|
+
dataSize = Math.min(dataSize, requestPayload.maximumDataSize);
|
|
322
|
+
}
|
|
323
|
+
|
|
324
|
+
let start = requestPayload.fileOffset + pageOffset;
|
|
325
|
+
|
|
326
|
+
/* v8 ignore start */
|
|
327
|
+
if (
|
|
328
|
+
requestPayload.manufacturerCode === Zcl.ManufacturerCode.LEGRAND_GROUP &&
|
|
329
|
+
requestPayload.fileOffset === 50 &&
|
|
330
|
+
requestPayload.maximumDataSize === 12
|
|
331
|
+
) {
|
|
332
|
+
// Hack for https://github.com/Koenkk/zigbee-OTA/issues/328 (Legrand OTA not working)
|
|
333
|
+
logger.info("Detected Legrand firmware issue, attempting to reset the OTA stack", NS);
|
|
334
|
+
// The following vector seems to buffer overflow the device to reset the OTA stack!
|
|
335
|
+
start = 78;
|
|
336
|
+
dataSize = 64;
|
|
337
|
+
}
|
|
338
|
+
/* v8 ignore stop */
|
|
339
|
+
|
|
340
|
+
if (pageSize) {
|
|
341
|
+
dataSize = Math.min(dataSize, pageSize - pageOffset);
|
|
342
|
+
}
|
|
343
|
+
|
|
344
|
+
let end = start + dataSize;
|
|
345
|
+
|
|
346
|
+
if (end > image.raw.length) {
|
|
347
|
+
end = image.raw.length;
|
|
348
|
+
}
|
|
349
|
+
|
|
350
|
+
logger.debug(
|
|
351
|
+
() => `Request offsets: fileOffset=${requestPayload.fileOffset} pageOffset=${pageOffset} maximumDataSize=${requestPayload.maximumDataSize}`,
|
|
352
|
+
NS,
|
|
353
|
+
);
|
|
354
|
+
logger.debug(() => `Payload offsets: start=${start} end=${end} dataSize=${dataSize}`, NS);
|
|
355
|
+
|
|
356
|
+
return {
|
|
357
|
+
status: Zcl.Status.SUCCESS,
|
|
358
|
+
manufacturerCode: requestPayload.manufacturerCode,
|
|
359
|
+
imageType: requestPayload.imageType,
|
|
360
|
+
fileVersion: requestPayload.fileVersion,
|
|
361
|
+
fileOffset: start,
|
|
362
|
+
dataSize: end - start,
|
|
363
|
+
data: image.raw.subarray(start, end),
|
|
364
|
+
};
|
|
365
|
+
}
|
|
366
|
+
|
|
367
|
+
// #endregion
|
|
368
|
+
|
|
369
|
+
type OtaDataRequest = TZclFrame<"genOta", "imageBlockRequest"> | TZclFrame<"genOta", "imagePageRequest">;
|
|
370
|
+
type OtaUpgradeEndRequest = TZclFrame<"genOta", "upgradeEndRequest">;
|
|
371
|
+
|
|
372
|
+
export class OtaSession {
|
|
373
|
+
#lastBlockResponseTime = 0;
|
|
374
|
+
#lastProgressUpdate = 0;
|
|
375
|
+
readonly #startTime: number;
|
|
376
|
+
|
|
377
|
+
get startTime() {
|
|
378
|
+
return this.#startTime;
|
|
379
|
+
}
|
|
380
|
+
|
|
381
|
+
constructor(
|
|
382
|
+
private readonly ieeeAddr: string,
|
|
383
|
+
private readonly endpoint: Endpoint,
|
|
384
|
+
private readonly image: OtaImage,
|
|
385
|
+
private readonly onProgress: (progress: number, remaining: number) => void,
|
|
386
|
+
private readonly dataSettings: OtaDataSettings,
|
|
387
|
+
private readonly waitForOtaCommand: <Co extends string>(
|
|
388
|
+
endpointId: number,
|
|
389
|
+
commandId: number,
|
|
390
|
+
transactionSequenceNumber: number | undefined,
|
|
391
|
+
timeout: number,
|
|
392
|
+
) => {promise: Promise<TZclFrame<"genOta", Co>>; cancel: () => void},
|
|
393
|
+
) {
|
|
394
|
+
this.#startTime = performance.now();
|
|
395
|
+
|
|
396
|
+
// TODO: should `dataSettings.requestTimeout` be override if >0?
|
|
397
|
+
// to allow easier testing when devices misbehave otherwise potentially overridden by below switch
|
|
398
|
+
// if (!this.dataSettings.requestTimeout) {
|
|
399
|
+
switch (image.header.manufacturerCode) {
|
|
400
|
+
case Zcl.ManufacturerCode.ROBERT_BOSCH_GMBH: {
|
|
401
|
+
// Bosch transmits the firmware updates in the background in their native implementation.
|
|
402
|
+
// According to the app, this can take up to 2 days. Therefore, we assume to get at least
|
|
403
|
+
// one package request per hour from the device here.
|
|
404
|
+
this.dataSettings.requestTimeout = 60 * 60 * 1000;
|
|
405
|
+
break;
|
|
406
|
+
}
|
|
407
|
+
case Zcl.ManufacturerCode.LEGRAND_GROUP: {
|
|
408
|
+
// Increase the timeout for Legrand devices, so that they will re-initiate and update themselves
|
|
409
|
+
// Newer firmwares have awkward behaviours when it comes to the handling of the last bytes of OTA updates
|
|
410
|
+
this.dataSettings.requestTimeout = 30 * 60 * 1000;
|
|
411
|
+
break;
|
|
412
|
+
}
|
|
413
|
+
case Zcl.ManufacturerCode.SHENZHEN_COOLKIT_TECHNOLOGY_CO_LTD: {
|
|
414
|
+
if (image.header.imageType === 8199) {
|
|
415
|
+
// increase the upgradeEndReq wait time to solve the problem of OTA timeout failure of Sonoff Devices
|
|
416
|
+
// (https://github.com/Koenkk/zigbee-herdsman-converters/issues/6657)
|
|
417
|
+
this.dataSettings.requestTimeout = 3600000;
|
|
418
|
+
}
|
|
419
|
+
break;
|
|
420
|
+
}
|
|
421
|
+
}
|
|
422
|
+
// }
|
|
423
|
+
|
|
424
|
+
if (!this.dataSettings.requestTimeout) {
|
|
425
|
+
this.dataSettings.requestTimeout = 150000; // ensures never zero
|
|
426
|
+
}
|
|
427
|
+
|
|
428
|
+
if (!this.dataSettings.baseSize) {
|
|
429
|
+
this.dataSettings.baseSize = 50; // ensures never zero
|
|
430
|
+
}
|
|
431
|
+
|
|
432
|
+
// report initial progress with estimated time
|
|
433
|
+
const expectedBlocks = Math.ceil(image.header.totalImageSize / dataSettings.baseSize);
|
|
434
|
+
const blocksPerSec = dataSettings.responseDelay > 0 ? Math.round((1000 / dataSettings.responseDelay) * 100) / 100 : 20; // (1000 / 50)
|
|
435
|
+
const estimatedRemainingSeconds = expectedBlocks / blocksPerSec;
|
|
436
|
+
|
|
437
|
+
onProgress(0, estimatedRemainingSeconds);
|
|
438
|
+
logger.info(
|
|
439
|
+
() =>
|
|
440
|
+
`OTA update of '${this.ieeeAddr}' estimated at ${estimatedRemainingSeconds} seconds (${expectedBlocks} chunks, ${blocksPerSec} per second)`,
|
|
441
|
+
NS,
|
|
442
|
+
);
|
|
443
|
+
}
|
|
444
|
+
|
|
445
|
+
public async run(): Promise<TZclFrame<"genOta", "upgradeEndRequest">> {
|
|
446
|
+
// can take a long time, use max (int32 - 1), ~24 days
|
|
447
|
+
const upgradeEndRequest = this.waitForOtaCommand<"upgradeEndRequest">(this.endpoint.ID, UPGRADE_END_REQUEST_ID, undefined, 2147483647);
|
|
448
|
+
|
|
449
|
+
try {
|
|
450
|
+
for await (const request of this.commandStream(upgradeEndRequest)) {
|
|
451
|
+
if (request.command.ID === UPGRADE_END_REQUEST_ID) {
|
|
452
|
+
return request as TZclFrame<"genOta", "upgradeEndRequest">;
|
|
453
|
+
}
|
|
454
|
+
|
|
455
|
+
if (request.command.ID === IMAGE_PAGE_REQUEST_ID) {
|
|
456
|
+
const pagePayload = request.payload as TClusterPayload<"genOta", "imagePageRequest">;
|
|
457
|
+
let pageOffset = 0;
|
|
458
|
+
|
|
459
|
+
while (pageOffset < pagePayload.pageSize) {
|
|
460
|
+
pageOffset = await this.sendImageBlockResponse(
|
|
461
|
+
pagePayload,
|
|
462
|
+
request.header.transactionSequenceNumber,
|
|
463
|
+
pageOffset,
|
|
464
|
+
pagePayload.pageSize,
|
|
465
|
+
);
|
|
466
|
+
}
|
|
467
|
+
} else {
|
|
468
|
+
await this.sendImageBlockResponse(
|
|
469
|
+
request.payload as TClusterPayload<"genOta", "imageBlockRequest">,
|
|
470
|
+
request.header.transactionSequenceNumber,
|
|
471
|
+
0,
|
|
472
|
+
0,
|
|
473
|
+
);
|
|
474
|
+
}
|
|
475
|
+
/* v8 ignore start */
|
|
476
|
+
}
|
|
477
|
+
|
|
478
|
+
// this code is logically unreachable
|
|
479
|
+
// the generator always yields `UPGRADE_END_REQUEST_ID` before completing or it will eventually throw a timeout
|
|
480
|
+
// but TypeScript can't detect this and requires a return statement
|
|
481
|
+
const endPayload = await upgradeEndRequest.promise;
|
|
482
|
+
|
|
483
|
+
return endPayload;
|
|
484
|
+
/* v8 ignore stop */
|
|
485
|
+
} catch (error) {
|
|
486
|
+
upgradeEndRequest.cancel();
|
|
487
|
+
|
|
488
|
+
const err = error as Error;
|
|
489
|
+
err.message = `Device ${this.ieeeAddr} did not start/finish firmware download after being notified. (${err.message})`;
|
|
490
|
+
|
|
491
|
+
throw err;
|
|
492
|
+
}
|
|
493
|
+
}
|
|
494
|
+
|
|
495
|
+
private async *commandStream(upgradeEndRequest: {
|
|
496
|
+
promise: Promise<TZclFrame<"genOta", "upgradeEndRequest">>;
|
|
497
|
+
cancel: () => void;
|
|
498
|
+
}): AsyncGenerator<OtaDataRequest | OtaUpgradeEndRequest> {
|
|
499
|
+
while (true) {
|
|
500
|
+
const imageBlockRequest = this.waitForOtaCommand<"imageBlockRequest">(
|
|
501
|
+
this.endpoint.ID,
|
|
502
|
+
IMAGE_BLOCK_REQUEST_ID,
|
|
503
|
+
undefined,
|
|
504
|
+
this.dataSettings.requestTimeout,
|
|
505
|
+
);
|
|
506
|
+
const imagePageRequest = this.waitForOtaCommand<"imagePageRequest">(
|
|
507
|
+
this.endpoint.ID,
|
|
508
|
+
IMAGE_PAGE_REQUEST_ID,
|
|
509
|
+
undefined,
|
|
510
|
+
this.dataSettings.requestTimeout,
|
|
511
|
+
);
|
|
512
|
+
const dataRequest = Promise.race([imageBlockRequest.promise, imagePageRequest.promise]);
|
|
513
|
+
const request = await Promise.race([dataRequest, upgradeEndRequest.promise]);
|
|
514
|
+
|
|
515
|
+
imageBlockRequest.cancel();
|
|
516
|
+
imagePageRequest.cancel();
|
|
517
|
+
|
|
518
|
+
// if this is `UPGRADE_END_REQUEST_ID`, `run()` will return and thus terminate the generator (no endless loop possible)
|
|
519
|
+
yield request;
|
|
520
|
+
}
|
|
521
|
+
}
|
|
522
|
+
|
|
523
|
+
private async sendImageBlockResponse(
|
|
524
|
+
requestPayload: TClusterCommandPayload<"genOta", "imageBlockRequest">,
|
|
525
|
+
requestTsn: number,
|
|
526
|
+
pageOffset: number,
|
|
527
|
+
pageSize: number,
|
|
528
|
+
): Promise<number> {
|
|
529
|
+
// throttle if needed
|
|
530
|
+
let callNow = performance.now();
|
|
531
|
+
const timeSinceLast = callNow - this.#lastBlockResponseTime;
|
|
532
|
+
const delayNeeded = this.dataSettings.responseDelay - timeSinceLast;
|
|
533
|
+
|
|
534
|
+
if (delayNeeded > 0) {
|
|
535
|
+
await new Promise((resolve) => setTimeout(resolve, delayNeeded));
|
|
536
|
+
|
|
537
|
+
// avoids a second call to `performance.now()`
|
|
538
|
+
callNow += delayNeeded;
|
|
539
|
+
}
|
|
540
|
+
|
|
541
|
+
this.#lastBlockResponseTime = callNow;
|
|
542
|
+
|
|
543
|
+
try {
|
|
544
|
+
const blockPayload = buildImageBlockPayload(this.image, requestPayload, pageOffset, pageSize, this.dataSettings.baseSize);
|
|
545
|
+
|
|
546
|
+
await this.endpoint.commandResponse("genOta", "imageBlockResponse", blockPayload, undefined, requestTsn);
|
|
547
|
+
|
|
548
|
+
const nextOffset = pageOffset + blockPayload.dataSize;
|
|
549
|
+
const now = performance.now();
|
|
550
|
+
|
|
551
|
+
if (now - this.#lastProgressUpdate > 30000) {
|
|
552
|
+
const totalDurationSeconds = (now - this.#startTime) / 1000;
|
|
553
|
+
const bytesPerSecond = requestPayload.fileOffset / totalDurationSeconds;
|
|
554
|
+
|
|
555
|
+
// first 30 seconds will be ignored due to first fileOffset being 0
|
|
556
|
+
// remain on ctor progress estimate until then (more reliable)
|
|
557
|
+
if (bytesPerSecond > 0) {
|
|
558
|
+
const percentage = Math.round((requestPayload.fileOffset / this.image.header.totalImageSize) * 10000) / 100;
|
|
559
|
+
const remainingSeconds = Math.round((this.image.header.totalImageSize - requestPayload.fileOffset) / bytesPerSecond);
|
|
560
|
+
|
|
561
|
+
logger.info(() => `OTA update of '${this.ieeeAddr}' at ${percentage}%, ${remainingSeconds} seconds remaining`, NS);
|
|
562
|
+
this.onProgress(percentage, remainingSeconds);
|
|
563
|
+
}
|
|
564
|
+
|
|
565
|
+
this.#lastProgressUpdate = now;
|
|
566
|
+
}
|
|
567
|
+
|
|
568
|
+
return nextOffset;
|
|
569
|
+
} catch (error) {
|
|
570
|
+
logger.debug(() => `Image block response failed for ${this.ieeeAddr}: ${(error as Error).message}`, NS);
|
|
571
|
+
|
|
572
|
+
return pageOffset;
|
|
573
|
+
}
|
|
574
|
+
}
|
|
575
|
+
}
|