Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

WIP: Shwap prototype #3184

Closed
wants to merge 141 commits into from
Closed
Show file tree
Hide file tree
Changes from 120 commits
Commits
Show all changes
141 commits
Select commit Hold shift + click to select a range
d953117
chore(moddas): speed up sampling for LN
Wondertan Nov 29, 2023
f122a71
prototype
Wondertan Sep 7, 2023
7237ad7
feat(modp2p): listen on WebTransport by default
Wondertan Sep 11, 2023
ab6bec8
lint
Wondertan Sep 12, 2023
2f08bdd
now test verifies all the share proofs
Wondertan Sep 17, 2023
b33515e
refactor sampling protocol and use proto for serialization
Wondertan Sep 18, 2023
59aa730
docs and tests for ipldv2
Wondertan Sep 18, 2023
1b3d881
add support for col proofs sampling
Wondertan Sep 21, 2023
b53769b
blockstore impl and various cleanups and improvements
Wondertan Sep 22, 2023
ce31854
initial support for ODS Mode
Wondertan Sep 22, 2023
3ab6b37
implement axis sampling
Wondertan Sep 30, 2023
041ed3d
introduce File interface and decouple ipldv2 tests from on disk file
Wondertan Oct 1, 2023
1601460
use height as block id
Wondertan Oct 19, 2023
600d186
chore: extract proto helper
Wondertan Oct 19, 2023
6673564
successful experiment with request size shortening for axis sampling
Wondertan Oct 19, 2023
830860d
docs fix
Wondertan Oct 19, 2023
9ffb284
request size optimization for share sample
Wondertan Oct 19, 2023
52f3ab9
refactor AxisID away and many more improvements
Wondertan Oct 22, 2023
21bd2fc
remove serialization ambigiouty and ensure there is only one serializ…
Wondertan Oct 22, 2023
cdbd694
cleanup proto field names
Wondertan Oct 22, 2023
c3e8450
namespace mh
Wondertan Dec 2, 2023
8a66fd5
namespace mh but finished and tested
Wondertan Dec 2, 2023
bbcd956
lol
Wondertan Dec 2, 2023
583481b
pass by value and cid must constructors
Wondertan Dec 3, 2023
a28cfef
fix data id test
Wondertan Dec 3, 2023
f6db8f9
blockservice constructor
Wondertan Dec 3, 2023
9a8b5ed
implement Getter and tests for it
Wondertan Dec 3, 2023
0d4dd27
rename to shwap
Wondertan Dec 6, 2023
c96579a
ensure only shares a cached in blockstore
Wondertan Dec 6, 2023
bb034b3
add sessions
Wondertan Dec 6, 2023
e6d39dc
create store v2 file interface (#2989)
walldiss Dec 6, 2023
82150f2
feat(store/mem_file): add in-memory eds file implementation (#2992)
walldiss Dec 6, 2023
4feea07
add ods eds files
walldiss Dec 7, 2023
e34394b
single read of ods for recomputed axes
walldiss Dec 8, 2023
698ae46
reduce parity allocations
walldiss Dec 8, 2023
90672ec
reuse allocated memory
walldiss Dec 12, 2023
0a9daec
minor rafactoring
walldiss Dec 12, 2023
fd82475
allow Store implementation to choose proof axis for Share
walldiss Dec 17, 2023
17e9821
move shareWithProof outside to share pkg
walldiss Dec 17, 2023
8b29af3
allow Store implementation to choose proof axis for Share
walldiss Dec 17, 2023
eae5359
remove option to select proof axis from store interface
walldiss Dec 18, 2023
daf4bcc
fix shadow subslicing by data copy
walldiss Dec 21, 2023
4d71dad
allow reconstructSome using direct reedsolomon
walldiss Dec 22, 2023
fc082f4
protocol updates:
Wondertan Dec 28, 2023
0f61c50
Merge branch 'update-store-interface' into vlad/shwamp-prototype
walldiss Jan 4, 2024
730f05e
Merge branch 'ods-file' into vlad/shwamp-prototype
walldiss Jan 4, 2024
6655b1d
Share with proof
walldiss Jan 4, 2024
c8e1926
Switch implementation to reconstructSome
walldiss Jan 5, 2024
ec71e12
add codec benchmark
walldiss Jan 5, 2024
74ab0b9
add different sizes to codec benchmark
walldiss Jan 5, 2024
7183820
Merge branch 'ods-file' into vlad/shwamp-prototype
walldiss Jan 13, 2024
ed9b593
update EDSFile implementations to support new Share interface
walldiss Jan 13, 2024
f5c1183
- update file interface
walldiss Jan 14, 2024
1d21a22
- add store
walldiss Jan 14, 2024
1272917
add cache
walldiss Jan 14, 2024
4190362
add shwamp multiplexer
walldiss Jan 14, 2024
5c6aa8d
add blockstore
walldiss Jan 14, 2024
e332f0a
add support for store in shrex
walldiss Jan 14, 2024
4ab0fbf
add support for store in store getter
walldiss Jan 14, 2024
2d5299a
add support for store in availability
walldiss Jan 14, 2024
85ba38d
update mem file
walldiss Jan 14, 2024
8f0315b
lots of changes
walldiss Jan 31, 2024
2f5563e
add store tests and benchmarks
walldiss Feb 5, 2024
efd829a
fix hashing for in-mem proofs cache
walldiss Feb 6, 2024
da5533b
fix shrex tests
walldiss Feb 6, 2024
c004096
add non-inclusion tests to file
walldiss Feb 6, 2024
fb93edb
fix shwap tests
walldiss Feb 6, 2024
6ad1791
handle empty sqaure in store and getters
walldiss Feb 7, 2024
7d85083
refactor shrexNd client to use rowIdx
walldiss Feb 7, 2024
8bde751
limit reader by known header instead of the one send over the wire
walldiss Feb 7, 2024
85e069b
add reader tests to all types of files
walldiss Feb 7, 2024
70dddf6
add proper prealloc for shwamp data request builder
walldiss Feb 7, 2024
0c8bc88
fix offset calc for file streaming
walldiss Feb 7, 2024
f3186f1
add streaming for mem file
walldiss Feb 7, 2024
f1556a4
add support for empty root in getters and store
walldiss Feb 7, 2024
05e5a5e
sort imports
walldiss Feb 7, 2024
ad117d7
fix shrexnd tests
walldiss Feb 8, 2024
4052a00
various tests fixes and improvements
walldiss Feb 8, 2024
134c554
store empty heights in availability
walldiss Feb 8, 2024
9a6d1a0
remove proofs collection into proofAdder
walldiss Feb 8, 2024
cf2d29e
close file after read everywhere
walldiss Feb 8, 2024
d79338e
put heights inside blocks folder
walldiss Feb 9, 2024
6b7080e
add concurrency safety for cached file
walldiss Feb 9, 2024
f8bbaca
improve logging for shrex eds
walldiss Feb 9, 2024
eb6e377
log amount of written bytes by server when stream interrupted
walldiss Feb 9, 2024
02b2e80
log amount of bytes read from stream
walldiss Feb 9, 2024
dd8a225
remove extra alloc in ods reader
walldiss Feb 10, 2024
2f7cb65
remove height method from edsdile
walldiss Feb 10, 2024
db0bb88
handle blocks duplicates in store
walldiss Feb 10, 2024
aeafcad
fix core tests
walldiss Feb 10, 2024
ae6a0af
add test blockstore for shwap and fix shwap roundtrip tests
walldiss Feb 15, 2024
9a0cc1d
close files inside blockstore instead of shwap handlers
walldiss Feb 15, 2024
72c4d5e
sort imports
walldiss Feb 15, 2024
3113f73
remove old store benchmarks
walldiss Feb 15, 2024
1a2256c
fix nodebuilder tests
walldiss Feb 15, 2024
c7dd8b3
some todos to rework availability tests
walldiss Feb 15, 2024
d148bad
fix shrex-eds tests
walldiss Feb 15, 2024
2886665
refactor shwap blockstore test
walldiss Feb 29, 2024
035a272
add validating file
walldiss Mar 6, 2024
9e29a18
wrap opened files in store with validation file and cache
walldiss Mar 6, 2024
db97ae6
store size and datahash in close_once_file
walldiss Mar 6, 2024
f2d4704
minor cleanup and renames
walldiss Mar 6, 2024
dfe79fd
add comment how server side shwap requests validation should work
walldiss Mar 6, 2024
e6c64df
iterate shrex-sub version
walldiss Mar 14, 2024
25250c8
version bitswap
walldiss Mar 14, 2024
6e654df
add share size validation to readShares
walldiss Mar 14, 2024
3e91d02
bump discovery dht tag version
walldiss Mar 18, 2024
777564d
fix validation file test
walldiss Mar 20, 2024
743fed2
aligh shwap with the spec
Wondertan Mar 26, 2024
1b1c9a1
Merge remote-tracking branch 'celestia/shwap-prototype' into shwap-pr…
walldiss Mar 27, 2024
7021639
use AxisHalf type in file interface
walldiss Mar 27, 2024
3e71d57
use AxisHalf in file implementations
walldiss Mar 27, 2024
74ed5c0
add q1q4 file
walldiss Mar 27, 2024
ab92e82
rename wrapping files to middleware pattern
walldiss Mar 27, 2024
28fe967
use Q1Q4 file in store
walldiss Mar 27, 2024
3b46993
remove redundant files from eds store
walldiss Mar 27, 2024
ba2f512
add edsid
Wondertan Mar 27, 2024
960ea10
extract ErrOperationNotSupported to getter interface
walldiss Mar 27, 2024
a0c885b
aggregate testing utils in the same folder
walldiss Mar 27, 2024
683bb93
- register verifier on message creation
walldiss Mar 27, 2024
83beea0
refactor shwap getter
walldiss Mar 27, 2024
772ec00
Merge remote-tracking branch 'celestia/shwap-prototype' into shwap-pr…
walldiss Mar 27, 2024
3ccf47b
aggregate testing utils in the same folder
walldiss Mar 27, 2024
6f7fdd2
rework retriever and add reconstruction getter
walldiss Mar 28, 2024
214392f
Merge remote-tracking branch 'celestia/shwap-prototype' into shwap-pr…
walldiss Mar 28, 2024
02030bf
feat(pruner): Implement `full` and `bridge` node pruning (#3150)
renaynay Mar 28, 2024
2ba8ec6
use rlock in retriever
walldiss Mar 28, 2024
04ad041
use reconstruction getter in full and light nodes
walldiss Mar 28, 2024
84241a4
Merge branch 'shwap-prototype' into prototype-v2
walldiss Mar 28, 2024
eef869d
address Hlibs comments
walldiss Mar 28, 2024
6394d37
move retriever test to proper pkg
walldiss Apr 1, 2024
09e93d7
integrate with pruner
walldiss Apr 1, 2024
39c7276
remove redundant panic on marshaling error
walldiss Apr 1, 2024
948013c
remove generics from shwap verification code
walldiss Apr 1, 2024
6f5db44
sort imports
walldiss Apr 1, 2024
7ea43f8
improve locking in store
walldiss Apr 1, 2024
b4b5a03
store roots instead of verifier
walldiss Apr 1, 2024
623a3d3
remove unnecessary key methods
Wondertan Apr 10, 2024
a02f31d
wrap file on get in store
walldiss Apr 11, 2024
94f1f02
refactor file wrapping in store
walldiss Apr 15, 2024
7580cdf
add validation conditions to shrex-nd server
walldiss Apr 15, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion api/docgen/examples.go
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,7 @@ var ExampleValues = map[reflect.Type]interface{}{
&byzantine.ErrByzantine{
Index: 0,
Axis: rsmt2d.Axis(0),
Shares: []*byzantine.ShareWithProof{},
Shares: []*share.ShareWithProof{},
},
),
reflect.TypeOf((*error)(nil)).Elem(): fmt.Errorf("error"),
Expand Down
19 changes: 0 additions & 19 deletions core/eds.go
Original file line number Diff line number Diff line change
@@ -1,11 +1,8 @@
package core

import (
"context"
"errors"
"fmt"

"github.com/filecoin-project/dagstore"
"github.com/tendermint/tendermint/types"

"github.com/celestiaorg/celestia-app/app"
Expand All @@ -15,9 +12,6 @@ import (
"github.com/celestiaorg/celestia-app/pkg/wrapper"
"github.com/celestiaorg/nmt"
"github.com/celestiaorg/rsmt2d"

"github.com/celestiaorg/celestia-node/share"
"github.com/celestiaorg/celestia-node/share/eds"
)

// extendBlock extends the given block data, returning the resulting
Expand Down Expand Up @@ -49,16 +43,3 @@ func extendShares(s [][]byte, options ...nmt.Option) (*rsmt2d.ExtendedDataSquare
wrapper.NewConstructor(uint64(squareSize),
options...))
}

// storeEDS will only store extended block if it is not empty and doesn't already exist.
func storeEDS(ctx context.Context, hash share.DataHash, eds *rsmt2d.ExtendedDataSquare, store *eds.Store) error {
if eds == nil {
return nil
}
err := store.Put(ctx, hash, eds)
if errors.Is(err, dagstore.ErrShardExists) {
// block with given root already exists, return nil
return nil
}
return err
}
28 changes: 10 additions & 18 deletions core/exchange.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,26 +9,25 @@ import (
"golang.org/x/sync/errgroup"

libhead "github.com/celestiaorg/go-header"
"github.com/celestiaorg/nmt"

"github.com/celestiaorg/celestia-node/header"
"github.com/celestiaorg/celestia-node/share/eds"
"github.com/celestiaorg/celestia-node/share/ipld"
"github.com/celestiaorg/celestia-node/libs/utils"
"github.com/celestiaorg/celestia-node/share/store"
)

const concurrencyLimit = 4

type Exchange struct {
fetcher *BlockFetcher
store *eds.Store
store *store.Store
construct header.ConstructFn

metrics *exchangeMetrics
}

func NewExchange(
fetcher *BlockFetcher,
store *eds.Store,
store *store.Store,
construct header.ConstructFn,
opts ...Option,
) (*Exchange, error) {
Expand Down Expand Up @@ -132,10 +131,7 @@ func (ce *Exchange) Get(ctx context.Context, hash libhead.Hash) (*header.Extende
}

// extend block data
adder := ipld.NewProofsAdder(int(block.Data.SquareSize))
defer adder.Purge()

eds, err := extendBlock(block.Data, block.Header.Version.App, nmt.NodeVisitor(adder.VisitFn()))
eds, err := extendBlock(block.Data, block.Header.Version.App)
if err != nil {
return nil, fmt.Errorf("extending block data for height %d: %w", &block.Height, err)
}
Expand All @@ -150,11 +146,11 @@ func (ce *Exchange) Get(ctx context.Context, hash libhead.Hash) (*header.Extende
&block.Height, hash, eh.Hash())
}

ctx = ipld.CtxWithProofsAdder(ctx, adder)
err = storeEDS(ctx, eh.DAH.Hash(), eds, ce.store)
f, err := ce.store.Put(ctx, eh.DAH.Hash(), eh.Height(), eds)
if err != nil {
return nil, fmt.Errorf("storing EDS to eds.Store for height %d: %w", &block.Height, err)
}
utils.CloseAndLog(log, "file", f)
return eh, nil
}

Expand All @@ -176,11 +172,7 @@ func (ce *Exchange) getExtendedHeaderByHeight(ctx context.Context, height *int64
}
log.Debugw("fetched signed block from core", "height", b.Header.Height)

// extend block data
adder := ipld.NewProofsAdder(int(b.Data.SquareSize))
defer adder.Purge()

eds, err := extendBlock(b.Data, b.Header.Version.App, nmt.NodeVisitor(adder.VisitFn()))
eds, err := extendBlock(b.Data, b.Header.Version.App)
if err != nil {
return nil, fmt.Errorf("extending block data for height %d: %w", b.Header.Height, err)
}
Expand All @@ -190,10 +182,10 @@ func (ce *Exchange) getExtendedHeaderByHeight(ctx context.Context, height *int64
panic(fmt.Errorf("constructing extended header for height %d: %w", b.Header.Height, err))
}

ctx = ipld.CtxWithProofsAdder(ctx, adder)
err = storeEDS(ctx, eh.DAH.Hash(), eds, ce.store)
f, err := ce.store.Put(ctx, eh.DAH.Hash(), eh.Height(), eds)
if err != nil {
return nil, fmt.Errorf("storing EDS to eds.Store for block height %d: %w", b.Header.Height, err)
}
utils.CloseAndLog(log, "file", f)
return eh, nil
}
10 changes: 4 additions & 6 deletions core/exchange_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,15 +5,13 @@ import (
"testing"
"time"

ds "github.com/ipfs/go-datastore"
ds_sync "github.com/ipfs/go-datastore/sync"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"

"github.com/celestiaorg/celestia-app/test/util/testnode"

"github.com/celestiaorg/celestia-node/header"
"github.com/celestiaorg/celestia-node/share/eds"
"github.com/celestiaorg/celestia-node/share/store"
)

func TestCoreExchange_RequestHeaders(t *testing.T) {
Expand Down Expand Up @@ -60,11 +58,11 @@ func createCoreFetcher(t *testing.T, cfg *testnode.Config) (*BlockFetcher, testn
return NewBlockFetcher(cctx.Client), cctx
}

func createStore(t *testing.T) *eds.Store {
func createStore(t *testing.T) *store.Store {
t.Helper()

storeCfg := eds.DefaultParameters()
store, err := eds.NewStore(storeCfg, t.TempDir(), ds_sync.MutexWrap(ds.NewMapDatastore()))
storeCfg := store.DefaultParameters()
store, err := store.NewStore(storeCfg, t.TempDir())
require.NoError(t, err)
return store
}
Expand Down
18 changes: 7 additions & 11 deletions core/listener.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,12 +12,11 @@ import (
"go.opentelemetry.io/otel/attribute"

libhead "github.com/celestiaorg/go-header"
"github.com/celestiaorg/nmt"

"github.com/celestiaorg/celestia-node/header"
"github.com/celestiaorg/celestia-node/share/eds"
"github.com/celestiaorg/celestia-node/share/ipld"
"github.com/celestiaorg/celestia-node/libs/utils"
"github.com/celestiaorg/celestia-node/share/p2p/shrexsub"
"github.com/celestiaorg/celestia-node/share/store"
)

var (
Expand All @@ -36,7 +35,7 @@ type Listener struct {
fetcher *BlockFetcher

construct header.ConstructFn
store *eds.Store
store *store.Store

headerBroadcaster libhead.Broadcaster[*header.ExtendedHeader]
hashBroadcaster shrexsub.BroadcastFn
Expand All @@ -53,7 +52,7 @@ func NewListener(
fetcher *BlockFetcher,
hashBroadcaster shrexsub.BroadcastFn,
construct header.ConstructFn,
store *eds.Store,
store *store.Store,
blocktime time.Duration,
opts ...Option,
) (*Listener, error) {
Expand Down Expand Up @@ -192,11 +191,8 @@ func (cl *Listener) handleNewSignedBlock(ctx context.Context, b types.EventDataS
span.SetAttributes(
attribute.Int64("height", b.Header.Height),
)
// extend block data
adder := ipld.NewProofsAdder(int(b.Data.SquareSize))
defer adder.Purge()

eds, err := extendBlock(b.Data, b.Header.Version.App, nmt.NodeVisitor(adder.VisitFn()))
eds, err := extendBlock(b.Data, b.Header.Version.App)
if err != nil {
return fmt.Errorf("extending block data: %w", err)
}
Expand All @@ -208,11 +204,11 @@ func (cl *Listener) handleNewSignedBlock(ctx context.Context, b types.EventDataS
}

// attempt to store block data if not empty
ctx = ipld.CtxWithProofsAdder(ctx, adder)
err = storeEDS(ctx, b.Header.DataHash.Bytes(), eds, cl.store)
f, err := cl.store.Put(ctx, eh.DAH.Hash(), eh.Height(), eds)
if err != nil {
return fmt.Errorf("storing EDS: %w", err)
}
utils.CloseAndLog(log, "file", f)

syncing, err := cl.fetcher.IsSyncing(ctx)
if err != nil {
Expand Down
13 changes: 5 additions & 8 deletions core/listener_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,8 @@ import (
"github.com/celestiaorg/celestia-node/header"
nodep2p "github.com/celestiaorg/celestia-node/nodebuilder/p2p"
"github.com/celestiaorg/celestia-node/share"
"github.com/celestiaorg/celestia-node/share/eds"
"github.com/celestiaorg/celestia-node/share/p2p/shrexsub"
"github.com/celestiaorg/celestia-node/share/store"
)

const networkID = "private"
Expand Down Expand Up @@ -84,16 +84,13 @@ func TestListenerWithNonEmptyBlocks(t *testing.T) {
eds := createEdsPubSub(ctx, t)

store := createStore(t)
err := store.Start(ctx)
require.NoError(t, err)
t.Cleanup(func() {
err = store.Stop(ctx)
require.NoError(t, err)
require.NoError(t, store.Close())
})

// create Listener and start listening
cl := createListener(ctx, t, fetcher, ps0, eds, store)
err = cl.Start(ctx)
err := cl.Start(ctx)
require.NoError(t, err)

// listen for eds hashes broadcasted through eds-sub and ensure store has
Expand All @@ -114,7 +111,7 @@ func TestListenerWithNonEmptyBlocks(t *testing.T) {
continue
}

has, err := store.Has(ctx, msg.DataHash)
has, err := store.HasByHash(ctx, msg.DataHash)
require.NoError(t, err)
require.True(t, has)
}
Expand Down Expand Up @@ -165,7 +162,7 @@ func createListener(
fetcher *BlockFetcher,
ps *pubsub.PubSub,
edsSub *shrexsub.PubSub,
store *eds.Store,
store *store.Store,
) *Listener {
p2pSub, err := p2p.NewSubscriber[*header.ExtendedHeader](ps, header.MsgID, p2p.WithSubscriberNetworkID(networkID))
require.NoError(t, err)
Expand Down
6 changes: 3 additions & 3 deletions go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -231,8 +231,8 @@ require (
github.com/jmhodges/levigo v1.0.0 // indirect
github.com/josharian/intern v1.0.0 // indirect
github.com/klauspost/compress v1.17.2 // indirect
github.com/klauspost/cpuid/v2 v2.2.5 // indirect
github.com/klauspost/reedsolomon v1.11.8 // indirect
github.com/klauspost/cpuid/v2 v2.2.6 // indirect
github.com/klauspost/reedsolomon v1.12.1-0.20240110152930-bb8917fa442f
github.com/koron/go-ssdp v0.0.4 // indirect
github.com/lib/pq v1.10.7 // indirect
github.com/libp2p/go-buffer-pool v0.1.0 // indirect
Expand Down Expand Up @@ -325,7 +325,7 @@ require (
golang.org/x/mod v0.13.0 // indirect
golang.org/x/net v0.17.0 // indirect
golang.org/x/oauth2 v0.11.0 // indirect
golang.org/x/sys v0.13.0 // indirect
golang.org/x/sys v0.16.0 // indirect
golang.org/x/term v0.13.0 // indirect
golang.org/x/tools v0.14.0 // indirect
golang.org/x/xerrors v0.0.0-20220907171357-04be3eba64a2 // indirect
Expand Down
8 changes: 8 additions & 0 deletions go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -1346,10 +1346,16 @@ github.com/klauspost/cpuid/v2 v2.2.1/go.mod h1:RVVoqg1df56z8g3pUjL/3lE5UfnlrJX8t
github.com/klauspost/cpuid/v2 v2.2.3/go.mod h1:RVVoqg1df56z8g3pUjL/3lE5UfnlrJX8tyFgg4nqhuY=
github.com/klauspost/cpuid/v2 v2.2.5 h1:0E5MSMDEoAulmXNFquVs//DdoomxaoTY1kUhbc/qbZg=
github.com/klauspost/cpuid/v2 v2.2.5/go.mod h1:Lcz8mBdAVJIBVzewtcLocK12l3Y+JytZYpaMropDUws=
github.com/klauspost/cpuid/v2 v2.2.6 h1:ndNyv040zDGIDh8thGkXYjnFtiN02M1PVVF+JE/48xc=
github.com/klauspost/cpuid/v2 v2.2.6/go.mod h1:Lcz8mBdAVJIBVzewtcLocK12l3Y+JytZYpaMropDUws=
github.com/klauspost/crc32 v0.0.0-20161016154125-cb6bfca970f6/go.mod h1:+ZoRqAPRLkC4NPOvfYeR5KNOrY6TD+/sAC3HXPZgDYg=
github.com/klauspost/pgzip v1.0.2-0.20170402124221-0bf5dcad4ada/go.mod h1:Ch1tH69qFZu15pkjo5kYi6mth2Zzwzt50oCQKQE9RUs=
github.com/klauspost/reedsolomon v1.11.8 h1:s8RpUW5TK4hjr+djiOpbZJB4ksx+TdYbRH7vHQpwPOY=
github.com/klauspost/reedsolomon v1.11.8/go.mod h1:4bXRN+cVzMdml6ti7qLouuYi32KHJ5MGv0Qd8a47h6A=
github.com/klauspost/reedsolomon v1.12.0 h1:I5FEp3xSwVCcEh3F5A7dofEfhXdF/bWhQWPH+XwBFno=
github.com/klauspost/reedsolomon v1.12.0/go.mod h1:EPLZJeh4l27pUGC3aXOjheaoh1I9yut7xTURiW3LQ9Y=
github.com/klauspost/reedsolomon v1.12.1-0.20240110152930-bb8917fa442f h1:QEQvCKqgPSTRn9UIT65LSKY+7LCcGyiH6tIh6vCeHEw=
github.com/klauspost/reedsolomon v1.12.1-0.20240110152930-bb8917fa442f/go.mod h1:nEi5Kjb6QqtbofI6s+cbG/j1da11c96IBYBSnVGtuBs=
github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=
github.com/konsorten/go-windows-terminal-sequences v1.0.3/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=
github.com/koron/go-ssdp v0.0.0-20180514024734-4a0ed625a78b/go.mod h1:5Ky9EC2xfoUKUor0Hjgi2BJhCSXJfMOFlmyYrVKGQMk=
Expand Down Expand Up @@ -2860,6 +2866,8 @@ golang.org/x/sys v0.11.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.12.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.13.0 h1:Af8nKPmuFypiUBjVoU9V20FiaFXOcuZI21p0ycVYYGE=
golang.org/x/sys v0.13.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.16.0 h1:xWw16ngr6ZMtmxDyKyIgsE93KNKz5HKmMa3b8ALHidU=
golang.org/x/sys v0.16.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
golang.org/x/term v0.0.0-20201117132131-f5c789dd3221/go.mod h1:Nr5EML6q2oocZ2LXRh80K7BxOlk5/8JxuGnuhpl+muw=
golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo=
golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8=
Expand Down
13 changes: 6 additions & 7 deletions header/headertest/fraud/testing.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,14 +12,13 @@ import (
"github.com/tendermint/tendermint/types"

"github.com/celestiaorg/celestia-app/pkg/da"
"github.com/celestiaorg/nmt"
"github.com/celestiaorg/rsmt2d"

"github.com/celestiaorg/celestia-node/header"
"github.com/celestiaorg/celestia-node/header/headertest"
"github.com/celestiaorg/celestia-node/share/eds"
"github.com/celestiaorg/celestia-node/share/eds/edstest"
"github.com/celestiaorg/celestia-node/share/ipld"
"github.com/celestiaorg/celestia-node/share/store"
)

// FraudMaker allows to produce an invalid header at the specified height in order to produce the
Expand All @@ -45,7 +44,7 @@ func NewFraudMaker(t *testing.T, height int64, vals []types.PrivValidator, valSe
}
}

func (f *FraudMaker) MakeExtendedHeader(odsSize int, edsStore *eds.Store) header.ConstructFn {
func (f *FraudMaker) MakeExtendedHeader(odsSize int, edsStore *store.Store) header.ConstructFn {
return func(
h *types.Header,
comm *types.Commit,
Expand All @@ -58,14 +57,14 @@ func (f *FraudMaker) MakeExtendedHeader(odsSize int, edsStore *eds.Store) header

hdr := *h
if h.Height == f.height {
adder := ipld.NewProofsAdder(odsSize)
square := edstest.RandByzantineEDS(f.t, odsSize, nmt.NodeVisitor(adder.VisitFn()))
square := edstest.RandByzantineEDS(f.t, odsSize)
dah, err := da.NewDataAvailabilityHeader(square)
require.NoError(f.t, err)
hdr.DataHash = dah.Hash()

ctx := ipld.CtxWithProofsAdder(context.Background(), adder)
require.NoError(f.t, edsStore.Put(ctx, h.DataHash.Bytes(), square))
file, err := edsStore.Put(context.Background(), dah.Hash(), uint64(h.Height), square)
require.NoError(f.t, err)
require.NoError(f.t, file.Close())

*eds = *square
}
Expand Down
13 changes: 13 additions & 0 deletions libs/utils/logcloser.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
package utils

import (
"io"

"github.com/ipfs/go-log/v2"
)

func CloseAndLog(log log.StandardLogger, name string, closer io.Closer) {
if err := closer.Close(); err != nil {
log.Warnf("closing %s: %s", name, err)
}
}
Loading