Skip to content

Commit

Permalink
Don't store ICAC when we don't have one. (#16132)
Browse files Browse the repository at this point in the history
The ESP32 storage backend fails out on null-with-0-length being
stored, so we are failing to commission ESP32 devices.  CI did not
catch this because our Linux/Darwin backends allow null-with-0-length.
  • Loading branch information
bzbarsky-apple authored and pull[bot] committed Aug 1, 2023
1 parent 9203117 commit 1669232
Showing 1 changed file with 28 additions and 9 deletions.
37 changes: 28 additions & 9 deletions src/credentials/FabricTable.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -68,10 +68,23 @@ CHIP_ERROR FabricInfo::CommitToStorage(PersistentStorageDelegate * storage)
ReturnErrorOnFailure(
storage->SyncSetKeyValue(keyAlloc.FabricRCAC(mFabric), mRootCert.data(), static_cast<uint16_t>(mRootCert.size())));

// If we stop storing ICA certs when empty, update LoadFromStorage
// accordingly to check for CHIP_ERROR_PERSISTED_STORAGE_VALUE_NOT_FOUND.
ReturnErrorOnFailure(
storage->SyncSetKeyValue(keyAlloc.FabricICAC(mFabric), mICACert.data(), static_cast<uint16_t>(mICACert.size())));
// Workaround for the fact that some storage backends do not allow storing
// a nullptr with 0 length. See
// https://github.com/project-chip/connectedhomeip/issues/16030.
if (!mICACert.empty())
{
ReturnErrorOnFailure(
storage->SyncSetKeyValue(keyAlloc.FabricICAC(mFabric), mICACert.data(), static_cast<uint16_t>(mICACert.size())));
}
else
{
// Make sure there is no stale data.
CHIP_ERROR err = storage->SyncDeleteKeyValue(keyAlloc.FabricICAC(mFabric));
if (err != CHIP_ERROR_PERSISTED_STORAGE_VALUE_NOT_FOUND)
{
ReturnErrorOnFailure(err);
}
}

ReturnErrorOnFailure(
storage->SyncSetKeyValue(keyAlloc.FabricNOC(mFabric), mNOCCert.data(), static_cast<uint16_t>(mNOCCert.size())));
Expand Down Expand Up @@ -149,11 +162,17 @@ CHIP_ERROR FabricInfo::LoadFromStorage(PersistentStorageDelegate * storage)

{
uint8_t buf[Credentials::kMaxCHIPCertLength];
uint16_t size = sizeof(buf);
// For now we always store an ICA cert buffer (possibly empty). If we
// stop doing that, check for
// CHIP_ERROR_PERSISTED_STORAGE_VALUE_NOT_FOUND here.
ReturnErrorOnFailure(storage->SyncGetKeyValue(keyAlloc.FabricICAC(mFabric), buf, size));
uint16_t size = sizeof(buf);
CHIP_ERROR err = storage->SyncGetKeyValue(keyAlloc.FabricICAC(mFabric), buf, size);
if (err == CHIP_ERROR_PERSISTED_STORAGE_VALUE_NOT_FOUND)
{
// That's OK; that just means no ICAC.
size = 0;
}
else
{
ReturnErrorOnFailure(err);
}
ReturnErrorOnFailure(SetICACert(ByteSpan(buf, size)));
}

Expand Down

0 comments on commit 1669232

Please sign in to comment.