Matter SDK Coverage Report
Current view: top level - protocols/secure_channel - CASEDestinationId.cpp (source / functions) Coverage Total Hit
Test: SHA:b879ecb8e99e175eea0a293a888bda853da2b19c Lines: 100.0 % 19 19
Test Date: 2025-01-17 19:00:11 Functions: 100.0 % 1 1

            Line data    Source code
       1              : /*
       2              :  *
       3              :  *    Copyright (c) 2022 Project CHIP Authors
       4              :  *
       5              :  *    Licensed under the Apache License, Version 2.0 (the "License");
       6              :  *    you may not use this file except in compliance with the License.
       7              :  *    You may obtain a copy of the License at
       8              :  *
       9              :  *        http://www.apache.org/licenses/LICENSE-2.0
      10              :  *
      11              :  *    Unless required by applicable law or agreed to in writing, software
      12              :  *    distributed under the License is distributed on an "AS IS" BASIS,
      13              :  *    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
      14              :  *    See the License for the specific language governing permissions and
      15              :  *    limitations under the License.
      16              :  */
      17              : 
      18              : #include <stdint.h>
      19              : 
      20              : #include <credentials/FabricTable.h>
      21              : #include <credentials/GroupDataProvider.h>
      22              : #include <lib/core/CHIPError.h>
      23              : #include <lib/support/BufferWriter.h>
      24              : #include <lib/support/Span.h>
      25              : 
      26              : #include "CASEDestinationId.h"
      27              : 
      28              : namespace chip {
      29              : 
      30              : using namespace chip::Crypto;
      31              : 
      32           23 : CHIP_ERROR GenerateCaseDestinationId(const ByteSpan & ipk, const ByteSpan & initiatorRandom, const ByteSpan & rootPubKey,
      33              :                                      FabricId fabricId, NodeId nodeId, MutableByteSpan & outDestinationId)
      34              : {
      35           23 :     VerifyOrReturnError(ipk.size() == kIPKSize, CHIP_ERROR_INVALID_ARGUMENT);
      36           23 :     VerifyOrReturnError(initiatorRandom.size() == kSigmaParamRandomNumberSize, CHIP_ERROR_INVALID_ARGUMENT);
      37           23 :     VerifyOrReturnError(rootPubKey.size() == kP256_PublicKey_Length, CHIP_ERROR_INVALID_ARGUMENT);
      38           23 :     VerifyOrReturnError(outDestinationId.size() >= kSHA256_Hash_Length, CHIP_ERROR_INVALID_ARGUMENT);
      39              : 
      40           23 :     constexpr size_t kDestinationMessageLen =
      41              :         kSigmaParamRandomNumberSize + kP256_PublicKey_Length + sizeof(FabricId) + sizeof(NodeId);
      42              :     uint8_t destinationMessage[kDestinationMessageLen];
      43              : 
      44           23 :     Encoding::LittleEndian::BufferWriter bbuf(destinationMessage, sizeof(destinationMessage));
      45           23 :     bbuf.Put(initiatorRandom.data(), initiatorRandom.size());
      46           23 :     bbuf.Put(rootPubKey.data(), rootPubKey.size());
      47           23 :     bbuf.Put64(fabricId);
      48           23 :     bbuf.Put64(nodeId);
      49              : 
      50           23 :     size_t written = 0;
      51           23 :     VerifyOrReturnError(bbuf.Fit(written), CHIP_ERROR_BUFFER_TOO_SMALL);
      52              : 
      53           23 :     HMAC_sha hmac;
      54              :     CHIP_ERROR err =
      55           23 :         hmac.HMAC_SHA256(ipk.data(), ipk.size(), bbuf.Buffer(), written, outDestinationId.data(), outDestinationId.size());
      56              : 
      57           23 :     if (err == CHIP_NO_ERROR)
      58              :     {
      59           23 :         outDestinationId.reduce_size(kSHA256_Hash_Length);
      60              :     }
      61              : 
      62           23 :     return err;
      63           23 : }
      64              : 
      65              : } // namespace chip
        

Generated by: LCOV version 2.0-1