From 53f1f11c6d94d1f6ec8041bccc7f5b96d5d0e4ff Mon Sep 17 00:00:00 2001 From: terence Date: Fri, 25 Oct 2024 10:59:57 -0700 Subject: [PATCH] Fix length check between kzg commitments and exist (#14581) --- CHANGELOG.md | 1 + beacon-chain/execution/engine_client.go | 4 ++-- beacon-chain/execution/engine_client_test.go | 12 ++++++++++++ 3 files changed, 15 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 40ae44f6fff1..d842d57b40d0 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -46,6 +46,7 @@ The format is based on Keep a Changelog, and this project adheres to Semantic Ve - wait for the async StreamEvent writer to exit before leaving the http handler, avoiding race condition panics [pr](https://github.com/prysmaticlabs/prysm/pull/14557) - Certain deb files were returning a 404 which made building new docker images without an existing cache impossible. This has been fixed with updates to rules_oci and bazel-lib. +- Fixed an issue where the length check between block body KZG commitments and the existing cache from the database was incompatible. ### Security diff --git a/beacon-chain/execution/engine_client.go b/beacon-chain/execution/engine_client.go index 2776b04eb767..6acb0eafd7d1 100644 --- a/beacon-chain/execution/engine_client.go +++ b/beacon-chain/execution/engine_client.go @@ -560,8 +560,8 @@ func (s *Service) ReconstructBlobSidecars(ctx context.Context, block interfaces. if err != nil { return nil, errors.Wrap(err, "could not get blob KZG commitments") } - if len(kzgCommitments) != len(exists) { - return nil, fmt.Errorf("mismatched lengths: KZG commitments %d, exists %d", len(kzgCommitments), len(exists)) + if len(kzgCommitments) > len(exists) { + return nil, fmt.Errorf("length of KZG commitments (%d) is greater than length of exists (%d)", len(kzgCommitments), len(exists)) } // Collect KZG hashes for non-existing blobs diff --git a/beacon-chain/execution/engine_client_test.go b/beacon-chain/execution/engine_client_test.go index 31db063ab59e..9d906c6d371f 100644 --- a/beacon-chain/execution/engine_client_test.go +++ b/beacon-chain/execution/engine_client_test.go @@ -2446,6 +2446,18 @@ func TestReconstructBlobSidecars(t *testing.T) { require.NoError(t, err) require.Equal(t, 3, len(verifiedBlobs)) }) + + t.Run("kzg is longer than exist", func(t *testing.T) { + srv := createBlobServer(t, 3) + defer srv.Close() + + rpcClient, client := setupRpcClient(t, srv.URL, client) + defer rpcClient.Close() + + exists := []bool{true, false, true, false, true} + _, err := client.ReconstructBlobSidecars(ctx, sb, r, exists) + require.ErrorContains(t, "length of KZG commitments (6) is greater than length of exists (5)", err) + }) } func createRandomKzgCommitments(t *testing.T, num int) [][]byte {