From 4b028c5b7272dd0563322bddd2f44ca8d589f61f Mon Sep 17 00:00:00 2001 From: AlCalzone Date: Fri, 12 Apr 2024 14:47:25 +0200 Subject: [PATCH] fix: handle synthetic multicast `SupervisionResult` in `sendCommand` (#6765) --- packages/zwave-js/src/lib/driver/Driver.ts | 16 +++++++++++++++- packages/zwave-js/src/lib/node/VirtualNode.ts | 5 ----- 2 files changed, 15 insertions(+), 6 deletions(-) diff --git a/packages/zwave-js/src/lib/driver/Driver.ts b/packages/zwave-js/src/lib/driver/Driver.ts index d217d4a294f6..1c5949946ff5 100644 --- a/packages/zwave-js/src/lib/driver/Driver.ts +++ b/packages/zwave-js/src/lib/driver/Driver.ts @@ -5654,8 +5654,22 @@ ${handlers.length} left`, } // Fall back to non-supervised commands + const result = await this.sendCommandInternal(command, options); + + // When sending S2 multicast commands to supporting nodes, the singlecast followups + // may use supervision. In this case, the multicast message generator returns a + // synthetic SupervisionCCReport. + // sendCommand is supposed to return a SupervisionResult though. + if ( + options?.s2MulticastGroupId != undefined + && result instanceof SupervisionCCReport + ) { + // @ts-expect-error TS doesn't know we've narrowed the return type to match + return result.toSupervisionResult(); + } + // @ts-expect-error TS doesn't know we've narrowed the return type to match - return this.sendCommandInternal(command, options); + return result; } /** @internal */ diff --git a/packages/zwave-js/src/lib/node/VirtualNode.ts b/packages/zwave-js/src/lib/node/VirtualNode.ts index baf0cd505443..dcfc5abd3af6 100644 --- a/packages/zwave-js/src/lib/node/VirtualNode.ts +++ b/packages/zwave-js/src/lib/node/VirtualNode.ts @@ -176,11 +176,6 @@ export class VirtualNode extends VirtualEndpoint implements IVirtualNode { options, ); - // api.setValue could technically return a SupervisionResult - // but supervision isn't used for multicast / broadcast - - // FIXME: It just may for S2 multicast - if (api.isSetValueOptimistic(valueId)) { // If the call did not throw, assume that the call was successful and remember the new value // for each node that was affected by this command