Skip to content

Commit

Permalink
ASN.1 null writer check should not bypass reading from TLVReader (#31088
Browse files Browse the repository at this point in the history
)

... since it is just intended to be an optimization.
  • Loading branch information
ksperling-apple authored and pull[bot] committed Jan 11, 2024
1 parent 59a0be0 commit 99bcb79
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 4 deletions.
8 changes: 4 additions & 4 deletions src/lib/asn1/ASN1Writer.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -234,13 +234,13 @@ CHIP_ERROR ASN1Writer::PutBitString(uint8_t unusedBitCount, const uint8_t * enco

CHIP_ERROR ASN1Writer::PutBitString(uint8_t unusedBitCount, chip::TLV::TLVReader & tlvReader)
{
ReturnErrorCodeIf(IsNullWriter(), CHIP_NO_ERROR);

ByteSpan encodedBits;
ReturnErrorOnFailure(tlvReader.Get(encodedBits));

VerifyOrReturnError(CanCastTo<int32_t>(encodedBits.size() + 1), ASN1_ERROR_LENGTH_OVERFLOW);

ReturnErrorCodeIf(IsNullWriter(), CHIP_NO_ERROR);

ReturnErrorOnFailure(
EncodeHead(kASN1TagClass_Universal, kASN1UniversalTag_BitString, false, static_cast<int32_t>(encodedBits.size() + 1)));

Expand Down Expand Up @@ -335,13 +335,13 @@ CHIP_ERROR ASN1Writer::PutValue(uint8_t cls, uint8_t tag, bool isConstructed, co

CHIP_ERROR ASN1Writer::PutValue(uint8_t cls, uint8_t tag, bool isConstructed, chip::TLV::TLVReader & tlvReader)
{
ReturnErrorCodeIf(IsNullWriter(), CHIP_NO_ERROR);

ByteSpan val;
ReturnErrorOnFailure(tlvReader.Get(val));

VerifyOrReturnError(CanCastTo<int32_t>(val.size()), ASN1_ERROR_LENGTH_OVERFLOW);

ReturnErrorCodeIf(IsNullWriter(), CHIP_NO_ERROR);

ReturnErrorOnFailure(EncodeHead(cls, tag, isConstructed, static_cast<int32_t>(val.size())));

WriteData(val.data(), val.size());
Expand Down
11 changes: 11 additions & 0 deletions src/lib/asn1/tests/TestASN1.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -304,6 +304,17 @@ static void TestASN1_NullWriter(nlTestSuite * inSuite, void * inContext)

encodedLen = writer.GetLengthWritten();
NL_TEST_ASSERT(inSuite, encodedLen == 0);

// Methods that take a reader should still read from it,
// even if the output is suppressed by the null writer.
TLVReader emptyTlvReader;
emptyTlvReader.Init(ByteSpan());
err = writer.PutBitString(0, emptyTlvReader);
NL_TEST_ASSERT(inSuite, err == CHIP_ERROR_WRONG_TLV_TYPE);

emptyTlvReader.Init(ByteSpan());
err = writer.PutOctetString(kASN1TagClass_ContextSpecific, 123, emptyTlvReader);
NL_TEST_ASSERT(inSuite, err == CHIP_ERROR_WRONG_TLV_TYPE);
}

static void TestASN1_ASN1UniversalTime(nlTestSuite * inSuite, void * inContext)
Expand Down

0 comments on commit 99bcb79

Please sign in to comment.