From e3302ce6fefe48371b001128210eb713d1ab20c8 Mon Sep 17 00:00:00 2001 From: litt3 <102969658+litt3@users.noreply.github.com> Date: Tue, 14 Jan 2025 16:18:36 -0500 Subject: [PATCH] Check blob key from disperser against actual key Signed-off-by: litt3 <102969658+litt3@users.noreply.github.com> --- api/clients/v2/disperser_client.go | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/api/clients/v2/disperser_client.go b/api/clients/v2/disperser_client.go index 4f4415fea..896c0c4cd 100644 --- a/api/clients/v2/disperser_client.go +++ b/api/clients/v2/disperser_client.go @@ -213,6 +213,23 @@ func (c *disperserClient) DisperseBlob( return nil, [32]byte{}, err } + actualBlobKey, err := blobHeader.BlobKey() + if err != nil { + // this shouldn't be possible, since the blob key has already been used when signing dispersal + return nil, [32]byte{}, fmt.Errorf("computing blob key: %w", err) + } + + blobKeyFromDisperser, err := corev2.BytesToBlobKey(reply.GetBlobKey()) + if err != nil { + return nil, [32]byte{}, fmt.Errorf("converting returned bytes to blob key: %w", err) + } + + if actualBlobKey != blobKeyFromDisperser { + return nil, [32]byte{}, fmt.Errorf( + "blob key returned by disperser (%v) doesn't match blob which was dispersed (%v)", + blobKeyFromDisperser, actualBlobKey) + } + return &blobStatus, corev2.BlobKey(reply.GetBlobKey()), nil }