From daad29d0de5a053402a4da1fe9ca597f854dfa5c Mon Sep 17 00:00:00 2001 From: Preston Van Loon Date: Wed, 21 Feb 2024 15:57:43 -0600 Subject: [PATCH] blob save: add better data checking for empty blob issues (#13647) --- beacon-chain/db/filesystem/blob.go | 17 +++++++++++++++-- 1 file changed, 15 insertions(+), 2 deletions(-) diff --git a/beacon-chain/db/filesystem/blob.go b/beacon-chain/db/filesystem/blob.go index 1f9d3b5db..f18168d85 100644 --- a/beacon-chain/db/filesystem/blob.go +++ b/beacon-chain/db/filesystem/blob.go @@ -21,7 +21,9 @@ import ( ) var ( - errIndexOutOfBounds = errors.New("blob index in file name >= MaxBlobsPerBlock") + errIndexOutOfBounds = errors.New("blob index in file name >= MaxBlobsPerBlock") + errEmptyBlobWritten = errors.New("zero bytes written to disk when saving blob sidecar") + errSidecarEmptySSZData = errors.New("sidecar marshalled to an empty ssz byte slice") ) const ( @@ -111,7 +113,10 @@ func (bs *BlobStorage) Save(sidecar blocks.VerifiedROBlob) error { sidecarData, err := sidecar.MarshalSSZ() if err != nil { return errors.Wrap(err, "failed to serialize sidecar data") + } else if len(sidecarData) == 0 { + return errSidecarEmptySSZData } + if err := bs.fs.MkdirAll(fname.dir(), directoryPermissions); err != nil { return err } @@ -138,7 +143,7 @@ func (bs *BlobStorage) Save(sidecar blocks.VerifiedROBlob) error { return errors.Wrap(err, "failed to create partial file") } - _, err = partialFile.Write(sidecarData) + n, err := partialFile.Write(sidecarData) if err != nil { closeErr := partialFile.Close() if closeErr != nil { @@ -151,6 +156,14 @@ func (bs *BlobStorage) Save(sidecar blocks.VerifiedROBlob) error { return err } + if n != len(sidecarData) { + return fmt.Errorf("failed to write the full bytes of sidecarData, wrote only %d of %d bytes", n, len(sidecarData)) + } + + if n == 0 { + return errEmptyBlobWritten + } + // Atomically rename the partial file to its final name. err = bs.fs.Rename(partPath, sszPath) if err != nil {