From a52f491f5f7b803f750b094af267c8da5c4b583f Mon Sep 17 00:00:00 2001 From: yunhanw Date: Wed, 17 Jan 2024 10:49:39 -0800 Subject: [PATCH] Return CHIP_ERROR_INVALID_IPK when providing the invalid IPK from android application --- src/controller/java/CHIPDeviceController-JNI.cpp | 6 +++++- src/lib/core/CHIPError.cpp | 3 +++ src/lib/core/CHIPError.h | 9 ++++++++- 3 files changed, 16 insertions(+), 2 deletions(-) diff --git a/src/controller/java/CHIPDeviceController-JNI.cpp b/src/controller/java/CHIPDeviceController-JNI.cpp index 9b3e67b6bf253b..adde00b6cfb4a5 100644 --- a/src/controller/java/CHIPDeviceController-JNI.cpp +++ b/src/controller/java/CHIPDeviceController-JNI.cpp @@ -228,7 +228,11 @@ JNI_METHOD(jint, onNOCChainGeneration) { JniByteArray jByteArrayIpk(env, ipk); - VerifyOrReturnValue(jByteArrayIpk.byteSpan().size() == sizeof(ipkValue), CHIP_ERROR_INTERNAL.AsInteger()); + if (jByteArrayIpk.byteSpan().size() != sizeof(ipkValue)) + { + ChipLogError(Controller, "Invalid IPK size %ld and expect %ld", jByteArrayIpk.byteSpan().size(), sizeof(ipkValue)); + return CHIP_ERROR_INVALID_IPK.AsInteger(); + } memcpy(&ipkValue[0], jByteArrayIpk.byteSpan().data(), jByteArrayIpk.byteSpan().size()); ipkOptional.SetValue(ipkTempSpan); diff --git a/src/lib/core/CHIPError.cpp b/src/lib/core/CHIPError.cpp index a3bdd148253cfb..565e1b065b5c4c 100644 --- a/src/lib/core/CHIPError.cpp +++ b/src/lib/core/CHIPError.cpp @@ -143,6 +143,9 @@ bool FormatCHIPError(char * buf, uint16_t bufSize, CHIP_ERROR err) case CHIP_ERROR_UNINITIALIZED.AsInteger(): desc = "Uninitialized"; break; + case CHIP_ERROR_INVALID_IPK.AsInteger(): + desc = "Invalid IPK"; + break; case CHIP_ERROR_INVALID_STRING_LENGTH.AsInteger(): desc = "Invalid string length"; break; diff --git a/src/lib/core/CHIPError.h b/src/lib/core/CHIPError.h index 3844bf53516b86..da3af4c29e681d 100644 --- a/src/lib/core/CHIPError.h +++ b/src/lib/core/CHIPError.h @@ -681,7 +681,14 @@ using CHIP_ERROR = ::chip::ChipError; */ #define CHIP_ERROR_UNINITIALIZED CHIP_CORE_ERROR(0x1c) -// AVAILABLE: 0x1d +/** + * @def CHIP_ERROR_INVALID_IPK + * + * @brief + * The IPK is invalid + * + */ +#define CHIP_ERROR_INVALID_IPK CHIP_CORE_ERROR(0x1d) /** * @def CHIP_ERROR_INVALID_STRING_LENGTH