-
Notifications
You must be signed in to change notification settings - Fork 27
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add support for Scope ID/Interface ID in CommissionIP API
Support the scope id/interface id using the procent sign as a separator. This allows to process link-local addresses.
- Loading branch information
Showing
1 changed file
with
54 additions
and
0 deletions.
There are no files selected for viewing
54 changes: 54 additions & 0 deletions
54
0005-Python-Parse-Interface-ID-from-IP-address-string-as-.patch
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
From 5b5e383674e78115107c7a95eb563902cd6b6014 Mon Sep 17 00:00:00 2001 | ||
Message-ID: <5b5e383674e78115107c7a95eb563902cd6b6014.1704821887.git.stefan@agner.ch> | ||
From: Stefan Agner <[email protected]> | ||
Date: Tue, 9 Jan 2024 18:35:50 +0100 | ||
Subject: [PATCH] [Python] Parse Interface ID from IP address string as well | ||
|
||
Currently, when passing a link-local address with an interface specified | ||
using the %<interface> notation leads to "CHIP Error 0x0000002F: Invalid | ||
argument". | ||
|
||
Correctly parse the interface ID as well and pass it to the PeerAddress | ||
object. | ||
--- | ||
.../python/ChipDeviceController-ScriptBinding.cpp | 10 ++++++---- | ||
1 file changed, 6 insertions(+), 4 deletions(-) | ||
|
||
diff --git a/src/controller/python/ChipDeviceController-ScriptBinding.cpp b/src/controller/python/ChipDeviceController-ScriptBinding.cpp | ||
index a7732a4836..e3e4de8d88 100644 | ||
--- a/src/controller/python/ChipDeviceController-ScriptBinding.cpp | ||
+++ b/src/controller/python/ChipDeviceController-ScriptBinding.cpp | ||
@@ -383,13 +383,14 @@ PyChipError pychip_DeviceController_ConnectIP(chip::Controller::DeviceCommission | ||
uint32_t setupPINCode, chip::NodeId nodeid) | ||
{ | ||
chip::Inet::IPAddress peerAddr; | ||
+ chip::Inet::InterfaceId ifaceOutput; | ||
chip::Transport::PeerAddress addr; | ||
chip::RendezvousParameters params = chip::RendezvousParameters().SetSetupPINCode(setupPINCode); | ||
|
||
- VerifyOrReturnError(chip::Inet::IPAddress::FromString(peerAddrStr, peerAddr), ToPyChipError(CHIP_ERROR_INVALID_ARGUMENT)); | ||
+ VerifyOrReturnError(chip::Inet::IPAddress::FromString(peerAddrStr, peerAddr, ifaceOutput), ToPyChipError(CHIP_ERROR_INVALID_ARGUMENT)); | ||
|
||
// TODO: IP rendezvous should use TCP connection. | ||
- addr.SetTransportType(chip::Transport::Type::kUdp).SetIPAddress(peerAddr); | ||
+ addr.SetTransportType(chip::Transport::Type::kUdp).SetIPAddress(peerAddr).SetInterface(ifaceOutput); | ||
params.SetPeerAddress(addr).SetDiscriminator(0); | ||
|
||
sPairingDelegate.SetExpectingPairingComplete(true); | ||
@@ -577,10 +578,11 @@ PyChipError pychip_DeviceController_EstablishPASESessionIP(chip::Controller::Dev | ||
uint32_t setupPINCode, chip::NodeId nodeid, uint16_t port) | ||
{ | ||
chip::Inet::IPAddress peerAddr; | ||
+ chip::Inet::InterfaceId ifaceOutput; | ||
chip::Transport::PeerAddress addr; | ||
RendezvousParameters params = chip::RendezvousParameters().SetSetupPINCode(setupPINCode); | ||
- VerifyOrReturnError(chip::Inet::IPAddress::FromString(peerAddrStr, peerAddr), ToPyChipError(CHIP_ERROR_INVALID_ARGUMENT)); | ||
- addr.SetTransportType(chip::Transport::Type::kUdp).SetIPAddress(peerAddr); | ||
+ VerifyOrReturnError(chip::Inet::IPAddress::FromString(peerAddrStr, peerAddr, ifaceOutput), ToPyChipError(CHIP_ERROR_INVALID_ARGUMENT)); | ||
+ addr.SetTransportType(chip::Transport::Type::kUdp).SetIPAddress(peerAddr).SetInterface(ifaceOutput); | ||
if (port != 0) | ||
{ | ||
addr.SetPort(port); | ||
-- | ||
2.43.0 | ||
|