From 1aed5601b521e25410d3cca86583b9e80b66b672 Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Thu, 26 Oct 2023 09:55:59 +0800 Subject: [PATCH 01/32] Adjust retainer models to use stream package instead of marshalutil --- pkg/storage/prunable/slotstore/retainer.go | 87 +++++++++++----------- 1 file changed, 42 insertions(+), 45 deletions(-) diff --git a/pkg/storage/prunable/slotstore/retainer.go b/pkg/storage/prunable/slotstore/retainer.go index 27a46c5d3..09ec0de7d 100644 --- a/pkg/storage/prunable/slotstore/retainer.go +++ b/pkg/storage/prunable/slotstore/retainer.go @@ -4,7 +4,7 @@ import ( "github.com/iotaledger/hive.go/ierrors" "github.com/iotaledger/hive.go/kvstore" "github.com/iotaledger/hive.go/lo" - "github.com/iotaledger/hive.go/serializer/v2/marshalutil" + "github.com/iotaledger/hive.go/serializer/v2/stream" iotago "github.com/iotaledger/iota.go/v4" "github.com/iotaledger/iota.go/v4/nodeclient/apimodels" ) @@ -20,28 +20,32 @@ type BlockRetainerData struct { } func (b *BlockRetainerData) Bytes() ([]byte, error) { - marshalUtil := marshalutil.New(2) - marshalUtil.WriteUint8(uint8(b.State)) - marshalUtil.WriteUint8(uint8(b.FailureReason)) + byteBuffer := stream.NewByteBuffer(2) - return marshalUtil.Bytes(), nil + if err := stream.Write(byteBuffer, b.State); err != nil { + return nil, ierrors.Wrap(err, "failed to write block state") + } + if err := stream.Write(byteBuffer, b.FailureReason); err != nil { + return nil, ierrors.Wrap(err, "failed to write block failure reason") + } + + return byteBuffer.Bytes() } -func (b *BlockRetainerData) FromBytes(bytes []byte) (int, error) { - marshalUtil := marshalutil.New(bytes) - state, err := marshalUtil.ReadUint8() - if err != nil { - return 0, err - } - b.State = apimodels.BlockState(state) +func BlockRetainerDataFromBytes(bytes []byte) (*BlockRetainerData, int, error) { + byteReader := stream.NewByteReader(bytes) - reason, err := marshalUtil.ReadUint8() - if err != nil { - return 0, err + var err error + b := new(BlockRetainerData) + + if b.State, err = stream.Read[apimodels.BlockState](byteReader); err != nil { + return nil, 0, ierrors.Wrap(err, "failed to read block state") + } + if b.FailureReason, err = stream.Read[apimodels.BlockFailureReason](byteReader); err != nil { + return nil, 0, ierrors.Wrap(err, "failed to read block failure reason") } - b.FailureReason = apimodels.BlockFailureReason(reason) - return marshalUtil.ReadOffset(), nil + return b, byteReader.BytesRead(), nil } type TransactionRetainerData struct { @@ -50,28 +54,31 @@ type TransactionRetainerData struct { } func (t *TransactionRetainerData) Bytes() ([]byte, error) { - marshalUtil := marshalutil.New(2) - marshalUtil.WriteUint8(uint8(t.State)) - marshalUtil.WriteUint8(uint8(t.FailureReason)) + byteBuffer := stream.NewByteBuffer(2) - return marshalUtil.Bytes(), nil + if err := stream.Write(byteBuffer, t.State); err != nil { + return nil, ierrors.Wrap(err, "failed to write transaction state") + } + if err := stream.Write(byteBuffer, t.FailureReason); err != nil { + return nil, ierrors.Wrap(err, "failed to write transaction failure reason") + } + return byteBuffer.Bytes() } -func (t *TransactionRetainerData) FromBytes(bytes []byte) (int, error) { - marshalUtil := marshalutil.New(bytes) - state, err := marshalUtil.ReadUint8() - if err != nil { - return 0, err - } - t.State = apimodels.TransactionState(state) +func TransactionRetainerDataFromBytes(bytes []byte) (*TransactionRetainerData, int, error) { + byteReader := stream.NewByteReader(bytes) - reason, err := marshalUtil.ReadUint8() - if err != nil { - return 0, err + var err error + t := new(TransactionRetainerData) + + if t.State, err = stream.Read[apimodels.TransactionState](byteReader); err != nil { + return nil, 0, ierrors.Wrap(err, "failed to read transaction state") + } + if t.FailureReason, err = stream.Read[apimodels.TransactionFailureReason](byteReader); err != nil { + return nil, 0, ierrors.Wrap(err, "failed to read transaction failure reason") } - t.FailureReason = apimodels.TransactionFailureReason(reason) - return marshalUtil.ReadOffset(), nil + return t, byteReader.BytesRead(), nil } type Retainer struct { @@ -88,23 +95,13 @@ func NewRetainer(slot iotago.SlotIndex, store kvstore.KVStore) (newRetainer *Ret iotago.BlockID.Bytes, iotago.BlockIDFromBytes, (*BlockRetainerData).Bytes, - func(bytes []byte) (*BlockRetainerData, int, error) { - b := new(BlockRetainerData) - c, err := b.FromBytes(bytes) - - return b, c, err - }, + BlockRetainerDataFromBytes, ), transactionStore: kvstore.NewTypedStore(lo.PanicOnErr(store.WithExtendedRealm(kvstore.Realm{transactionStorePrefix})), iotago.BlockID.Bytes, iotago.BlockIDFromBytes, (*TransactionRetainerData).Bytes, - func(bytes []byte) (*TransactionRetainerData, int, error) { - t := new(TransactionRetainerData) - c, err := t.FromBytes(bytes) - - return t, c, err - }, + TransactionRetainerDataFromBytes, ), } } From 72c83bf14c19f69eb48a1f812f41fe53ac6060e5 Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Fri, 27 Oct 2023 10:35:39 +0800 Subject: [PATCH 02/32] Adjust utxoledger to use stream package instead marshalutil --- .../engine/utxoledger/database_prefixes.go | 4 +- pkg/protocol/engine/utxoledger/manager.go | 2 + .../engine/utxoledger/marshalutils_helper.go | 43 --------- pkg/protocol/engine/utxoledger/output.go | 83 +++++++----------- pkg/protocol/engine/utxoledger/slot_diff.go | 87 +++++++++++-------- pkg/protocol/engine/utxoledger/snapshot.go | 20 +---- pkg/protocol/engine/utxoledger/spent.go | 56 ++++++------ .../engine/utxoledger/spent_status.go | 24 ++--- pkg/protocol/engine/utxoledger/state_tree.go | 14 ++- 9 files changed, 135 insertions(+), 198 deletions(-) delete mode 100644 pkg/protocol/engine/utxoledger/marshalutils_helper.go diff --git a/pkg/protocol/engine/utxoledger/database_prefixes.go b/pkg/protocol/engine/utxoledger/database_prefixes.go index 12dcd559e..8ff909c73 100644 --- a/pkg/protocol/engine/utxoledger/database_prefixes.go +++ b/pkg/protocol/engine/utxoledger/database_prefixes.go @@ -36,7 +36,7 @@ const ( 1 byte + 34 bytes Value: - BlockID + iotago.SlotIndex + TransactionCreationSlot (time.Time) + iotago.Output.Serialized() + BlockID + iotago.SlotIndex + TransactionCreationSlot (time.Slot) + iotago.Output.Serialized() 40 bytes + 4 bytes + 8 byte s + 1 byte type + X bytes Spent Output: @@ -46,7 +46,7 @@ const ( 1 byte + 34 bytes Value: - TargetTransactionID (iotago.SignedTransactionID) + TransactionAcceptedSlotIndex (iotago.SlotIndex) + TransactionCreationSlot (time.Time) + TargetTransactionID (iotago.SignedTransactionID) + TransactionAcceptedSlotIndex (iotago.SlotIndex) + TransactionCreationSlot (time.Slot) 32 bytes + 8 bytes + 8 bytes Unspent Output: diff --git a/pkg/protocol/engine/utxoledger/manager.go b/pkg/protocol/engine/utxoledger/manager.go index 83fd376f5..b55ddb22e 100644 --- a/pkg/protocol/engine/utxoledger/manager.go +++ b/pkg/protocol/engine/utxoledger/manager.go @@ -28,6 +28,8 @@ func New(store kvstore.KVStore, apiProvider iotago.APIProvider) *Manager { return &Manager{ store: store, stateTree: ads.NewMap[iotago.Identifier](lo.PanicOnErr(store.WithExtendedRealm(kvstore.Realm{StoreKeyPrefixStateTree})), + iotago.Identifier.Bytes, + iotago.IdentifierFromBytes, iotago.OutputID.Bytes, iotago.OutputIDFromBytes, (*stateTreeMetadata).Bytes, diff --git a/pkg/protocol/engine/utxoledger/marshalutils_helper.go b/pkg/protocol/engine/utxoledger/marshalutils_helper.go deleted file mode 100644 index b19e747fc..000000000 --- a/pkg/protocol/engine/utxoledger/marshalutils_helper.go +++ /dev/null @@ -1,43 +0,0 @@ -package utxoledger - -import ( - "github.com/iotaledger/hive.go/lo" - "github.com/iotaledger/hive.go/serializer/v2/marshalutil" - iotago "github.com/iotaledger/iota.go/v4" -) - -func ParseOutputID(ms *marshalutil.MarshalUtil) (iotago.OutputID, error) { - bytes, err := ms.ReadBytes(iotago.OutputIDLength) - if err != nil { - return iotago.EmptyOutputID, err - } - - return iotago.OutputID(bytes), nil -} - -func parseTransactionID(ms *marshalutil.MarshalUtil) (iotago.TransactionID, error) { - bytes, err := ms.ReadBytes(iotago.TransactionIDLength) - if err != nil { - return iotago.EmptyTransactionID, err - } - - return iotago.TransactionID(bytes), nil -} - -func ParseBlockID(ms *marshalutil.MarshalUtil) (iotago.BlockID, error) { - bytes, err := ms.ReadBytes(iotago.BlockIDLength) - if err != nil { - return iotago.EmptyBlockID, err - } - - return iotago.BlockID(bytes), nil -} - -func parseSlotIndex(ms *marshalutil.MarshalUtil) (iotago.SlotIndex, error) { - bytes, err := ms.ReadBytes(iotago.SlotIndexLength) - if err != nil { - return 0, err - } - - return lo.DropCount(iotago.SlotIndexFromBytes(bytes)) -} diff --git a/pkg/protocol/engine/utxoledger/output.go b/pkg/protocol/engine/utxoledger/output.go index 3b6b5e396..6dc1e2b6a 100644 --- a/pkg/protocol/engine/utxoledger/output.go +++ b/pkg/protocol/engine/utxoledger/output.go @@ -8,7 +8,7 @@ import ( "github.com/iotaledger/hive.go/kvstore" "github.com/iotaledger/hive.go/lo" "github.com/iotaledger/hive.go/serializer/v2" - "github.com/iotaledger/hive.go/serializer/v2/marshalutil" + "github.com/iotaledger/hive.go/serializer/v2/stream" iotago "github.com/iotaledger/iota.go/v4" ) @@ -193,11 +193,13 @@ func (o *Output) CopyWithBlockIDAndSlotBooked(blockID iotago.BlockID, slotBooked // - kvStorable func outputStorageKeyForOutputID(outputID iotago.OutputID) []byte { - ms := marshalutil.New(iotago.OutputIDLength + 1) - ms.WriteByte(StoreKeyPrefixOutput) // 1 byte - ms.WriteBytes(outputID[:]) // iotago.OutputIDLength bytes + byteBuffer := stream.NewByteBuffer(iotago.OutputIDLength + serializer.OneByte) - return ms.Bytes() + // There can't be any errors. + _ = stream.Write(byteBuffer, StoreKeyPrefixOutput) + _ = stream.Write(byteBuffer, outputID) + + return lo.PanicOnErr(byteBuffer.Bytes()) } func (o *Output) KVStorableKey() (key []byte) { @@ -205,68 +207,41 @@ func (o *Output) KVStorableKey() (key []byte) { } func (o *Output) KVStorableValue() (value []byte) { - ms := marshalutil.New() - ms.WriteBytes(o.blockID[:]) // BlockIDLength bytes - ms.WriteBytes(o.slotBooked.MustBytes()) // 4 bytes - - ms.WriteUint32(uint32(len(o.encodedOutput))) // 4 bytes - ms.WriteBytes(o.encodedOutput) + byteBuffer := stream.NewByteBuffer() - ms.WriteUint32(uint32(len(o.encodedProof))) // 4 bytes - ms.WriteBytes(o.encodedProof) + // There can't be any errors. + _ = stream.Write(byteBuffer, o.blockID) + _ = stream.Write(byteBuffer, o.slotBooked) + _ = stream.WriteByteSlice(byteBuffer, o.encodedOutput, serializer.SeriLengthPrefixTypeAsUint32) + _ = stream.WriteByteSlice(byteBuffer, o.encodedProof, serializer.SeriLengthPrefixTypeAsUint32) - return ms.Bytes() + return lo.PanicOnErr(byteBuffer.Bytes()) } func (o *Output) kvStorableLoad(_ *Manager, key []byte, value []byte) error { - // Parse key - keyUtil := marshalutil.New(key) - - // Read prefix output - _, err := keyUtil.ReadByte() - if err != nil { - return err - } - - // Read OutputID - if o.outputID, err = ParseOutputID(keyUtil); err != nil { - return err - } + var err error - // Parse value - valueUtil := marshalutil.New(value) + keyReader := stream.NewByteReader(key) - // Read BlockID - if o.blockID, err = ParseBlockID(valueUtil); err != nil { - return err + if _, err = stream.Read[byte](keyReader); err != nil { + return ierrors.Wrap(err, "unable to read prefix") } - - // Read Slot - o.slotBooked, err = parseSlotIndex(valueUtil) - if err != nil { - return err + if o.outputID, err = stream.Read[iotago.OutputID](keyReader); err != nil { + return ierrors.Wrap(err, "unable to read outputID") } - // Read Output - outputLen, err := valueUtil.ReadUint32() - if err != nil { - return err + valueReader := stream.NewByteReader(value) + if o.blockID, err = stream.Read[iotago.BlockID](valueReader); err != nil { + return ierrors.Wrap(err, "unable to read blockID") } - - o.encodedOutput, err = valueUtil.ReadBytes(int(outputLen)) - if err != nil { - return err + if o.slotBooked, err = stream.Read[iotago.SlotIndex](valueReader); err != nil { + return ierrors.Wrap(err, "unable to read slotBooked") } - - // Read Output proof - proofLen, err := valueUtil.ReadUint32() - if err != nil { - return err + if o.encodedOutput, err = stream.ReadByteSlice(valueReader, serializer.SeriLengthPrefixTypeAsUint32); err != nil { + return ierrors.Wrap(err, "unable to read encodedOutput") } - - o.encodedProof, err = valueUtil.ReadBytes(int(proofLen)) - if err != nil { - return err + if o.encodedProof, err = stream.ReadByteSlice(valueReader, serializer.SeriLengthPrefixTypeAsUint32); err != nil { + return ierrors.Wrap(err, "unable to read encodedProof") } return nil diff --git a/pkg/protocol/engine/utxoledger/slot_diff.go b/pkg/protocol/engine/utxoledger/slot_diff.go index dd54bd492..829dc08ac 100644 --- a/pkg/protocol/engine/utxoledger/slot_diff.go +++ b/pkg/protocol/engine/utxoledger/slot_diff.go @@ -7,7 +7,9 @@ import ( "github.com/iotaledger/hive.go/ierrors" "github.com/iotaledger/hive.go/kvstore" - "github.com/iotaledger/hive.go/serializer/v2/marshalutil" + "github.com/iotaledger/hive.go/lo" + "github.com/iotaledger/hive.go/serializer/v2" + "github.com/iotaledger/hive.go/serializer/v2/stream" iotago "github.com/iotaledger/iota.go/v4" ) @@ -21,12 +23,14 @@ type SlotDiff struct { Spents Spents } -func slotDiffKeyForIndex(index iotago.SlotIndex) []byte { - m := marshalutil.New(iotago.SlotIndexLength + 1) - m.WriteByte(StoreKeyPrefixSlotDiffs) - m.WriteBytes(index.MustBytes()) +func slotDiffKeyForIndex(slot iotago.SlotIndex) []byte { + byteBuffer := stream.NewByteBuffer(serializer.OneByte + iotago.SlotIndexLength) - return m.Bytes() + // There can't be any errors. + _ = stream.Write(byteBuffer, StoreKeyPrefixSlotDiffs) + _ = stream.Write(byteBuffer, slot) + + return lo.PanicOnErr(byteBuffer.Bytes()) } func (sd *SlotDiff) KVStorableKey() []byte { @@ -34,40 +38,48 @@ func (sd *SlotDiff) KVStorableKey() []byte { } func (sd *SlotDiff) KVStorableValue() []byte { - m := marshalutil.New() + byteBuffer := stream.NewByteBuffer() - m.WriteUint32(uint32(len(sd.Outputs))) - for _, output := range sd.sortedOutputs() { - m.WriteBytes(output.outputID[:]) - } + // There can't be any errors. + _ = stream.WriteCollection(byteBuffer, serializer.SeriLengthPrefixTypeAsUint32, func() (elementsCount int, err error) { + for _, output := range sd.sortedOutputs() { + _ = stream.Write(byteBuffer, output.outputID) + } - m.WriteUint32(uint32(len(sd.Spents))) - for _, spent := range sd.sortedSpents() { - m.WriteBytes(spent.output.outputID[:]) - } + return len(sd.Outputs), nil + }) - return m.Bytes() + _ = stream.WriteCollection(byteBuffer, serializer.SeriLengthPrefixTypeAsUint32, func() (elementsCount int, err error) { + for _, spent := range sd.sortedSpents() { + _ = stream.Write(byteBuffer, spent.output.outputID) + } + + return len(sd.Spents), nil + }) + + return lo.PanicOnErr(byteBuffer.Bytes()) } // note that this method relies on the data being available within other "tables". func (sd *SlotDiff) kvStorableLoad(manager *Manager, key []byte, value []byte) error { - slot, _, err := iotago.SlotIndexFromBytes(key[1:]) - if err != nil { + var err error + + if sd.Slot, _, err = iotago.SlotIndexFromBytes(key[1:]); err != nil { return err } - marshalUtil := marshalutil.New(value) + byteReader := stream.NewByteReader(value) - outputCount, err := marshalUtil.ReadUint32() + outputsCount, err := stream.PeekCollectionSize(byteReader, serializer.SeriLengthPrefixTypeAsUint32) if err != nil { - return err + return ierrors.Wrap(err, "unable to peek outputs count") } - outputs := make(Outputs, int(outputCount)) - for i := 0; i < int(outputCount); i++ { - var outputID iotago.OutputID - if outputID, err = ParseOutputID(marshalUtil); err != nil { - return err + outputs := make(Outputs, outputsCount) + if err = stream.ReadCollection(byteReader, serializer.SeriLengthPrefixTypeAsUint32, func(i int) error { + outputID, err := stream.Read[iotago.OutputID](byteReader) + if err != nil { + return ierrors.Wrap(err, "unable to read outputID") } output, err := manager.ReadOutputByOutputIDWithoutLocking(outputID) @@ -76,18 +88,22 @@ func (sd *SlotDiff) kvStorableLoad(manager *Manager, key []byte, value []byte) e } outputs[i] = output + + return nil + }); err != nil { + return ierrors.Wrapf(err, "unable to read slot diff outputs") } - spentCount, err := marshalUtil.ReadUint32() + spentsCount, err := stream.PeekCollectionSize(byteReader, serializer.SeriLengthPrefixTypeAsUint32) if err != nil { - return err + return ierrors.Wrap(err, "unable to peek spents count") } - spents := make(Spents, spentCount) - for i := 0; i < int(spentCount); i++ { - var outputID iotago.OutputID - if outputID, err = ParseOutputID(marshalUtil); err != nil { - return err + spents := make(Spents, spentsCount) + if err = stream.ReadCollection(byteReader, serializer.SeriLengthPrefixTypeAsUint32, func(i int) error { + outputID, err := stream.Read[iotago.OutputID](byteReader) + if err != nil { + return ierrors.Wrap(err, "unable to read outputID") } spent, err := manager.ReadSpentForOutputIDWithoutLocking(outputID) @@ -96,9 +112,12 @@ func (sd *SlotDiff) kvStorableLoad(manager *Manager, key []byte, value []byte) e } spents[i] = spent + + return nil + }); err != nil { + return ierrors.Wrapf(err, "unable to read slot diff spents") } - sd.Slot = slot sd.Outputs = outputs sd.Spents = spents diff --git a/pkg/protocol/engine/utxoledger/snapshot.go b/pkg/protocol/engine/utxoledger/snapshot.go index 719a69b30..0fec1d4e3 100644 --- a/pkg/protocol/engine/utxoledger/snapshot.go +++ b/pkg/protocol/engine/utxoledger/snapshot.go @@ -5,7 +5,7 @@ import ( "io" "github.com/iotaledger/hive.go/ierrors" - "github.com/iotaledger/hive.go/serializer/v2/marshalutil" + "github.com/iotaledger/hive.go/serializer/v2/byteutils" "github.com/iotaledger/hive.go/serializer/v2/serix" "github.com/iotaledger/iota-core/pkg/utils" iotago "github.com/iotaledger/iota.go/v4" @@ -14,16 +14,7 @@ import ( // Helpers to serialize/deserialize into/from snapshots func (o *Output) SnapshotBytes() []byte { - m := marshalutil.New() - m.WriteBytes(o.outputID[:]) - m.WriteBytes(o.blockID[:]) - m.WriteUint32(uint32(o.slotBooked)) - m.WriteUint32(uint32(len(o.encodedOutput))) - m.WriteBytes(o.encodedOutput) - m.WriteUint32(uint32(len(o.encodedProof))) - m.WriteBytes(o.encodedProof) - - return m.Bytes() + return byteutils.ConcatBytes(o.outputID[:], o.KVStorableValue()) } func OutputFromSnapshotReader(reader io.ReadSeeker, apiProvider iotago.APIProvider) (*Output, error) { @@ -76,12 +67,9 @@ func OutputFromSnapshotReader(reader io.ReadSeeker, apiProvider iotago.APIProvid } func (s *Spent) SnapshotBytes() []byte { - m := marshalutil.New() - m.WriteBytes(s.Output().SnapshotBytes()) - m.WriteBytes(s.transactionIDSpent[:]) - // we don't need to write indexSpent because this info is available in the milestoneDiff that consumes the output - return m.Bytes() + + return byteutils.ConcatBytes(s.Output().SnapshotBytes(), s.transactionIDSpent[:]) } func SpentFromSnapshotReader(reader io.ReadSeeker, apiProvider iotago.APIProvider, indexSpent iotago.SlotIndex) (*Spent, error) { diff --git a/pkg/protocol/engine/utxoledger/spent.go b/pkg/protocol/engine/utxoledger/spent.go index cdb41baeb..1b1a0a888 100644 --- a/pkg/protocol/engine/utxoledger/spent.go +++ b/pkg/protocol/engine/utxoledger/spent.go @@ -3,8 +3,11 @@ package utxoledger import ( "bytes" + "github.com/iotaledger/hive.go/ierrors" "github.com/iotaledger/hive.go/kvstore" - "github.com/iotaledger/hive.go/serializer/v2/marshalutil" + "github.com/iotaledger/hive.go/lo" + "github.com/iotaledger/hive.go/serializer/v2" + "github.com/iotaledger/hive.go/serializer/v2/stream" iotago "github.com/iotaledger/iota.go/v4" ) @@ -84,11 +87,13 @@ func NewSpent(output *Output, transactionIDSpent iotago.TransactionID, slotSpent } func spentStorageKeyForOutputID(outputID iotago.OutputID) []byte { - ms := marshalutil.New(iotago.OutputIDLength + 1) - ms.WriteByte(StoreKeyPrefixOutputSpent) // 1 byte - ms.WriteBytes(outputID[:]) // iotago.OutputIDLength bytes + byteBuffer := stream.NewByteBuffer(iotago.OutputIDLength + serializer.OneByte) - return ms.Bytes() + // There can't be any errors. + _ = stream.Write(byteBuffer, StoreKeyPrefixOutputSpent) // 1 byte + _ = stream.Write(byteBuffer, outputID) + + return lo.PanicOnErr(byteBuffer.Bytes()) } func (s *Spent) KVStorableKey() (key []byte) { @@ -96,40 +101,33 @@ func (s *Spent) KVStorableKey() (key []byte) { } func (s *Spent) KVStorableValue() (value []byte) { - ms := marshalutil.New(iotago.TransactionIDLength + iotago.SlotIndexLength) - ms.WriteBytes(s.transactionIDSpent[:]) // iotago.TransactionIDLength bytes - ms.WriteBytes(s.slotSpent.MustBytes()) // iotago.SlotIndexLength bytes + byteBuffer := stream.NewByteBuffer(iotago.TransactionIDLength + iotago.SlotIndexLength) + + // There can't be any errors. + _ = stream.Write(byteBuffer, s.transactionIDSpent) + _ = stream.Write(byteBuffer, s.slotSpent) - return ms.Bytes() + return lo.PanicOnErr(byteBuffer.Bytes()) } func (s *Spent) kvStorableLoad(_ *Manager, key []byte, value []byte) error { - // Parse key - keyUtil := marshalutil.New(key) + var err error + keyReader := stream.NewByteReader(key) - // Read prefix output - _, err := keyUtil.ReadByte() - if err != nil { - return err + if _, err = stream.Read[byte](keyReader); err != nil { + return ierrors.Wrap(err, "unable to read prefix") } - - // Read OutputID - if s.outputID, err = ParseOutputID(keyUtil); err != nil { - return err + if s.outputID, err = stream.Read[iotago.OutputID](keyReader); err != nil { + return ierrors.Wrap(err, "unable to read outputID") } - // Parse value - valueUtil := marshalutil.New(value) + valueReader := stream.NewByteReader(value) - // Read transaction ID - if s.transactionIDSpent, err = parseTransactionID(valueUtil); err != nil { - return err + if s.transactionIDSpent, err = stream.Read[iotago.TransactionID](valueReader); err != nil { + return ierrors.Wrap(err, "unable to read transactionIDSpent") } - - // Read slot index spent index - s.slotSpent, err = parseSlotIndex(valueUtil) - if err != nil { - return err + if s.slotSpent, err = stream.Read[iotago.SlotIndex](valueReader); err != nil { + return ierrors.Wrap(err, "unable to read slotSpent") } return nil diff --git a/pkg/protocol/engine/utxoledger/spent_status.go b/pkg/protocol/engine/utxoledger/spent_status.go index 2a2bb6fc4..bfd34409e 100644 --- a/pkg/protocol/engine/utxoledger/spent_status.go +++ b/pkg/protocol/engine/utxoledger/spent_status.go @@ -2,7 +2,9 @@ package utxoledger import ( "github.com/iotaledger/hive.go/kvstore" - "github.com/iotaledger/hive.go/serializer/v2/marshalutil" + "github.com/iotaledger/hive.go/lo" + "github.com/iotaledger/hive.go/serializer/v2" + "github.com/iotaledger/hive.go/serializer/v2/stream" iotago "github.com/iotaledger/iota.go/v4" ) @@ -17,11 +19,13 @@ type OutputConsumer func(output *Output) bool type LookupKey []byte func lookupKeyUnspentOutput(outputID iotago.OutputID) LookupKey { - ms := marshalutil.New(iotago.OutputIDLength + 1) - ms.WriteByte(StoreKeyPrefixOutputUnspent) // 1 byte - ms.WriteBytes(outputID[:]) // iotago.OutputIDLength bytes + byteBuffer := stream.NewByteBuffer(serializer.OneByte + iotago.OutputIDLength) - return ms.Bytes() + // There can't be any errors. + _ = stream.Write(byteBuffer, StoreKeyPrefixOutputUnspent) + _ = stream.Write(byteBuffer, outputID) + + return lo.PanicOnErr(byteBuffer.Bytes()) } func (o *Output) UnspentLookupKey() LookupKey { @@ -29,14 +33,10 @@ func (o *Output) UnspentLookupKey() LookupKey { } func outputIDFromDatabaseKey(key LookupKey) (iotago.OutputID, error) { - ms := marshalutil.New([]byte(key)) - - // prefix - if _, err := ms.ReadByte(); err != nil { - return iotago.OutputID{}, err - } + // Skip 1 byte prefix. + outputID, _, err := iotago.OutputIDFromBytes(key[1:]) - return ParseOutputID(ms) + return outputID, err } func markAsUnspent(output *Output, mutations kvstore.BatchedMutations) error { diff --git a/pkg/protocol/engine/utxoledger/state_tree.go b/pkg/protocol/engine/utxoledger/state_tree.go index 06f04fab5..1e5f3af3f 100644 --- a/pkg/protocol/engine/utxoledger/state_tree.go +++ b/pkg/protocol/engine/utxoledger/state_tree.go @@ -6,17 +6,16 @@ import ( "github.com/iotaledger/hive.go/ads" "github.com/iotaledger/hive.go/ierrors" "github.com/iotaledger/hive.go/kvstore/mapdb" - "github.com/iotaledger/hive.go/serializer/v2/marshalutil" iotago "github.com/iotaledger/iota.go/v4" ) type stateTreeMetadata struct { - Time iotago.SlotIndex + Slot iotago.SlotIndex } func newStateMetadata(output *Output) *stateTreeMetadata { return &stateTreeMetadata{ - Time: output.SlotCreated(), + Slot: output.SlotCreated(), } } @@ -25,7 +24,7 @@ func stateMetadataFromBytes(b []byte) (*stateTreeMetadata, int, error) { var err error var n int - s.Time, n, err = iotago.SlotIndexFromBytes(b) + s.Slot, n, err = iotago.SlotIndexFromBytes(b) if err != nil { return nil, 0, err } @@ -34,10 +33,7 @@ func stateMetadataFromBytes(b []byte) (*stateTreeMetadata, int, error) { } func (s *stateTreeMetadata) Bytes() ([]byte, error) { - ms := marshalutil.New(iotago.SlotIndexLength) - ms.WriteBytes(s.Time.MustBytes()) - - return ms.Bytes(), nil + return s.Slot.Bytes() } func (m *Manager) StateTreeRoot() iotago.Identifier { @@ -46,6 +42,8 @@ func (m *Manager) StateTreeRoot() iotago.Identifier { func (m *Manager) CheckStateTree() bool { comparisonTree := ads.NewMap[iotago.Identifier](mapdb.NewMapDB(), + iotago.Identifier.Bytes, + iotago.IdentifierFromBytes, iotago.OutputID.Bytes, iotago.OutputIDFromBytes, (*stateTreeMetadata).Bytes, From 5558829e06b202c641b4d966960137044a880401 Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Fri, 27 Oct 2023 12:34:55 +0800 Subject: [PATCH 03/32] Replace usage of marshalutil with stream package in network --- pkg/network/peer.go | 93 +++++++++++++++----------- pkg/network/protocols/core/protocol.go | 26 ++++--- 2 files changed, 71 insertions(+), 48 deletions(-) diff --git a/pkg/network/peer.go b/pkg/network/peer.go index 4b5b0a298..f63a2a4f5 100644 --- a/pkg/network/peer.go +++ b/pkg/network/peer.go @@ -10,7 +10,8 @@ import ( "github.com/iotaledger/hive.go/crypto/ed25519" "github.com/iotaledger/hive.go/ierrors" - "github.com/iotaledger/hive.go/serializer/v2/marshalutil" + "github.com/iotaledger/hive.go/serializer/v2" + "github.com/iotaledger/hive.go/serializer/v2/stream" ) const DefaultReconnectInterval = 5 * time.Second @@ -78,17 +79,29 @@ func (p *Peer) SetConnStatus(cs ConnectionStatus) { } func (p *Peer) Bytes() ([]byte, error) { - m := marshalutil.New() - m.WriteUint64(uint64(len(p.ID))) - m.WriteBytes([]byte(p.ID)) - m.WriteUint8(uint8(len(p.PeerAddresses))) - for _, addr := range p.PeerAddresses { - addrBytes := addr.Bytes() - m.WriteUint64(uint64(len(addrBytes))) - m.WriteBytes(addrBytes) + byteBuffer := stream.NewByteBuffer() + + if err := stream.WriteObject(byteBuffer, p.ID, serializer.UInt16ByteSize, func(id peer.ID) ([]byte, error) { + return []byte(id), nil + }); err != nil { + return nil, ierrors.Wrap(err, "failed to write peer ID") + } + + if err := stream.WriteCollection(byteBuffer, serializer.OneByte, func() (elementsCount int, err error) { + for _, addr := range p.PeerAddresses { + if err = stream.WriteObject(byteBuffer, addr, serializer.UInt16ByteSize, func(m multiaddr.Multiaddr) ([]byte, error) { + return m.Bytes(), nil + }); err != nil { + return 0, ierrors.Wrap(err, "failed to write peer address") + } + } + + return len(p.PeerAddresses), nil + }); err != nil { + return nil, ierrors.Wrap(err, "failed to write peer addresses") } - return m.Bytes(), nil + return byteBuffer.Bytes() } func (p *Peer) String() string { @@ -97,46 +110,48 @@ func (p *Peer) String() string { // peerFromBytes parses a peer from a byte slice. func peerFromBytes(bytes []byte) (*Peer, error) { - m := marshalutil.New(bytes) - idLen, err := m.ReadUint64() - if err != nil { - return nil, err - } - idBytes, err := m.ReadBytes(int(idLen)) - if err != nil { - return nil, err - } - id := peer.ID(idBytes) - - peer := &Peer{ - ID: id, + p := &Peer{ PeerAddresses: make([]multiaddr.Multiaddr, 0), ConnStatus: &atomic.Value{}, RemoveCh: make(chan struct{}), DoneCh: make(chan struct{}), } - peer.SetConnStatus(ConnStatusDisconnected) + var err error + byteReader := stream.NewByteReader(bytes) - peerAddrLen, err := m.ReadUint8() - if err != nil { - return nil, err - } - for i := 0; i < int(peerAddrLen); i++ { - addrLen, err := m.ReadUint64() - if err != nil { - return nil, err - } - addrBytes, err := m.ReadBytes(int(addrLen)) + if p.ID, err = stream.ReadObject(byteReader, serializer.UInt16ByteSize, func(bytes []byte) (peer.ID, int, error) { + id, err := peer.IDFromBytes(bytes) if err != nil { - return nil, err + return "", 0, ierrors.Wrap(err, "failed to parse peerID") } - addr, err := multiaddr.NewMultiaddrBytes(addrBytes) + + return id, len(bytes), nil + }); err != nil { + return nil, ierrors.Wrap(err, "failed to read peer ID") + } + + p.SetConnStatus(ConnStatusDisconnected) + + if err = stream.ReadCollection(byteReader, serializer.OneByte, func(i int) error { + addr, err := stream.ReadObject(byteReader, serializer.UInt16ByteSize, func(bytes []byte) (multiaddr.Multiaddr, int, error) { + m, err := multiaddr.NewMultiaddrBytes(bytes) + if err != nil { + return nil, 0, ierrors.Wrap(err, "failed to parse peer address") + } + + return m, len(bytes), nil + }) if err != nil { - return nil, err + return ierrors.Wrap(err, "failed to read peer address") } - peer.PeerAddresses = append(peer.PeerAddresses, addr) + + p.PeerAddresses = append(p.PeerAddresses, addr) + + return nil + }); err != nil { + return nil, ierrors.Wrap(err, "failed to read peer addresses") } - return peer, nil + return p, nil } diff --git a/pkg/network/protocols/core/protocol.go b/pkg/network/protocols/core/protocol.go index d67ab7b06..45181dfd2 100644 --- a/pkg/network/protocols/core/protocol.go +++ b/pkg/network/protocols/core/protocol.go @@ -14,8 +14,9 @@ import ( "github.com/iotaledger/hive.go/runtime/options" "github.com/iotaledger/hive.go/runtime/syncutils" "github.com/iotaledger/hive.go/runtime/workerpool" - "github.com/iotaledger/hive.go/serializer/v2/marshalutil" + "github.com/iotaledger/hive.go/serializer/v2" "github.com/iotaledger/hive.go/serializer/v2/serix" + "github.com/iotaledger/hive.go/serializer/v2/stream" "github.com/iotaledger/iota-core/pkg/model" "github.com/iotaledger/iota-core/pkg/network" nwmodels "github.com/iotaledger/iota-core/pkg/network/protocols/core/models" @@ -73,16 +74,23 @@ func (p *Protocol) SendSlotCommitment(cm *model.Commitment, to ...peer.ID) { } func (p *Protocol) SendAttestations(cm *model.Commitment, attestations []*iotago.Attestation, merkleProof *merklehasher.Proof[iotago.Identifier], to ...peer.ID) { - encodedAttestations := marshalutil.New() - encodedAttestations.WriteUint32(uint32(len(attestations))) - for _, att := range attestations { - iotagoAPI := lo.PanicOnErr(p.apiProvider.APIForVersion(att.ProtocolVersion)) - encodedAttestations.WriteBytes(lo.PanicOnErr(iotagoAPI.Encode(att))) + byteBuffer := stream.NewByteBuffer() + + if err := stream.WriteCollection(byteBuffer, serializer.UInt32ByteSize, func() (elementsCount int, err error) { + for _, att := range attestations { + if err = stream.WriteObject(byteBuffer, att, serializer.UInt16ByteSize, (*iotago.Attestation).Bytes); err != nil { + return 0, ierrors.Wrapf(err, "failed to write attestation %v", att) + } + } + + return len(attestations), nil + }); err != nil { + panic(err) } p.network.Send(&nwmodels.Packet{Body: &nwmodels.Packet_Attestations{Attestations: &nwmodels.Attestations{ Commitment: cm.Data(), - Attestations: encodedAttestations.Bytes(), + Attestations: lo.PanicOnErr(byteBuffer.Bytes()), MerkleProof: lo.PanicOnErr(merkleProof.Bytes()), }}}, to...) } @@ -172,7 +180,7 @@ func (p *Protocol) onBlockRequest(idBytes []byte, id peer.ID) { } func (p *Protocol) onSlotCommitment(commitmentBytes []byte, id peer.ID) { - receivedCommitment, err := model.CommitmentFromBytes(commitmentBytes, p.apiProvider, serix.WithValidation()) + receivedCommitment, _, err := model.CommitmentFromBytes(commitmentBytes, p.apiProvider, serix.WithValidation()) if err != nil { p.Events.Error.Trigger(ierrors.Wrap(err, "failed to deserialize slot commitment"), id) @@ -193,7 +201,7 @@ func (p *Protocol) onSlotCommitmentRequest(idBytes []byte, id peer.ID) { } func (p *Protocol) onAttestations(commitmentBytes []byte, attestationsBytes []byte, merkleProof []byte, id peer.ID) { - cm, err := model.CommitmentFromBytes(commitmentBytes, p.apiProvider, serix.WithValidation()) + cm, _, err := model.CommitmentFromBytes(commitmentBytes, p.apiProvider, serix.WithValidation()) if err != nil { p.Events.Error.Trigger(ierrors.Wrap(err, "failed to deserialize commitment"), id) From 45e79968eb2782c849ec472dda829026ab01b58d Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Fri, 27 Oct 2023 12:36:14 +0800 Subject: [PATCH 04/32] Adjust settings to new stream package --- pkg/model/commitment.go | 33 +++++++++++++++++----- pkg/storage/permanent/commitments.go | 29 ++++++++----------- pkg/storage/permanent/settings.go | 42 +++++++++++----------------- 3 files changed, 55 insertions(+), 49 deletions(-) diff --git a/pkg/model/commitment.go b/pkg/model/commitment.go index cf17c8c4f..bade9cb63 100644 --- a/pkg/model/commitment.go +++ b/pkg/model/commitment.go @@ -50,28 +50,43 @@ func CommitmentFromCommitment(iotaCommitment *iotago.Commitment, api iotago.API, return newCommitment(commitmentID, iotaCommitment, data, api) } -func CommitmentFromBytes(data []byte, apiProvider iotago.APIProvider, opts ...serix.Option) (*Commitment, error) { +func CommitmentFromBytesFactory(apiProvider iotago.APIProvider, opts ...serix.Option) func(bytes []byte) (*Commitment, int, error) { + return func(bytes []byte) (*Commitment, int, error) { + return CommitmentFromBytes(bytes, apiProvider, opts...) + } +} + +func CommitmentFromBytes(data []byte, apiProvider iotago.APIProvider, opts ...serix.Option) (*Commitment, int, error) { + totalBytesRead := 0 + + // We read the version byte here to determine the API to use, but then we decode the entire commitment again. + // Thus, we don't count the version byte as read bytes. version, _, err := iotago.VersionFromBytes(data) if err != nil { - return nil, ierrors.Wrap(err, "failed to determine version") + return nil, 0, ierrors.Wrap(err, "failed to determine version") } apiForVersion, err := apiProvider.APIForVersion(version) if err != nil { - return nil, ierrors.Wrapf(err, "failed to get API for version %d", version) + return nil, 0, ierrors.Wrapf(err, "failed to get API for version %d", version) } iotaCommitment := new(iotago.Commitment) - if _, err := apiForVersion.Decode(data, iotaCommitment, opts...); err != nil { - return nil, err + if totalBytesRead, err = apiForVersion.Decode(data, iotaCommitment, opts...); err != nil { + return nil, 0, ierrors.Wrap(err, "failed to decode commitment") } commitmentID, err := iotaCommitment.ID() if err != nil { - return nil, err + return nil, 0, ierrors.Wrap(err, "failed to determine commitment ID") } - return newCommitment(commitmentID, iotaCommitment, data, apiForVersion) + commitment, err := newCommitment(commitmentID, iotaCommitment, data, apiForVersion) + if err != nil { + return nil, 0, ierrors.Wrap(err, "failed to create commitment") + } + + return commitment, totalBytesRead, nil } func (c *Commitment) ID() iotago.CommitmentID { @@ -102,6 +117,10 @@ func (c *Commitment) Data() []byte { return c.data } +func (c *Commitment) Bytes() ([]byte, error) { + return c.data, nil +} + func (c *Commitment) Commitment() *iotago.Commitment { return c.commitment } diff --git a/pkg/storage/permanent/commitments.go b/pkg/storage/permanent/commitments.go index abc4b59c2..9d256ff4d 100644 --- a/pkg/storage/permanent/commitments.go +++ b/pkg/storage/permanent/commitments.go @@ -1,11 +1,13 @@ package permanent import ( + "fmt" "io" "github.com/iotaledger/hive.go/ierrors" "github.com/iotaledger/hive.go/kvstore" "github.com/iotaledger/hive.go/lo" + "github.com/iotaledger/hive.go/serializer/v2" "github.com/iotaledger/hive.go/serializer/v2/stream" "github.com/iotaledger/iota-core/pkg/model" iotago "github.com/iotaledger/iota.go/v4" @@ -22,13 +24,8 @@ func NewCommitments(store kvstore.KVStore, apiProvider iotago.APIProvider) *Comm store: kvstore.NewTypedStore(store, iotago.SlotIndex.Bytes, iotago.SlotIndexFromBytes, - func(c *model.Commitment) ([]byte, error) { - return c.Data(), nil - }, - func(bytes []byte) (*model.Commitment, int, error) { - c, err := model.CommitmentFromBytes(bytes, apiProvider) - return c, len(bytes), err - }, + (*model.Commitment).Bytes, + model.CommitmentFromBytesFactory(apiProvider), ), } } @@ -42,14 +39,15 @@ func (c *Commitments) Load(slot iotago.SlotIndex) (commitment *model.Commitment, } func (c *Commitments) Export(writer io.WriteSeeker, targetSlot iotago.SlotIndex) (err error) { - if err := stream.WriteCollection(writer, func() (elementsCount uint64, err error) { - var count uint64 + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (elementsCount int, err error) { + var count int for slot := iotago.SlotIndex(0); slot <= targetSlot; slot++ { commitmentBytes, err := c.store.KVStore().Get(lo.PanicOnErr(slot.Bytes())) if err != nil { return 0, ierrors.Wrapf(err, "failed to load commitment for slot %d", slot) } - if err := stream.WriteBlob(writer, commitmentBytes); err != nil { + fmt.Println("commitmentBytes", len(commitmentBytes), commitmentBytes) + if err := stream.WriteByteSlice(writer, commitmentBytes, serializer.SeriLengthPrefixTypeAsUint16); err != nil { return 0, ierrors.Wrapf(err, "failed to write commitment for slot %d", slot) } @@ -65,17 +63,14 @@ func (c *Commitments) Export(writer io.WriteSeeker, targetSlot iotago.SlotIndex) } func (c *Commitments) Import(reader io.ReadSeeker) (err error) { - if err := stream.ReadCollection(reader, func(i int) error { - commitmentBytes, err := stream.ReadBlob(reader) + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(i int) error { + commitment, err := stream.ReadObject[*model.Commitment](reader, serializer.SeriLengthPrefixTypeAsUint16, func(bytes []byte) (*model.Commitment, int, error) { + return model.CommitmentFromBytes(bytes, c.apiProvider) + }) if err != nil { return ierrors.Wrapf(err, "failed to read commitment at index %d", i) } - commitment, err := model.CommitmentFromBytes(commitmentBytes, c.apiProvider) - if err != nil { - return ierrors.Wrapf(err, "failed to parse commitment at index %d", i) - } - if err := c.Store(commitment); err != nil { return ierrors.Wrapf(err, "failed to store commitment at index %d", i) } diff --git a/pkg/storage/permanent/settings.go b/pkg/storage/permanent/settings.go index d1ad5fe82..e7fd7d08e 100644 --- a/pkg/storage/permanent/settings.go +++ b/pkg/storage/permanent/settings.go @@ -10,6 +10,7 @@ import ( "github.com/iotaledger/hive.go/lo" "github.com/iotaledger/hive.go/runtime/options" "github.com/iotaledger/hive.go/runtime/syncutils" + "github.com/iotaledger/hive.go/serializer/v2" "github.com/iotaledger/hive.go/serializer/v2/byteutils" "github.com/iotaledger/hive.go/serializer/v2/stream" "github.com/iotaledger/hive.go/stringify" @@ -65,17 +66,8 @@ func NewSettings(store kvstore.KVStore, opts ...options.Option[api.EpochBasedPro storeLatestCommitment: kvstore.NewTypedValue( store, []byte{latestCommitmentKey}, - func(commitment *model.Commitment) ([]byte, error) { - return commitment.Data(), nil - }, - func(bytes []byte) (*model.Commitment, int, error) { - commitment, err := model.CommitmentFromBytes(bytes, apiProvider) - if err != nil { - return nil, 0, err - } - - return commitment, len(bytes), nil - }, + (*model.Commitment).Bytes, + model.CommitmentFromBytesFactory(apiProvider), ), storeLatestFinalizedSlot: kvstore.NewTypedValue( store, @@ -346,7 +338,7 @@ func (s *Settings) Export(writer io.WriteSeeker, targetCommitment *iotago.Commit commitmentBytes = s.LatestCommitment().Data() } - if err := stream.WriteBlob(writer, commitmentBytes); err != nil { + if err := stream.WriteByteSlice(writer, commitmentBytes, serializer.SeriLengthPrefixTypeAsUint16); err != nil { return ierrors.Wrap(err, "failed to write commitment") } @@ -358,8 +350,8 @@ func (s *Settings) Export(writer io.WriteSeeker, targetCommitment *iotago.Commit defer s.mutex.RUnlock() // Export protocol versions - if err := stream.WriteCollection(writer, func() (uint64, error) { - var count uint64 + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint16, func() (int, error) { + var count int var innerErr error if err := s.storeProtocolVersionEpochMapping.Iterate(kvstore.EmptyPrefix, func(version iotago.Version, epoch iotago.EpochIndex) bool { @@ -391,8 +383,8 @@ func (s *Settings) Export(writer io.WriteSeeker, targetCommitment *iotago.Commit // TODO: rollback future protocol parameters if it was added after targetCommitment.Slot() // Export future protocol parameters - if err := stream.WriteCollection(writer, func() (uint64, error) { - var count uint64 + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint16, func() (int, error) { + var count int var innerErr error if err := s.storeFutureProtocolParameters.Iterate(kvstore.EmptyPrefix, func(version iotago.Version, tuple *types.Tuple[iotago.EpochIndex, iotago.Identifier]) bool { @@ -428,8 +420,8 @@ func (s *Settings) Export(writer io.WriteSeeker, targetCommitment *iotago.Commit } // Export protocol parameters: we only export the parameters up until the current active ones. - if err := stream.WriteCollection(writer, func() (uint64, error) { - var paramsCount uint64 + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint16, func() (int, error) { + var paramsCount int var innerErr error if err := s.storeProtocolParameters.KVStore().Iterate(kvstore.EmptyPrefix, func(key kvstore.Key, value kvstore.Value) bool { @@ -444,7 +436,7 @@ func (s *Settings) Export(writer io.WriteSeeker, targetCommitment *iotago.Commit return true } - if err := stream.WriteBlob(writer, value); err != nil { + if err := stream.WriteByteSlice(writer, value, serializer.SeriLengthPrefixTypeAsUint32); err != nil { innerErr = err return false } @@ -467,7 +459,7 @@ func (s *Settings) Export(writer io.WriteSeeker, targetCommitment *iotago.Commit } func (s *Settings) Import(reader io.ReadSeeker) (err error) { - commitmentBytes, err := stream.ReadBlob(reader) + commitmentBytes, err := stream.ReadByteSlice(reader, serializer.SeriLengthPrefixTypeAsUint16) if err != nil { return ierrors.Wrap(err, "failed to read commitment") } @@ -482,7 +474,7 @@ func (s *Settings) Import(reader io.ReadSeeker) (err error) { } // Read protocol version epoch mapping - if err := stream.ReadCollection(reader, func(i int) error { + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint16, func(i int) error { version, err := stream.Read[iotago.Version](reader) if err != nil { return ierrors.Wrap(err, "failed to parse version") @@ -504,7 +496,7 @@ func (s *Settings) Import(reader io.ReadSeeker) (err error) { } // Read future protocol parameters - if err := stream.ReadCollection(reader, func(i int) error { + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint16, func(i int) error { version, err := stream.Read[iotago.Version](reader) if err != nil { return ierrors.Wrap(err, "failed to parse version") @@ -530,8 +522,8 @@ func (s *Settings) Import(reader io.ReadSeeker) (err error) { } // Read protocol parameters - if err := stream.ReadCollection(reader, func(i int) error { - paramsBytes, err := stream.ReadBlob(reader) + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint16, func(i int) error { + paramsBytes, err := stream.ReadByteSlice(reader, serializer.SeriLengthPrefixTypeAsUint32) if err != nil { return ierrors.Wrapf(err, "failed to read protocol parameters bytes at index %d", i) } @@ -550,7 +542,7 @@ func (s *Settings) Import(reader io.ReadSeeker) (err error) { } // Now that we parsed the protocol parameters, we can parse the commitment since there will be an API available - commitment, err := model.CommitmentFromBytes(commitmentBytes, s.apiProvider) + commitment, _, err := model.CommitmentFromBytes(commitmentBytes, s.apiProvider) if err != nil { return ierrors.Wrap(err, "failed to parse commitment") } From b8ff52b0ae5bf0f95f3f457e97022924729e1ded Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Fri, 27 Oct 2023 12:39:06 +0800 Subject: [PATCH 05/32] Adjust to changes of ads.Map and ads.Set --- pkg/protocol/block_dispatcher.go | 16 +++++++++-- pkg/protocol/commitment_verifier.go | 27 +++---------------- pkg/protocol/engine/committed_slot_api.go | 8 +++++- pkg/protocol/engine/mempool/v1/state_diff.go | 8 +++++- .../slotnotarization/slotmutations.go | 8 +++++- .../sybilprotectionv1/performance/rewards.go | 2 ++ .../sybilprotectionv1/sybilprotection.go | 2 ++ 7 files changed, 43 insertions(+), 28 deletions(-) diff --git a/pkg/protocol/block_dispatcher.go b/pkg/protocol/block_dispatcher.go index 4737fe5da..09122a576 100644 --- a/pkg/protocol/block_dispatcher.go +++ b/pkg/protocol/block_dispatcher.go @@ -220,7 +220,13 @@ func (b *BlockDispatcher) processWarpSyncResponse(commitmentID iotago.Commitment return nil } - acceptedBlocks := ads.NewSet[iotago.Identifier, iotago.BlockID](mapdb.NewMapDB(), iotago.BlockID.Bytes, iotago.BlockIDFromBytes) + acceptedBlocks := ads.NewSet[iotago.Identifier, iotago.BlockID]( + mapdb.NewMapDB(), + iotago.Identifier.Bytes, + iotago.IdentifierFromBytes, + iotago.BlockID.Bytes, + iotago.BlockIDFromBytes, + ) for _, blockID := range blockIDs { _ = acceptedBlocks.Add(blockID) // a mapdb can newer return an error } @@ -229,7 +235,13 @@ func (b *BlockDispatcher) processWarpSyncResponse(commitmentID iotago.Commitment return ierrors.Errorf("failed to verify tangle merkle proof for %s", commitmentID) } - acceptedTransactionIDs := ads.NewSet[iotago.Identifier, iotago.TransactionID](mapdb.NewMapDB(), iotago.TransactionID.Bytes, iotago.TransactionIDFromBytes) + acceptedTransactionIDs := ads.NewSet[iotago.Identifier, iotago.TransactionID]( + mapdb.NewMapDB(), + iotago.Identifier.Bytes, + iotago.IdentifierFromBytes, + iotago.TransactionID.Bytes, + iotago.TransactionIDFromBytes, + ) for _, transactionID := range transactionIDs { _ = acceptedTransactionIDs.Add(transactionID) // a mapdb can never return an error } diff --git a/pkg/protocol/commitment_verifier.go b/pkg/protocol/commitment_verifier.go index 85e715d89..5e53b3783 100644 --- a/pkg/protocol/commitment_verifier.go +++ b/pkg/protocol/commitment_verifier.go @@ -36,31 +36,12 @@ func NewCommitmentVerifier(mainEngine *engine.Engine, lastCommonCommitmentBefore func (c *CommitmentVerifier) verifyCommitment(commitment *model.Commitment, attestations []*iotago.Attestation, merkleProof *merklehasher.Proof[iotago.Identifier]) (blockIDsFromAttestations iotago.BlockIDs, cumulativeWeight uint64, err error) { // 1. Verify that the provided attestations are indeed the ones that were included in the commitment. tree := ads.NewMap[iotago.Identifier](mapdb.NewMapDB(), + iotago.Identifier.Bytes, + iotago.IdentifierFromBytes, iotago.AccountID.Bytes, iotago.AccountIDFromBytes, - func(attestation *iotago.Attestation) ([]byte, error) { - apiForVersion, err := c.engine.APIForVersion(attestation.ProtocolVersion) - if err != nil { - return nil, ierrors.Wrapf(err, "failed to get API for version %d", attestation.ProtocolVersion) - } - - return apiForVersion.Encode(attestation) - }, - func(bytes []byte) (*iotago.Attestation, int, error) { - version, _, err := iotago.VersionFromBytes(bytes) - if err != nil { - return nil, 0, ierrors.Wrap(err, "failed to determine version") - } - - a := new(iotago.Attestation) - apiForVersion, err := c.engine.APIForVersion(version) - if err != nil { - return nil, 0, ierrors.Wrapf(err, "failed to get API for version %d", version) - } - n, err := apiForVersion.Decode(bytes, a) - - return a, n, err - }, + (*iotago.Attestation).Bytes, + iotago.AttestationFromBytes(c.engine), ) for _, att := range attestations { diff --git a/pkg/protocol/engine/committed_slot_api.go b/pkg/protocol/engine/committed_slot_api.go index edb604814..63f750a6d 100644 --- a/pkg/protocol/engine/committed_slot_api.go +++ b/pkg/protocol/engine/committed_slot_api.go @@ -83,7 +83,13 @@ func (c *CommittedSlotAPI) TransactionIDs() (iotago.TransactionIDs, error) { return nil, ierrors.Errorf("failed to get mutations of slot index %d", c.CommitmentID.Slot()) } - set := ads.NewSet[iotago.Identifier](store, iotago.TransactionID.Bytes, iotago.TransactionIDFromBytes) + set := ads.NewSet[iotago.Identifier]( + store, + iotago.Identifier.Bytes, + iotago.IdentifierFromBytes, + iotago.TransactionID.Bytes, + iotago.TransactionIDFromBytes, + ) transactionIDs := make(iotago.TransactionIDs, 0, set.Size()) if err = set.Stream(func(txID iotago.TransactionID) error { diff --git a/pkg/protocol/engine/mempool/v1/state_diff.go b/pkg/protocol/engine/mempool/v1/state_diff.go index 3fe5bb794..f5cbf214b 100644 --- a/pkg/protocol/engine/mempool/v1/state_diff.go +++ b/pkg/protocol/engine/mempool/v1/state_diff.go @@ -31,7 +31,13 @@ func NewStateDiff(slot iotago.SlotIndex, kv kvstore.KVStore) *StateDiff { createdOutputs: shrinkingmap.New[mempool.StateID, mempool.StateMetadata](), executedTransactions: orderedmap.New[iotago.TransactionID, mempool.TransactionMetadata](), stateUsageCounters: shrinkingmap.New[mempool.StateID, int](), - mutations: ads.NewSet[iotago.Identifier](kv, iotago.TransactionID.Bytes, iotago.TransactionIDFromBytes), + mutations: ads.NewSet[iotago.Identifier]( + kv, + iotago.Identifier.Bytes, + iotago.IdentifierFromBytes, + iotago.TransactionID.Bytes, + iotago.TransactionIDFromBytes, + ), } } diff --git a/pkg/protocol/engine/notarization/slotnotarization/slotmutations.go b/pkg/protocol/engine/notarization/slotnotarization/slotmutations.go index 8e60dd53f..08aa10799 100644 --- a/pkg/protocol/engine/notarization/slotnotarization/slotmutations.go +++ b/pkg/protocol/engine/notarization/slotnotarization/slotmutations.go @@ -76,7 +76,13 @@ func (m *SlotMutations) Reset(index iotago.SlotIndex) { func (m *SlotMutations) AcceptedBlocks(index iotago.SlotIndex, createIfMissing ...bool) ads.Set[iotago.Identifier, iotago.BlockID] { if len(createIfMissing) > 0 && createIfMissing[0] { return lo.Return1(m.acceptedBlocksBySlot.GetOrCreate(index, func() ads.Set[iotago.Identifier, iotago.BlockID] { - return ads.NewSet[iotago.Identifier](mapdb.NewMapDB(), iotago.BlockID.Bytes, iotago.BlockIDFromBytes) + return ads.NewSet[iotago.Identifier]( + mapdb.NewMapDB(), + iotago.Identifier.Bytes, + iotago.IdentifierFromBytes, + iotago.BlockID.Bytes, + iotago.BlockIDFromBytes, + ) })) } diff --git a/pkg/protocol/sybilprotection/sybilprotectionv1/performance/rewards.go b/pkg/protocol/sybilprotection/sybilprotectionv1/performance/rewards.go index a2dbdeaad..498d00d99 100644 --- a/pkg/protocol/sybilprotection/sybilprotectionv1/performance/rewards.go +++ b/pkg/protocol/sybilprotection/sybilprotectionv1/performance/rewards.go @@ -190,6 +190,8 @@ func (t *Tracker) rewardsMap(epoch iotago.EpochIndex) (ads.Map[iotago.Identifier } return ads.NewMap[iotago.Identifier](kv, + iotago.Identifier.Bytes, + iotago.IdentifierFromBytes, iotago.AccountID.Bytes, iotago.AccountIDFromBytes, (*model.PoolRewards).Bytes, diff --git a/pkg/protocol/sybilprotection/sybilprotectionv1/sybilprotection.go b/pkg/protocol/sybilprotection/sybilprotectionv1/sybilprotection.go index 1e15ec4e2..dce623236 100644 --- a/pkg/protocol/sybilprotection/sybilprotectionv1/sybilprotection.go +++ b/pkg/protocol/sybilprotection/sybilprotectionv1/sybilprotection.go @@ -222,6 +222,8 @@ func (o *SybilProtection) committeeRoot(targetCommitteeEpoch iotago.EpochIndex) committeeTree := ads.NewSet[iotago.Identifier]( mapdb.NewMapDB(), + iotago.Identifier.Bytes, + iotago.IdentifierFromBytes, iotago.AccountID.Bytes, iotago.AccountIDFromBytes, ) From 5383f6626f6c8cc27948b5212ffa9c0086e96d78 Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Fri, 27 Oct 2023 12:39:58 +0800 Subject: [PATCH 06/32] Adjust new stream package --- .../attestation/slotattestation/snapshot.go | 40 +++++-------------- .../attestation/slotattestation/storage.go | 5 ++- .../slotattestation/testframework_test.go | 5 ++- pkg/protocol/engine/eviction/state.go | 35 +++++----------- .../signalingupgradeorchestrator/snapshot.go | 23 ++++++----- 5 files changed, 39 insertions(+), 69 deletions(-) diff --git a/pkg/protocol/engine/attestation/slotattestation/snapshot.go b/pkg/protocol/engine/attestation/slotattestation/snapshot.go index 12f70bd4a..8de3dfaff 100644 --- a/pkg/protocol/engine/attestation/slotattestation/snapshot.go +++ b/pkg/protocol/engine/attestation/slotattestation/snapshot.go @@ -4,6 +4,7 @@ import ( "io" "github.com/iotaledger/hive.go/ierrors" + "github.com/iotaledger/hive.go/serializer/v2" "github.com/iotaledger/hive.go/serializer/v2/stream" iotago "github.com/iotaledger/iota.go/v4" ) @@ -13,28 +14,14 @@ func (m *Manager) Import(reader io.ReadSeeker) error { defer m.commitmentMutex.Unlock() var attestations []*iotago.Attestation - if err := stream.ReadCollection(reader, func(i int) error { - attestationBytes, err := stream.ReadBlob(reader) - if err != nil { - return ierrors.Wrap(err, "failed to read attestation") - } - - version, _, err := iotago.VersionFromBytes(attestationBytes) - if err != nil { - return ierrors.Wrap(err, "failed to determine version") - } + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint32, func(i int) error { - apiForVersion, err := m.apiProvider.APIForVersion(version) + attestation, err := stream.ReadObject[*iotago.Attestation](reader, serializer.SeriLengthPrefixTypeAsUint16, iotago.AttestationFromBytes(m.apiProvider)) if err != nil { - return ierrors.Wrapf(err, "failed to get API for version %d", version) + return ierrors.Wrapf(err, "failed to read attestation %d", i) } - importedAttestation := new(iotago.Attestation) - if _, err = apiForVersion.Decode(attestationBytes, importedAttestation); err != nil { - return ierrors.Wrapf(err, "failed to decode attestation %d", i) - } - - attestations = append(attestations, importedAttestation) + attestations = append(attestations, attestation) return nil }); err != nil { @@ -88,23 +75,14 @@ func (m *Manager) Export(writer io.WriteSeeker, targetSlot iotago.SlotIndex) err return ierrors.Wrapf(err, "failed to stream attestations of slot %d", targetSlot) } - if err = stream.WriteCollection(writer, func() (uint64, error) { + if err = stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint32, func() (int, error) { for _, a := range attestations { - apiForVersion, err := m.apiProvider.APIForVersion(a.ProtocolVersion) - if err != nil { - return 0, ierrors.Wrapf(err, "failed to get API for version %d", a.ProtocolVersion) - } - bytes, err := apiForVersion.Encode(a) - if err != nil { - return 0, ierrors.Wrapf(err, "failed to encode attestation %v", a) - } - - if writeErr := stream.WriteBlob(writer, bytes); writeErr != nil { - return 0, ierrors.Wrapf(writeErr, "failed to write attestation %v", a) + if err := stream.WriteObject(writer, a, serializer.SeriLengthPrefixTypeAsUint16, (*iotago.Attestation).Bytes); err != nil { + return 0, ierrors.Wrapf(err, "failed to write attestation %v", a) } } - return uint64(len(attestations)), nil + return len(attestations), nil }); err != nil { return ierrors.Wrapf(err, "failed to write attestations of slot %d", targetSlot) } diff --git a/pkg/protocol/engine/attestation/slotattestation/storage.go b/pkg/protocol/engine/attestation/slotattestation/storage.go index b5c198e30..8037bfcd5 100644 --- a/pkg/protocol/engine/attestation/slotattestation/storage.go +++ b/pkg/protocol/engine/attestation/slotattestation/storage.go @@ -99,7 +99,10 @@ func (m *Manager) attestationsForSlot(index iotago.SlotIndex) (ads.Map[iotago.Id return nil, ierrors.Wrapf(err, "failed to get extended realm for attestations of slot %d", index) } - return ads.NewMap[iotago.Identifier](attestationsStorage, + return ads.NewMap[iotago.Identifier]( + attestationsStorage, + iotago.Identifier.Bytes, + iotago.IdentifierFromBytes, iotago.AccountID.Bytes, iotago.AccountIDFromBytes, (*iotago.Attestation).Bytes, diff --git a/pkg/protocol/engine/attestation/slotattestation/testframework_test.go b/pkg/protocol/engine/attestation/slotattestation/testframework_test.go index ad77b48fe..6f403f7aa 100644 --- a/pkg/protocol/engine/attestation/slotattestation/testframework_test.go +++ b/pkg/protocol/engine/attestation/slotattestation/testframework_test.go @@ -148,7 +148,10 @@ func (t *TestFramework) AssertCommit(slot iotago.SlotIndex, expectedCW uint64, e require.EqualValues(t.test, expectedCW, cw) - expectedTree := ads.NewMap[iotago.Identifier](mapdb.NewMapDB(), + expectedTree := ads.NewMap[iotago.Identifier]( + mapdb.NewMapDB(), + iotago.Identifier.Bytes, + iotago.IdentifierFromBytes, iotago.AccountID.Bytes, iotago.AccountIDFromBytes, (*iotago.Attestation).Bytes, diff --git a/pkg/protocol/engine/eviction/state.go b/pkg/protocol/engine/eviction/state.go index 104af2c3e..f107aa71b 100644 --- a/pkg/protocol/engine/eviction/state.go +++ b/pkg/protocol/engine/eviction/state.go @@ -10,6 +10,7 @@ import ( "github.com/iotaledger/hive.go/lo" "github.com/iotaledger/hive.go/runtime/options" "github.com/iotaledger/hive.go/runtime/syncutils" + "github.com/iotaledger/hive.go/serializer/v2" "github.com/iotaledger/hive.go/serializer/v2/stream" "github.com/iotaledger/iota-core/pkg/storage/prunable/slotstore" iotago "github.com/iotaledger/iota.go/v4" @@ -185,18 +186,18 @@ func (s *State) Export(writer io.WriteSeeker, lowerTarget iotago.SlotIndex, targ latestNonEmptySlot := iotago.SlotIndex(0) - if err := stream.WriteCollection(writer, func() (elementsCount uint64, err error) { + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint32, func() (elementsCount int, err error) { for currentSlot := start; currentSlot <= targetSlot; currentSlot++ { storage, err := s.rootBlockStorageFunc(currentSlot) if err != nil { continue } if err = storage.StreamBytes(func(rootBlockIDBytes []byte, commitmentIDBytes []byte) (err error) { - if err = stream.WriteBlob(writer, rootBlockIDBytes); err != nil { + if err = stream.WriteBytes(writer, rootBlockIDBytes); err != nil { return ierrors.Wrapf(err, "failed to write root block ID %s", rootBlockIDBytes) } - if err = stream.WriteBlob(writer, commitmentIDBytes); err != nil { + if err = stream.WriteBytes(writer, commitmentIDBytes); err != nil { return ierrors.Wrapf(err, "failed to write root block's %s commitment %s", rootBlockIDBytes, commitmentIDBytes) } @@ -221,7 +222,7 @@ func (s *State) Export(writer io.WriteSeeker, lowerTarget iotago.SlotIndex, targ latestNonEmptySlot = 0 } - if err := stream.WriteSerializable(writer, latestNonEmptySlot, iotago.SlotIndexLength); err != nil { + if err := stream.Write(writer, latestNonEmptySlot); err != nil { return ierrors.Wrap(err, "failed to write latest non empty slot") } @@ -230,26 +231,15 @@ func (s *State) Export(writer io.WriteSeeker, lowerTarget iotago.SlotIndex, targ // Import imports the root blocks from the given reader. func (s *State) Import(reader io.ReadSeeker) error { - if err := stream.ReadCollection(reader, func(i int) error { - - blockIDBytes, err := stream.ReadBlob(reader) + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint32, func(i int) error { + rootBlockID, err := stream.Read[iotago.BlockID](reader) if err != nil { return ierrors.Wrapf(err, "failed to read root block id %d", i) } - rootBlockID, _, err := iotago.BlockIDFromBytes(blockIDBytes) - if err != nil { - return ierrors.Wrapf(err, "failed to parse root block id %d", i) - } - - commitmentIDBytes, err := stream.ReadBlob(reader) + commitmentID, err := stream.Read[iotago.CommitmentID](reader) if err != nil { - return ierrors.Wrapf(err, "failed to read root block's %s commitment id", rootBlockID) - } - - commitmentID, _, err := iotago.CommitmentIDFromBytes(commitmentIDBytes) - if err != nil { - return ierrors.Wrapf(err, "failed to parse root block's %s commitment id", rootBlockID) + return ierrors.Wrapf(err, "failed to read root block's %s commitment id %d", rootBlockID, i) } if s.rootBlocks.Get(rootBlockID.Slot(), true).Set(rootBlockID, commitmentID) { @@ -263,16 +253,11 @@ func (s *State) Import(reader io.ReadSeeker) error { return ierrors.Wrap(err, "failed to read root blocks") } - latestNonEmptySlotBytes, err := stream.ReadBytes(reader, iotago.SlotIndexLength) + latestNonEmptySlot, err := stream.Read[iotago.SlotIndex](reader) if err != nil { return ierrors.Wrap(err, "failed to read latest non empty slot") } - latestNonEmptySlot, _, err := iotago.SlotIndexFromBytes(latestNonEmptySlotBytes) - if err != nil { - return ierrors.Wrap(err, "failed to parse latest non empty slot") - } - s.setLatestNonEmptySlot(latestNonEmptySlot) return nil diff --git a/pkg/protocol/engine/upgrade/signalingupgradeorchestrator/snapshot.go b/pkg/protocol/engine/upgrade/signalingupgradeorchestrator/snapshot.go index 3d31872ea..f15379c7f 100644 --- a/pkg/protocol/engine/upgrade/signalingupgradeorchestrator/snapshot.go +++ b/pkg/protocol/engine/upgrade/signalingupgradeorchestrator/snapshot.go @@ -4,6 +4,7 @@ import ( "io" "github.com/iotaledger/hive.go/ierrors" + "github.com/iotaledger/hive.go/serializer/v2" "github.com/iotaledger/hive.go/serializer/v2/stream" "github.com/iotaledger/iota-core/pkg/core/account" "github.com/iotaledger/iota-core/pkg/model" @@ -21,13 +22,13 @@ func (o *Orchestrator) Import(reader io.ReadSeeker) error { o.lastCommittedSlot = slot upgradeSignalMap := make(map[account.SeatIndex]*model.SignaledBlock) - if err := stream.ReadCollection(reader, func(i int) error { + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint32, func(i int) error { seat, err := stream.Read[account.SeatIndex](reader) if err != nil { return ierrors.Wrap(err, "failed to read seat") } - signaledBlock, err := stream.ReadFunc(reader, model.SignaledBlockFromBytesFunc(o.apiProvider.APIForSlot(slot))) + signaledBlock, err := stream.ReadObject(reader, serializer.SeriLengthPrefixTypeAsUint16, model.SignaledBlockFromBytesFunc(o.apiProvider.APIForSlot(slot))) if err != nil { return ierrors.Wrap(err, "failed to read signaled block") } @@ -55,13 +56,13 @@ func (o *Orchestrator) Import(reader io.ReadSeeker) error { latestSignals.Set(seat, signaledBlock) } - if err := stream.ReadCollection(reader, func(i int) error { + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsByte, func(i int) error { epoch, err := stream.Read[iotago.EpochIndex](reader) if err != nil { return ierrors.Wrap(err, "failed to read epoch") } - versionAndHash, err := stream.ReadFunc(reader, model.VersionAndHashFromBytes) + versionAndHash, err := stream.ReadFixedSizeObject(reader, model.VersionAndHashSize, model.VersionAndHashFromBytes) if err != nil { return ierrors.Wrap(err, "failed to read versionAndHash") } @@ -87,19 +88,19 @@ func (o *Orchestrator) Export(writer io.WriteSeeker, targetSlot iotago.SlotIndex } // Export the upgrade signals for the target slot. Since these are rolled forward exporting the last slot is sufficient. - if err := stream.WriteCollection(writer, func() (elementsCount uint64, err error) { - var exportedCount uint64 + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint32, func() (elementsCount int, err error) { + var exportedCount int upgradeSignals, err := o.upgradeSignalsPerSlotFunc(targetSlot) if err != nil { return 0, ierrors.Wrapf(err, "failed to get upgrade signals for target slot %d", targetSlot) } if err := upgradeSignals.StreamBytes(func(seatBytes []byte, signaledBlockBytes []byte) error { - if err := stream.Write(writer, seatBytes); err != nil { + if err := stream.WriteBytes(writer, seatBytes); err != nil { return ierrors.Wrap(err, "failed to write seat") } - if err := stream.WriteBlob(writer, signaledBlockBytes); err != nil { + if err := stream.WriteByteSlice(writer, signaledBlockBytes, serializer.SeriLengthPrefixTypeAsUint16); err != nil { return ierrors.Wrap(err, "failed to write signaled block") } @@ -116,8 +117,8 @@ func (o *Orchestrator) Export(writer io.WriteSeeker, targetSlot iotago.SlotIndex } // Export the successfully signaled epochs for the signaling window. - if err := stream.WriteCollection(writer, func() (elementsCount uint64, err error) { - var exportedCount uint64 + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsByte, func() (elementsCount int, err error) { + var exportedCount int apiForSlot := o.apiProvider.APIForSlot(targetSlot) currentEpoch := apiForSlot.TimeProvider().EpochFromSlot(targetSlot) @@ -137,7 +138,7 @@ func (o *Orchestrator) Export(writer io.WriteSeeker, targetSlot iotago.SlotIndex if err := stream.Write(writer, epoch); err != nil { return 0, ierrors.Wrapf(err, "failed to write epoch %d", epoch) } - if err := stream.WriteSerializable(writer, versionAndHash); err != nil { + if err := stream.WriteFixedSizeObject(writer, versionAndHash, model.VersionAndHashSize, model.VersionAndHash.Bytes); err != nil { return 0, ierrors.Wrapf(err, "failed to write versionAndHash for epoch %d", epoch) } From bb8d582042e4b13fa40973d9987420486da3586b Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Fri, 27 Oct 2023 12:41:14 +0800 Subject: [PATCH 07/32] Adjust accounts to new stream package and remove marshalutil usage --- pkg/core/account/accounts.go | 50 ++++++----- pkg/core/account/pool.go | 51 ++++++----- pkg/model/account_diff.go | 80 +++++++++++------ pkg/model/poolstats.go | 88 ++++++++++--------- pkg/protocol/engine/accounts/accounts.go | 70 ++++++++++----- .../engine/accounts/accountsledger/manager.go | 8 +- .../accounts/accountsledger/testsuite_test.go | 4 +- pkg/protocol/engine/accounts/credits.go | 51 +++++++---- pkg/protocol/engine/accounts/mana/manager.go | 2 +- .../engine/accounts/mana/manager_test.go | 2 +- .../snapshotcreator/snapshotcreator.go | 2 +- pkg/tests/accounts_test.go | 12 +-- pkg/tests/upgrade_signaling_test.go | 14 +-- pkg/testsuite/accounts.go | 8 +- 14 files changed, 268 insertions(+), 174 deletions(-) diff --git a/pkg/core/account/accounts.go b/pkg/core/account/accounts.go index 45fdc7f3c..8d16c5047 100644 --- a/pkg/core/account/accounts.go +++ b/pkg/core/account/accounts.go @@ -9,7 +9,8 @@ import ( "github.com/iotaledger/hive.go/ds/shrinkingmap" "github.com/iotaledger/hive.go/ierrors" "github.com/iotaledger/hive.go/runtime/syncutils" - "github.com/iotaledger/hive.go/serializer/v2/marshalutil" + "github.com/iotaledger/hive.go/serializer/v2" + "github.com/iotaledger/hive.go/serializer/v2/stream" iotago "github.com/iotaledger/iota.go/v4" ) @@ -134,6 +135,7 @@ func AccountsFromReader(readSeeker io.ReadSeeker) (*Accounts, int, error) { } func (a *Accounts) readFromReadSeeker(reader io.ReadSeeker) (n int, err error) { + // TODO: improve this a.mutex.Lock() defer a.mutex.Unlock() @@ -181,31 +183,39 @@ func (a *Accounts) readFromReadSeeker(reader io.ReadSeeker) (n int, err error) { return n, nil } -func (a *Accounts) Bytes() (bytes []byte, err error) { +func (a *Accounts) Bytes() ([]byte, error) { a.mutex.RLock() defer a.mutex.RUnlock() - m := marshalutil.New() - - m.WriteUint32(uint32(a.accountPools.Size())) - var innerErr error - a.ForEach(func(id iotago.AccountID, pool *Pool) bool { - m.WriteBytes(id[:]) - poolBytes, err := pool.Bytes() - if err != nil { - innerErr = err - return false + byteBuffer := stream.NewByteBuffer() + + if err := stream.WriteCollection(byteBuffer, serializer.SeriLengthPrefixTypeAsUint32, func() (elementsCount int, err error) { + var innerErr error + a.ForEach(func(id iotago.AccountID, pool *Pool) bool { + if innerErr = stream.Write(byteBuffer, id); innerErr != nil { + return false + } + + if innerErr = stream.WriteFixedSizeObject(byteBuffer, pool, poolBytesLength, func(pool *Pool) ([]byte, error) { + return pool.Bytes() + }); innerErr != nil { + return false + } + + return true + }) + if innerErr != nil { + return 0, innerErr } - m.WriteBytes(poolBytes) - - return true - }) - m.WriteBool(a.reused.Load()) + return a.accountPools.Size(), nil + }); err != nil { + return nil, ierrors.Wrap(err, "failed to write accounts") + } - if innerErr != nil { - return nil, innerErr + if err := stream.Write(byteBuffer, a.reused.Load()); err != nil { + return nil, ierrors.Wrap(err, "failed to write reused flag") } - return m.Bytes(), nil + return byteBuffer.Bytes() } diff --git a/pkg/core/account/pool.go b/pkg/core/account/pool.go index 5815420db..44827eb11 100644 --- a/pkg/core/account/pool.go +++ b/pkg/core/account/pool.go @@ -2,11 +2,12 @@ package account import ( "github.com/iotaledger/hive.go/ierrors" - "github.com/iotaledger/hive.go/serializer/v2/marshalutil" + "github.com/iotaledger/hive.go/serializer/v2" + "github.com/iotaledger/hive.go/serializer/v2/stream" iotago "github.com/iotaledger/iota.go/v4" ) -const poolBytesLength = 3 * marshalutil.Uint64Size +const poolBytesLength = 3 * serializer.UInt64ByteSize // Pool represents all the data we need for a given validator and epoch to calculate its rewards data. type Pool struct { @@ -19,33 +20,35 @@ type Pool struct { func PoolFromBytes(bytes []byte) (*Pool, int, error) { p := new(Pool) - m := marshalutil.New(bytes) - poolStake, err := m.ReadUint64() - if err != nil { - return nil, m.ReadOffset(), ierrors.Wrap(err, "failed to parse pool stake") - } - p.PoolStake = iotago.BaseToken(poolStake) - validatorStake, err := m.ReadUint64() - if err != nil { - return nil, m.ReadOffset(), ierrors.Wrap(err, "failed to parse validator stake") - } - p.ValidatorStake = iotago.BaseToken(validatorStake) + var err error + byteReader := stream.NewByteReader(bytes) - fixedCost, err := m.ReadUint64() - if err != nil { - return nil, m.ReadOffset(), ierrors.Wrap(err, "failed to parse fixed cost") + if p.PoolStake, err = stream.Read[iotago.BaseToken](byteReader); err != nil { + return nil, 0, ierrors.Wrap(err, "failed to read PoolStake") + } + if p.ValidatorStake, err = stream.Read[iotago.BaseToken](byteReader); err != nil { + return nil, 0, ierrors.Wrap(err, "failed to read ValidatorStake") + } + if p.FixedCost, err = stream.Read[iotago.Mana](byteReader); err != nil { + return nil, 0, ierrors.Wrap(err, "failed to read FixedCost") } - p.FixedCost = iotago.Mana(fixedCost) - return p, m.ReadOffset(), nil + return p, byteReader.BytesRead(), nil } -func (p *Pool) Bytes() (bytes []byte, err error) { - m := marshalutil.New() - m.WriteUint64(uint64(p.PoolStake)) - m.WriteUint64(uint64(p.ValidatorStake)) - m.WriteUint64(uint64(p.FixedCost)) +func (p *Pool) Bytes() ([]byte, error) { + byteBuffer := stream.NewByteBuffer(poolBytesLength) + + if err := stream.Write(byteBuffer, p.PoolStake); err != nil { + return nil, ierrors.Wrap(err, "failed to write PoolStake") + } + if err := stream.Write(byteBuffer, p.ValidatorStake); err != nil { + return nil, ierrors.Wrap(err, "failed to write ValidatorStake") + } + if err := stream.Write(byteBuffer, p.FixedCost); err != nil { + return nil, ierrors.Wrap(err, "failed to write FixedCost") + } - return m.Bytes(), nil + return byteBuffer.Bytes() } diff --git a/pkg/model/account_diff.go b/pkg/model/account_diff.go index fadef8c74..f90259da4 100644 --- a/pkg/model/account_diff.go +++ b/pkg/model/account_diff.go @@ -9,7 +9,6 @@ import ( "github.com/iotaledger/hive.go/ierrors" "github.com/iotaledger/hive.go/lo" "github.com/iotaledger/hive.go/serializer/v2" - "github.com/iotaledger/hive.go/serializer/v2/marshalutil" "github.com/iotaledger/hive.go/serializer/v2/stream" iotago "github.com/iotaledger/iota.go/v4" ) @@ -18,7 +17,7 @@ import ( type AccountDiff struct { BICChange iotago.BlockIssuanceCredits - PreviousUpdatedTime iotago.SlotIndex + PreviousUpdatedSlot iotago.SlotIndex NewExpirySlot iotago.SlotIndex PreviousExpirySlot iotago.SlotIndex @@ -44,7 +43,7 @@ type AccountDiff struct { func NewAccountDiff() *AccountDiff { return &AccountDiff{ BICChange: 0, - PreviousUpdatedTime: 0, + PreviousUpdatedSlot: 0, NewExpirySlot: 0, PreviousExpirySlot: 0, NewOutputID: iotago.EmptyOutputID, @@ -61,36 +60,60 @@ func NewAccountDiff() *AccountDiff { } func (d AccountDiff) Bytes() ([]byte, error) { - m := marshalutil.New() + byteBuffer := stream.NewByteBuffer() - m.WriteInt64(int64(d.BICChange)) - m.WriteUint32(uint32(d.PreviousUpdatedTime)) - m.WriteUint32(uint32(d.NewExpirySlot)) - m.WriteUint32(uint32(d.PreviousExpirySlot)) - m.WriteBytes(lo.PanicOnErr(d.NewOutputID.Bytes())) - m.WriteBytes(lo.PanicOnErr(d.PreviousOutputID.Bytes())) + if err := stream.Write(byteBuffer, d.BICChange); err != nil { + return nil, ierrors.Wrap(err, "unable to write BICChange value in the diff") + } + if err := stream.Write(byteBuffer, d.PreviousUpdatedSlot); err != nil { + return nil, ierrors.Wrap(err, "unable to write PreviousUpdatedSlot in the diff") + } + if err := stream.Write(byteBuffer, d.NewExpirySlot); err != nil { + return nil, ierrors.Wrap(err, "unable to write NewExpirySlot in the diff") + } + if err := stream.Write(byteBuffer, d.PreviousExpirySlot); err != nil { + return nil, ierrors.Wrap(err, "unable to write PreviousExpirySlot in the diff") + } + if err := stream.Write(byteBuffer, d.NewOutputID); err != nil { + return nil, ierrors.Wrap(err, "unable to write NewOutputID in the diff") + } + if err := stream.Write(byteBuffer, d.PreviousOutputID); err != nil { + return nil, ierrors.Wrap(err, "unable to write PreviousOutputID in the diff") + } - if err := writeBlockIssuerKeys(m, d.BlockIssuerKeysAdded); err != nil { + if err := writeBlockIssuerKeys(byteBuffer, d.BlockIssuerKeysAdded); err != nil { return nil, err } - if err := writeBlockIssuerKeys(m, d.BlockIssuerKeysRemoved); err != nil { + if err := writeBlockIssuerKeys(byteBuffer, d.BlockIssuerKeysRemoved); err != nil { return nil, err } - m.WriteInt64(d.ValidatorStakeChange) - m.WriteInt64(d.DelegationStakeChange) - m.WriteInt64(d.FixedCostChange) - m.WriteUint64(uint64(d.StakeEndEpochChange)) - m.WriteBytes(lo.PanicOnErr(d.NewLatestSupportedVersionAndHash.Bytes())) - m.WriteBytes(lo.PanicOnErr(d.PrevLatestSupportedVersionAndHash.Bytes())) + if err := stream.Write(byteBuffer, d.ValidatorStakeChange); err != nil { + return nil, ierrors.Wrap(err, "unable to write ValidatorStakeChange in the diff") + } + if err := stream.Write(byteBuffer, d.DelegationStakeChange); err != nil { + return nil, ierrors.Wrap(err, "unable to write DelegationStakeChange in the diff") + } + if err := stream.Write(byteBuffer, d.FixedCostChange); err != nil { + return nil, ierrors.Wrap(err, "unable to write FixedCostChange in the diff") + } + if err := stream.Write(byteBuffer, d.StakeEndEpochChange); err != nil { + return nil, ierrors.Wrap(err, "unable to write StakeEndEpochChange in the diff") + } + if err := stream.WriteFixedSizeObject(byteBuffer, d.NewLatestSupportedVersionAndHash, VersionAndHashSize, VersionAndHash.Bytes); err != nil { + return nil, ierrors.Wrap(err, "unable to write NewLatestSupportedVersionAndHash in the diff") + } + if err := stream.WriteFixedSizeObject(byteBuffer, d.PrevLatestSupportedVersionAndHash, VersionAndHashSize, VersionAndHash.Bytes); err != nil { + return nil, ierrors.Wrap(err, "unable to write PrevLatestSupportedVersionAndHash in the diff") + } - return m.Bytes(), nil + return byteBuffer.Bytes() } func (d *AccountDiff) Clone() *AccountDiff { return &AccountDiff{ BICChange: d.BICChange, - PreviousUpdatedTime: d.PreviousUpdatedTime, + PreviousUpdatedSlot: d.PreviousUpdatedSlot, NewExpirySlot: d.NewExpirySlot, PreviousExpirySlot: d.PreviousExpirySlot, NewOutputID: d.NewOutputID, @@ -107,20 +130,23 @@ func (d *AccountDiff) Clone() *AccountDiff { } func (d *AccountDiff) FromBytes(b []byte) (int, error) { + // TODO: remove return d.readFromReadSeeker(bytes.NewReader(b)) } func (d *AccountDiff) FromReader(readSeeker io.ReadSeeker) error { + // TODO: remove return lo.Return2(d.readFromReadSeeker(readSeeker)) } func (d *AccountDiff) readFromReadSeeker(reader io.ReadSeeker) (offset int, err error) { + // TODO: adjust to new stream API if err = binary.Read(reader, binary.LittleEndian, &d.BICChange); err != nil { return offset, ierrors.Wrap(err, "unable to read account BIC balance value in the diff") } offset += 8 - if err = binary.Read(reader, binary.LittleEndian, &d.PreviousUpdatedTime); err != nil { + if err = binary.Read(reader, binary.LittleEndian, &d.PreviousUpdatedSlot); err != nil { return offset, ierrors.Wrap(err, "unable to read previous updated time in the diff") } offset += iotago.SlotIndexLength @@ -204,22 +230,26 @@ func (d *AccountDiff) readFromReadSeeker(reader io.ReadSeeker) (offset int, err return offset, nil } -func writeBlockIssuerKeys(m *marshalutil.MarshalUtil, blockIssuerKeys iotago.BlockIssuerKeys) error { +func writeBlockIssuerKeys(byteBuffer *stream.ByteBuffer, blockIssuerKeys iotago.BlockIssuerKeys) error { + // TODO: improve this + blockIssuerKeysBytes, err := iotago.CommonSerixAPI().Encode(context.TODO(), blockIssuerKeys) if err != nil { return ierrors.Wrap(err, "unable to encode blockIssuerKeys in the diff") } - m.WriteUint64(uint64(len(blockIssuerKeysBytes))) - m.WriteBytes(blockIssuerKeysBytes) + if err := stream.WriteByteSlice(byteBuffer, blockIssuerKeysBytes, serializer.SeriLengthPrefixTypeAsUint64); err != nil { + return ierrors.Wrap(err, "unable to write blockIssuerKeysBytes in the diff") + } return nil } func readBlockIssuerKeys(reader io.ReadSeeker) (iotago.BlockIssuerKeys, int, error) { + // TODO: improve this var bytesConsumed int - blockIssuerKeysBytes, err := stream.ReadBlob(reader) + blockIssuerKeysBytes, err := stream.ReadByteSlice(reader, serializer.SeriLengthPrefixTypeAsUint64) if err != nil { return nil, bytesConsumed, ierrors.Wrap(err, "unable to read blockIssuerKeysBytes in the diff") } diff --git a/pkg/model/poolstats.go b/pkg/model/poolstats.go index b8ce0a5c0..54dd23857 100644 --- a/pkg/model/poolstats.go +++ b/pkg/model/poolstats.go @@ -2,7 +2,7 @@ package model import ( "github.com/iotaledger/hive.go/ierrors" - "github.com/iotaledger/hive.go/serializer/v2/marshalutil" + "github.com/iotaledger/hive.go/serializer/v2/stream" iotago "github.com/iotaledger/iota.go/v4" ) @@ -15,34 +15,37 @@ type PoolsStats struct { func PoolsStatsFromBytes(bytes []byte) (*PoolsStats, int, error) { p := new(PoolsStats) - m := marshalutil.New(bytes) - totalStake, err := m.ReadUint64() - if err != nil { - return nil, m.ReadOffset(), ierrors.Wrap(err, "failed to parse total stake") - } - p.TotalStake = iotago.BaseToken(totalStake) - totalValidatorStake, err := m.ReadUint64() - if err != nil { - return nil, m.ReadOffset(), ierrors.Wrap(err, "failed to parse total validator stake") - } - p.TotalValidatorStake = iotago.BaseToken(totalValidatorStake) + var err error + byteReader := stream.NewByteReader(bytes) - p.ProfitMargin, err = m.ReadUint64() - if err != nil { - return nil, m.ReadOffset(), ierrors.Wrap(err, "failed to parse profit margin") + if p.TotalStake, err = stream.Read[iotago.BaseToken](byteReader); err != nil { + return nil, 0, ierrors.Wrap(err, "failed to read TotalStake") + } + if p.TotalValidatorStake, err = stream.Read[iotago.BaseToken](byteReader); err != nil { + return nil, 0, ierrors.Wrap(err, "failed to read TotalValidatorStake") + } + if p.ProfitMargin, err = stream.Read[uint64](byteReader); err != nil { + return nil, 0, ierrors.Wrap(err, "failed to read ProfitMargin") } - return p, m.ReadOffset(), nil + return p, byteReader.BytesRead(), nil } func (p *PoolsStats) Bytes() ([]byte, error) { - m := marshalutil.New() - m.WriteUint64(uint64(p.TotalStake)) - m.WriteUint64(uint64(p.TotalValidatorStake)) - m.WriteUint64(p.ProfitMargin) + byteBuffer := stream.NewByteBuffer() + + if err := stream.Write(byteBuffer, p.TotalStake); err != nil { + return nil, ierrors.Wrap(err, "failed to write TotalStake") + } + if err := stream.Write(byteBuffer, p.TotalValidatorStake); err != nil { + return nil, ierrors.Wrap(err, "failed to write TotalValidatorStake") + } + if err := stream.Write(byteBuffer, p.ProfitMargin); err != nil { + return nil, ierrors.Wrap(err, "failed to write ProfitMargin") + } - return m.Bytes(), nil + return byteBuffer.Bytes() } type PoolRewards struct { @@ -56,34 +59,35 @@ type PoolRewards struct { func PoolRewardsFromBytes(bytes []byte) (*PoolRewards, int, error) { p := new(PoolRewards) - m := marshalutil.New(bytes) - poolStake, err := m.ReadUint64() - if err != nil { - return nil, m.ReadOffset(), ierrors.Wrap(err, "failed to parse pool stake") - } - p.PoolStake = iotago.BaseToken(poolStake) + var err error + byteReader := stream.NewByteReader(bytes) - poolRewards, err := m.ReadUint64() - if err != nil { - return nil, m.ReadOffset(), ierrors.Wrap(err, "failed to parse pool rewards") + if p.PoolStake, err = stream.Read[iotago.BaseToken](byteReader); err != nil { + return nil, 0, ierrors.Wrap(err, "failed to read PoolStake") } - p.PoolRewards = iotago.Mana(poolRewards) - - fixedCost, err := m.ReadUint64() - if err != nil { - return nil, m.ReadOffset(), ierrors.Wrap(err, "failed to parse fixed cost") + if p.PoolRewards, err = stream.Read[iotago.Mana](byteReader); err != nil { + return nil, 0, ierrors.Wrap(err, "failed to read PoolRewards") + } + if p.FixedCost, err = stream.Read[iotago.Mana](byteReader); err != nil { + return nil, 0, ierrors.Wrap(err, "failed to read FixedCost") } - p.FixedCost = iotago.Mana(fixedCost) - return p, m.ReadOffset(), nil + return p, byteReader.BytesRead(), nil } func (p *PoolRewards) Bytes() ([]byte, error) { - m := marshalutil.New() - m.WriteUint64(uint64(p.PoolStake)) - m.WriteUint64(uint64(p.PoolRewards)) - m.WriteUint64(uint64(p.FixedCost)) + byteBuffer := stream.NewByteBuffer() + + if err := stream.Write(byteBuffer, p.PoolStake); err != nil { + return nil, ierrors.Wrap(err, "failed to write PoolStake") + } + if err := stream.Write(byteBuffer, p.PoolRewards); err != nil { + return nil, ierrors.Wrap(err, "failed to write PoolRewards") + } + if err := stream.Write(byteBuffer, p.FixedCost); err != nil { + return nil, ierrors.Wrap(err, "failed to write FixedCost") + } - return m.Bytes(), nil + return byteBuffer.Bytes() } diff --git a/pkg/protocol/engine/accounts/accounts.go b/pkg/protocol/engine/accounts/accounts.go index 403f569c0..8a30080e2 100644 --- a/pkg/protocol/engine/accounts/accounts.go +++ b/pkg/protocol/engine/accounts/accounts.go @@ -9,7 +9,8 @@ import ( "github.com/iotaledger/hive.go/ierrors" "github.com/iotaledger/hive.go/lo" "github.com/iotaledger/hive.go/runtime/options" - "github.com/iotaledger/hive.go/serializer/v2/marshalutil" + "github.com/iotaledger/hive.go/serializer/v2" + "github.com/iotaledger/hive.go/serializer/v2/stream" "github.com/iotaledger/iota-core/pkg/model" iotago "github.com/iotaledger/iota.go/v4" ) @@ -64,7 +65,7 @@ func (a *AccountData) Clone() *AccountData { ID: a.ID, Credits: &BlockIssuanceCredits{ Value: a.Credits.Value, - UpdateTime: a.Credits.UpdateTime, + UpdateSlot: a.Credits.UpdateSlot, }, ExpirySlot: a.ExpirySlot, OutputID: a.OutputID, @@ -87,6 +88,7 @@ func (a *AccountData) FromReader(readSeeker io.ReadSeeker) error { } func (a *AccountData) readFromReadSeeker(reader io.ReadSeeker) (int, error) { + // TODO: improve this var bytesConsumed int bytesRead, err := io.ReadFull(reader, a.ID[:]) @@ -103,7 +105,7 @@ func (a *AccountData) readFromReadSeeker(reader io.ReadSeeker) (int, error) { } bytesConsumed += 8 - if err := binary.Read(reader, binary.LittleEndian, &a.Credits.UpdateTime); err != nil { + if err := binary.Read(reader, binary.LittleEndian, &a.Credits.UpdateSlot); err != nil { return bytesConsumed, ierrors.Wrapf(err, "unable to read updatedTime for account balance for accountID %s", a.ID) } bytesConsumed += iotago.SlotIndexLength @@ -189,27 +191,55 @@ func (a *AccountData) readFromReadSeeker(reader io.ReadSeeker) (int, error) { } func (a AccountData) Bytes() ([]byte, error) { - idBytes, err := a.ID.Bytes() - if err != nil { - return nil, ierrors.Wrap(err, "failed to marshal account id") + byteBuffer := stream.NewByteBuffer() + + if err := stream.Write(byteBuffer, a.ID); err != nil { + return nil, ierrors.Wrap(err, "failed to write AccountID") + } + if err := stream.WriteFixedSizeObject(byteBuffer, a.Credits, BlockIssuanceCreditsBytesLength, func(credits *BlockIssuanceCredits) ([]byte, error) { + return credits.Bytes() + }); err != nil { + return nil, ierrors.Wrap(err, "failed to write Credits") + } + if err := stream.Write(byteBuffer, a.ExpirySlot); err != nil { + return nil, ierrors.Wrap(err, "failed to write ExpirySlot") } - m := marshalutil.New() - m.WriteBytes(idBytes) - m.WriteBytes(lo.PanicOnErr(a.Credits.Bytes())) - m.WriteUint32(uint32(a.ExpirySlot)) - m.WriteBytes(lo.PanicOnErr(a.OutputID.Bytes())) - m.WriteByte(byte(len(a.BlockIssuerKeys))) - for _, key := range a.BlockIssuerKeys { - m.WriteBytes(key.Bytes()) + if err := stream.Write(byteBuffer, a.OutputID); err != nil { + return nil, ierrors.Wrap(err, "failed to write OutputID") + } + + if err := stream.WriteCollection(byteBuffer, serializer.SeriLengthPrefixTypeAsByte, func() (elementsCount int, err error) { + // TODO: write this properly as object (depends on how we read it) + for _, key := range a.BlockIssuerKeys { + if _, err = byteBuffer.Write(key.Bytes()); err != nil { + return 0, ierrors.Wrap(err, "failed to write BlockIssuerKey") + } + } + + return len(a.BlockIssuerKeys), nil + }); err != nil { + return nil, ierrors.Wrap(err, "failed to write BlockIssuerKeys") } - m.WriteUint64(uint64(a.ValidatorStake)) - m.WriteUint64(uint64(a.DelegationStake)) - m.WriteUint64(uint64(a.FixedCost)) - m.WriteUint32(uint32(a.StakeEndEpoch)) - m.WriteBytes(lo.PanicOnErr(a.LatestSupportedProtocolVersionAndHash.Bytes())) + if err := stream.Write(byteBuffer, a.ValidatorStake); err != nil { + return nil, ierrors.Wrap(err, "failed to write ValidatorStake") + } + if err := stream.Write(byteBuffer, a.DelegationStake); err != nil { + return nil, ierrors.Wrap(err, "failed to write DelegationStake") + } + if err := stream.Write(byteBuffer, a.FixedCost); err != nil { + return nil, ierrors.Wrap(err, "failed to write FixedCost") + } + if err := stream.Write(byteBuffer, a.StakeEndEpoch); err != nil { + return nil, ierrors.Wrap(err, "failed to write StakeEndEpoch") + } + if err := stream.WriteFixedSizeObject(byteBuffer, a.LatestSupportedProtocolVersionAndHash, model.VersionAndHashSize, func(versionAndHash model.VersionAndHash) ([]byte, error) { + return versionAndHash.Bytes() + }); err != nil { + return nil, ierrors.Wrap(err, "failed to write LatestSupportedProtocolVersionAndHash") + } - return m.Bytes(), nil + return byteBuffer.Bytes() } func WithCredits(credits *BlockIssuanceCredits) options.Option[AccountData] { diff --git a/pkg/protocol/engine/accounts/accountsledger/manager.go b/pkg/protocol/engine/accounts/accountsledger/manager.go index 53459cb0c..01b48ce58 100644 --- a/pkg/protocol/engine/accounts/accountsledger/manager.go +++ b/pkg/protocol/engine/accounts/accountsledger/manager.go @@ -60,6 +60,8 @@ func New( blockBurns: shrinkingmap.New[iotago.SlotIndex, ds.Set[iotago.BlockID]](), latestSupportedVersionSignals: memstorage.NewIndexedStorage[iotago.SlotIndex, iotago.AccountID, *model.SignaledBlock](), accountsTree: ads.NewMap[iotago.Identifier](accountsStore, + iotago.Identifier.Bytes, + iotago.IdentifierFromBytes, iotago.AccountID.Bytes, iotago.AccountIDFromBytes, (*accounts.AccountData).Bytes, @@ -379,7 +381,7 @@ func (m *Manager) rollbackAccountTo(accountData *accounts.AccountData, targetSlo } // update the account data with the diff - accountData.Credits.Update(-diffChange.BICChange, diffChange.PreviousUpdatedTime) + accountData.Credits.Update(-diffChange.BICChange, diffChange.PreviousUpdatedSlot) // update the expiry slot of the account if it was changed if diffChange.PreviousExpirySlot != diffChange.NewExpirySlot { accountData.ExpirySlot = diffChange.PreviousExpirySlot @@ -444,7 +446,7 @@ func (m *Manager) preserveDestroyedAccountData(accountID iotago.AccountID) (acco slotDiff.PreviousExpirySlot = accountData.ExpirySlot slotDiff.NewOutputID = iotago.EmptyOutputID slotDiff.PreviousOutputID = accountData.OutputID - slotDiff.PreviousUpdatedTime = accountData.Credits.UpdateTime + slotDiff.PreviousUpdatedSlot = accountData.Credits.UpdateSlot slotDiff.BlockIssuerKeysRemoved = accountData.BlockIssuerKeys.Clone() slotDiff.ValidatorStakeChange = -int64(accountData.ValidatorStake) @@ -519,7 +521,7 @@ func (m *Manager) commitAccountTree(slot iotago.SlotIndex, accountDiffChanges ma if diffChange.BICChange != 0 || !exists { // decay the credits to the current slot if the account exists if exists { - decayedPreviousCredits, err := m.apiProvider.APIForSlot(slot).ManaDecayProvider().ManaWithDecay(iotago.Mana(accountData.Credits.Value), accountData.Credits.UpdateTime, slot) + decayedPreviousCredits, err := m.apiProvider.APIForSlot(slot).ManaDecayProvider().ManaWithDecay(iotago.Mana(accountData.Credits.Value), accountData.Credits.UpdateSlot, slot) if err != nil { return ierrors.Wrapf(err, "can't retrieve account, could not decay credits for account (%s) in slot (%d)", accountData.ID, slot) } diff --git a/pkg/protocol/engine/accounts/accountsledger/testsuite_test.go b/pkg/protocol/engine/accounts/accountsledger/testsuite_test.go index b090c64c5..d7b89baf6 100644 --- a/pkg/protocol/engine/accounts/accountsledger/testsuite_test.go +++ b/pkg/protocol/engine/accounts/accountsledger/testsuite_test.go @@ -131,7 +131,7 @@ func (t *TestSuite) ApplySlotActions(slot iotago.SlotIndex, rmc iotago.Mana, act BICChange: iotago.BlockIssuanceCredits(action.TotalAllotments), // manager takes AccountDiff only with allotments filled in when applyDiff is triggered BlockIssuerKeysAdded: t.BlockIssuerKeys(action.AddedKeys, true), BlockIssuerKeysRemoved: t.BlockIssuerKeys(action.RemovedKeys, true), - PreviousUpdatedTime: prevAccountFields.BICUpdatedAt, + PreviousUpdatedSlot: prevAccountFields.BICUpdatedAt, NewExpirySlot: prevAccountFields.ExpirySlot, DelegationStakeChange: action.DelegationStakeChange, @@ -265,7 +265,7 @@ func (t *TestSuite) assertDiff(slot iotago.SlotIndex, accountID iotago.AccountID expectedAccountDiff := accountsSlotBuildData.SlotDiff[accountID] require.Equal(t.T, expectedAccountDiff.PreviousOutputID, actualDiff.PreviousOutputID) - require.Equal(t.T, expectedAccountDiff.PreviousUpdatedTime, actualDiff.PreviousUpdatedTime) + require.Equal(t.T, expectedAccountDiff.PreviousUpdatedSlot, actualDiff.PreviousUpdatedSlot) require.Equal(t.T, expectedAccountDiff.NewExpirySlot, actualDiff.NewExpirySlot) require.Equal(t.T, expectedAccountDiff.PreviousExpirySlot, actualDiff.PreviousExpirySlot) diff --git a/pkg/protocol/engine/accounts/credits.go b/pkg/protocol/engine/accounts/credits.go index a4df3e5b8..39d4d1b54 100644 --- a/pkg/protocol/engine/accounts/credits.go +++ b/pkg/protocol/engine/accounts/credits.go @@ -1,49 +1,64 @@ package accounts import ( - "github.com/iotaledger/hive.go/lo" - "github.com/iotaledger/hive.go/serializer/v2/marshalutil" + "github.com/iotaledger/hive.go/ierrors" + "github.com/iotaledger/hive.go/serializer/v2" + "github.com/iotaledger/hive.go/serializer/v2/stream" iotago "github.com/iotaledger/iota.go/v4" ) +const BlockIssuanceCreditsBytesLength = serializer.Int64ByteSize + serializer.UInt32ByteSize + // BlockIssuanceCredits is a weight annotated with the slot it was last updated in. type BlockIssuanceCredits struct { Value iotago.BlockIssuanceCredits - UpdateTime iotago.SlotIndex + UpdateSlot iotago.SlotIndex } // NewBlockIssuanceCredits creates a new Credits instance. func NewBlockIssuanceCredits(value iotago.BlockIssuanceCredits, updateTime iotago.SlotIndex) (newCredits *BlockIssuanceCredits) { return &BlockIssuanceCredits{ Value: value, - UpdateTime: updateTime, + UpdateSlot: updateTime, } } // Bytes returns a serialized version of the Credits. -func (c BlockIssuanceCredits) Bytes() ([]byte, error) { - m := marshalutil.New() +func (c *BlockIssuanceCredits) Bytes() ([]byte, error) { + byteBuffer := stream.NewByteBuffer() + + if err := stream.Write(byteBuffer, c.Value); err != nil { + return nil, ierrors.Wrap(err, "failed to write value") + } - m.WriteInt64(int64(c.Value)) - m.WriteUint32(uint32(c.UpdateTime)) + if err := stream.Write(byteBuffer, c.UpdateSlot); err != nil { + return nil, ierrors.Wrap(err, "failed to write updateTime") + } - return m.Bytes(), nil + return byteBuffer.Bytes() } -// FromBytes parses a serialized version of the Credits. -func (c *BlockIssuanceCredits) FromBytes(bytes []byte) (int, error) { - m := marshalutil.New(bytes) +func BlockIssuanceCreditsFromBytes(bytes []byte) (*BlockIssuanceCredits, int, error) { + c := new(BlockIssuanceCredits) - c.Value = iotago.BlockIssuanceCredits(lo.PanicOnErr(m.ReadInt64())) - c.UpdateTime = iotago.SlotIndex(lo.PanicOnErr(m.ReadUint32())) + var err error + byteReader := stream.NewByteReader(bytes) + + if c.Value, err = stream.Read[iotago.BlockIssuanceCredits](byteReader); err != nil { + return nil, 0, ierrors.Wrap(err, "failed to read value") + } + + if c.UpdateSlot, err = stream.Read[iotago.SlotIndex](byteReader); err != nil { + return nil, 0, ierrors.Wrap(err, "failed to read updateTime") + } - return m.ReadOffset(), nil + return c, byteReader.BytesRead(), nil } // Update updates the Credits increasing Value and updateTime. -func (c *BlockIssuanceCredits) Update(change iotago.BlockIssuanceCredits, updateTime ...iotago.SlotIndex) { +func (c *BlockIssuanceCredits) Update(change iotago.BlockIssuanceCredits, updateSlot ...iotago.SlotIndex) { c.Value += change - if len(updateTime) > 0 { - c.UpdateTime = updateTime[0] + if len(updateSlot) > 0 { + c.UpdateSlot = updateSlot[0] } } diff --git a/pkg/protocol/engine/accounts/mana/manager.go b/pkg/protocol/engine/accounts/mana/manager.go index b53432329..d9c6ae32f 100644 --- a/pkg/protocol/engine/accounts/mana/manager.go +++ b/pkg/protocol/engine/accounts/mana/manager.go @@ -222,5 +222,5 @@ func (m *Manager) getBIC(accountID iotago.AccountID, slot iotago.SlotIndex) (bic return 0, 0, nil } - return iotago.Mana(accountBIC.Credits.Value), accountBIC.Credits.UpdateTime, nil + return iotago.Mana(accountBIC.Credits.Value), accountBIC.Credits.UpdateSlot, nil } diff --git a/pkg/protocol/engine/accounts/mana/manager_test.go b/pkg/protocol/engine/accounts/mana/manager_test.go index f4d58dd62..767367087 100644 --- a/pkg/protocol/engine/accounts/mana/manager_test.go +++ b/pkg/protocol/engine/accounts/mana/manager_test.go @@ -72,7 +72,7 @@ func TestManager_GetManaOnAccountOverflow(t *testing.T) { ID: id, Credits: &accounts.BlockIssuanceCredits{ Value: iotago.MaxBlockIssuanceCredits/2 + iotago.MaxBlockIssuanceCredits/4, - UpdateTime: 1, + UpdateSlot: 1, }, ExpirySlot: iotago.MaxSlotIndex, OutputID: iotago.OutputID{}, diff --git a/pkg/protocol/snapshotcreator/snapshotcreator.go b/pkg/protocol/snapshotcreator/snapshotcreator.go index 5223e0083..9f95c1520 100644 --- a/pkg/protocol/snapshotcreator/snapshotcreator.go +++ b/pkg/protocol/snapshotcreator/snapshotcreator.go @@ -82,7 +82,7 @@ func CreateSnapshot(opts ...options.Option[Options]) error { accountID := blake2b.Sum256(ed25519PubKey[:]) committeeAccountsData = append(committeeAccountsData, &accounts.AccountData{ ID: accountID, - Credits: &accounts.BlockIssuanceCredits{Value: snapshotAccountDetails.BlockIssuanceCredits, UpdateTime: 0}, + Credits: &accounts.BlockIssuanceCredits{Value: snapshotAccountDetails.BlockIssuanceCredits, UpdateSlot: 0}, ExpirySlot: snapshotAccountDetails.ExpirySlot, OutputID: iotago.OutputID{}, BlockIssuerKeys: iotago.BlockIssuerKeys{snapshotAccountDetails.IssuerKey}, diff --git a/pkg/tests/accounts_test.go b/pkg/tests/accounts_test.go index 1195eba30..d73d85ab1 100644 --- a/pkg/tests/accounts_test.go +++ b/pkg/tests/accounts_test.go @@ -109,7 +109,7 @@ func Test_TransitionAccount(t *testing.T) { ts.AssertAccountDiff(genesisAccountOutput.AccountID, block1Slot, &model.AccountDiff{ BICChange: 0, - PreviousUpdatedTime: 0, + PreviousUpdatedSlot: 0, PreviousExpirySlot: 1, NewExpirySlot: 1, NewOutputID: iotago.OutputIDFromTransactionIDAndIndex(ts.TransactionFramework.TransactionID("TX1"), 0), @@ -167,7 +167,7 @@ func Test_TransitionAccount(t *testing.T) { // assert diff of a destroyed account, to make sure we can correctly restore it ts.AssertAccountDiff(genesisAccountOutput.AccountID, block2Slot, &model.AccountDiff{ BICChange: -iotago.BlockIssuanceCredits(123), - PreviousUpdatedTime: 0, + PreviousUpdatedSlot: 0, NewExpirySlot: 0, PreviousExpirySlot: 1, NewOutputID: iotago.EmptyOutputID, @@ -185,7 +185,7 @@ func Test_TransitionAccount(t *testing.T) { ts.AssertAccountDiff(newAccountOutput.AccountID, block2Slot, &model.AccountDiff{ BICChange: 0, - PreviousUpdatedTime: 0, + PreviousUpdatedSlot: 0, NewExpirySlot: newAccountExpirySlot, PreviousExpirySlot: 0, NewOutputID: newAccount.OutputID(), @@ -237,7 +237,7 @@ func Test_TransitionAccount(t *testing.T) { ts.AssertAccountDiff(newAccountOutput.AccountID, block3Slot, &model.AccountDiff{ BICChange: 0, - PreviousUpdatedTime: 0, + PreviousUpdatedSlot: 0, NewOutputID: iotago.EmptyOutputID, PreviousOutputID: iotago.EmptyOutputID, BlockIssuerKeysAdded: iotago.NewBlockIssuerKeys(), @@ -283,7 +283,7 @@ func Test_TransitionAccount(t *testing.T) { // Transitioning to delayed claiming effectively removes the delegation, so we expect a negative delegation stake change. ts.AssertAccountDiff(newAccountOutput.AccountID, block4Slot, &model.AccountDiff{ BICChange: 0, - PreviousUpdatedTime: 0, + PreviousUpdatedSlot: 0, NewOutputID: iotago.EmptyOutputID, PreviousOutputID: iotago.EmptyOutputID, BlockIssuerKeysAdded: iotago.NewBlockIssuerKeys(), @@ -370,7 +370,7 @@ func Test_TransitionAccount(t *testing.T) { ts.AssertAccountDiff(implicitAccountID, slotIndexBlock6, &model.AccountDiff{ BICChange: 0, - PreviousUpdatedTime: 0, + PreviousUpdatedSlot: 0, NewOutputID: fullAccountOutputID, PreviousOutputID: implicitAccountOutputID, PreviousExpirySlot: iotago.MaxSlotIndex, diff --git a/pkg/tests/upgrade_signaling_test.go b/pkg/tests/upgrade_signaling_test.go index b5ce6336b..85961acfd 100644 --- a/pkg/tests/upgrade_signaling_test.go +++ b/pkg/tests/upgrade_signaling_test.go @@ -131,7 +131,7 @@ func Test_Upgrade_Signaling(t *testing.T) { ts.AssertAccountData(&accounts.AccountData{ ID: ts.Node("nodeA").Validator.AccountID, - Credits: &accounts.BlockIssuanceCredits{Value: iotago.MaxBlockIssuanceCredits / 2, UpdateTime: 0}, + Credits: &accounts.BlockIssuanceCredits{Value: iotago.MaxBlockIssuanceCredits / 2, UpdateSlot: 0}, ExpirySlot: iotago.MaxSlotIndex, OutputID: ts.AccountOutput("Genesis:1").OutputID(), BlockIssuerKeys: iotago.NewBlockIssuerKeys(iotago.Ed25519PublicKeyBlockIssuerKeyFromPublicKey(ed25519.PublicKey(ts.Node("nodeA").Validator.PublicKey))), @@ -144,7 +144,7 @@ func Test_Upgrade_Signaling(t *testing.T) { ts.AssertAccountData(&accounts.AccountData{ ID: ts.DefaultBasicBlockIssuer().AccountID, - Credits: &accounts.BlockIssuanceCredits{Value: iotago.MaxBlockIssuanceCredits / 2, UpdateTime: 0}, + Credits: &accounts.BlockIssuanceCredits{Value: iotago.MaxBlockIssuanceCredits / 2, UpdateSlot: 0}, ExpirySlot: iotago.MaxSlotIndex, OutputID: ts.AccountOutput("Genesis:5").OutputID(), BlockIssuerKeys: iotago.NewBlockIssuerKeys(iotago.Ed25519PublicKeyBlockIssuerKeyFromPublicKey(ed25519.PublicKey(ts.DefaultBasicBlockIssuer().PublicKey))), @@ -165,7 +165,7 @@ func Test_Upgrade_Signaling(t *testing.T) { // check account data before all nodes set the current version ts.AssertAccountData(&accounts.AccountData{ ID: ts.Node("nodeA").Validator.AccountID, - Credits: &accounts.BlockIssuanceCredits{Value: iotago.MaxBlockIssuanceCredits / 2, UpdateTime: 0}, + Credits: &accounts.BlockIssuanceCredits{Value: iotago.MaxBlockIssuanceCredits / 2, UpdateSlot: 0}, ExpirySlot: iotago.MaxSlotIndex, OutputID: ts.AccountOutput("Genesis:1").OutputID(), BlockIssuerKeys: iotago.NewBlockIssuerKeys(iotago.Ed25519PublicKeyBlockIssuerKeyFromPublicKey(ed25519.PublicKey(ts.Node("nodeA").Validator.PublicKey))), @@ -178,7 +178,7 @@ func Test_Upgrade_Signaling(t *testing.T) { ts.AssertAccountData(&accounts.AccountData{ ID: ts.Node("nodeD").Validator.AccountID, - Credits: &accounts.BlockIssuanceCredits{Value: iotago.MaxBlockIssuanceCredits / 2, UpdateTime: 0}, + Credits: &accounts.BlockIssuanceCredits{Value: iotago.MaxBlockIssuanceCredits / 2, UpdateSlot: 0}, ExpirySlot: iotago.MaxSlotIndex, OutputID: ts.AccountOutput("Genesis:4").OutputID(), BlockIssuerKeys: iotago.NewBlockIssuerKeys(iotago.Ed25519PublicKeyBlockIssuerKeyFromPublicKey(ed25519.PublicKey(ts.Node("nodeD").Validator.PublicKey))), @@ -199,7 +199,7 @@ func Test_Upgrade_Signaling(t *testing.T) { ts.AssertAccountData(&accounts.AccountData{ ID: ts.Node("nodeA").Validator.AccountID, - Credits: &accounts.BlockIssuanceCredits{Value: iotago.MaxBlockIssuanceCredits / 2, UpdateTime: 0}, + Credits: &accounts.BlockIssuanceCredits{Value: iotago.MaxBlockIssuanceCredits / 2, UpdateSlot: 0}, ExpirySlot: iotago.MaxSlotIndex, OutputID: ts.AccountOutput("Genesis:1").OutputID(), BlockIssuerKeys: iotago.NewBlockIssuerKeys(iotago.Ed25519PublicKeyBlockIssuerKeyFromPublicKey(ed25519.PublicKey(ts.Node("nodeA").Validator.PublicKey))), @@ -364,7 +364,7 @@ func Test_Upgrade_Signaling(t *testing.T) { // check account data at the end of the test ts.AssertAccountData(&accounts.AccountData{ ID: ts.Node("nodeA").Validator.AccountID, - Credits: &accounts.BlockIssuanceCredits{Value: iotago.MaxBlockIssuanceCredits / 2, UpdateTime: 0}, + Credits: &accounts.BlockIssuanceCredits{Value: iotago.MaxBlockIssuanceCredits / 2, UpdateSlot: 0}, ExpirySlot: iotago.MaxSlotIndex, OutputID: ts.AccountOutput("Genesis:1").OutputID(), BlockIssuerKeys: iotago.NewBlockIssuerKeys(iotago.Ed25519PublicKeyBlockIssuerKeyFromPublicKey(ed25519.PublicKey(ts.Node("nodeA").Validator.PublicKey))), @@ -377,7 +377,7 @@ func Test_Upgrade_Signaling(t *testing.T) { ts.AssertAccountData(&accounts.AccountData{ ID: ts.Node("nodeD").Validator.AccountID, - Credits: &accounts.BlockIssuanceCredits{Value: iotago.MaxBlockIssuanceCredits / 2, UpdateTime: 0}, + Credits: &accounts.BlockIssuanceCredits{Value: iotago.MaxBlockIssuanceCredits / 2, UpdateSlot: 0}, ExpirySlot: iotago.MaxSlotIndex, OutputID: ts.AccountOutput("Genesis:4").OutputID(), BlockIssuerKeys: iotago.NewBlockIssuerKeys(iotago.Ed25519PublicKeyBlockIssuerKeyFromPublicKey(ed25519.PublicKey(ts.Node("nodeD").Validator.PublicKey))), diff --git a/pkg/testsuite/accounts.go b/pkg/testsuite/accounts.go index b3683761a..715276ef4 100644 --- a/pkg/testsuite/accounts.go +++ b/pkg/testsuite/accounts.go @@ -29,8 +29,8 @@ func (t *TestSuite) AssertAccountData(accountData *accounts.AccountData, nodes . return ierrors.Errorf("AssertAccountData: %s: accountID %s expected credits value %d, got %d", node.Name, accountData.ID, accountData.Credits.Value, actualAccountData.Credits.Value) } - if accountData.Credits.UpdateTime != actualAccountData.Credits.UpdateTime { - return ierrors.Errorf("AssertAccountData: %s: accountID %s expected credits update time %d, got %d", node.Name, accountData.ID, accountData.Credits.UpdateTime, actualAccountData.Credits.UpdateTime) + if accountData.Credits.UpdateSlot != actualAccountData.Credits.UpdateSlot { + return ierrors.Errorf("AssertAccountData: %s: accountID %s expected credits update time %d, got %d", node.Name, accountData.ID, accountData.Credits.UpdateSlot, actualAccountData.Credits.UpdateSlot) } if accountData.OutputID != actualAccountData.OutputID { @@ -98,8 +98,8 @@ func (t *TestSuite) AssertAccountDiff(accountID iotago.AccountID, index iotago.S return ierrors.Errorf("AssertAccountDiff: %s: expected change %d but actual %d for account %s at slot %d", node.Name, accountDiff.BICChange, actualAccountDiff.BICChange, accountID, index) } - if accountDiff.PreviousUpdatedTime != actualAccountDiff.PreviousUpdatedTime { - return ierrors.Errorf("AssertAccountDiff: %s: expected previous updated time %d but actual %d for account %s at slot %d", node.Name, accountDiff.PreviousUpdatedTime, actualAccountDiff.PreviousUpdatedTime, accountID, index) + if accountDiff.PreviousUpdatedSlot != actualAccountDiff.PreviousUpdatedSlot { + return ierrors.Errorf("AssertAccountDiff: %s: expected previous updated time %d but actual %d for account %s at slot %d", node.Name, accountDiff.PreviousUpdatedSlot, actualAccountDiff.PreviousUpdatedSlot, accountID, index) } if accountDiff.NewExpirySlot != actualAccountDiff.NewExpirySlot { From 59e7583295ceefd25eb401bfb864a227f45c5d04 Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Fri, 27 Oct 2023 12:41:53 +0800 Subject: [PATCH 08/32] Adjust debug API to changes of ads.Map and ads.Set --- components/debugapi/blocks.go | 8 +++++++- components/debugapi/transactions.go | 8 +++++++- 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/components/debugapi/blocks.go b/components/debugapi/blocks.go index 4f9a07abb..948aa76e0 100644 --- a/components/debugapi/blocks.go +++ b/components/debugapi/blocks.go @@ -16,7 +16,13 @@ func getSlotBlockIDs(index iotago.SlotIndex) (*BlockChangesResponse, error) { } includedBlocks := make([]string, 0) - tangleTree := ads.NewSet[iotago.Identifier](mapdb.NewMapDB(), iotago.BlockID.Bytes, iotago.BlockIDFromBytes) + tangleTree := ads.NewSet[iotago.Identifier]( + mapdb.NewMapDB(), + iotago.Identifier.Bytes, + iotago.IdentifierFromBytes, + iotago.BlockID.Bytes, + iotago.BlockIDFromBytes, + ) _ = blocksForSlot.StreamKeys(func(blockID iotago.BlockID) error { includedBlocks = append(includedBlocks, blockID.String()) diff --git a/components/debugapi/transactions.go b/components/debugapi/transactions.go index 6724032c9..8a325e98c 100644 --- a/components/debugapi/transactions.go +++ b/components/debugapi/transactions.go @@ -21,7 +21,13 @@ func storeTransactionsPerSlot(scd *notarization.SlotCommittedDetails) error { if err != nil { return ierrors.Wrapf(err, "failed to retrieve state diff for slot %d", slot) } - mutationsTree := ads.NewSet[iotago.Identifier](mapdb.NewMapDB(), iotago.TransactionID.Bytes, iotago.TransactionIDFromBytes) + mutationsTree := ads.NewSet[iotago.Identifier]( + mapdb.NewMapDB(), + iotago.Identifier.Bytes, + iotago.IdentifierFromBytes, + iotago.TransactionID.Bytes, + iotago.TransactionIDFromBytes, + ) tcs := &TransactionsChangesResponse{ Index: slot, IncludedTransactions: make([]string, 0), From 6a5e28b53e152748910c4b8bf2b9e2971368dad4 Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Tue, 31 Oct 2023 14:31:57 +0800 Subject: [PATCH 09/32] Adjust to renaming changes in https://github.com/iotaledger/hive.go/commit/a5ebefef719aa7c85f97b405e589cdaf3e3678e7 --- pkg/network/peer.go | 8 ++++---- pkg/network/protocols/core/protocol.go | 2 +- .../engine/attestation/slotattestation/snapshot.go | 4 ++-- .../upgrade/signalingupgradeorchestrator/snapshot.go | 8 ++++---- pkg/protocol/engine/utxoledger/output.go | 8 ++++---- pkg/storage/permanent/commitments.go | 7 +++---- pkg/storage/permanent/settings.go | 8 ++++---- 7 files changed, 22 insertions(+), 23 deletions(-) diff --git a/pkg/network/peer.go b/pkg/network/peer.go index f63a2a4f5..b52410792 100644 --- a/pkg/network/peer.go +++ b/pkg/network/peer.go @@ -81,7 +81,7 @@ func (p *Peer) SetConnStatus(cs ConnectionStatus) { func (p *Peer) Bytes() ([]byte, error) { byteBuffer := stream.NewByteBuffer() - if err := stream.WriteObject(byteBuffer, p.ID, serializer.UInt16ByteSize, func(id peer.ID) ([]byte, error) { + if err := stream.WriteObjectWithSize(byteBuffer, p.ID, serializer.UInt16ByteSize, func(id peer.ID) ([]byte, error) { return []byte(id), nil }); err != nil { return nil, ierrors.Wrap(err, "failed to write peer ID") @@ -89,7 +89,7 @@ func (p *Peer) Bytes() ([]byte, error) { if err := stream.WriteCollection(byteBuffer, serializer.OneByte, func() (elementsCount int, err error) { for _, addr := range p.PeerAddresses { - if err = stream.WriteObject(byteBuffer, addr, serializer.UInt16ByteSize, func(m multiaddr.Multiaddr) ([]byte, error) { + if err = stream.WriteObjectWithSize(byteBuffer, addr, serializer.UInt16ByteSize, func(m multiaddr.Multiaddr) ([]byte, error) { return m.Bytes(), nil }); err != nil { return 0, ierrors.Wrap(err, "failed to write peer address") @@ -120,7 +120,7 @@ func peerFromBytes(bytes []byte) (*Peer, error) { var err error byteReader := stream.NewByteReader(bytes) - if p.ID, err = stream.ReadObject(byteReader, serializer.UInt16ByteSize, func(bytes []byte) (peer.ID, int, error) { + if p.ID, err = stream.ReadObjectWithSize(byteReader, serializer.UInt16ByteSize, func(bytes []byte) (peer.ID, int, error) { id, err := peer.IDFromBytes(bytes) if err != nil { return "", 0, ierrors.Wrap(err, "failed to parse peerID") @@ -134,7 +134,7 @@ func peerFromBytes(bytes []byte) (*Peer, error) { p.SetConnStatus(ConnStatusDisconnected) if err = stream.ReadCollection(byteReader, serializer.OneByte, func(i int) error { - addr, err := stream.ReadObject(byteReader, serializer.UInt16ByteSize, func(bytes []byte) (multiaddr.Multiaddr, int, error) { + addr, err := stream.ReadObjectWithSize(byteReader, serializer.UInt16ByteSize, func(bytes []byte) (multiaddr.Multiaddr, int, error) { m, err := multiaddr.NewMultiaddrBytes(bytes) if err != nil { return nil, 0, ierrors.Wrap(err, "failed to parse peer address") diff --git a/pkg/network/protocols/core/protocol.go b/pkg/network/protocols/core/protocol.go index 45181dfd2..b19b168a0 100644 --- a/pkg/network/protocols/core/protocol.go +++ b/pkg/network/protocols/core/protocol.go @@ -78,7 +78,7 @@ func (p *Protocol) SendAttestations(cm *model.Commitment, attestations []*iotago if err := stream.WriteCollection(byteBuffer, serializer.UInt32ByteSize, func() (elementsCount int, err error) { for _, att := range attestations { - if err = stream.WriteObject(byteBuffer, att, serializer.UInt16ByteSize, (*iotago.Attestation).Bytes); err != nil { + if err = stream.WriteObjectWithSize(byteBuffer, att, serializer.UInt16ByteSize, (*iotago.Attestation).Bytes); err != nil { return 0, ierrors.Wrapf(err, "failed to write attestation %v", att) } } diff --git a/pkg/protocol/engine/attestation/slotattestation/snapshot.go b/pkg/protocol/engine/attestation/slotattestation/snapshot.go index 8de3dfaff..0b4b3c14e 100644 --- a/pkg/protocol/engine/attestation/slotattestation/snapshot.go +++ b/pkg/protocol/engine/attestation/slotattestation/snapshot.go @@ -16,7 +16,7 @@ func (m *Manager) Import(reader io.ReadSeeker) error { var attestations []*iotago.Attestation if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint32, func(i int) error { - attestation, err := stream.ReadObject[*iotago.Attestation](reader, serializer.SeriLengthPrefixTypeAsUint16, iotago.AttestationFromBytes(m.apiProvider)) + attestation, err := stream.ReadObjectWithSize[*iotago.Attestation](reader, serializer.SeriLengthPrefixTypeAsUint16, iotago.AttestationFromBytes(m.apiProvider)) if err != nil { return ierrors.Wrapf(err, "failed to read attestation %d", i) } @@ -77,7 +77,7 @@ func (m *Manager) Export(writer io.WriteSeeker, targetSlot iotago.SlotIndex) err if err = stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint32, func() (int, error) { for _, a := range attestations { - if err := stream.WriteObject(writer, a, serializer.SeriLengthPrefixTypeAsUint16, (*iotago.Attestation).Bytes); err != nil { + if err := stream.WriteObjectWithSize(writer, a, serializer.SeriLengthPrefixTypeAsUint16, (*iotago.Attestation).Bytes); err != nil { return 0, ierrors.Wrapf(err, "failed to write attestation %v", a) } } diff --git a/pkg/protocol/engine/upgrade/signalingupgradeorchestrator/snapshot.go b/pkg/protocol/engine/upgrade/signalingupgradeorchestrator/snapshot.go index f15379c7f..f4b6a1926 100644 --- a/pkg/protocol/engine/upgrade/signalingupgradeorchestrator/snapshot.go +++ b/pkg/protocol/engine/upgrade/signalingupgradeorchestrator/snapshot.go @@ -28,7 +28,7 @@ func (o *Orchestrator) Import(reader io.ReadSeeker) error { return ierrors.Wrap(err, "failed to read seat") } - signaledBlock, err := stream.ReadObject(reader, serializer.SeriLengthPrefixTypeAsUint16, model.SignaledBlockFromBytesFunc(o.apiProvider.APIForSlot(slot))) + signaledBlock, err := stream.ReadObjectWithSize(reader, serializer.SeriLengthPrefixTypeAsUint16, model.SignaledBlockFromBytesFunc(o.apiProvider.APIForSlot(slot))) if err != nil { return ierrors.Wrap(err, "failed to read signaled block") } @@ -62,7 +62,7 @@ func (o *Orchestrator) Import(reader io.ReadSeeker) error { return ierrors.Wrap(err, "failed to read epoch") } - versionAndHash, err := stream.ReadFixedSizeObject(reader, model.VersionAndHashSize, model.VersionAndHashFromBytes) + versionAndHash, err := stream.ReadObject(reader, model.VersionAndHashSize, model.VersionAndHashFromBytes) if err != nil { return ierrors.Wrap(err, "failed to read versionAndHash") } @@ -100,7 +100,7 @@ func (o *Orchestrator) Export(writer io.WriteSeeker, targetSlot iotago.SlotIndex return ierrors.Wrap(err, "failed to write seat") } - if err := stream.WriteByteSlice(writer, signaledBlockBytes, serializer.SeriLengthPrefixTypeAsUint16); err != nil { + if err := stream.WriteBytesWithSize(writer, signaledBlockBytes, serializer.SeriLengthPrefixTypeAsUint16); err != nil { return ierrors.Wrap(err, "failed to write signaled block") } @@ -138,7 +138,7 @@ func (o *Orchestrator) Export(writer io.WriteSeeker, targetSlot iotago.SlotIndex if err := stream.Write(writer, epoch); err != nil { return 0, ierrors.Wrapf(err, "failed to write epoch %d", epoch) } - if err := stream.WriteFixedSizeObject(writer, versionAndHash, model.VersionAndHashSize, model.VersionAndHash.Bytes); err != nil { + if err := stream.WriteObject(writer, versionAndHash, model.VersionAndHash.Bytes); err != nil { return 0, ierrors.Wrapf(err, "failed to write versionAndHash for epoch %d", epoch) } diff --git a/pkg/protocol/engine/utxoledger/output.go b/pkg/protocol/engine/utxoledger/output.go index 6dc1e2b6a..0194b65c1 100644 --- a/pkg/protocol/engine/utxoledger/output.go +++ b/pkg/protocol/engine/utxoledger/output.go @@ -212,8 +212,8 @@ func (o *Output) KVStorableValue() (value []byte) { // There can't be any errors. _ = stream.Write(byteBuffer, o.blockID) _ = stream.Write(byteBuffer, o.slotBooked) - _ = stream.WriteByteSlice(byteBuffer, o.encodedOutput, serializer.SeriLengthPrefixTypeAsUint32) - _ = stream.WriteByteSlice(byteBuffer, o.encodedProof, serializer.SeriLengthPrefixTypeAsUint32) + _ = stream.WriteBytesWithSize(byteBuffer, o.encodedOutput, serializer.SeriLengthPrefixTypeAsUint32) + _ = stream.WriteBytesWithSize(byteBuffer, o.encodedProof, serializer.SeriLengthPrefixTypeAsUint32) return lo.PanicOnErr(byteBuffer.Bytes()) } @@ -237,10 +237,10 @@ func (o *Output) kvStorableLoad(_ *Manager, key []byte, value []byte) error { if o.slotBooked, err = stream.Read[iotago.SlotIndex](valueReader); err != nil { return ierrors.Wrap(err, "unable to read slotBooked") } - if o.encodedOutput, err = stream.ReadByteSlice(valueReader, serializer.SeriLengthPrefixTypeAsUint32); err != nil { + if o.encodedOutput, err = stream.ReadBytesWithSize(valueReader, serializer.SeriLengthPrefixTypeAsUint32); err != nil { return ierrors.Wrap(err, "unable to read encodedOutput") } - if o.encodedProof, err = stream.ReadByteSlice(valueReader, serializer.SeriLengthPrefixTypeAsUint32); err != nil { + if o.encodedProof, err = stream.ReadBytesWithSize(valueReader, serializer.SeriLengthPrefixTypeAsUint32); err != nil { return ierrors.Wrap(err, "unable to read encodedProof") } diff --git a/pkg/storage/permanent/commitments.go b/pkg/storage/permanent/commitments.go index 9d256ff4d..e4dff5157 100644 --- a/pkg/storage/permanent/commitments.go +++ b/pkg/storage/permanent/commitments.go @@ -1,7 +1,6 @@ package permanent import ( - "fmt" "io" "github.com/iotaledger/hive.go/ierrors" @@ -46,8 +45,8 @@ func (c *Commitments) Export(writer io.WriteSeeker, targetSlot iotago.SlotIndex) if err != nil { return 0, ierrors.Wrapf(err, "failed to load commitment for slot %d", slot) } - fmt.Println("commitmentBytes", len(commitmentBytes), commitmentBytes) - if err := stream.WriteByteSlice(writer, commitmentBytes, serializer.SeriLengthPrefixTypeAsUint16); err != nil { + + if err := stream.WriteBytesWithSize(writer, commitmentBytes, serializer.SeriLengthPrefixTypeAsUint16); err != nil { return 0, ierrors.Wrapf(err, "failed to write commitment for slot %d", slot) } @@ -64,7 +63,7 @@ func (c *Commitments) Export(writer io.WriteSeeker, targetSlot iotago.SlotIndex) func (c *Commitments) Import(reader io.ReadSeeker) (err error) { if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(i int) error { - commitment, err := stream.ReadObject[*model.Commitment](reader, serializer.SeriLengthPrefixTypeAsUint16, func(bytes []byte) (*model.Commitment, int, error) { + commitment, err := stream.ReadObjectWithSize[*model.Commitment](reader, serializer.SeriLengthPrefixTypeAsUint16, func(bytes []byte) (*model.Commitment, int, error) { return model.CommitmentFromBytes(bytes, c.apiProvider) }) if err != nil { diff --git a/pkg/storage/permanent/settings.go b/pkg/storage/permanent/settings.go index e7fd7d08e..cca9807cd 100644 --- a/pkg/storage/permanent/settings.go +++ b/pkg/storage/permanent/settings.go @@ -338,7 +338,7 @@ func (s *Settings) Export(writer io.WriteSeeker, targetCommitment *iotago.Commit commitmentBytes = s.LatestCommitment().Data() } - if err := stream.WriteByteSlice(writer, commitmentBytes, serializer.SeriLengthPrefixTypeAsUint16); err != nil { + if err := stream.WriteBytesWithSize(writer, commitmentBytes, serializer.SeriLengthPrefixTypeAsUint16); err != nil { return ierrors.Wrap(err, "failed to write commitment") } @@ -436,7 +436,7 @@ func (s *Settings) Export(writer io.WriteSeeker, targetCommitment *iotago.Commit return true } - if err := stream.WriteByteSlice(writer, value, serializer.SeriLengthPrefixTypeAsUint32); err != nil { + if err := stream.WriteBytesWithSize(writer, value, serializer.SeriLengthPrefixTypeAsUint32); err != nil { innerErr = err return false } @@ -459,7 +459,7 @@ func (s *Settings) Export(writer io.WriteSeeker, targetCommitment *iotago.Commit } func (s *Settings) Import(reader io.ReadSeeker) (err error) { - commitmentBytes, err := stream.ReadByteSlice(reader, serializer.SeriLengthPrefixTypeAsUint16) + commitmentBytes, err := stream.ReadBytesWithSize(reader, serializer.SeriLengthPrefixTypeAsUint16) if err != nil { return ierrors.Wrap(err, "failed to read commitment") } @@ -523,7 +523,7 @@ func (s *Settings) Import(reader io.ReadSeeker) (err error) { // Read protocol parameters if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint16, func(i int) error { - paramsBytes, err := stream.ReadByteSlice(reader, serializer.SeriLengthPrefixTypeAsUint32) + paramsBytes, err := stream.ReadBytesWithSize(reader, serializer.SeriLengthPrefixTypeAsUint32) if err != nil { return ierrors.Wrapf(err, "failed to read protocol parameters bytes at index %d", i) } From e242934e751e02321e1ce9a10a75966c6360fc47 Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Tue, 31 Oct 2023 16:33:13 +0800 Subject: [PATCH 10/32] Improve serialization of accounts: get rid of PositionedWriter and binary.Write usage and instead apply new stream package --- pkg/core/account/accounts.go | 81 ++---- pkg/core/account/accounts_test.go | 2 +- pkg/model/account_diff.go | 167 +++++------- pkg/protocol/engine/accounts/accounts.go | 120 +++------ .../engine/accounts/accountsledger/manager.go | 8 +- .../accounts/accountsledger/snapshot.go | 245 ++++++++---------- pkg/protocol/engine/accounts/credits.go | 2 +- pkg/protocol/engine/ledger/ledger/ledger.go | 2 +- .../sybilprotectionv1/performance/snapshot.go | 2 +- .../prunable/slotstore/accountdiffs.go | 13 +- 10 files changed, 251 insertions(+), 391 deletions(-) diff --git a/pkg/core/account/accounts.go b/pkg/core/account/accounts.go index 8d16c5047..d091f381d 100644 --- a/pkg/core/account/accounts.go +++ b/pkg/core/account/accounts.go @@ -1,8 +1,6 @@ package account import ( - "bytes" - "encoding/binary" "io" "sync/atomic" @@ -27,14 +25,9 @@ type Accounts struct { // NewAccounts creates a new Weights instance. func NewAccounts() *Accounts { - a := new(Accounts) - a.initialize() - - return a -} - -func (a *Accounts) initialize() { - a.accountPools = shrinkingmap.New[iotago.AccountID, *Pool]() + return &Accounts{ + accountPools: shrinkingmap.New[iotago.AccountID, *Pool](), + } } func (a *Accounts) Has(id iotago.AccountID) bool { @@ -124,63 +117,45 @@ func (a *Accounts) SelectCommittee(members ...iotago.AccountID) *SeatedAccounts } func AccountsFromBytes(b []byte) (*Accounts, int, error) { - return AccountsFromReader(bytes.NewReader(b)) -} - -func AccountsFromReader(readSeeker io.ReadSeeker) (*Accounts, int, error) { - a := new(Accounts) - n, err := a.readFromReadSeeker(readSeeker) - - return a, n, err -} - -func (a *Accounts) readFromReadSeeker(reader io.ReadSeeker) (n int, err error) { - // TODO: improve this - a.mutex.Lock() - defer a.mutex.Unlock() - - a.initialize() + reader := stream.NewByteReader(b) - var accountCount uint32 - if err = binary.Read(reader, binary.LittleEndian, &accountCount); err != nil { - return n, ierrors.Wrap(err, "unable to read accounts count") + a, err := AccountsFromReader(reader) + if err != nil { + return nil, 0, ierrors.Wrap(err, "unable to read accounts from bytes") } - n += 4 - - for i := uint32(0); i < accountCount; i++ { - var accountID iotago.AccountID - if _, err = io.ReadFull(reader, accountID[:]); err != nil { - return 0, ierrors.Wrap(err, "unable to read accountID") - } - n += iotago.AccountIDLength + return a, reader.BytesRead(), nil +} - poolBytes := make([]byte, poolBytesLength) - if _, err = io.ReadFull(reader, poolBytes); err != nil { - return 0, ierrors.Wrap(err, "unable to read pool bytes") - } - n += poolBytesLength +func AccountsFromReader(reader io.Reader) (*Accounts, error) { + a := NewAccounts() - pool, c, err := PoolFromBytes(poolBytes) + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint32, func(i int) error { + accountID, err := stream.Read[iotago.AccountID](reader) if err != nil { - return 0, ierrors.Wrap(err, "failed to parse pool") + return ierrors.Wrapf(err, "unable to read accountID at index %d", i) } - if c != poolBytesLength { - return 0, ierrors.Wrap(err, "invalid pool bytes length") + pool, err := stream.ReadObject(reader, poolBytesLength, PoolFromBytes) + if err != nil { + return ierrors.Wrapf(err, "unable to read pool at index %d", i) } a.setWithoutLocking(accountID, pool) + + return nil + }); err != nil { + return nil, ierrors.Wrap(err, "failed to read account data") } - var reused bool - if err = binary.Read(reader, binary.LittleEndian, &reused); err != nil { - return n, ierrors.Wrap(err, "unable to read reused flag") + reused, err := stream.Read[bool](reader) + if err != nil { + return nil, ierrors.Wrap(err, "failed to read reused flag") } + a.reused.Store(reused) - n++ - return n, nil + return a, nil } func (a *Accounts) Bytes() ([]byte, error) { @@ -196,9 +171,7 @@ func (a *Accounts) Bytes() ([]byte, error) { return false } - if innerErr = stream.WriteFixedSizeObject(byteBuffer, pool, poolBytesLength, func(pool *Pool) ([]byte, error) { - return pool.Bytes() - }); innerErr != nil { + if innerErr = stream.WriteObject(byteBuffer, pool, (*Pool).Bytes); innerErr != nil { return false } diff --git a/pkg/core/account/accounts_test.go b/pkg/core/account/accounts_test.go index 7838ddf6b..88c294c35 100644 --- a/pkg/core/account/accounts_test.go +++ b/pkg/core/account/accounts_test.go @@ -97,7 +97,7 @@ func TestAccounts(t *testing.T) { require.Equal(t, accounts, accounts2) // check "AccountsFromReader" - accounts3, _, err := account.AccountsFromReader(bytes.NewReader(accountBytes)) + accounts3, err := account.AccountsFromReader(bytes.NewReader(accountBytes)) require.NoError(t, err) // check if the new account is the same diff --git a/pkg/model/account_diff.go b/pkg/model/account_diff.go index f90259da4..9ded15b89 100644 --- a/pkg/model/account_diff.go +++ b/pkg/model/account_diff.go @@ -1,9 +1,7 @@ package model import ( - "bytes" "context" - "encoding/binary" "io" "github.com/iotaledger/hive.go/ierrors" @@ -59,7 +57,26 @@ func NewAccountDiff() *AccountDiff { } } -func (d AccountDiff) Bytes() ([]byte, error) { +func (d *AccountDiff) Clone() *AccountDiff { + return &AccountDiff{ + BICChange: d.BICChange, + PreviousUpdatedSlot: d.PreviousUpdatedSlot, + NewExpirySlot: d.NewExpirySlot, + PreviousExpirySlot: d.PreviousExpirySlot, + NewOutputID: d.NewOutputID, + PreviousOutputID: d.PreviousOutputID, + BlockIssuerKeysAdded: lo.CopySlice(d.BlockIssuerKeysAdded), + BlockIssuerKeysRemoved: lo.CopySlice(d.BlockIssuerKeysRemoved), + ValidatorStakeChange: d.ValidatorStakeChange, + DelegationStakeChange: d.DelegationStakeChange, + FixedCostChange: d.FixedCostChange, + StakeEndEpochChange: d.StakeEndEpochChange, + NewLatestSupportedVersionAndHash: d.NewLatestSupportedVersionAndHash, + PrevLatestSupportedVersionAndHash: d.PrevLatestSupportedVersionAndHash, + } +} + +func (d *AccountDiff) Bytes() ([]byte, error) { byteBuffer := stream.NewByteBuffer() if err := stream.Write(byteBuffer, d.BICChange); err != nil { @@ -100,134 +117,80 @@ func (d AccountDiff) Bytes() ([]byte, error) { if err := stream.Write(byteBuffer, d.StakeEndEpochChange); err != nil { return nil, ierrors.Wrap(err, "unable to write StakeEndEpochChange in the diff") } - if err := stream.WriteFixedSizeObject(byteBuffer, d.NewLatestSupportedVersionAndHash, VersionAndHashSize, VersionAndHash.Bytes); err != nil { + if err := stream.WriteObject(byteBuffer, d.NewLatestSupportedVersionAndHash, VersionAndHash.Bytes); err != nil { return nil, ierrors.Wrap(err, "unable to write NewLatestSupportedVersionAndHash in the diff") } - if err := stream.WriteFixedSizeObject(byteBuffer, d.PrevLatestSupportedVersionAndHash, VersionAndHashSize, VersionAndHash.Bytes); err != nil { + if err := stream.WriteObject(byteBuffer, d.PrevLatestSupportedVersionAndHash, VersionAndHash.Bytes); err != nil { return nil, ierrors.Wrap(err, "unable to write PrevLatestSupportedVersionAndHash in the diff") } return byteBuffer.Bytes() } -func (d *AccountDiff) Clone() *AccountDiff { - return &AccountDiff{ - BICChange: d.BICChange, - PreviousUpdatedSlot: d.PreviousUpdatedSlot, - NewExpirySlot: d.NewExpirySlot, - PreviousExpirySlot: d.PreviousExpirySlot, - NewOutputID: d.NewOutputID, - PreviousOutputID: d.PreviousOutputID, - BlockIssuerKeysAdded: lo.CopySlice(d.BlockIssuerKeysAdded), - BlockIssuerKeysRemoved: lo.CopySlice(d.BlockIssuerKeysRemoved), - ValidatorStakeChange: d.ValidatorStakeChange, - DelegationStakeChange: d.DelegationStakeChange, - FixedCostChange: d.FixedCostChange, - StakeEndEpochChange: d.StakeEndEpochChange, - NewLatestSupportedVersionAndHash: d.NewLatestSupportedVersionAndHash, - PrevLatestSupportedVersionAndHash: d.PrevLatestSupportedVersionAndHash, - } -} +func AccountDiffFromReader(reader io.Reader) (*AccountDiff, error) { + var err error + d := NewAccountDiff() -func (d *AccountDiff) FromBytes(b []byte) (int, error) { - // TODO: remove - return d.readFromReadSeeker(bytes.NewReader(b)) -} - -func (d *AccountDiff) FromReader(readSeeker io.ReadSeeker) error { - // TODO: remove - return lo.Return2(d.readFromReadSeeker(readSeeker)) -} - -func (d *AccountDiff) readFromReadSeeker(reader io.ReadSeeker) (offset int, err error) { - // TODO: adjust to new stream API - if err = binary.Read(reader, binary.LittleEndian, &d.BICChange); err != nil { - return offset, ierrors.Wrap(err, "unable to read account BIC balance value in the diff") + if d.BICChange, err = stream.Read[iotago.BlockIssuanceCredits](reader); err != nil { + return nil, ierrors.Wrap(err, "unable to read account BIC balance value in the diff") } - offset += 8 - - if err = binary.Read(reader, binary.LittleEndian, &d.PreviousUpdatedSlot); err != nil { - return offset, ierrors.Wrap(err, "unable to read previous updated time in the diff") + if d.PreviousUpdatedSlot, err = stream.Read[iotago.SlotIndex](reader); err != nil { + return nil, ierrors.Wrap(err, "unable to read previous updated time in the diff") } - offset += iotago.SlotIndexLength - - if err = binary.Read(reader, binary.LittleEndian, &d.NewExpirySlot); err != nil { - return offset, ierrors.Wrap(err, "unable to read new expiry slot in the diff") + if d.NewExpirySlot, err = stream.Read[iotago.SlotIndex](reader); err != nil { + return nil, ierrors.Wrap(err, "unable to read new expiry slot in the diff") } - offset += iotago.SlotIndexLength - - if err = binary.Read(reader, binary.LittleEndian, &d.PreviousExpirySlot); err != nil { - return offset, ierrors.Wrap(err, "unable to read previous expiry slot in the diff") + if d.PreviousExpirySlot, err = stream.Read[iotago.SlotIndex](reader); err != nil { + return nil, ierrors.Wrap(err, "unable to read previous expiry slot in the diff") } - offset += iotago.SlotIndexLength - - if err = binary.Read(reader, binary.LittleEndian, &d.NewOutputID); err != nil { - return offset, ierrors.Wrap(err, "unable to read new outputID in the diff") + if d.NewOutputID, err = stream.Read[iotago.OutputID](reader); err != nil { + return nil, ierrors.Wrap(err, "unable to read new outputID in the diff") } - offset += iotago.OutputIDLength - - if err = binary.Read(reader, binary.LittleEndian, &d.PreviousOutputID); err != nil { - return offset, ierrors.Wrap(err, "unable to read previous outputID in the diff") + if d.PreviousOutputID, err = stream.Read[iotago.OutputID](reader); err != nil { + return nil, ierrors.Wrap(err, "unable to read previous outputID in the diff") } - offset += iotago.OutputIDLength - keysAdded, bytesRead, err := readBlockIssuerKeys(reader) + // TODO: refactor serialization of blockIssuerKeys + keysAdded, _, err := readBlockIssuerKeys(reader) if err != nil { - return offset, ierrors.Wrap(err, "unable to read added blockIssuerKeys in the diff") + return nil, ierrors.Wrap(err, "unable to read added blockIssuerKeys in the diff") } - offset += bytesRead - d.BlockIssuerKeysAdded = keysAdded - keysRemoved, bytesRead, err := readBlockIssuerKeys(reader) + keysRemoved, _, err := readBlockIssuerKeys(reader) if err != nil { - return offset, ierrors.Wrap(err, "unable to read removed blockIssuerKeys in the diff") + return nil, ierrors.Wrap(err, "unable to read removed blockIssuerKeys in the diff") } - offset += bytesRead - d.BlockIssuerKeysRemoved = keysRemoved - if err = binary.Read(reader, binary.LittleEndian, &d.ValidatorStakeChange); err != nil { - return offset, ierrors.Wrap(err, "unable to read validator stake change in the diff") + if d.ValidatorStakeChange, err = stream.Read[int64](reader); err != nil { + return nil, ierrors.Wrap(err, "unable to read validator stake change in the diff") } - offset += 8 - - if err = binary.Read(reader, binary.LittleEndian, &d.DelegationStakeChange); err != nil { - return offset, ierrors.Wrap(err, "unable to read delegation stake change in the diff") + if d.DelegationStakeChange, err = stream.Read[int64](reader); err != nil { + return nil, ierrors.Wrap(err, "unable to read delegation stake change in the diff") } - offset += 8 - - if err = binary.Read(reader, binary.LittleEndian, &d.FixedCostChange); err != nil { - return offset, ierrors.Wrap(err, "unable to read fixed cost change in the diff") + if d.FixedCostChange, err = stream.Read[int64](reader); err != nil { + return nil, ierrors.Wrap(err, "unable to read fixed cost change in the diff") } - offset += 8 - - if err = binary.Read(reader, binary.LittleEndian, &d.StakeEndEpochChange); err != nil { - return offset, ierrors.Wrap(err, "unable to read new stake end epoch in the diff") + if d.StakeEndEpochChange, err = stream.Read[int64](reader); err != nil { + return nil, ierrors.Wrap(err, "unable to read new stake end epoch in the diff") } - offset += 8 - - newVersionAndHashBytes := make([]byte, VersionAndHashSize) - if err = binary.Read(reader, binary.LittleEndian, newVersionAndHashBytes); err != nil { - return offset, ierrors.Wrap(err, "unable to read new version and hash bytes in the diff") + if d.NewLatestSupportedVersionAndHash, err = stream.ReadObject(reader, VersionAndHashSize, VersionAndHashFromBytes); err != nil { + return nil, ierrors.Wrap(err, "unable to read new latest supported version and hash in the diff") } - d.NewLatestSupportedVersionAndHash, _, err = VersionAndHashFromBytes(newVersionAndHashBytes) - if err != nil { - return offset, ierrors.Wrap(err, "unable to parse new version and hash bytes in the diff") + if d.PrevLatestSupportedVersionAndHash, err = stream.ReadObject(reader, VersionAndHashSize, VersionAndHashFromBytes); err != nil { + return nil, ierrors.Wrap(err, "unable to read prev latest supported version and hash in the diff") } - offset += len(newVersionAndHashBytes) - prevVersionAndHashBytes := make([]byte, VersionAndHashSize) - if err = binary.Read(reader, binary.LittleEndian, prevVersionAndHashBytes); err != nil { - return offset, ierrors.Wrap(err, "unable to read prev version and hash bytes in the diff") - } - d.PrevLatestSupportedVersionAndHash, _, err = VersionAndHashFromBytes(prevVersionAndHashBytes) - if err != nil { - return offset, ierrors.Wrap(err, "unable to parse prev version and hash bytes in the diff") - } - offset += len(prevVersionAndHashBytes) + return d, nil +} + +func AccountDiffFromBytes(b []byte) (*AccountDiff, int, error) { + reader := stream.NewByteReader(b) + + a, err := AccountDiffFromReader(reader) - return offset, nil + return a, reader.BytesRead(), err } func writeBlockIssuerKeys(byteBuffer *stream.ByteBuffer, blockIssuerKeys iotago.BlockIssuerKeys) error { @@ -238,18 +201,18 @@ func writeBlockIssuerKeys(byteBuffer *stream.ByteBuffer, blockIssuerKeys iotago. return ierrors.Wrap(err, "unable to encode blockIssuerKeys in the diff") } - if err := stream.WriteByteSlice(byteBuffer, blockIssuerKeysBytes, serializer.SeriLengthPrefixTypeAsUint64); err != nil { + if err := stream.WriteBytesWithSize(byteBuffer, blockIssuerKeysBytes, serializer.SeriLengthPrefixTypeAsUint64); err != nil { return ierrors.Wrap(err, "unable to write blockIssuerKeysBytes in the diff") } return nil } -func readBlockIssuerKeys(reader io.ReadSeeker) (iotago.BlockIssuerKeys, int, error) { +func readBlockIssuerKeys(reader io.Reader) (iotago.BlockIssuerKeys, int, error) { // TODO: improve this var bytesConsumed int - blockIssuerKeysBytes, err := stream.ReadByteSlice(reader, serializer.SeriLengthPrefixTypeAsUint64) + blockIssuerKeysBytes, err := stream.ReadBytesWithSize(reader, serializer.SeriLengthPrefixTypeAsUint64) if err != nil { return nil, bytesConsumed, ierrors.Wrap(err, "unable to read blockIssuerKeysBytes in the diff") } diff --git a/pkg/protocol/engine/accounts/accounts.go b/pkg/protocol/engine/accounts/accounts.go index 8a30080e2..0ff70bd94 100644 --- a/pkg/protocol/engine/accounts/accounts.go +++ b/pkg/protocol/engine/accounts/accounts.go @@ -1,13 +1,11 @@ package accounts import ( - "bytes" "encoding/binary" "io" "github.com/iotaledger/hive.go/crypto/ed25519" "github.com/iotaledger/hive.go/ierrors" - "github.com/iotaledger/hive.go/lo" "github.com/iotaledger/hive.go/runtime/options" "github.com/iotaledger/hive.go/serializer/v2" "github.com/iotaledger/hive.go/serializer/v2/stream" @@ -79,126 +77,94 @@ func (a *AccountData) Clone() *AccountData { } } -func (a *AccountData) FromBytes(b []byte) (int, error) { - return a.readFromReadSeeker(bytes.NewReader(b)) -} - -func (a *AccountData) FromReader(readSeeker io.ReadSeeker) error { - return lo.Return2(a.readFromReadSeeker(readSeeker)) -} +func AccountDataFromReader(reader io.Reader) (*AccountData, error) { -func (a *AccountData) readFromReadSeeker(reader io.ReadSeeker) (int, error) { - // TODO: improve this - var bytesConsumed int - - bytesRead, err := io.ReadFull(reader, a.ID[:]) + accountID, err := stream.Read[iotago.AccountID](reader) if err != nil { - return bytesConsumed, ierrors.Wrap(err, "unable to read accountID") + return nil, ierrors.Wrap(err, "unable to read accountID") } - bytesConsumed += bytesRead - - a.Credits = &BlockIssuanceCredits{} - - if err := binary.Read(reader, binary.LittleEndian, &a.Credits.Value); err != nil { - return bytesConsumed, ierrors.Wrapf(err, "unable to read account balance value for accountID %s", a.ID) - } - bytesConsumed += 8 - - if err := binary.Read(reader, binary.LittleEndian, &a.Credits.UpdateSlot); err != nil { - return bytesConsumed, ierrors.Wrapf(err, "unable to read updatedTime for account balance for accountID %s", a.ID) - } - bytesConsumed += iotago.SlotIndexLength + a := NewAccountData(accountID) - if err := binary.Read(reader, binary.LittleEndian, &a.ExpirySlot); err != nil { - return bytesConsumed, ierrors.Wrapf(err, "unable to read expiry slot for accountID %s", a.ID) + if a.Credits, err = stream.ReadObject(reader, BlockIssuanceCreditsBytesLength, BlockIssuanceCreditsFromBytes); err != nil { + return nil, ierrors.Wrap(err, "unable to read credits") } - bytesConsumed += iotago.SlotIndexLength - - if err := binary.Read(reader, binary.LittleEndian, &a.OutputID); err != nil { - return bytesConsumed, ierrors.Wrapf(err, "unable to read outputID for accountID %s", a.ID) + if a.ExpirySlot, err = stream.Read[iotago.SlotIndex](reader); err != nil { + return nil, ierrors.Wrap(err, "unable to read expiry slot") } - bytesConsumed += iotago.OutputIDLength - - var blockIssuerKeyCount uint8 - if err := binary.Read(reader, binary.LittleEndian, &blockIssuerKeyCount); err != nil { - return bytesConsumed, ierrors.Wrapf(err, "unable to read blockIssuerKeyCount count for accountID %s", a.ID) + if a.OutputID, err = stream.Read[iotago.OutputID](reader); err != nil { + return nil, ierrors.Wrap(err, "unable to read outputID") } - bytesConsumed++ - a.BlockIssuerKeys = iotago.NewBlockIssuerKeys() - for i := uint8(0); i < blockIssuerKeyCount; i++ { + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsByte, func(i int) error { + // TODO: improve this var blockIssuerKeyType iotago.BlockIssuerKeyType if err := binary.Read(reader, binary.LittleEndian, &blockIssuerKeyType); err != nil { - return bytesConsumed, ierrors.Wrapf(err, "unable to read block issuer key type for accountID %s", a.ID) + return ierrors.Wrapf(err, "unable to read block issuer key type for accountID %s", a.ID) } - bytesConsumed++ switch blockIssuerKeyType { case iotago.BlockIssuerKeyEd25519PublicKey: var ed25519PublicKey ed25519.PublicKey - bytesRead, err = io.ReadFull(reader, ed25519PublicKey[:]) + _, err = io.ReadFull(reader, ed25519PublicKey[:]) if err != nil { - return bytesConsumed, ierrors.Wrapf(err, "unable to read public key index %d for accountID %s", i, a.ID) + return ierrors.Wrapf(err, "unable to read public key index %d for accountID %s", i, a.ID) } - bytesConsumed += bytesRead a.BlockIssuerKeys.Add(iotago.Ed25519PublicKeyBlockIssuerKeyFromPublicKey(ed25519PublicKey)) case iotago.BlockIssuerKeyPublicKeyHash: var implicitAccountCreationAddress iotago.ImplicitAccountCreationAddress - bytesRead, err = io.ReadFull(reader, implicitAccountCreationAddress[:]) + _, err = io.ReadFull(reader, implicitAccountCreationAddress[:]) if err != nil { - return bytesConsumed, ierrors.Wrapf(err, "unable to read address %d for accountID %s", i, a.ID) + return ierrors.Wrapf(err, "unable to read address %d for accountID %s", i, a.ID) } - bytesConsumed += bytesRead a.BlockIssuerKeys.Add(iotago.Ed25519PublicKeyHashBlockIssuerKeyFromImplicitAccountCreationAddress(&implicitAccountCreationAddress)) default: - return bytesConsumed, ierrors.Wrapf(err, "unsupported block issuer key type %d for accountID %s at offset %d", blockIssuerKeyType, a.ID, i) + return ierrors.Wrapf(err, "unsupported block issuer key type %d for accountID %s at offset %d", blockIssuerKeyType, a.ID, i) } - } - if err := binary.Read(reader, binary.LittleEndian, &(a.ValidatorStake)); err != nil { - return bytesConsumed, ierrors.Wrapf(err, "unable to read validator stake for accountID %s", a.ID) + return nil + }); err != nil { + return nil, ierrors.Wrap(err, "unable to read block issuer keys") } - bytesConsumed += iotago.BaseTokenSize - if err := binary.Read(reader, binary.LittleEndian, &(a.DelegationStake)); err != nil { - return bytesConsumed, ierrors.Wrapf(err, "unable to read delegation stake for accountID %s", a.ID) + if a.ValidatorStake, err = stream.Read[iotago.BaseToken](reader); err != nil { + return nil, ierrors.Wrap(err, "unable to read validator stake") } - bytesConsumed += iotago.BaseTokenSize - if err := binary.Read(reader, binary.LittleEndian, &(a.FixedCost)); err != nil { - return bytesConsumed, ierrors.Wrapf(err, "unable to read fixed cost for accountID %s", a.ID) + if a.DelegationStake, err = stream.Read[iotago.BaseToken](reader); err != nil { + return nil, ierrors.Wrap(err, "unable to read delegation stake") } - bytesConsumed += iotago.ManaSize - if err := binary.Read(reader, binary.LittleEndian, &(a.StakeEndEpoch)); err != nil { - return bytesConsumed, ierrors.Wrapf(err, "unable to read stake end epoch for accountID %s", a.ID) + if a.FixedCost, err = stream.Read[iotago.Mana](reader); err != nil { + return nil, ierrors.Wrap(err, "unable to read fixed cost") } - bytesConsumed += iotago.EpochIndexLength - versionAndHashBytes := make([]byte, model.VersionAndHashSize) - if err := binary.Read(reader, binary.LittleEndian, versionAndHashBytes); err != nil { - return bytesConsumed, ierrors.Wrapf(err, "unable to read latest supported protocol version for accountID %s", a.ID) + if a.StakeEndEpoch, err = stream.Read[iotago.EpochIndex](reader); err != nil { + return nil, ierrors.Wrap(err, "unable to read stake end epoch") } - if a.LatestSupportedProtocolVersionAndHash, _, err = model.VersionAndHashFromBytes(versionAndHashBytes[:]); err != nil { - return 0, err + if a.LatestSupportedProtocolVersionAndHash, err = stream.ReadObject(reader, model.VersionAndHashSize, model.VersionAndHashFromBytes); err != nil { + return nil, ierrors.Wrap(err, "unable to read latest supported protocol version and hash") } - bytesConsumed += len(versionAndHashBytes) + return a, nil +} - return bytesConsumed, nil +func AccountDataFromBytes(b []byte) (*AccountData, int, error) { + reader := stream.NewByteReader(b) + + a, err := AccountDataFromReader(reader) + + return a, reader.BytesRead(), err } -func (a AccountData) Bytes() ([]byte, error) { +func (a *AccountData) Bytes() ([]byte, error) { byteBuffer := stream.NewByteBuffer() if err := stream.Write(byteBuffer, a.ID); err != nil { return nil, ierrors.Wrap(err, "failed to write AccountID") } - if err := stream.WriteFixedSizeObject(byteBuffer, a.Credits, BlockIssuanceCreditsBytesLength, func(credits *BlockIssuanceCredits) ([]byte, error) { - return credits.Bytes() - }); err != nil { + if err := stream.WriteObject(byteBuffer, a.Credits, (*BlockIssuanceCredits).Bytes); err != nil { return nil, ierrors.Wrap(err, "failed to write Credits") } if err := stream.Write(byteBuffer, a.ExpirySlot); err != nil { @@ -233,9 +199,7 @@ func (a AccountData) Bytes() ([]byte, error) { if err := stream.Write(byteBuffer, a.StakeEndEpoch); err != nil { return nil, ierrors.Wrap(err, "failed to write StakeEndEpoch") } - if err := stream.WriteFixedSizeObject(byteBuffer, a.LatestSupportedProtocolVersionAndHash, model.VersionAndHashSize, func(versionAndHash model.VersionAndHash) ([]byte, error) { - return versionAndHash.Bytes() - }); err != nil { + if err := stream.WriteObject(byteBuffer, a.LatestSupportedProtocolVersionAndHash, model.VersionAndHash.Bytes); err != nil { return nil, ierrors.Wrap(err, "failed to write LatestSupportedProtocolVersionAndHash") } diff --git a/pkg/protocol/engine/accounts/accountsledger/manager.go b/pkg/protocol/engine/accounts/accountsledger/manager.go index 01b48ce58..c30643a64 100644 --- a/pkg/protocol/engine/accounts/accountsledger/manager.go +++ b/pkg/protocol/engine/accounts/accountsledger/manager.go @@ -65,12 +65,8 @@ func New( iotago.AccountID.Bytes, iotago.AccountIDFromBytes, (*accounts.AccountData).Bytes, - func(bytes []byte) (object *accounts.AccountData, consumed int, err error) { - a := new(accounts.AccountData) - consumed, err = a.FromBytes(bytes) - - return a, consumed, err - }), + accounts.AccountDataFromBytes, + ), block: blockFunc, slotDiff: slotDiffFunc, } diff --git a/pkg/protocol/engine/accounts/accountsledger/snapshot.go b/pkg/protocol/engine/accounts/accountsledger/snapshot.go index 8f8d565c4..de3dbe89a 100644 --- a/pkg/protocol/engine/accounts/accountsledger/snapshot.go +++ b/pkg/protocol/engine/accounts/accountsledger/snapshot.go @@ -1,14 +1,14 @@ package accountsledger import ( - "encoding/binary" "io" "github.com/iotaledger/hive.go/ierrors" "github.com/iotaledger/hive.go/lo" + "github.com/iotaledger/hive.go/serializer/v2" + "github.com/iotaledger/hive.go/serializer/v2/stream" "github.com/iotaledger/iota-core/pkg/model" "github.com/iotaledger/iota-core/pkg/protocol/engine/accounts" - "github.com/iotaledger/iota-core/pkg/utils" iotago "github.com/iotaledger/iota.go/v4" ) @@ -16,24 +16,23 @@ func (m *Manager) Import(reader io.ReadSeeker) error { m.mutex.Lock() defer m.mutex.Unlock() - var accountCount uint64 - var slotDiffCount uint64 - - // The number of accounts contained within this snapshot. - if err := binary.Read(reader, binary.LittleEndian, &accountCount); err != nil { - return ierrors.Wrap(err, "unable to read account count") - } + // populate the account tree, account tree should be empty at this point + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(i int) error { + accountData, err := stream.ReadObjectFromReader(reader, accounts.AccountDataFromReader) + if err != nil { + return ierrors.Wrapf(err, "unable to read account data at index %d", i) + } - // The number of slot diffs contained within this snapshot. - if err := binary.Read(reader, binary.LittleEndian, &slotDiffCount); err != nil { - return ierrors.Wrap(err, "unable to read slot diffs count") - } + if err := m.accountsTree.Set(accountData.ID, accountData); err != nil { + return ierrors.Wrapf(err, "unable to set account %s", accountData.ID) + } - if err := m.importAccountTree(reader, accountCount); err != nil { - return ierrors.Wrap(err, "unable to import account tree") + return nil + }); err != nil { + return ierrors.Wrap(err, "failed to read account data") } - if err := m.readSlotDiffs(reader, slotDiffCount); err != nil { + if err := m.readSlotDiffs(reader); err != nil { return ierrors.Wrap(err, "unable to import slot diffs") } @@ -44,64 +43,42 @@ func (m *Manager) Export(writer io.WriteSeeker, targetIndex iotago.SlotIndex) er m.mutex.Lock() defer m.mutex.Unlock() - var accountCount uint64 - var slotDiffsCount uint64 - - pWriter := utils.NewPositionedWriter(writer) - - if err := pWriter.WriteValue("accounts count", accountCount, true); err != nil { - return ierrors.Wrap(err, "unable to write accounts count") - } - - if err := pWriter.WriteValue("slot diffs count", slotDiffsCount, true); err != nil { - return ierrors.Wrap(err, "unable to write slot diffs count") - } - - accountCount, err := m.exportAccountTree(pWriter, targetIndex) - if err != nil { - return ierrors.Wrapf(err, "unable to export account for target index %d", targetIndex) - } - - if err = pWriter.WriteValueAtBookmark("accounts count", accountCount); err != nil { - return ierrors.Wrap(err, "unable to write accounts count") - } - - if slotDiffsCount, err = m.writeSlotDiffs(pWriter, targetIndex); err != nil { - return ierrors.Wrapf(err, "unable to export slot diffs for target index %d", targetIndex) - } + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (int, error) { + elements, err := m.exportAccountTree(writer, targetIndex) + if err != nil { + return 0, ierrors.Wrap(err, "can't write account tree") + } - if err = pWriter.WriteValueAtBookmark("slot diffs count", slotDiffsCount); err != nil { - return ierrors.Wrap(err, "unable to write slot diffs count") + return elements, nil + }); err != nil { + return ierrors.Wrapf(err, "unable to export accounts for slot %d", targetIndex) } - return nil -} - -func (m *Manager) importAccountTree(reader io.ReadSeeker, accountCount uint64) error { - // populate the account tree, account tree should be empty at this point - for i := uint64(0); i < accountCount; i++ { - accountData := &accounts.AccountData{} - if err := accountData.FromReader(reader); err != nil { - return ierrors.Wrap(err, "unable to read account data") + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (elementsCount int, err error) { + elementsCount, err = m.writeSlotDiffs(writer, targetIndex) + if err != nil { + return 0, ierrors.Wrap(err, "can't write slot diffs") } - if err := m.accountsTree.Set(accountData.ID, accountData); err != nil { - return ierrors.Wrapf(err, "unable to set account %s", accountData.ID) - } + return elementsCount, nil + }); err != nil { + return ierrors.Wrapf(err, "unable to export slot diffs for slot %d", targetIndex) } return nil } // exportAccountTree exports the AccountTree at a certain target slot, returning the total amount of exported accounts. -func (m *Manager) exportAccountTree(pWriter *utils.PositionedWriter, targetIndex iotago.SlotIndex) (accountCount uint64, err error) { - if err = m.accountsTree.Stream(func(accountID iotago.AccountID, accountData *accounts.AccountData) error { - if _, err = m.rollbackAccountTo(accountData, targetIndex); err != nil { +func (m *Manager) exportAccountTree(writer io.WriteSeeker, targetIndex iotago.SlotIndex) (int, error) { + var accountCount int + + if err := m.accountsTree.Stream(func(accountID iotago.AccountID, accountData *accounts.AccountData) error { + if _, err := m.rollbackAccountTo(accountData, targetIndex); err != nil { return ierrors.Wrapf(err, "unable to rollback account %s", accountID) } - if err = writeAccountData(pWriter, accountData); err != nil { - return ierrors.Wrapf(err, "unable to write data for account %s", accountID) + if err := stream.WriteObject(writer, accountData, (*accounts.AccountData).Bytes); err != nil { + return ierrors.Wrapf(err, "unable to write account %s", accountID) } accountCount++ @@ -112,17 +89,18 @@ func (m *Manager) exportAccountTree(pWriter *utils.PositionedWriter, targetIndex } // we might have entries that were destroyed, that are present in diffs but not in the tree from the latestCommittedIndex we streamed above - recreatedAccountsCount, err := m.recreateDestroyedAccounts(pWriter, targetIndex) + recreatedAccountsCount, err := m.recreateDestroyedAccounts(writer, targetIndex) return accountCount + recreatedAccountsCount, err } -func (m *Manager) recreateDestroyedAccounts(pWriter *utils.PositionedWriter, targetSlot iotago.SlotIndex) (recreatedAccountsCount uint64, err error) { +func (m *Manager) recreateDestroyedAccounts(writer io.WriteSeeker, targetSlot iotago.SlotIndex) (int, error) { + var recreatedAccountsCount int destroyedAccounts := make(map[iotago.AccountID]*accounts.AccountData) for slot := m.latestCommittedSlot; slot > targetSlot; slot-- { // it should be impossible that `m.slotDiff(slot)` returns an error, because it is impossible to export a pruned slot - err = lo.PanicOnErr(m.slotDiff(slot)).StreamDestroyed(func(accountID iotago.AccountID) bool { + err := lo.PanicOnErr(m.slotDiff(slot)).StreamDestroyed(func(accountID iotago.AccountID) bool { // actual data will be filled in by rollbackAccountTo accountData := accounts.NewAccountData(accountID) @@ -143,136 +121,127 @@ func (m *Manager) recreateDestroyedAccounts(pWriter *utils.PositionedWriter, tar return 0, ierrors.Errorf("account %s was not destroyed", accountID) } - if err = writeAccountData(pWriter, accountData); err != nil { - return 0, ierrors.Wrapf(err, "unable to write account %s to snapshot", accountID) + if err := stream.WriteObject(writer, accountData, (*accounts.AccountData).Bytes); err != nil { + return 0, ierrors.Wrapf(err, "unable to write account %s", accountID) } } return recreatedAccountsCount, nil } -func writeAccountData(writer *utils.PositionedWriter, accountData *accounts.AccountData) error { - accountBytes, err := accountData.Bytes() - if err != nil { - return ierrors.Wrapf(err, "unable to get account data snapshot bytes for accountID %s", accountData.ID) - } - - if err = writer.WriteBytes(accountBytes); err != nil { - return ierrors.Wrapf(err, "unable to write account data for accountID %s", accountData.ID) - } - - return nil -} - -func (m *Manager) readSlotDiffs(reader io.ReadSeeker, slotDiffCount uint64) error { - for i := uint64(0); i < slotDiffCount; i++ { - var slot iotago.SlotIndex - var accountsInDiffCount uint64 - - if err := binary.Read(reader, binary.LittleEndian, &slot); err != nil { - return ierrors.Wrap(err, "unable to read slot index") - } - - if err := binary.Read(reader, binary.LittleEndian, &accountsInDiffCount); err != nil { - return ierrors.Wrap(err, "unable to read accounts in diff count") - } - if accountsInDiffCount == 0 { - continue - } - - diffStore, err := m.slotDiff(slot) +func (m *Manager) readSlotDiffs(reader io.ReadSeeker) error { + // Read all the slots. + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(i int) error { + slot, err := stream.Read[iotago.SlotIndex](reader) if err != nil { - return ierrors.Errorf("unable to import account slot diffs for slot %d", slot) + return ierrors.Wrapf(err, "unable to read slot index at index %d", i) } - for j := uint64(0); j < accountsInDiffCount; j++ { - var accountID iotago.AccountID - if _, err := io.ReadFull(reader, accountID[:]); err != nil { + // Read all the slot diffs within each slot. + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(j int) error { + diffStore, err := m.slotDiff(slot) + if err != nil { + return ierrors.Wrapf(err, "unable to get account diff storage for slot %d", slot) + } + + accountID, err := stream.Read[iotago.AccountID](reader) + if err != nil { return ierrors.Wrapf(err, "unable to read accountID for index %d", j) } - var destroyed bool - if err := binary.Read(reader, binary.LittleEndian, &destroyed); err != nil { + destroyed, err := stream.Read[bool](reader) + if err != nil { return ierrors.Wrapf(err, "unable to read destroyed flag for accountID %s", accountID) } - accountDiff := model.NewAccountDiff() + var accountDiff *model.AccountDiff if !destroyed { - if err := accountDiff.FromReader(reader); err != nil { + if accountDiff, err = stream.ReadObjectFromReader(reader, model.AccountDiffFromReader); err != nil { return ierrors.Wrapf(err, "unable to read account diff for accountID %s", accountID) } + } else { + accountDiff = model.NewAccountDiff() } if err := diffStore.Store(accountID, accountDiff, destroyed); err != nil { return ierrors.Wrapf(err, "unable to store slot diff for accountID %s", accountID) } + + return nil + }); err != nil { + return ierrors.Wrapf(err, "unable to read accounts in diff count at index %d", i) } + + return nil + }); err != nil { + return ierrors.Wrap(err, "failed to read slot diffs") } return nil } -func (m *Manager) writeSlotDiffs(pWriter *utils.PositionedWriter, targetSlot iotago.SlotIndex) (slotDiffsCount uint64, err error) { +func (m *Manager) writeSlotDiffs(writer io.WriteSeeker, targetSlot iotago.SlotIndex) (int, error) { + var slotDiffsCount int + // write slot diffs until being able to reach targetSlot, where the exported tree is at slot := iotago.SlotIndex(1) maxCommittableAge := m.apiProvider.APIForSlot(targetSlot).ProtocolParameters().MaxCommittableAge() - if targetSlot > maxCommittableAge { slot = targetSlot - maxCommittableAge } for ; slot <= targetSlot; slot++ { - var accountsInDiffCount uint64 - - // The index of the slot diffs. - if err = pWriter.WriteValue("slot index", slot); err != nil { - return 0, err - } + var accountsInDiffCount int - // The number of account entries within this slot diff. - if err = pWriter.WriteValue("inDiff accounts count", accountsInDiffCount, true); err != nil { - return 0, err + if err := stream.Write(writer, slot); err != nil { + return 0, ierrors.Wrapf(err, "unable to write slot %d", slot) } - slotDiffsCount++ - - var innerErr error slotDiffs, err := m.slotDiff(slot) if err != nil { // if slot is already pruned, then don't write anything continue } - if err = slotDiffs.Stream(func(accountID iotago.AccountID, accountDiff *model.AccountDiff, destroyed bool) bool { - if err = pWriter.WriteBytes(lo.PanicOnErr(accountID.Bytes())); err != nil { - innerErr = ierrors.Wrapf(err, "unable to write accountID for account %s", accountID) - } + if err = stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (int, error) { + var innerErr error - if err = pWriter.WriteValue("destroyed flag", destroyed); err != nil { - innerErr = ierrors.Wrapf(err, "unable to write destroyed flag for account %s", accountID) - } + if err = slotDiffs.Stream(func(accountID iotago.AccountID, accountDiff *model.AccountDiff, destroyed bool) bool { - if !destroyed { - if err = pWriter.WriteBytes(lo.PanicOnErr(accountDiff.Bytes())); err != nil { - innerErr = ierrors.Wrapf(err, "unable to write account diff for account %s", accountID) + if err = stream.Write(writer, accountID); err != nil { + innerErr = ierrors.Wrapf(err, "unable to write accountID for account %s", accountID) + return false + } + + if err = stream.Write(writer, destroyed); err != nil { + innerErr = ierrors.Wrapf(err, "unable to write destroyed flag for account %s", accountID) + return false + } + + if !destroyed { + if err = stream.WriteObject(writer, accountDiff, (*model.AccountDiff).Bytes); err != nil { + innerErr = ierrors.Wrapf(err, "unable to write account diff for account %s", accountID) + return false + } } + + accountsInDiffCount++ + + return true + }); err != nil { + return 0, ierrors.Wrapf(err, "unable to stream slot diff for index %d", slot) } - accountsInDiffCount++ + if innerErr != nil { + return 0, ierrors.Wrapf(innerErr, "unable to stream slot diff for index %d", slot) + } - return true + return accountsInDiffCount, nil }); err != nil { - return 0, ierrors.Wrapf(err, "unable to stream slot diff for index %d", slot) + return 0, ierrors.Wrapf(err, "unable to write slot diff %d", slot) } - if innerErr != nil { - return 0, ierrors.Wrapf(innerErr, "unable to write slot diff for index %d", slot) - } - - // The number of diffs contained within this slot. - if err = pWriter.WriteValueAtBookmark("inDiff accounts count", accountsInDiffCount); err != nil { - return 0, err - } + slotDiffsCount++ } return slotDiffsCount, nil diff --git a/pkg/protocol/engine/accounts/credits.go b/pkg/protocol/engine/accounts/credits.go index 39d4d1b54..3d04118c3 100644 --- a/pkg/protocol/engine/accounts/credits.go +++ b/pkg/protocol/engine/accounts/credits.go @@ -7,7 +7,7 @@ import ( iotago "github.com/iotaledger/iota.go/v4" ) -const BlockIssuanceCreditsBytesLength = serializer.Int64ByteSize + serializer.UInt32ByteSize +const BlockIssuanceCreditsBytesLength = serializer.Int64ByteSize + iotago.SlotIndexLength // BlockIssuanceCredits is a weight annotated with the slot it was last updated in. type BlockIssuanceCredits struct { diff --git a/pkg/protocol/engine/ledger/ledger/ledger.go b/pkg/protocol/engine/ledger/ledger/ledger.go index a6c177204..0e5491ba4 100644 --- a/pkg/protocol/engine/ledger/ledger/ledger.go +++ b/pkg/protocol/engine/ledger/ledger/ledger.go @@ -656,7 +656,7 @@ func (l *Ledger) processStateDiffTransactions(stateDiff mempool.StateDiff) (spen } accountDiff.BICChange += iotago.BlockIssuanceCredits(allotment.Mana) - accountDiff.PreviousUpdatedTime = accountData.Credits.UpdateTime + accountDiff.PreviousUpdatedSlot = accountData.Credits.UpdateSlot // we are not transitioning the allotted account, so the new and previous expiry slots are the same accountDiff.PreviousExpirySlot = accountData.ExpirySlot diff --git a/pkg/protocol/sybilprotection/sybilprotectionv1/performance/snapshot.go b/pkg/protocol/sybilprotection/sybilprotectionv1/performance/snapshot.go index cf02cd05f..867ce0699 100644 --- a/pkg/protocol/sybilprotection/sybilprotectionv1/performance/snapshot.go +++ b/pkg/protocol/sybilprotection/sybilprotectionv1/performance/snapshot.go @@ -196,7 +196,7 @@ func (t *Tracker) importCommittees(reader io.ReadSeeker) error { return ierrors.Wrap(err, "unable to read epoch index") } - committee, _, err := account.AccountsFromReader(reader) + committee, err := account.AccountsFromReader(reader) if err != nil { return ierrors.Wrapf(err, "unable to read committee for the epoch index %d", epoch) } diff --git a/pkg/storage/prunable/slotstore/accountdiffs.go b/pkg/storage/prunable/slotstore/accountdiffs.go index 8aa889fa4..e04eb5242 100644 --- a/pkg/storage/prunable/slotstore/accountdiffs.go +++ b/pkg/storage/prunable/slotstore/accountdiffs.go @@ -31,19 +31,14 @@ func NewAccountDiffs(slot iotago.SlotIndex, store kvstore.KVStore, api iotago.AP iotago.AccountID.Bytes, iotago.AccountIDFromBytes, (*model.AccountDiff).Bytes, - func(bytes []byte) (object *model.AccountDiff, consumed int, err error) { - diff := new(model.AccountDiff) - n, err := diff.FromBytes(bytes) - - return diff, n, err - }), + model.AccountDiffFromBytes, + ), destroyedAccounts: kvstore.NewTypedStore[iotago.AccountID, types.Empty](lo.PanicOnErr(store.WithExtendedRealm(kvstore.Realm{destroyedAccountsPrefix})), iotago.AccountID.Bytes, iotago.AccountIDFromBytes, types.Empty.Bytes, - func(bytes []byte) (object types.Empty, consumed int, err error) { - return types.Void, 0, nil - }), + types.EmptyFromBytes, + ), } } From cd0292b9f41855370aab5020321e631dc9e76dd8 Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Wed, 1 Nov 2023 16:52:55 +0800 Subject: [PATCH 11/32] Remove PositionedWriter --- pkg/utils/ioutils.go | 58 -------------------------------------------- 1 file changed, 58 deletions(-) diff --git a/pkg/utils/ioutils.go b/pkg/utils/ioutils.go index 5c7d810b4..4d802a069 100644 --- a/pkg/utils/ioutils.go +++ b/pkg/utils/ioutils.go @@ -38,61 +38,3 @@ func WriteBytesFunc(writeSeeker io.WriteSeeker, bytes []byte, offsetsToIncrease return nil } - -type PositionedWriter struct { - bookmarks map[string]int64 - writer io.WriteSeeker -} - -func NewPositionedWriter(writer io.WriteSeeker) *PositionedWriter { - p := &PositionedWriter{ - bookmarks: make(map[string]int64), - writer: writer, - } - - return p -} - -func (p *PositionedWriter) WriteBytes(bytes []byte) error { - return WriteBytesFunc(p.writer, bytes) -} - -func (p *PositionedWriter) WriteValue(name string, value interface{}, saveBookmark ...bool) error { - if len(saveBookmark) > 0 && saveBookmark[0] { - currentPosition, err := p.writer.Seek(0, io.SeekCurrent) - if err != nil { - return err - } - p.bookmarks[name] = currentPosition - } - if err := WriteValueFunc(p.writer, value); err != nil { - return ierrors.Wrapf(err, "unable to write value %s", name) - } - - return nil -} - -func (p *PositionedWriter) WriteValueAtBookmark(name string, value interface{}) error { - bookmarkPosition, ok := p.bookmarks[name] - if !ok { - return ierrors.Errorf("unable to find saved position for bookmark %s", name) - } - originalPosition, err := p.writer.Seek(0, io.SeekCurrent) - if err != nil { - return ierrors.Wrap(err, "unable to obtain current seek position") - } - if bookmarkPosition >= originalPosition { - return ierrors.Errorf("cannot write into the future, current write position %d is greater than or equal to the bookmark position %d", originalPosition, bookmarkPosition) - } - if _, err := p.writer.Seek(bookmarkPosition, io.SeekStart); err != nil { - return ierrors.Wrapf(err, "unable to seek back to bookmark %s position", name) - } - if err := WriteValueFunc(p.writer, value); err != nil { - return ierrors.Wrapf(err, "unable to write value %s", name) - } - if _, err := p.writer.Seek(originalPosition, io.SeekStart); err != nil { - return ierrors.Wrap(err, "unable to seek to original position") - } - - return nil -} From 96763c3263afb6a1503f44145355f51633764238 Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Wed, 1 Nov 2023 16:53:58 +0800 Subject: [PATCH 12/32] Adjust ValidatorPerformance to use stream package instead of manual binary.Read and deprecated PositionedWriter --- pkg/model/poolstats.go | 58 ++- pkg/model/validator_performance.go | 59 ++- pkg/model/version_and_hash.go | 2 +- .../sybilprotectionv1/performance/snapshot.go | 431 ++++++++---------- .../performance/testsuite_test.go | 6 +- pkg/storage/prunable/prunable_slot.go | 8 +- 6 files changed, 286 insertions(+), 278 deletions(-) diff --git a/pkg/model/poolstats.go b/pkg/model/poolstats.go index 54dd23857..c18dc15da 100644 --- a/pkg/model/poolstats.go +++ b/pkg/model/poolstats.go @@ -1,6 +1,8 @@ package model import ( + "io" + "github.com/iotaledger/hive.go/ierrors" "github.com/iotaledger/hive.go/serializer/v2/stream" iotago "github.com/iotaledger/iota.go/v4" @@ -13,20 +15,29 @@ type PoolsStats struct { ProfitMargin uint64 } -func PoolsStatsFromBytes(bytes []byte) (*PoolsStats, int, error) { +func PoolStatsFromReader(reader io.Reader) (*PoolsStats, error) { p := new(PoolsStats) var err error - byteReader := stream.NewByteReader(bytes) - - if p.TotalStake, err = stream.Read[iotago.BaseToken](byteReader); err != nil { - return nil, 0, ierrors.Wrap(err, "failed to read TotalStake") + if p.TotalStake, err = stream.Read[iotago.BaseToken](reader); err != nil { + return nil, ierrors.Wrap(err, "failed to read TotalStake") + } + if p.TotalValidatorStake, err = stream.Read[iotago.BaseToken](reader); err != nil { + return nil, ierrors.Wrap(err, "failed to read TotalValidatorStake") } - if p.TotalValidatorStake, err = stream.Read[iotago.BaseToken](byteReader); err != nil { - return nil, 0, ierrors.Wrap(err, "failed to read TotalValidatorStake") + if p.ProfitMargin, err = stream.Read[uint64](reader); err != nil { + return nil, ierrors.Wrap(err, "failed to read ProfitMargin") } - if p.ProfitMargin, err = stream.Read[uint64](byteReader); err != nil { - return nil, 0, ierrors.Wrap(err, "failed to read ProfitMargin") + + return p, nil +} + +func PoolsStatsFromBytes(bytes []byte) (*PoolsStats, int, error) { + byteReader := stream.NewByteReader(bytes) + + p, err := PoolStatsFromReader(byteReader) + if err != nil { + return nil, 0, ierrors.Wrap(err, "failed to parse PoolStats") } return p, byteReader.BytesRead(), nil @@ -57,20 +68,29 @@ type PoolRewards struct { FixedCost iotago.Mana } -func PoolRewardsFromBytes(bytes []byte) (*PoolRewards, int, error) { - p := new(PoolRewards) - +func PoolRewardsFromReader(reader io.Reader) (*PoolRewards, error) { var err error - byteReader := stream.NewByteReader(bytes) + p := new(PoolRewards) - if p.PoolStake, err = stream.Read[iotago.BaseToken](byteReader); err != nil { - return nil, 0, ierrors.Wrap(err, "failed to read PoolStake") + if p.PoolStake, err = stream.Read[iotago.BaseToken](reader); err != nil { + return nil, ierrors.Wrap(err, "failed to read PoolStake") + } + if p.PoolRewards, err = stream.Read[iotago.Mana](reader); err != nil { + return nil, ierrors.Wrap(err, "failed to read PoolRewards") } - if p.PoolRewards, err = stream.Read[iotago.Mana](byteReader); err != nil { - return nil, 0, ierrors.Wrap(err, "failed to read PoolRewards") + if p.FixedCost, err = stream.Read[iotago.Mana](reader); err != nil { + return nil, ierrors.Wrap(err, "failed to read FixedCost") } - if p.FixedCost, err = stream.Read[iotago.Mana](byteReader); err != nil { - return nil, 0, ierrors.Wrap(err, "failed to read FixedCost") + + return p, nil +} + +func PoolRewardsFromBytes(bytes []byte) (*PoolRewards, int, error) { + byteReader := stream.NewByteReader(bytes) + + p, err := PoolRewardsFromReader(byteReader) + if err != nil { + return nil, 0, ierrors.Wrap(err, "failed to parse PoolRewards") } return p, byteReader.BytesRead(), nil diff --git a/pkg/model/validator_performance.go b/pkg/model/validator_performance.go index bd72a1be1..04ec5dbeb 100644 --- a/pkg/model/validator_performance.go +++ b/pkg/model/validator_performance.go @@ -1,15 +1,18 @@ package model import ( - iotago "github.com/iotaledger/iota.go/v4" + "io" + + "github.com/iotaledger/hive.go/ierrors" + "github.com/iotaledger/hive.go/serializer/v2/stream" ) type ValidatorPerformance struct { // works if ValidatorBlocksPerSlot is less than 32 because we use it as bit vector - SlotActivityVector uint32 `serix:"0"` + SlotActivityVector uint32 // can be uint8 because max count per slot is maximally ValidatorBlocksPerSlot + 1 - BlockIssuedCount uint8 `serix:"1"` - HighestSupportedVersionAndHash VersionAndHash `serix:"2"` + BlockIssuedCount uint8 + HighestSupportedVersionAndHash VersionAndHash } func NewValidatorPerformance() *ValidatorPerformance { @@ -20,18 +23,46 @@ func NewValidatorPerformance() *ValidatorPerformance { } } -func ValidatorPerformanceFromBytes(decodeAPI iotago.API) func([]byte) (*ValidatorPerformance, int, error) { - return func(bytes []byte) (*ValidatorPerformance, int, error) { - validatorPerformance := new(ValidatorPerformance) - consumedBytes, err := decodeAPI.Decode(bytes, validatorPerformance) - if err != nil { - return nil, 0, err - } +func ValidatorPerformanceFromBytes(bytes []byte) (*ValidatorPerformance, int, error) { + byteReader := stream.NewByteReader(bytes) + + v, err := ValidatorPerformanceFromReader(byteReader) + if err != nil { + return nil, 0, ierrors.Wrap(err, "failed to parse ValidatorPerformance") + } - return validatorPerformance, consumedBytes, nil + return v, byteReader.BytesRead(), nil +} + +func ValidatorPerformanceFromReader(reader io.Reader) (*ValidatorPerformance, error) { + var err error + v := NewValidatorPerformance() + + if v.SlotActivityVector, err = stream.Read[uint32](reader); err != nil { + return nil, ierrors.Wrap(err, "failed to read SlotActivityVector") + } + if v.BlockIssuedCount, err = stream.Read[uint8](reader); err != nil { + return nil, ierrors.Wrap(err, "failed to read BlockIssuedCount") } + if v.HighestSupportedVersionAndHash, err = stream.ReadObject(reader, VersionAndHashSize, VersionAndHashFromBytes); err != nil { + return nil, ierrors.Wrap(err, "failed to read HighestSupportedVersionAndHash") + } + + return v, nil } -func (p *ValidatorPerformance) Bytes(api iotago.API) ([]byte, error) { - return api.Encode(p) +func (p *ValidatorPerformance) Bytes() ([]byte, error) { + byteBuffer := stream.NewByteBuffer() + + if err := stream.Write(byteBuffer, p.SlotActivityVector); err != nil { + return nil, ierrors.Wrap(err, "failed to write SlotActivityVector") + } + if err := stream.Write(byteBuffer, p.BlockIssuedCount); err != nil { + return nil, ierrors.Wrap(err, "failed to write BlockIssuedCount") + } + if err := stream.WriteObject(byteBuffer, p.HighestSupportedVersionAndHash, VersionAndHash.Bytes); err != nil { + return nil, ierrors.Wrap(err, "failed to write HighestSupportedVersionAndHash") + } + + return byteBuffer.Bytes() } diff --git a/pkg/model/version_and_hash.go b/pkg/model/version_and_hash.go index 8475cc04c..46747799d 100644 --- a/pkg/model/version_and_hash.go +++ b/pkg/model/version_and_hash.go @@ -7,7 +7,7 @@ import ( iotago "github.com/iotaledger/iota.go/v4" ) -const VersionAndHashSize = iotago.IdentifierLength + iotago.VersionLength +const VersionAndHashSize = iotago.VersionLength + iotago.IdentifierLength type VersionAndHash struct { Version iotago.Version `serix:"0"` diff --git a/pkg/protocol/sybilprotection/sybilprotectionv1/performance/snapshot.go b/pkg/protocol/sybilprotection/sybilprotectionv1/performance/snapshot.go index 867ce0699..c75d49618 100644 --- a/pkg/protocol/sybilprotection/sybilprotectionv1/performance/snapshot.go +++ b/pkg/protocol/sybilprotection/sybilprotectionv1/performance/snapshot.go @@ -1,14 +1,14 @@ package performance import ( - "encoding/binary" "io" "github.com/iotaledger/hive.go/ierrors" "github.com/iotaledger/hive.go/lo" + "github.com/iotaledger/hive.go/serializer/v2" + "github.com/iotaledger/hive.go/serializer/v2/stream" "github.com/iotaledger/iota-core/pkg/core/account" "github.com/iotaledger/iota-core/pkg/model" - "github.com/iotaledger/iota-core/pkg/utils" iotago "github.com/iotaledger/iota.go/v4" ) @@ -46,26 +46,25 @@ func (t *Tracker) Export(writer io.WriteSeeker, targetSlotIndex iotago.SlotIndex timeProvider := t.apiProvider.APIForSlot(targetSlotIndex).TimeProvider() targetEpoch := timeProvider.EpochFromSlot(targetSlotIndex) - positionedWriter := utils.NewPositionedWriter(writer) // if the target index is the last slot of the epoch, the epoch was committed if timeProvider.EpochEnd(targetEpoch) != targetSlotIndex { targetEpoch-- } - if err := t.exportPerformanceFactor(positionedWriter, timeProvider.EpochStart(targetEpoch+1), targetSlotIndex); err != nil { + if err := t.exportPerformanceFactor(writer, timeProvider.EpochStart(targetEpoch+1), targetSlotIndex); err != nil { return ierrors.Wrap(err, "unable to export performance factor") } - if err := t.exportPoolRewards(positionedWriter, targetEpoch); err != nil { + if err := t.exportPoolRewards(writer, targetEpoch); err != nil { return ierrors.Wrap(err, "unable to export pool rewards") } - if err := t.exportPoolsStats(positionedWriter, targetEpoch); err != nil { + if err := t.exportPoolsStats(writer, targetEpoch); err != nil { return ierrors.Wrap(err, "unable to export pool stats") } - if err := t.exportCommittees(positionedWriter, targetSlotIndex); err != nil { + if err := t.exportCommittees(writer, targetSlotIndex); err != nil { return ierrors.Wrap(err, "unable to export committees") } @@ -73,20 +72,10 @@ func (t *Tracker) Export(writer io.WriteSeeker, targetSlotIndex iotago.SlotIndex } func (t *Tracker) importPerformanceFactor(reader io.ReadSeeker) error { - var slotCount uint64 - if err := binary.Read(reader, binary.LittleEndian, &slotCount); err != nil { - return ierrors.Wrap(err, "unable to read slot count") - } - - for i := uint64(0); i < slotCount; i++ { - var slot iotago.SlotIndex - if err := binary.Read(reader, binary.LittleEndian, &slot); err != nil { - return ierrors.Wrap(err, "unable to read slot index") - } - - var accountsCount uint64 - if err := binary.Read(reader, binary.LittleEndian, &accountsCount); err != nil { - return ierrors.Wrapf(err, "unable to read accounts count for slot index %d", slot) + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(i int) error { + slot, err := stream.Read[iotago.SlotIndex](reader) + if err != nil { + return ierrors.Wrapf(err, "unable to read slot index at index %d", i) } performanceFactors, err := t.validatorPerformancesFunc(slot) @@ -94,36 +83,37 @@ func (t *Tracker) importPerformanceFactor(reader io.ReadSeeker) error { return ierrors.Wrapf(err, "unable to get performance factors for slot index %d", slot) } - for j := uint64(0); j < accountsCount; j++ { - var accountID iotago.AccountID - if err = binary.Read(reader, binary.LittleEndian, &accountID); err != nil { - return ierrors.Wrapf(err, "unable to read account id for the slot index %d", slot) + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(j int) error { + accountID, err := stream.Read[iotago.AccountID](reader) + if err != nil { + return ierrors.Wrapf(err, "unable to read account id at index %d", j) } - - var performanceFactor model.ValidatorPerformance - if err = binary.Read(reader, binary.LittleEndian, &performanceFactor); err != nil { - return ierrors.Wrapf(err, "unable to read performance factor for account %s and slot index %d", accountID, slot) + performanceFactor, err := stream.ReadObjectFromReader(reader, model.ValidatorPerformanceFromReader) + if err != nil { + return ierrors.Wrapf(err, "unable to read performance factor for account %s and slot %d", accountID, slot) } - - if err = performanceFactors.Store(accountID, &performanceFactor); err != nil { + if err = performanceFactors.Store(accountID, performanceFactor); err != nil { return ierrors.Wrapf(err, "unable to store performance factor for account %s and slot index %d", accountID, slot) } + + return nil + }); err != nil { + return ierrors.Wrapf(err, "unable to read performance factors for slot %d", slot) } + + return nil + }); err != nil { + return ierrors.Wrap(err, "unable to read performance factors collection") } return nil } func (t *Tracker) importPoolRewards(reader io.ReadSeeker) error { - var epochCount uint64 - if err := binary.Read(reader, binary.LittleEndian, &epochCount); err != nil { - return ierrors.Wrap(err, "unable to read epoch count") - } - - for i := uint64(0); i < epochCount; i++ { - var epoch iotago.EpochIndex - if err := binary.Read(reader, binary.LittleEndian, &epoch); err != nil { - return ierrors.Wrap(err, "unable to read epoch index") + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(int) error { + epoch, err := stream.Read[iotago.EpochIndex](reader) + if err != nil { + return ierrors.Wrap(err, "unable to read epoch") } rewardsTree, err := t.rewardsMap(epoch) @@ -131,307 +121,280 @@ func (t *Tracker) importPoolRewards(reader io.ReadSeeker) error { return ierrors.Wrapf(err, "unable to get rewards tree for epoch index %d", epoch) } - var accountsCount uint64 - if err = binary.Read(reader, binary.LittleEndian, &accountsCount); err != nil { - return ierrors.Wrapf(err, "unable to read accounts count for epoch index %d", epoch) - } - - for j := uint64(0); j < accountsCount; j++ { - var accountID iotago.AccountID - if err = binary.Read(reader, binary.LittleEndian, &accountID); err != nil { - return ierrors.Wrapf(err, "unable to read account id for the epoch index %d", epoch) + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(int) error { + accountID, err := stream.Read[iotago.AccountID](reader) + if err != nil { + return ierrors.Wrap(err, "unable to read account id") } - var reward model.PoolRewards - if err = binary.Read(reader, binary.LittleEndian, &reward); err != nil { + reward, err := stream.ReadObjectFromReader(reader, model.PoolRewardsFromReader) + if err != nil { return ierrors.Wrapf(err, "unable to read reward for account %s and epoch index %d", accountID, epoch) } - if err = rewardsTree.Set(accountID, &reward); err != nil { + if err = rewardsTree.Set(accountID, reward); err != nil { return ierrors.Wrapf(err, "unable to set reward for account %s and epoch index %d", accountID, epoch) } + + return nil + }); err != nil { + return ierrors.Wrapf(err, "unable to read rewards collection for epoch %d", epoch) } - if err = rewardsTree.Commit(); err != nil { + if err := rewardsTree.Commit(); err != nil { return ierrors.Wrapf(err, "unable to commit rewards for epoch index %d", epoch) } + + return nil + }); err != nil { + return ierrors.Wrap(err, "unable to read pool rewards collection") } return nil } func (t *Tracker) importPoolsStats(reader io.ReadSeeker) error { - var epochCount uint64 - if err := binary.Read(reader, binary.LittleEndian, &epochCount); err != nil { - return ierrors.Wrap(err, "unable to read epoch count") - } - - for i := uint64(0); i < epochCount; i++ { - var epoch iotago.EpochIndex - if err := binary.Read(reader, binary.LittleEndian, &epoch); err != nil { - return ierrors.Wrap(err, "unable to read epoch index") + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(int) error { + epoch, err := stream.Read[iotago.EpochIndex](reader) + if err != nil { + return ierrors.Wrap(err, "unable to read epoch") } - var poolStats model.PoolsStats - if err := binary.Read(reader, binary.LittleEndian, &poolStats); err != nil { - return ierrors.Wrapf(err, "unable to read pool stats for epoch index %d", epoch) + poolStats, err := stream.ReadObjectFromReader(reader, model.PoolStatsFromReader) + if err != nil { + return ierrors.Wrapf(err, "unable to read pool stats for epoch %d", epoch) } - if err := t.poolStatsStore.Store(epoch, &poolStats); err != nil { + if err := t.poolStatsStore.Store(epoch, poolStats); err != nil { return ierrors.Wrapf(err, "unable to store pool stats for the epoch index %d", epoch) } + + return nil + }); err != nil { + return ierrors.Wrap(err, "unable to read pool stats collection") } return nil } func (t *Tracker) importCommittees(reader io.ReadSeeker) error { - var epochCount uint64 - if err := binary.Read(reader, binary.LittleEndian, &epochCount); err != nil { - return ierrors.Wrap(err, "unable to read committees epoch count") - } - for i := uint64(0); i < epochCount; i++ { - var epoch iotago.EpochIndex - if err := binary.Read(reader, binary.LittleEndian, &epoch); err != nil { + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(int) error { + epoch, err := stream.Read[iotago.EpochIndex](reader) + if err != nil { return ierrors.Wrap(err, "unable to read epoch index") } committee, err := account.AccountsFromReader(reader) if err != nil { - return ierrors.Wrapf(err, "unable to read committee for the epoch index %d", epoch) + return ierrors.Wrapf(err, "unable to read committee for the epoch %d", epoch) } if err = t.committeeStore.Store(epoch, committee); err != nil { return ierrors.Wrap(err, "unable to store committee") } + + return nil + }); err != nil { + return ierrors.Wrap(err, "unable to read committees collection") } return nil } -func (t *Tracker) exportPerformanceFactor(pWriter *utils.PositionedWriter, startSlot, targetSlot iotago.SlotIndex) error { +func (t *Tracker) exportPerformanceFactor(writer io.WriteSeeker, startSlot, targetSlot iotago.SlotIndex) error { t.performanceFactorsMutex.RLock() defer t.performanceFactorsMutex.RUnlock() - var slotCount uint64 - if err := pWriter.WriteValue("pf slot count", slotCount, true); err != nil { - return ierrors.Wrap(err, "unable to write pf slot count") - } + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (int, error) { + var slotCount int - for currentSlot := startSlot; currentSlot <= targetSlot; currentSlot++ { - if err := pWriter.WriteValue("slot index", currentSlot); err != nil { - return ierrors.Wrapf(err, "unable to write slot index %d", currentSlot) - } + for currentSlot := startSlot; currentSlot <= targetSlot; currentSlot++ { + if err := stream.Write(writer, currentSlot); err != nil { + return 0, ierrors.Wrapf(err, "unable to write slot index %d", currentSlot) + } - var accountsCount uint64 - if err := pWriter.WriteValue("pf account count", accountsCount, true); err != nil { - return ierrors.Wrapf(err, "unable to write pf accounts count for slot index %d", currentSlot) - } + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (int, error) { + var accountsCount int - performanceFactors, err := t.validatorPerformancesFunc(currentSlot) - if err != nil { - return ierrors.Wrapf(err, "unable to get performance factors for slot index %d", currentSlot) - } + performanceFactors, err := t.validatorPerformancesFunc(currentSlot) + if err != nil { + return 0, ierrors.Wrapf(err, "unable to get performance factors for slot index %d", currentSlot) + } - if err = performanceFactors.Stream(func(accountID iotago.AccountID, pf *model.ValidatorPerformance) error { - if err = pWriter.WriteValue("account id", accountID); err != nil { - return ierrors.Wrapf(err, "unable to write account id %s for slot %d", accountID, currentSlot) - } + if err = performanceFactors.Stream(func(accountID iotago.AccountID, pf *model.ValidatorPerformance) error { + if err := stream.Write(writer, accountID); err != nil { + return ierrors.Wrapf(err, "unable to write account id %s for slot %d", accountID, currentSlot) + } - bytes, err := t.apiProvider.APIForSlot(currentSlot).Encode(pf) - if err != nil { - return ierrors.Wrapf(err, "unable to encode performance factor for accountID %s and slot index %d", accountID, currentSlot) - } + if err := stream.WriteObject(writer, pf, (*model.ValidatorPerformance).Bytes); err != nil { + return ierrors.Wrapf(err, "unable to write performance factor for accountID %s and slot index %d", accountID, currentSlot) + } - if err = pWriter.WriteBytes(bytes); err != nil { - return ierrors.Wrapf(err, "unable to write performance factor for accountID %s and slot index %d", accountID, currentSlot) - } + accountsCount++ - accountsCount++ + return nil + }); err != nil { + return 0, ierrors.Wrapf(err, "unable to write performance factors for slot index %d", currentSlot) + } - return nil - }); err != nil { - return ierrors.Wrapf(err, "unable to write performance factors for slot index %d", currentSlot) - } + return accountsCount, nil + }); err != nil { + return 0, ierrors.Wrapf(err, "unable to write accounts for slot %d", currentSlot) + } - if err = pWriter.WriteValueAtBookmark("pf account count", accountsCount); err != nil { - return ierrors.Wrap(err, "unable to write pf accounts count") + slotCount++ } - slotCount++ - } - - if err := pWriter.WriteValueAtBookmark("pf slot count", slotCount); err != nil { - return ierrors.Wrap(err, "unable to write pf slot count at bookmarked position") + return slotCount, nil + }); err != nil { + return ierrors.Wrap(err, "unable to write slot count") } return nil } -func (t *Tracker) exportPoolRewards(pWriter *utils.PositionedWriter, targetEpoch iotago.EpochIndex) error { +func (t *Tracker) exportPoolRewards(writer io.WriteSeeker, targetEpoch iotago.EpochIndex) error { // export all stored pools // in theory we could save the epoch count only once, because stats and rewards should be the same length - var epochCount uint64 - if err := pWriter.WriteValue("pool rewards epoch count", epochCount, true); err != nil { - return ierrors.Wrap(err, "unable to write epoch count") - } - for epoch := targetEpoch; epoch > iotago.EpochIndex(lo.Max(0, int(targetEpoch)-daysInYear)); epoch-- { - rewardsMap, err := t.rewardsMap(epoch) - if err != nil { - return ierrors.Wrapf(err, "unable to get rewards tree for epoch index %d", epoch) - } - // if the map was not present in storage we can skip this epoch and the previous ones, as we never stored any rewards - if !rewardsMap.WasRestoredFromStorage() { - break - } - - if err = pWriter.WriteValue("epoch index", epoch); err != nil { - return ierrors.Wrapf(err, "unable to write epoch index for epoch index %d", epoch) - } - - var accountCount uint64 - if err = pWriter.WriteValue("pool rewards account count", accountCount, true); err != nil { - return ierrors.Wrapf(err, "unable to write account count for epoch index %d", epoch) - } + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (int, error) { + var epochCount int - if err = rewardsMap.Stream(func(key iotago.AccountID, value *model.PoolRewards) error { - if err = pWriter.WriteValue("account id", key); err != nil { - return ierrors.Wrapf(err, "unable to write account id for epoch index %d and accountID %s", epoch, key) + for epoch := targetEpoch; epoch > iotago.EpochIndex(lo.Max(0, int(targetEpoch)-daysInYear)); epoch-- { + rewardsMap, err := t.rewardsMap(epoch) + if err != nil { + return 0, ierrors.Wrapf(err, "unable to get rewards tree for epoch %d", epoch) + } + // if the map was not present in storage we can skip this epoch and the previous ones, as we never stored any rewards + if !rewardsMap.WasRestoredFromStorage() { + break } - if err = pWriter.WriteValue("account rewards", value); err != nil { - return ierrors.Wrapf(err, "unable to write account rewards for epoch index %d and accountID %s", epoch, key) + if err := stream.Write(writer, epoch); err != nil { + return 0, ierrors.Wrapf(err, "unable to write epoch index for epoch index %d", epoch) } - accountCount++ + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (int, error) { + var accountCount int - return nil - }); err != nil { - return ierrors.Wrapf(err, "unable to stream rewards for epoch index %d", epoch) - } + if err = rewardsMap.Stream(func(key iotago.AccountID, value *model.PoolRewards) error { + if err := stream.Write(writer, key); err != nil { + return ierrors.Wrapf(err, "unable to write account id for epoch %d and accountID %s", epoch, key) + } - if err = pWriter.WriteValueAtBookmark("pool rewards account count", accountCount); err != nil { - return ierrors.Wrapf(err, "unable to write account count for epoch index %d at bookmarked position", epoch) - } + if err := stream.WriteObject(writer, value, (*model.PoolRewards).Bytes); err != nil { + return ierrors.Wrapf(err, "unable to write account rewards for epoch index %d and accountID %s", epoch, key) + } - epochCount++ - } + accountCount++ - if err := pWriter.WriteValueAtBookmark("pool rewards epoch count", epochCount); err != nil { - return ierrors.Wrap(err, "unable to write epoch count at bookmarked position") + return nil + }); err != nil { + return 0, ierrors.Wrapf(err, "unable to stream rewards for epoch index %d", epoch) + } + + return accountCount, nil + }); err != nil { + return 0, ierrors.Wrapf(err, "unable to write rewards for epoch index %d", epoch) + } + + epochCount++ + } + + return epochCount, nil + }); err != nil { + return ierrors.Wrap(err, "unable to write pool rewards collection") } return nil } -func (t *Tracker) exportPoolsStats(pWriter *utils.PositionedWriter, targetEpoch iotago.EpochIndex) error { - var epochCount uint64 - if err := pWriter.WriteValue("pools stats epoch count", epochCount, true); err != nil { - return ierrors.Wrap(err, "unable to write epoch count") - } - // export all stored pools - var innerErr error - if err := t.poolStatsStore.StreamBytes(func(key []byte, value []byte) error { - epoch, _, err := iotago.EpochIndexFromBytes(key) - if err != nil { - innerErr = err +func (t *Tracker) exportPoolsStats(writer io.WriteSeeker, targetEpoch iotago.EpochIndex) error { + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (int, error) { + var epochCount int - return innerErr - } + // export all stored pools + if err := t.poolStatsStore.StreamBytes(func(key []byte, value []byte) error { + epoch, _, err := iotago.EpochIndexFromBytes(key) + if err != nil { + return err + } - if epoch > targetEpoch { - // continue - return nil - } - if err := pWriter.WriteBytes(key); err != nil { - innerErr = ierrors.Wrapf(err, "unable to write epoch index %d", epoch) + if epoch > targetEpoch { + // continue + return nil + } - return innerErr - } + if err := stream.WriteBytes(writer, key); err != nil { + return ierrors.Wrapf(err, "unable to write epoch index %d", epoch) + } + + if err := stream.WriteBytes(writer, value); err != nil { + return ierrors.Wrapf(err, "unable to write pools stats for epoch %d", epoch) + } - if err := pWriter.WriteBytes(value); err != nil { - innerErr = ierrors.Wrapf(err, "unable to write pools stats for epoch %d", epoch) + epochCount++ - return innerErr + return nil + }); err != nil { + return 0, ierrors.Wrap(err, "unable to iterate over pools stats") } - epochCount++ - - return nil + return epochCount, nil }); err != nil { - return ierrors.Wrap(err, "unable to iterate over pools stats") - } else if innerErr != nil { - return ierrors.Wrap(innerErr, "error while iterating over pools stats") - } - if err := pWriter.WriteValueAtBookmark("pools stats epoch count", epochCount); err != nil { - return ierrors.Wrap(err, "unable to write stats epoch count at bookmarked position") + return ierrors.Wrap(err, "unable to write pool stats collection") } return nil } -func (t *Tracker) exportCommittees(pWriter *utils.PositionedWriter, targetSlot iotago.SlotIndex) error { - var epochCount uint64 - if err := pWriter.WriteValue("committees epoch count", epochCount, true); err != nil { - return ierrors.Wrap(err, "unable to write committees epoch count") - } - +func (t *Tracker) exportCommittees(writer io.WriteSeeker, targetSlot iotago.SlotIndex) error { apiForSlot := t.apiProvider.APIForSlot(targetSlot) epochFromTargetSlot := apiForSlot.TimeProvider().EpochFromSlot(targetSlot) pointOfNoReturn := apiForSlot.TimeProvider().EpochEnd(epochFromTargetSlot) - apiForSlot.ProtocolParameters().MaxCommittableAge() - var innerErr error - err := t.committeeStore.StreamBytes(func(epochBytes []byte, committeeBytes []byte) error { - epoch, _, err := iotago.EpochIndexFromBytes(epochBytes) - if err != nil { - innerErr = err - - return innerErr - } + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (int, error) { + var epochCount int - // We have a committee for an epoch higher than the targetSlot - // 1. we trust the point of no return, we export the committee for the next epoch - // 2. if we don't trust the point-of-no-return - // - we were able to rotate a committee, then we export it - // - we were not able to rotate a committee (reused), then we don't export it - if epoch > epochFromTargetSlot && targetSlot < pointOfNoReturn { - committee, _, err := account.AccountsFromBytes(committeeBytes) + if err := t.committeeStore.StreamBytes(func(epochBytes []byte, committeeBytes []byte) error { + epoch, _, err := iotago.EpochIndexFromBytes(epochBytes) if err != nil { - innerErr = ierrors.Wrapf(err, "failed to parse committee bytes for epoch %d", epoch) - - return innerErr + return err } - if committee.IsReused() { - return nil + + // We have a committee for an epoch higher than the targetSlot + // 1. we trust the point of no return, we export the committee for the next epoch + // 2. if we don't trust the point-of-no-return + // - we were able to rotate a committee, then we export it + // - we were not able to rotate a committee (reused), then we don't export it + if epoch > epochFromTargetSlot && targetSlot < pointOfNoReturn { + committee, _, err := account.AccountsFromBytes(committeeBytes) + if err != nil { + return ierrors.Wrapf(err, "failed to parse committee bytes for epoch %d", epoch) + } + if committee.IsReused() { + return nil + } } - } - if err := pWriter.WriteBytes(epochBytes); err != nil { - innerErr = ierrors.Wrap(err, "unable to write epoch index") + if err := stream.WriteBytes(writer, epochBytes); err != nil { + return ierrors.Wrapf(err, "unable to write epoch index %d", epoch) + } + if err := stream.WriteBytes(writer, committeeBytes); err != nil { + return ierrors.Wrapf(err, "unable to write committee for epoch %d", epoch) + } - return innerErr - } - if err := pWriter.WriteBytes(committeeBytes); err != nil { - innerErr = ierrors.Wrap(err, "unable to write epoch committee") + epochCount++ - return innerErr + return nil + }); err != nil { + return 0, ierrors.Wrap(err, "unable to iterate over committee base store") } - epochCount++ - - return nil - }) - if err != nil { - return ierrors.Wrapf(err, "unable to iterate over committee base store: %w", innerErr) - } - if innerErr != nil { - return ierrors.Wrap(err, "error while iterating over committee base store") - } - - if err = pWriter.WriteValueAtBookmark("committees epoch count", epochCount); err != nil { - return ierrors.Wrap(err, "unable to write committee epoch count at bookmarked position") + return epochCount, nil + }); err != nil { + return ierrors.Wrap(err, "unable to write committees collection") } return nil diff --git a/pkg/protocol/sybilprotection/sybilprotectionv1/performance/testsuite_test.go b/pkg/protocol/sybilprotection/sybilprotectionv1/performance/testsuite_test.go index 684e21916..91f481481 100644 --- a/pkg/protocol/sybilprotection/sybilprotectionv1/performance/testsuite_test.go +++ b/pkg/protocol/sybilprotection/sybilprotectionv1/performance/testsuite_test.go @@ -61,10 +61,8 @@ func (t *TestSuite) InitPerformanceTracker() { p := slotstore.NewStore(slot, prunableStores[slot], iotago.AccountID.Bytes, iotago.AccountIDFromBytes, - func(s *model.ValidatorPerformance) ([]byte, error) { - return s.Bytes(t.api) - }, - model.ValidatorPerformanceFromBytes(t.api), + (*model.ValidatorPerformance).Bytes, + model.ValidatorPerformanceFromBytes, ) return p, nil diff --git a/pkg/storage/prunable/prunable_slot.go b/pkg/storage/prunable/prunable_slot.go index 0549278b8..9297c5977 100644 --- a/pkg/storage/prunable/prunable_slot.go +++ b/pkg/storage/prunable/prunable_slot.go @@ -82,15 +82,11 @@ func (p *Prunable) ValidatorPerformances(slot iotago.SlotIndex) (*slotstore.Stor return nil, ierrors.Wrapf(database.ErrEpochPruned, "could not get performance factors with slot %d", slot) } - apiForSlot := p.apiProvider.APIForSlot(slot) - return slotstore.NewStore(slot, kv, iotago.AccountID.Bytes, iotago.AccountIDFromBytes, - func(s *model.ValidatorPerformance) ([]byte, error) { - return s.Bytes(apiForSlot) - }, - model.ValidatorPerformanceFromBytes(apiForSlot), + (*model.ValidatorPerformance).Bytes, + model.ValidatorPerformanceFromBytes, ), nil } From 0c643cf5428b2c8aa4284ba17dfc77fa8ee2dde9 Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Thu, 2 Nov 2023 12:37:43 +0800 Subject: [PATCH 13/32] Make (de)serialization of BlockIssuerKeys consistent using new methods from iota.go --- pkg/model/account_diff.go | 57 +++------------------ pkg/model/poolstats.go | 4 +- pkg/model/validator_performance.go | 2 +- pkg/protocol/engine/accounts/accounts.go | 46 ++--------------- pkg/protocol/engine/utxoledger/slot_diff.go | 4 +- 5 files changed, 15 insertions(+), 98 deletions(-) diff --git a/pkg/model/account_diff.go b/pkg/model/account_diff.go index 9ded15b89..80647fb5e 100644 --- a/pkg/model/account_diff.go +++ b/pkg/model/account_diff.go @@ -1,12 +1,10 @@ package model import ( - "context" "io" "github.com/iotaledger/hive.go/ierrors" "github.com/iotaledger/hive.go/lo" - "github.com/iotaledger/hive.go/serializer/v2" "github.com/iotaledger/hive.go/serializer/v2/stream" iotago "github.com/iotaledger/iota.go/v4" ) @@ -98,11 +96,11 @@ func (d *AccountDiff) Bytes() ([]byte, error) { return nil, ierrors.Wrap(err, "unable to write PreviousOutputID in the diff") } - if err := writeBlockIssuerKeys(byteBuffer, d.BlockIssuerKeysAdded); err != nil { - return nil, err + if err := stream.WriteObject(byteBuffer, d.BlockIssuerKeysAdded, iotago.BlockIssuerKeys.Bytes); err != nil { + return nil, ierrors.Wrap(err, "unable to write added blockIssuerKeys in the diff") } - if err := writeBlockIssuerKeys(byteBuffer, d.BlockIssuerKeysRemoved); err != nil { - return nil, err + if err := stream.WriteObject(byteBuffer, d.BlockIssuerKeysRemoved, iotago.BlockIssuerKeys.Bytes); err != nil { + return nil, ierrors.Wrap(err, "unable to write removed blockIssuerKeys in the diff") } if err := stream.Write(byteBuffer, d.ValidatorStakeChange); err != nil { @@ -127,7 +125,7 @@ func (d *AccountDiff) Bytes() ([]byte, error) { return byteBuffer.Bytes() } -func AccountDiffFromReader(reader io.Reader) (*AccountDiff, error) { +func AccountDiffFromReader(reader io.ReadSeeker) (*AccountDiff, error) { var err error d := NewAccountDiff() @@ -150,18 +148,12 @@ func AccountDiffFromReader(reader io.Reader) (*AccountDiff, error) { return nil, ierrors.Wrap(err, "unable to read previous outputID in the diff") } - // TODO: refactor serialization of blockIssuerKeys - keysAdded, _, err := readBlockIssuerKeys(reader) - if err != nil { + if d.BlockIssuerKeysAdded, err = stream.ReadObjectFromReader(reader, iotago.BlockIssuerKeysFromReader); err != nil { return nil, ierrors.Wrap(err, "unable to read added blockIssuerKeys in the diff") } - d.BlockIssuerKeysAdded = keysAdded - - keysRemoved, _, err := readBlockIssuerKeys(reader) - if err != nil { + if d.BlockIssuerKeysRemoved, err = stream.ReadObjectFromReader(reader, iotago.BlockIssuerKeysFromReader); err != nil { return nil, ierrors.Wrap(err, "unable to read removed blockIssuerKeys in the diff") } - d.BlockIssuerKeysRemoved = keysRemoved if d.ValidatorStakeChange, err = stream.Read[int64](reader); err != nil { return nil, ierrors.Wrap(err, "unable to read validator stake change in the diff") @@ -192,38 +184,3 @@ func AccountDiffFromBytes(b []byte) (*AccountDiff, int, error) { return a, reader.BytesRead(), err } - -func writeBlockIssuerKeys(byteBuffer *stream.ByteBuffer, blockIssuerKeys iotago.BlockIssuerKeys) error { - // TODO: improve this - - blockIssuerKeysBytes, err := iotago.CommonSerixAPI().Encode(context.TODO(), blockIssuerKeys) - if err != nil { - return ierrors.Wrap(err, "unable to encode blockIssuerKeys in the diff") - } - - if err := stream.WriteBytesWithSize(byteBuffer, blockIssuerKeysBytes, serializer.SeriLengthPrefixTypeAsUint64); err != nil { - return ierrors.Wrap(err, "unable to write blockIssuerKeysBytes in the diff") - } - - return nil -} - -func readBlockIssuerKeys(reader io.Reader) (iotago.BlockIssuerKeys, int, error) { - // TODO: improve this - var bytesConsumed int - - blockIssuerKeysBytes, err := stream.ReadBytesWithSize(reader, serializer.SeriLengthPrefixTypeAsUint64) - if err != nil { - return nil, bytesConsumed, ierrors.Wrap(err, "unable to read blockIssuerKeysBytes in the diff") - } - - bytesConsumed += serializer.UInt64ByteSize // add the blob size - bytesConsumed += len(blockIssuerKeysBytes) - - var blockIssuerKeys iotago.BlockIssuerKeys - if _, err := iotago.CommonSerixAPI().Decode(context.TODO(), blockIssuerKeysBytes, &blockIssuerKeys); err != nil { - return nil, bytesConsumed, ierrors.Wrap(err, "unable to decode blockIssuerKeys in the diff") - } - - return blockIssuerKeys, bytesConsumed, nil -} diff --git a/pkg/model/poolstats.go b/pkg/model/poolstats.go index c18dc15da..eada06d32 100644 --- a/pkg/model/poolstats.go +++ b/pkg/model/poolstats.go @@ -15,7 +15,7 @@ type PoolsStats struct { ProfitMargin uint64 } -func PoolStatsFromReader(reader io.Reader) (*PoolsStats, error) { +func PoolStatsFromReader(reader io.ReadSeeker) (*PoolsStats, error) { p := new(PoolsStats) var err error @@ -68,7 +68,7 @@ type PoolRewards struct { FixedCost iotago.Mana } -func PoolRewardsFromReader(reader io.Reader) (*PoolRewards, error) { +func PoolRewardsFromReader(reader io.ReadSeeker) (*PoolRewards, error) { var err error p := new(PoolRewards) diff --git a/pkg/model/validator_performance.go b/pkg/model/validator_performance.go index 04ec5dbeb..4569f4f65 100644 --- a/pkg/model/validator_performance.go +++ b/pkg/model/validator_performance.go @@ -34,7 +34,7 @@ func ValidatorPerformanceFromBytes(bytes []byte) (*ValidatorPerformance, int, er return v, byteReader.BytesRead(), nil } -func ValidatorPerformanceFromReader(reader io.Reader) (*ValidatorPerformance, error) { +func ValidatorPerformanceFromReader(reader io.ReadSeeker) (*ValidatorPerformance, error) { var err error v := NewValidatorPerformance() diff --git a/pkg/protocol/engine/accounts/accounts.go b/pkg/protocol/engine/accounts/accounts.go index 0ff70bd94..8acd50a53 100644 --- a/pkg/protocol/engine/accounts/accounts.go +++ b/pkg/protocol/engine/accounts/accounts.go @@ -1,13 +1,10 @@ package accounts import ( - "encoding/binary" "io" - "github.com/iotaledger/hive.go/crypto/ed25519" "github.com/iotaledger/hive.go/ierrors" "github.com/iotaledger/hive.go/runtime/options" - "github.com/iotaledger/hive.go/serializer/v2" "github.com/iotaledger/hive.go/serializer/v2/stream" "github.com/iotaledger/iota-core/pkg/model" iotago "github.com/iotaledger/iota.go/v4" @@ -77,8 +74,7 @@ func (a *AccountData) Clone() *AccountData { } } -func AccountDataFromReader(reader io.Reader) (*AccountData, error) { - +func AccountDataFromReader(reader io.ReadSeeker) (*AccountData, error) { accountID, err := stream.Read[iotago.AccountID](reader) if err != nil { return nil, ierrors.Wrap(err, "unable to read accountID") @@ -96,34 +92,7 @@ func AccountDataFromReader(reader io.Reader) (*AccountData, error) { return nil, ierrors.Wrap(err, "unable to read outputID") } - if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsByte, func(i int) error { - // TODO: improve this - var blockIssuerKeyType iotago.BlockIssuerKeyType - if err := binary.Read(reader, binary.LittleEndian, &blockIssuerKeyType); err != nil { - return ierrors.Wrapf(err, "unable to read block issuer key type for accountID %s", a.ID) - } - - switch blockIssuerKeyType { - case iotago.BlockIssuerKeyEd25519PublicKey: - var ed25519PublicKey ed25519.PublicKey - _, err = io.ReadFull(reader, ed25519PublicKey[:]) - if err != nil { - return ierrors.Wrapf(err, "unable to read public key index %d for accountID %s", i, a.ID) - } - a.BlockIssuerKeys.Add(iotago.Ed25519PublicKeyBlockIssuerKeyFromPublicKey(ed25519PublicKey)) - case iotago.BlockIssuerKeyPublicKeyHash: - var implicitAccountCreationAddress iotago.ImplicitAccountCreationAddress - _, err = io.ReadFull(reader, implicitAccountCreationAddress[:]) - if err != nil { - return ierrors.Wrapf(err, "unable to read address %d for accountID %s", i, a.ID) - } - a.BlockIssuerKeys.Add(iotago.Ed25519PublicKeyHashBlockIssuerKeyFromImplicitAccountCreationAddress(&implicitAccountCreationAddress)) - default: - return ierrors.Wrapf(err, "unsupported block issuer key type %d for accountID %s at offset %d", blockIssuerKeyType, a.ID, i) - } - - return nil - }); err != nil { + if a.BlockIssuerKeys, err = stream.ReadObjectFromReader(reader, iotago.BlockIssuerKeysFromReader); err != nil { return nil, ierrors.Wrap(err, "unable to read block issuer keys") } @@ -174,16 +143,7 @@ func (a *AccountData) Bytes() ([]byte, error) { return nil, ierrors.Wrap(err, "failed to write OutputID") } - if err := stream.WriteCollection(byteBuffer, serializer.SeriLengthPrefixTypeAsByte, func() (elementsCount int, err error) { - // TODO: write this properly as object (depends on how we read it) - for _, key := range a.BlockIssuerKeys { - if _, err = byteBuffer.Write(key.Bytes()); err != nil { - return 0, ierrors.Wrap(err, "failed to write BlockIssuerKey") - } - } - - return len(a.BlockIssuerKeys), nil - }); err != nil { + if err := stream.WriteObject(byteBuffer, a.BlockIssuerKeys, iotago.BlockIssuerKeys.Bytes); err != nil { return nil, ierrors.Wrap(err, "failed to write BlockIssuerKeys") } diff --git a/pkg/protocol/engine/utxoledger/slot_diff.go b/pkg/protocol/engine/utxoledger/slot_diff.go index 829dc08ac..6462a52f3 100644 --- a/pkg/protocol/engine/utxoledger/slot_diff.go +++ b/pkg/protocol/engine/utxoledger/slot_diff.go @@ -70,7 +70,7 @@ func (sd *SlotDiff) kvStorableLoad(manager *Manager, key []byte, value []byte) e byteReader := stream.NewByteReader(value) - outputsCount, err := stream.PeekCollectionSize(byteReader, serializer.SeriLengthPrefixTypeAsUint32) + outputsCount, err := stream.Peek(byteReader, serializer.SeriLengthPrefixTypeAsUint32) if err != nil { return ierrors.Wrap(err, "unable to peek outputs count") } @@ -94,7 +94,7 @@ func (sd *SlotDiff) kvStorableLoad(manager *Manager, key []byte, value []byte) e return ierrors.Wrapf(err, "unable to read slot diff outputs") } - spentsCount, err := stream.PeekCollectionSize(byteReader, serializer.SeriLengthPrefixTypeAsUint32) + spentsCount, err := stream.Peek(byteReader, serializer.SeriLengthPrefixTypeAsUint32) if err != nil { return ierrors.Wrap(err, "unable to peek spents count") } From 3865cc473957de43372d23b0443ef3a96e66f5b3 Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Fri, 3 Nov 2023 20:32:37 +0800 Subject: [PATCH 14/32] Simplify typedKVstore usage --- .../engine/attestation/slotattestation/storage.go | 13 ++----------- 1 file changed, 2 insertions(+), 11 deletions(-) diff --git a/pkg/protocol/engine/attestation/slotattestation/storage.go b/pkg/protocol/engine/attestation/slotattestation/storage.go index 96a1caea8..55e9b5c6b 100644 --- a/pkg/protocol/engine/attestation/slotattestation/storage.go +++ b/pkg/protocol/engine/attestation/slotattestation/storage.go @@ -72,20 +72,11 @@ func (m *Manager) trackerStorage(index iotago.SlotIndex) (*kvstore.TypedStore[io return nil, ierrors.Wrapf(err, "failed to get extended realm for tracker of slot %d", index) } - api := m.apiProvider.APIForSlot(index) - return kvstore.NewTypedStore[iotago.AccountID, *iotago.Attestation](trackerStorage, iotago.AccountID.Bytes, iotago.AccountIDFromBytes, - func(v *iotago.Attestation) ([]byte, error) { - return api.Encode(v) - }, - func(bytes []byte) (object *iotago.Attestation, consumed int, err error) { - attestation := new(iotago.Attestation) - consumed, err = api.Decode(bytes, attestation) - - return attestation, consumed, err - }, + (*iotago.Attestation).Bytes, + iotago.AttestationFromBytes(m.apiProvider), ), nil } From 6cdd097c350160d825e2ce50a5ac6945ac442c9b Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Fri, 3 Nov 2023 20:32:52 +0800 Subject: [PATCH 15/32] Remove ioutils --- pkg/utils/ioutils.go | 40 ---------------------------------------- 1 file changed, 40 deletions(-) delete mode 100644 pkg/utils/ioutils.go diff --git a/pkg/utils/ioutils.go b/pkg/utils/ioutils.go deleted file mode 100644 index 4d802a069..000000000 --- a/pkg/utils/ioutils.go +++ /dev/null @@ -1,40 +0,0 @@ -package utils - -import ( - "encoding/binary" - "io" - - "github.com/iotaledger/hive.go/ierrors" -) - -func increaseOffsets(amount int64, offsets ...*int64) { - for _, offset := range offsets { - *offset += amount - } -} - -func WriteValueFunc(writeSeeker io.WriteSeeker, value any, offsetsToIncrease ...*int64) error { - length := binary.Size(value) - if length == -1 { - return ierrors.New("unable to determine length of value") - } - - if err := binary.Write(writeSeeker, binary.LittleEndian, value); err != nil { - return ierrors.Wrap(err, "unable to write value") - } - - increaseOffsets(int64(length), offsetsToIncrease...) - - return nil -} - -func WriteBytesFunc(writeSeeker io.WriteSeeker, bytes []byte, offsetsToIncrease ...*int64) error { - length, err := writeSeeker.Write(bytes) - if err != nil { - return ierrors.Wrap(err, "unable to write bytes") - } - - increaseOffsets(int64(length), offsetsToIncrease...) - - return nil -} From d406b7b5fd123381bf0deca48e38e6df20cc9cc2 Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Fri, 3 Nov 2023 20:33:26 +0800 Subject: [PATCH 16/32] Adjust utxo ledger to use stream package instead of ioutils --- pkg/protocol/engine/utxoledger/manager.go | 17 +- pkg/protocol/engine/utxoledger/slot_diff.go | 5 +- pkg/protocol/engine/utxoledger/snapshot.go | 150 ++++++++---------- .../engine/utxoledger/snapshot_test.go | 9 +- 4 files changed, 74 insertions(+), 107 deletions(-) diff --git a/pkg/protocol/engine/utxoledger/manager.go b/pkg/protocol/engine/utxoledger/manager.go index b55ddb22e..e4109254c 100644 --- a/pkg/protocol/engine/utxoledger/manager.go +++ b/pkg/protocol/engine/utxoledger/manager.go @@ -2,13 +2,13 @@ package utxoledger import ( "crypto/sha256" - "encoding/binary" "github.com/iotaledger/hive.go/ads" "github.com/iotaledger/hive.go/ierrors" "github.com/iotaledger/hive.go/kvstore" "github.com/iotaledger/hive.go/lo" "github.com/iotaledger/hive.go/runtime/syncutils" + "github.com/iotaledger/hive.go/serializer/v2/stream" iotago "github.com/iotaledger/iota.go/v4" ) @@ -370,7 +370,8 @@ func (m *Manager) LedgerStateSHA256Sum() ([]byte, error) { if err != nil { return nil, err } - if err := binary.Write(ledgerStateHash, binary.LittleEndian, ledgerSlot); err != nil { + + if err := stream.Write(ledgerStateHash, ledgerSlot); err != nil { return nil, err } @@ -386,22 +387,16 @@ func (m *Manager) LedgerStateSHA256Sum() ([]byte, error) { return nil, err } - if _, err := ledgerStateHash.Write(output.outputID[:]); err != nil { + if err := stream.Write(ledgerStateHash, outputID); err != nil { return nil, err } - if _, err := ledgerStateHash.Write(output.KVStorableValue()); err != nil { + if err := stream.WriteBytes(ledgerStateHash, output.KVStorableValue()); err != nil { return nil, err } } - // Add root of the state tree - stateTreeBytes, err := m.StateTreeRoot().Bytes() - if err != nil { - return nil, err - } - - if _, err := ledgerStateHash.Write(stateTreeBytes); err != nil { + if err := stream.Write(ledgerStateHash, m.StateTreeRoot()); err != nil { return nil, err } diff --git a/pkg/protocol/engine/utxoledger/slot_diff.go b/pkg/protocol/engine/utxoledger/slot_diff.go index 6462a52f3..07b05c7a8 100644 --- a/pkg/protocol/engine/utxoledger/slot_diff.go +++ b/pkg/protocol/engine/utxoledger/slot_diff.go @@ -2,7 +2,6 @@ package utxoledger import ( "crypto/sha256" - "encoding/binary" "sort" "github.com/iotaledger/hive.go/ierrors" @@ -146,11 +145,11 @@ func (sd *SlotDiff) sortedSpents() LexicalOrderedSpents { func (sd *SlotDiff) SHA256Sum() ([]byte, error) { sdDiffHash := sha256.New() - if err := binary.Write(sdDiffHash, binary.LittleEndian, sd.KVStorableKey()); err != nil { + if err := stream.WriteBytes(sdDiffHash, sd.KVStorableKey()); err != nil { return nil, ierrors.Errorf("unable to serialize slot diff: %w", err) } - if err := binary.Write(sdDiffHash, binary.LittleEndian, sd.KVStorableValue()); err != nil { + if err := stream.WriteBytes(sdDiffHash, sd.KVStorableValue()); err != nil { return nil, ierrors.Errorf("unable to serialize slot diff: %w", err) } diff --git a/pkg/protocol/engine/utxoledger/snapshot.go b/pkg/protocol/engine/utxoledger/snapshot.go index 0fec1d4e3..cc7cff2e9 100644 --- a/pkg/protocol/engine/utxoledger/snapshot.go +++ b/pkg/protocol/engine/utxoledger/snapshot.go @@ -5,9 +5,10 @@ import ( "io" "github.com/iotaledger/hive.go/ierrors" + "github.com/iotaledger/hive.go/serializer/v2" "github.com/iotaledger/hive.go/serializer/v2/byteutils" "github.com/iotaledger/hive.go/serializer/v2/serix" - "github.com/iotaledger/iota-core/pkg/utils" + "github.com/iotaledger/hive.go/serializer/v2/stream" iotago "github.com/iotaledger/iota.go/v4" ) @@ -128,34 +129,36 @@ func ReadSlotDiffToSnapshotReader(reader io.ReadSeeker, apiProvider iotago.APIPr return slotDiff, nil } -func WriteSlotDiffToSnapshotWriter(writer io.WriteSeeker, diff *SlotDiff) (written int64, err error) { - var totalBytesWritten int64 - - if err := utils.WriteValueFunc(writer, diff.Slot.MustBytes(), &totalBytesWritten); err != nil { - return 0, ierrors.Wrap(err, "unable to write slot diff index") - } - - if err := utils.WriteValueFunc(writer, uint64(len(diff.Outputs)), &totalBytesWritten); err != nil { - return 0, ierrors.Wrap(err, "unable to write slot diff created count") +func WriteSlotDiffToSnapshotWriter(writer io.WriteSeeker, diff *SlotDiff) error { + if err := stream.Write(writer, diff.Slot); err != nil { + return ierrors.Wrap(err, "unable to write slot diff index") } - for _, output := range diff.sortedOutputs() { - if err := utils.WriteBytesFunc(writer, output.SnapshotBytes(), &totalBytesWritten); err != nil { - return 0, ierrors.Wrap(err, "unable to write slot diff created output") + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (elementsCount int, err error) { + for _, output := range diff.sortedOutputs() { + if err := stream.WriteBytes(writer, output.SnapshotBytes()); err != nil { + return 0, ierrors.Wrap(err, "unable to write slot diff created output") + } } - } - if err := utils.WriteValueFunc(writer, uint64(len(diff.Spents)), &totalBytesWritten); err != nil { - return 0, ierrors.Wrap(err, "unable to write slot diff consumed count") + return len(diff.Outputs), nil + }); err != nil { + return ierrors.Wrap(err, "unable to write slot diff created collection") } - for _, spent := range diff.sortedSpents() { - if err := utils.WriteBytesFunc(writer, spent.SnapshotBytes(), &totalBytesWritten); err != nil { - return 0, ierrors.Wrap(err, "unable to write slot diff created output") + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (elementsCount int, err error) { + for _, spent := range diff.sortedSpents() { + if err := stream.WriteBytes(writer, spent.SnapshotBytes()); err != nil { + return 0, ierrors.Wrap(err, "unable to write slot diff spent output") + } } + + return len(diff.Spents), nil + }); err != nil { + return ierrors.Wrap(err, "unable to write slot diff spent collection") } - return totalBytesWritten, nil + return nil } // Import imports the ledger state from the given reader. @@ -163,6 +166,7 @@ func (m *Manager) Import(reader io.ReadSeeker) error { m.WriteLockLedger() defer m.WriteUnlockLedger() + // TODO: change this to stream API and collections var snapshotLedgerIndex iotago.SlotIndex if err := binary.Read(reader, binary.LittleEndian, &snapshotLedgerIndex); err != nil { return ierrors.Errorf("unable to read LS ledger index: %w", err) @@ -177,11 +181,6 @@ func (m *Manager) Import(reader io.ReadSeeker) error { return ierrors.Errorf("unable to read LS output count: %w", err) } - var slotDiffCount uint64 - if err := binary.Read(reader, binary.LittleEndian, &slotDiffCount); err != nil { - return ierrors.Errorf("unable to read LS slot diff count: %w", err) - } - for i := uint64(0); i < outputCount; i++ { output, err := OutputFromSnapshotReader(reader, m.apiProvider) if err != nil { @@ -193,6 +192,11 @@ func (m *Manager) Import(reader io.ReadSeeker) error { } } + var slotDiffCount uint64 + if err := binary.Read(reader, binary.LittleEndian, &slotDiffCount); err != nil { + return ierrors.Errorf("unable to read LS slot diff count: %w", err) + } + for i := uint64(0); i < slotDiffCount; i++ { slotDiff, err := ReadSlotDiffToSnapshotReader(reader, m.apiProvider) if err != nil { @@ -224,83 +228,55 @@ func (m *Manager) Export(writer io.WriteSeeker, targetIndex iotago.SlotIndex) er if err != nil { return err } - if err := utils.WriteValueFunc(writer, ledgerIndex); err != nil { - return ierrors.Wrap(err, "unable to write ledger index") - } - - var relativeCountersPosition int64 - - var outputCount uint64 - var slotDiffCount uint64 - - // Outputs Count - // The amount of UTXOs contained within this snapshot. - if err := utils.WriteValueFunc(writer, outputCount, &relativeCountersPosition); err != nil { - return ierrors.Wrap(err, "unable to write outputs count") - } - - // Slot Diffs Count - // The amount of slot diffs contained within this snapshot. - if err := utils.WriteValueFunc(writer, slotDiffCount, &relativeCountersPosition); err != nil { - return ierrors.Wrap(err, "unable to write slot diffs count") - } - // Get all UTXOs and sort them by outputID - outputIDs, err := m.UnspentOutputsIDs(ReadLockLedger(false)) - if err != nil { - return ierrors.Wrap(err, "error while retrieving unspent outputIDs") + if err := stream.Write(writer, ledgerIndex); err != nil { + return ierrors.Wrap(err, "unable to write ledger index") } - for _, outputID := range outputIDs.RemoveDupsAndSort() { - output, err := m.ReadOutputByOutputIDWithoutLocking(outputID) + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (int, error) { + // Get all UTXOs and sort them by outputID + outputIDs, err := m.UnspentOutputsIDs(ReadLockLedger(false)) if err != nil { - return ierrors.Wrapf(err, "error while retrieving output %s", outputID) - } - - if err := utils.WriteBytesFunc(writer, output.SnapshotBytes(), &relativeCountersPosition); err != nil { - return ierrors.Wrap(err, "unable to write output ID") + return 0, ierrors.Wrap(err, "error while retrieving unspent outputIDs") } - outputCount++ - } + var outputCount int + for _, outputID := range outputIDs.RemoveDupsAndSort() { + output, err := m.ReadOutputByOutputIDWithoutLocking(outputID) + if err != nil { + return 0, ierrors.Wrapf(err, "error while retrieving output %s", outputID) + } - for diffIndex := ledgerIndex; diffIndex > targetIndex; diffIndex-- { - slotDiff, err := m.SlotDiffWithoutLocking(diffIndex) - if err != nil { - return ierrors.Wrapf(err, "error while retrieving slot diffs for slot %s", diffIndex) - } + if err := stream.WriteBytes(writer, output.SnapshotBytes()); err != nil { + return 0, ierrors.Wrapf(err, "unable to write output with ID %s", outputID) + } - written, err := WriteSlotDiffToSnapshotWriter(writer, slotDiff) - if err != nil { - return ierrors.Wrapf(err, "error while writing slot diffs for slot %s", diffIndex) + outputCount++ } - relativeCountersPosition += written - slotDiffCount++ + return outputCount, nil + }); err != nil { + return ierrors.Wrap(err, "unable to write unspent output collection") } - // seek back to the file position of the counters - if _, err := writer.Seek(-relativeCountersPosition, io.SeekCurrent); err != nil { - return ierrors.Errorf("unable to seek to LS counter placeholders: %w", err) - } - - var countersSize int64 + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (int, error) { + var slotDiffCount int + for diffIndex := ledgerIndex; diffIndex > targetIndex; diffIndex-- { + slotDiff, err := m.SlotDiffWithoutLocking(diffIndex) + if err != nil { + return 0, ierrors.Wrapf(err, "error while retrieving slot diffs for slot %s", diffIndex) + } - // Outputs Count - // The amount of UTXOs contained within this snapshot. - if err := utils.WriteValueFunc(writer, outputCount, &countersSize); err != nil { - return ierrors.Wrap(err, "unable to write outputs count") - } + if WriteSlotDiffToSnapshotWriter(writer, slotDiff) != nil { + return 0, ierrors.Wrapf(err, "error while writing slot diffs for slot %s", diffIndex) + } - // Slot Diffs Count - // The amount of slot diffs contained within this snapshot. - if err := utils.WriteValueFunc(writer, slotDiffCount, &countersSize); err != nil { - return ierrors.Wrap(err, "unable to write slot diffs count") - } + slotDiffCount++ + } - // seek back to the last write position - if _, err := writer.Seek(relativeCountersPosition-countersSize, io.SeekCurrent); err != nil { - return ierrors.Errorf("unable to seek to LS last written position: %w", err) + return slotDiffCount, nil + }); err != nil { + return ierrors.Wrap(err, "unable to write slot diff collection") } return nil diff --git a/pkg/protocol/engine/utxoledger/snapshot_test.go b/pkg/protocol/engine/utxoledger/snapshot_test.go index 5e174887a..3da486320 100644 --- a/pkg/protocol/engine/utxoledger/snapshot_test.go +++ b/pkg/protocol/engine/utxoledger/snapshot_test.go @@ -152,11 +152,9 @@ func TestReadSlotDiffToSnapshotReader(t *testing.T) { } writer := &writerseeker.WriterSeeker{} - written, err := utxoledger.WriteSlotDiffToSnapshotWriter(writer, slotDiff) + err := utxoledger.WriteSlotDiffToSnapshotWriter(writer, slotDiff) require.NoError(t, err) - require.Equal(t, int64(writer.BytesReader().Len()), written) - reader := writer.BytesReader() readSlotDiff, err := utxoledger.ReadSlotDiffToSnapshotReader(reader, api.SingleVersionProvider(iotago_tpkg.TestAPI)) require.NoError(t, err) @@ -182,11 +180,9 @@ func TestWriteSlotDiffToSnapshotWriter(t *testing.T) { } writer := &writerseeker.WriterSeeker{} - written, err := utxoledger.WriteSlotDiffToSnapshotWriter(writer, slotDiff) + err := utxoledger.WriteSlotDiffToSnapshotWriter(writer, slotDiff) require.NoError(t, err) - require.Equal(t, int64(writer.BytesReader().Len()), written) - reader := writer.BytesReader() var readSlot iotago.SlotIndex @@ -358,6 +354,7 @@ func TestManager_Export(t *testing.T) { // Test exporting at the current slot 2 { + // TODO: replace with our own BytesBuffer, adjust test to use stream API writer := &writerseeker.WriterSeeker{} require.NoError(t, manager.Export(writer, 2)) From 1ce61baa977387bcd51b835468ed6e14d61c5cfa Mon Sep 17 00:00:00 2001 From: Piotr Macek <4007944+piotrm50@users.noreply.github.com> Date: Fri, 3 Nov 2023 15:31:45 +0100 Subject: [PATCH 17/32] Remove unnecessary checks --- pkg/protocol/engine/tipmanager/v1/tipmanager.go | 17 +++++++---------- 1 file changed, 7 insertions(+), 10 deletions(-) diff --git a/pkg/protocol/engine/tipmanager/v1/tipmanager.go b/pkg/protocol/engine/tipmanager/v1/tipmanager.go index 671e45327..22dcf6e37 100644 --- a/pkg/protocol/engine/tipmanager/v1/tipmanager.go +++ b/pkg/protocol/engine/tipmanager/v1/tipmanager.go @@ -140,25 +140,22 @@ func (t *TipManager) setupBlockMetadata(tipMetadata *TipMetadata) { // forEachParentByType iterates through the parents of the given block and calls the consumer for each parent. func (t *TipManager) forEachParentByType(block *blocks.Block, consumer func(parentType iotago.ParentsType, parentMetadata *TipMetadata)) { - if block == nil || block.ProtocolBlock() == nil { - return - } - for _, parent := range block.ParentsWithType() { if metadataStorage := t.metadataStorage(parent.ID.Slot()); metadataStorage != nil { - // Make sure we don't add rootblocks back to the tips. + // Make sure we don't add root blocks back to the tips. parentBlock, exists := t.retrieveBlock(parent.ID) + if !exists || parentBlock.IsRootBlock() { continue } - if parentMetadata, created := metadataStorage.GetOrCreate(parent.ID, func() *TipMetadata { return NewBlockMetadata(parentBlock) }); parentMetadata.Block() != nil { - consumer(parent.Type, parentMetadata) + parentMetadata, created := metadataStorage.GetOrCreate(parent.ID, func() *TipMetadata { return NewBlockMetadata(parentBlock) }) + consumer(parent.Type, parentMetadata) - if created { - t.setupBlockMetadata(parentMetadata) - } + if created { + t.setupBlockMetadata(parentMetadata) } + } } } From e29210a1a1184f9a04b87caf26acf3bc4b876193 Mon Sep 17 00:00:00 2001 From: Piotr Macek <4007944+piotrm50@users.noreply.github.com> Date: Fri, 3 Nov 2023 15:32:48 +0100 Subject: [PATCH 18/32] Panic and log block metadata before nil pointer exception happens. --- pkg/protocol/engine/tipmanager/v1/tipmanager.go | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/pkg/protocol/engine/tipmanager/v1/tipmanager.go b/pkg/protocol/engine/tipmanager/v1/tipmanager.go index 22dcf6e37..ee9ae2cdf 100644 --- a/pkg/protocol/engine/tipmanager/v1/tipmanager.go +++ b/pkg/protocol/engine/tipmanager/v1/tipmanager.go @@ -1,6 +1,8 @@ package tipmanagerv1 import ( + "fmt" + "github.com/iotaledger/hive.go/ds/randommap" "github.com/iotaledger/hive.go/ds/shrinkingmap" "github.com/iotaledger/hive.go/lo" @@ -149,6 +151,10 @@ func (t *TipManager) forEachParentByType(block *blocks.Block, consumer func(pare continue } + if parentBlock.ModelBlock() == nil { + panic(fmt.Sprintf(">> parentBlock exists, but parentBlock.ProtocolBlock() == nil, %s", parentBlock.String())) + } + parentMetadata, created := metadataStorage.GetOrCreate(parent.ID, func() *TipMetadata { return NewBlockMetadata(parentBlock) }) consumer(parent.Type, parentMetadata) From b1e02f17e6e4ed1ae642963619ba11c9d2804e2d Mon Sep 17 00:00:00 2001 From: Piotr Macek <4007944+piotrm50@users.noreply.github.com> Date: Fri, 3 Nov 2023 15:36:35 +0100 Subject: [PATCH 19/32] Replace a panic with a print, since a panic will happen anyway. --- pkg/protocol/engine/tipmanager/v1/tipmanager.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pkg/protocol/engine/tipmanager/v1/tipmanager.go b/pkg/protocol/engine/tipmanager/v1/tipmanager.go index ee9ae2cdf..2e5bef0fc 100644 --- a/pkg/protocol/engine/tipmanager/v1/tipmanager.go +++ b/pkg/protocol/engine/tipmanager/v1/tipmanager.go @@ -152,7 +152,7 @@ func (t *TipManager) forEachParentByType(block *blocks.Block, consumer func(pare } if parentBlock.ModelBlock() == nil { - panic(fmt.Sprintf(">> parentBlock exists, but parentBlock.ProtocolBlock() == nil, %s", parentBlock.String())) + fmt.Printf(">> parentBlock exists, but parentBlock.ProtocolBlock() == nil\n %s\n", parentBlock.String()) } parentMetadata, created := metadataStorage.GetOrCreate(parent.ID, func() *TipMetadata { return NewBlockMetadata(parentBlock) }) From 49a0be6dc04b5e99852abc50eef7aa600c05e6a3 Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Mon, 6 Nov 2023 11:02:10 +0800 Subject: [PATCH 20/32] Remove dependency to github.com/orcaman/writerseeker --- go.mod | 1 - .../sybilprotectionv1/performance/snapshot_test.go | 10 +++++----- 2 files changed, 5 insertions(+), 6 deletions(-) diff --git a/go.mod b/go.mod index ec5d2d7d5..b6e084f67 100644 --- a/go.mod +++ b/go.mod @@ -33,7 +33,6 @@ require ( github.com/mr-tron/base58 v1.2.0 github.com/multiformats/go-multiaddr v0.12.0 github.com/multiformats/go-varint v0.0.7 - github.com/orcaman/writerseeker v0.0.0-20200621085525-1d3f536ff85e github.com/otiai10/copy v1.14.0 github.com/prometheus/client_golang v1.17.0 github.com/spf13/pflag v1.0.5 diff --git a/pkg/protocol/sybilprotection/sybilprotectionv1/performance/snapshot_test.go b/pkg/protocol/sybilprotection/sybilprotectionv1/performance/snapshot_test.go index 2f5ccc8c8..d74d8c2bd 100644 --- a/pkg/protocol/sybilprotection/sybilprotectionv1/performance/snapshot_test.go +++ b/pkg/protocol/sybilprotection/sybilprotectionv1/performance/snapshot_test.go @@ -3,9 +3,9 @@ package performance import ( "testing" - "github.com/orcaman/writerseeker" "github.com/stretchr/testify/require" + "github.com/iotaledger/hive.go/serializer/v2/stream" iotago "github.com/iotaledger/iota.go/v4" ) @@ -37,7 +37,7 @@ func TestManager_Import_Export(t *testing.T) { } { - writer := &writerseeker.WriterSeeker{} + writer := stream.NewByteBuffer() delegatorRewardBeforeImport, validatorRewardBeforeImport := ts.calculateExpectedRewards(epochsCount, epochActions) // export two full epochs @@ -47,14 +47,14 @@ func TestManager_Import_Export(t *testing.T) { ts.InitPerformanceTracker() - err = ts.Instance.Import(writer.BytesReader()) + err = ts.Instance.Import(writer.Reader()) require.NoError(t, err) delegatorRewardAfterImport, validatorRewardAfterImport := ts.calculateExpectedRewards(epochsCount, epochActions) require.Equal(t, delegatorRewardBeforeImport, delegatorRewardAfterImport) require.Equal(t, validatorRewardBeforeImport, validatorRewardAfterImport) } { - writer := &writerseeker.WriterSeeker{} + writer := stream.NewByteBuffer() delegatorRewardBeforeImport, validatorRewardBeforeImport := ts.calculateExpectedRewards(epochsCount, epochActions) // export at the beginning of epoch 2, skip epoch 3 at all @@ -64,7 +64,7 @@ func TestManager_Import_Export(t *testing.T) { ts.InitPerformanceTracker() - err = ts.Instance.Import(writer.BytesReader()) + err = ts.Instance.Import(writer.Reader()) require.NoError(t, err) delegatorRewardAfterImport, validatorRewardAfterImport := ts.calculateExpectedRewards(epochsCount, epochActions) From 7f5bd3db1793bda267428f12f3c9c0f81b768623 Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Mon, 6 Nov 2023 11:02:40 +0800 Subject: [PATCH 21/32] Adjust utxo ledger to use stream package instead of manual binary.Read --- .../accounts/accountsledger/snapshot_test.go | 12 +- pkg/protocol/engine/utxoledger/snapshot.go | 143 +++++++++--------- .../engine/utxoledger/snapshot_test.go | 59 ++++---- 3 files changed, 106 insertions(+), 108 deletions(-) diff --git a/pkg/protocol/engine/accounts/accountsledger/snapshot_test.go b/pkg/protocol/engine/accounts/accountsledger/snapshot_test.go index 89b8f4058..c94f5d06c 100644 --- a/pkg/protocol/engine/accounts/accountsledger/snapshot_test.go +++ b/pkg/protocol/engine/accounts/accountsledger/snapshot_test.go @@ -3,9 +3,9 @@ package accountsledger_test import ( "testing" - "github.com/orcaman/writerseeker" "github.com/stretchr/testify/require" + "github.com/iotaledger/hive.go/serializer/v2/stream" "github.com/iotaledger/iota-core/pkg/model" iotago "github.com/iotaledger/iota.go/v4" "github.com/iotaledger/iota.go/v4/tpkg" @@ -176,15 +176,15 @@ func TestManager_Import_Export(t *testing.T) { }, }) - //// Export and import the account ledger into new manager for the latest slot. + // Export and import the account ledger into new manager for the latest slot. { - writer := &writerseeker.WriterSeeker{} + writer := stream.NewByteBuffer() err := ts.Instance.Export(writer, iotago.SlotIndex(3)) require.NoError(t, err) ts.Instance = ts.initAccountLedger() - err = ts.Instance.Import(writer.BytesReader()) + err = ts.Instance.Import(writer.Reader()) require.NoError(t, err) ts.Instance.SetLatestCommittedSlot(3) @@ -193,13 +193,13 @@ func TestManager_Import_Export(t *testing.T) { // Export and import for pre-latest slot. { - writer := &writerseeker.WriterSeeker{} + writer := stream.NewByteBuffer() err := ts.Instance.Export(writer, iotago.SlotIndex(2)) require.NoError(t, err) ts.Instance = ts.initAccountLedger() - err = ts.Instance.Import(writer.BytesReader()) + err = ts.Instance.Import(writer.Reader()) require.NoError(t, err) ts.Instance.SetLatestCommittedSlot(2) diff --git a/pkg/protocol/engine/utxoledger/snapshot.go b/pkg/protocol/engine/utxoledger/snapshot.go index cc7cff2e9..c94a115f4 100644 --- a/pkg/protocol/engine/utxoledger/snapshot.go +++ b/pkg/protocol/engine/utxoledger/snapshot.go @@ -1,7 +1,6 @@ package utxoledger import ( - "encoding/binary" "io" "github.com/iotaledger/hive.go/ierrors" @@ -19,49 +18,50 @@ func (o *Output) SnapshotBytes() []byte { } func OutputFromSnapshotReader(reader io.ReadSeeker, apiProvider iotago.APIProvider) (*Output, error) { - outputID := iotago.OutputID{} - if _, err := io.ReadFull(reader, outputID[:]); err != nil { - return nil, ierrors.Errorf("unable to read LS output ID: %w", err) + outputID, err := stream.Read[iotago.OutputID](reader) + if err != nil { + return nil, ierrors.Wrap(err, "unable to read LS output ID") } - blockID := iotago.BlockID{} - if _, err := io.ReadFull(reader, blockID[:]); err != nil { - return nil, ierrors.Errorf("unable to read LS block ID: %w", err) + blockID, err := stream.Read[iotago.BlockID](reader) + if err != nil { + return nil, ierrors.Wrap(err, "unable to read LS block ID") } - var slotBooked iotago.SlotIndex - if err := binary.Read(reader, binary.LittleEndian, &slotBooked); err != nil { - return nil, ierrors.Errorf("unable to read LS output milestone index booked: %w", err) + slotBooked, err := stream.Read[iotago.SlotIndex](reader) + if err != nil { + return nil, ierrors.Wrap(err, "unable to read LS output slot booked") } - var outputLength uint32 - if err := binary.Read(reader, binary.LittleEndian, &outputLength); err != nil { - return nil, ierrors.Errorf("unable to read LS output length: %w", err) - } + var outputBytes []byte + output, err := stream.ReadObjectWithSize(reader, serializer.SeriLengthPrefixTypeAsUint32, func(bytes []byte) (iotago.TxEssenceOutput, int, error) { + outputBytes = bytes - outputBytes := make([]byte, outputLength) - if _, err := io.ReadFull(reader, outputBytes); err != nil { - return nil, ierrors.Errorf("unable to read LS output bytes: %w", err) - } + var o iotago.TxEssenceOutput + readBytes, err := apiProvider.APIForSlot(blockID.Slot()).Decode(bytes, &o, serix.WithValidation()) + if err != nil { + return nil, 0, ierrors.Wrap(err, "invalid LS output address") + } - var output iotago.TxEssenceOutput - if _, err := apiProvider.APIForSlot(blockID.Slot()).Decode(outputBytes, &output, serix.WithValidation()); err != nil { - return nil, ierrors.Errorf("invalid LS output address: %w", err) + return o, readBytes, nil + }) + if err != nil { + return nil, ierrors.Wrap(err, "unable to read LS output") } - var proofLength uint32 - if err := binary.Read(reader, binary.LittleEndian, &proofLength); err != nil { - return nil, ierrors.Errorf("unable to read LS output proof length: %w", err) - } + var proofBytes []byte + proof, err := stream.ReadObjectWithSize(reader, serializer.SeriLengthPrefixTypeAsUint32, func(bytes []byte) (*iotago.OutputIDProof, int, error) { + proofBytes = bytes - proofBytes := make([]byte, proofLength) - if _, err := io.ReadFull(reader, proofBytes); err != nil { - return nil, ierrors.Errorf("unable to read LS output proof bytes: %w", err) - } + proof, readBytes, err := iotago.OutputIDProofFromBytes(apiProvider.APIForSlot(blockID.Slot()))(proofBytes) + if err != nil { + return nil, 0, ierrors.Wrap(err, "invalid LS output proof") + } - proof, _, err := iotago.OutputIDProofFromBytes(apiProvider.APIForSlot(blockID.Slot()))(proofBytes) + return proof, readBytes, nil + }) if err != nil { - return nil, ierrors.Errorf("invalid LS output proof: %w", err) + return nil, ierrors.Wrap(err, "unable to read LS output proof") } return NewOutput(apiProvider, outputID, blockID, slotBooked, output, outputBytes, proof, proofBytes), nil @@ -79,51 +79,54 @@ func SpentFromSnapshotReader(reader io.ReadSeeker, apiProvider iotago.APIProvide return nil, err } - transactionIDSpent := iotago.TransactionID{} - if _, err := io.ReadFull(reader, transactionIDSpent[:]); err != nil { - return nil, ierrors.Errorf("unable to read LS transaction ID spent: %w", err) + transactionIDSpent, err := stream.Read[iotago.TransactionID](reader) + if err != nil { + return nil, ierrors.Wrap(err, "unable to read LS transaction ID spent") } return NewSpent(output, transactionIDSpent, indexSpent), nil } func ReadSlotDiffToSnapshotReader(reader io.ReadSeeker, apiProvider iotago.APIProvider) (*SlotDiff, error) { + var err error slotDiff := &SlotDiff{} - var diffIndex iotago.SlotIndex - if err := binary.Read(reader, binary.LittleEndian, &diffIndex); err != nil { - return nil, ierrors.Errorf("unable to read slot diff index: %w", err) + if slotDiff.Slot, err = stream.Read[iotago.SlotIndex](reader); err != nil { + return nil, ierrors.Wrap(err, "unable to read slot diff index") } - slotDiff.Slot = diffIndex - var createdCount uint64 - if err := binary.Read(reader, binary.LittleEndian, &createdCount); err != nil { - return nil, ierrors.Errorf("unable to read slot diff created count: %w", err) + createdCount, err := stream.Peek(reader, serializer.SeriLengthPrefixTypeAsUint64) + if err != nil { + return nil, ierrors.Wrap(err, "unable to peek slot diff created count") } - slotDiff.Outputs = make(Outputs, createdCount) - for i := uint64(0); i < createdCount; i++ { - var err error + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(i int) error { slotDiff.Outputs[i], err = OutputFromSnapshotReader(reader, apiProvider) if err != nil { - return nil, ierrors.Errorf("unable to read slot diff output: %w", err) + return ierrors.Wrap(err, "unable to read slot diff output") } - } - var consumedCount uint64 - if err := binary.Read(reader, binary.LittleEndian, &consumedCount); err != nil { - return nil, ierrors.Errorf("unable to read slot diff consumed count: %w", err) + return nil + }); err != nil { + return nil, ierrors.Wrap(err, "unable to read slot diff created collection") } + consumedCount, err := stream.Peek(reader, serializer.SeriLengthPrefixTypeAsUint64) + if err != nil { + return nil, ierrors.Wrap(err, "unable to peek slot diff consumed count") + } slotDiff.Spents = make(Spents, consumedCount) - for i := uint64(0); i < consumedCount; i++ { - var err error + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(i int) error { slotDiff.Spents[i], err = SpentFromSnapshotReader(reader, apiProvider, slotDiff.Slot) if err != nil { - return nil, ierrors.Errorf("unable to read slot diff spent: %w", err) + return ierrors.Wrap(err, "unable to read slot diff spent") } + + return nil + }); err != nil { + return nil, ierrors.Wrap(err, "unable to read slot diff consumed collection") } return slotDiff, nil @@ -166,41 +169,33 @@ func (m *Manager) Import(reader io.ReadSeeker) error { m.WriteLockLedger() defer m.WriteUnlockLedger() - // TODO: change this to stream API and collections - var snapshotLedgerIndex iotago.SlotIndex - if err := binary.Read(reader, binary.LittleEndian, &snapshotLedgerIndex); err != nil { - return ierrors.Errorf("unable to read LS ledger index: %w", err) + snapshotLedgerIndex, err := stream.Read[iotago.SlotIndex](reader) + if err != nil { + return ierrors.Wrap(err, "unable to read LS ledger index") } - if err := m.StoreLedgerIndexWithoutLocking(snapshotLedgerIndex); err != nil { return err } - var outputCount uint64 - if err := binary.Read(reader, binary.LittleEndian, &outputCount); err != nil { - return ierrors.Errorf("unable to read LS output count: %w", err) - } - - for i := uint64(0); i < outputCount; i++ { + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(i int) error { output, err := OutputFromSnapshotReader(reader, m.apiProvider) if err != nil { - return ierrors.Errorf("at pos %d: %w", i, err) + return ierrors.Wrapf(err, "at pos %d", i) } if err := m.importUnspentOutputWithoutLocking(output); err != nil { - return err + return ierrors.Wrap(err, "unable to import LS output") } - } - var slotDiffCount uint64 - if err := binary.Read(reader, binary.LittleEndian, &slotDiffCount); err != nil { - return ierrors.Errorf("unable to read LS slot diff count: %w", err) + return nil + }); err != nil { + return ierrors.Wrap(err, "unable to read LS output collection") } - for i := uint64(0); i < slotDiffCount; i++ { + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(i int) error { slotDiff, err := ReadSlotDiffToSnapshotReader(reader, m.apiProvider) if err != nil { - return err + return ierrors.Wrapf(err, "unable to read LS slot diff at index %d", i) } if slotDiff.Slot != snapshotLedgerIndex-iotago.SlotIndex(i) { @@ -208,8 +203,12 @@ func (m *Manager) Import(reader io.ReadSeeker) error { } if err := m.RollbackDiffWithoutLocking(slotDiff.Slot, slotDiff.Outputs, slotDiff.Spents); err != nil { - return err + return ierrors.Wrapf(err, "unable to rollback LS slot diff at index %d", i) } + + return nil + }); err != nil { + return ierrors.Wrap(err, "unable to read LS slot diff collection") } if err := m.stateTree.Commit(); err != nil { diff --git a/pkg/protocol/engine/utxoledger/snapshot_test.go b/pkg/protocol/engine/utxoledger/snapshot_test.go index 3da486320..1331bbab3 100644 --- a/pkg/protocol/engine/utxoledger/snapshot_test.go +++ b/pkg/protocol/engine/utxoledger/snapshot_test.go @@ -5,12 +5,12 @@ import ( "encoding/binary" "testing" - "github.com/orcaman/writerseeker" "github.com/stretchr/testify/require" "github.com/iotaledger/hive.go/kvstore" "github.com/iotaledger/hive.go/kvstore/mapdb" "github.com/iotaledger/hive.go/lo" + "github.com/iotaledger/hive.go/serializer/v2/stream" "github.com/iotaledger/iota-core/pkg/protocol/engine/utxoledger" "github.com/iotaledger/iota-core/pkg/protocol/engine/utxoledger/tpkg" "github.com/iotaledger/iota-core/pkg/utils" @@ -151,11 +151,11 @@ func TestReadSlotDiffToSnapshotReader(t *testing.T) { }, } - writer := &writerseeker.WriterSeeker{} + writer := stream.NewByteBuffer() err := utxoledger.WriteSlotDiffToSnapshotWriter(writer, slotDiff) require.NoError(t, err) - reader := writer.BytesReader() + reader := writer.Reader() readSlotDiff, err := utxoledger.ReadSlotDiffToSnapshotReader(reader, api.SingleVersionProvider(iotago_tpkg.TestAPI)) require.NoError(t, err) @@ -179,11 +179,11 @@ func TestWriteSlotDiffToSnapshotWriter(t *testing.T) { }, } - writer := &writerseeker.WriterSeeker{} + writer := stream.NewByteBuffer() err := utxoledger.WriteSlotDiffToSnapshotWriter(writer, slotDiff) require.NoError(t, err) - reader := writer.BytesReader() + reader := writer.Reader() var readSlot iotago.SlotIndex require.NoError(t, binary.Read(reader, binary.LittleEndian, &readSlot)) @@ -267,10 +267,10 @@ func TestManager_Import(t *testing.T) { // Test exporting and importing at the current slot 2 { - writer := &writerseeker.WriterSeeker{} + writer := stream.NewByteBuffer() require.NoError(t, manager.Export(writer, 2)) - reader := writer.BytesReader() + reader := writer.Reader() importedSlot2 := utxoledger.New(mapdb.NewMapDB(), api.SingleVersionProvider(iotago_tpkg.TestAPI)) require.NoError(t, importedSlot2.Import(reader)) @@ -281,10 +281,10 @@ func TestManager_Import(t *testing.T) { // Test exporting and importing at slot 1 { - writer := &writerseeker.WriterSeeker{} + writer := stream.NewByteBuffer() require.NoError(t, manager.Export(writer, 1)) - reader := writer.BytesReader() + reader := writer.Reader() importedSlot1 := utxoledger.New(mapdb.NewMapDB(), api.SingleVersionProvider(iotago_tpkg.TestAPI)) require.NoError(t, importedSlot1.Import(reader)) @@ -298,10 +298,10 @@ func TestManager_Import(t *testing.T) { // Test exporting and importing at slot 0 { - writer := &writerseeker.WriterSeeker{} + writer := stream.NewByteBuffer() require.NoError(t, manager.Export(writer, 0)) - reader := writer.BytesReader() + reader := writer.Reader() importedSlot0 := utxoledger.New(mapdb.NewMapDB(), api.SingleVersionProvider(iotago_tpkg.TestAPI)) require.NoError(t, importedSlot0.Import(reader)) @@ -354,11 +354,10 @@ func TestManager_Export(t *testing.T) { // Test exporting at the current slot 2 { - // TODO: replace with our own BytesBuffer, adjust test to use stream API - writer := &writerseeker.WriterSeeker{} + writer := stream.NewByteBuffer() require.NoError(t, manager.Export(writer, 2)) - reader := writer.BytesReader() + reader := writer.Reader() var snapshotLedgerSlot iotago.SlotIndex require.NoError(t, binary.Read(reader, binary.LittleEndian, &snapshotLedgerSlot)) @@ -368,10 +367,6 @@ func TestManager_Export(t *testing.T) { require.NoError(t, binary.Read(reader, binary.LittleEndian, &outputCount)) require.Equal(t, uint64(8), outputCount) - var slotDiffCount uint64 - require.NoError(t, binary.Read(reader, binary.LittleEndian, &slotDiffCount)) - require.Equal(t, uint64(0), slotDiffCount) - var snapshotOutputs utxoledger.Outputs for i := uint64(0); i < outputCount; i++ { output, err := utxoledger.OutputFromSnapshotReader(reader, api.SingleVersionProvider(iotago_tpkg.TestAPI)) @@ -384,14 +379,18 @@ func TestManager_Export(t *testing.T) { require.NoError(t, err) tpkg.EqualOutputs(t, unspentOutputs, snapshotOutputs) + + var slotDiffCount uint64 + require.NoError(t, binary.Read(reader, binary.LittleEndian, &slotDiffCount)) + require.Equal(t, uint64(0), slotDiffCount) } // Test exporting at slot 1 { - writer := &writerseeker.WriterSeeker{} + writer := stream.NewByteBuffer() require.NoError(t, manager.Export(writer, 1)) - reader := writer.BytesReader() + reader := writer.Reader() var snapshotLedgerSlot iotago.SlotIndex require.NoError(t, binary.Read(reader, binary.LittleEndian, &snapshotLedgerSlot)) @@ -401,10 +400,6 @@ func TestManager_Export(t *testing.T) { require.NoError(t, binary.Read(reader, binary.LittleEndian, &outputCount)) require.Equal(t, uint64(8), outputCount) - var slotDiffCount uint64 - require.NoError(t, binary.Read(reader, binary.LittleEndian, &slotDiffCount)) - require.Equal(t, uint64(1), slotDiffCount) - var snapshotOutputs utxoledger.Outputs for i := uint64(0); i < outputCount; i++ { output, err := utxoledger.OutputFromSnapshotReader(reader, api.SingleVersionProvider(iotago_tpkg.TestAPI)) @@ -417,6 +412,10 @@ func TestManager_Export(t *testing.T) { tpkg.EqualOutputs(t, unspentOutputs, snapshotOutputs) + var slotDiffCount uint64 + require.NoError(t, binary.Read(reader, binary.LittleEndian, &slotDiffCount)) + require.Equal(t, uint64(1), slotDiffCount) + for i := uint64(0); i < slotDiffCount; i++ { diff, err := utxoledger.ReadSlotDiffToSnapshotReader(reader, api.SingleVersionProvider(iotago_tpkg.TestAPI)) require.NoError(t, err) @@ -426,10 +425,10 @@ func TestManager_Export(t *testing.T) { // Test exporting at slot 0 { - writer := &writerseeker.WriterSeeker{} + writer := stream.NewByteBuffer() require.NoError(t, manager.Export(writer, 0)) - reader := writer.BytesReader() + reader := writer.Reader() var snapshotLedgerSlot iotago.SlotIndex require.NoError(t, binary.Read(reader, binary.LittleEndian, &snapshotLedgerSlot)) @@ -439,10 +438,6 @@ func TestManager_Export(t *testing.T) { require.NoError(t, binary.Read(reader, binary.LittleEndian, &outputCount)) require.Equal(t, uint64(8), outputCount) - var slotDiffCount uint64 - require.NoError(t, binary.Read(reader, binary.LittleEndian, &slotDiffCount)) - require.Equal(t, uint64(2), slotDiffCount) - var snapshotOutputs utxoledger.Outputs for i := uint64(0); i < outputCount; i++ { output, err := utxoledger.OutputFromSnapshotReader(reader, api.SingleVersionProvider(iotago_tpkg.TestAPI)) @@ -455,6 +450,10 @@ func TestManager_Export(t *testing.T) { tpkg.EqualOutputs(t, unspentOutputs, snapshotOutputs) + var slotDiffCount uint64 + require.NoError(t, binary.Read(reader, binary.LittleEndian, &slotDiffCount)) + require.Equal(t, uint64(2), slotDiffCount) + for i := uint64(0); i < slotDiffCount; i++ { diff, err := utxoledger.ReadSlotDiffToSnapshotReader(reader, api.SingleVersionProvider(iotago_tpkg.TestAPI)) require.NoError(t, err) From 9cfc6730c803d6f45f8ae04cccc9b8c26714eb78 Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Mon, 6 Nov 2023 14:40:28 +0800 Subject: [PATCH 22/32] Update go.mod to latest hive.go --- go.mod | 30 +++++------ go.sum | 62 +++++++++++----------- pkg/storage/prunable/slotstore/retainer.go | 1 + tools/gendoc/go.mod | 30 +++++------ tools/gendoc/go.sum | 62 +++++++++++----------- tools/genesis-snapshot/go.mod | 26 ++++----- tools/genesis-snapshot/go.sum | 54 +++++++++---------- 7 files changed, 130 insertions(+), 135 deletions(-) diff --git a/go.mod b/go.mod index 953a30d0b..893f1a33c 100644 --- a/go.mod +++ b/go.mod @@ -10,22 +10,22 @@ require ( github.com/google/uuid v1.4.0 github.com/gorilla/websocket v1.5.0 github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 - github.com/iotaledger/hive.go/ads v0.0.0-20231027195901-620bd7470e42 - github.com/iotaledger/hive.go/app v0.0.0-20231027195901-620bd7470e42 - github.com/iotaledger/hive.go/constraints v0.0.0-20231027195901-620bd7470e42 - github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231027195901-620bd7470e42 - github.com/iotaledger/hive.go/crypto v0.0.0-20231027195901-620bd7470e42 - github.com/iotaledger/hive.go/ds v0.0.0-20231027195901-620bd7470e42 - github.com/iotaledger/hive.go/ierrors v0.0.0-20231027195901-620bd7470e42 - github.com/iotaledger/hive.go/kvstore v0.0.0-20231027195901-620bd7470e42 - github.com/iotaledger/hive.go/lo v0.0.0-20231027195901-620bd7470e42 - github.com/iotaledger/hive.go/logger v0.0.0-20231027195901-620bd7470e42 - github.com/iotaledger/hive.go/runtime v0.0.0-20231027195901-620bd7470e42 - github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231027195901-620bd7470e42 - github.com/iotaledger/hive.go/stringify v0.0.0-20231027195901-620bd7470e42 + github.com/iotaledger/hive.go/ads v0.0.0-20231106033111-7f3042d04fc4 + github.com/iotaledger/hive.go/app v0.0.0-20231106033111-7f3042d04fc4 + github.com/iotaledger/hive.go/constraints v0.0.0-20231106033111-7f3042d04fc4 + github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231106033111-7f3042d04fc4 + github.com/iotaledger/hive.go/crypto v0.0.0-20231106033111-7f3042d04fc4 + github.com/iotaledger/hive.go/ds v0.0.0-20231106033111-7f3042d04fc4 + github.com/iotaledger/hive.go/ierrors v0.0.0-20231106033111-7f3042d04fc4 + github.com/iotaledger/hive.go/kvstore v0.0.0-20231106033111-7f3042d04fc4 + github.com/iotaledger/hive.go/lo v0.0.0-20231106033111-7f3042d04fc4 + github.com/iotaledger/hive.go/logger v0.0.0-20231106033111-7f3042d04fc4 + github.com/iotaledger/hive.go/runtime v0.0.0-20231106033111-7f3042d04fc4 + github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231106033111-7f3042d04fc4 + github.com/iotaledger/hive.go/stringify v0.0.0-20231106033111-7f3042d04fc4 github.com/iotaledger/inx-app v1.0.0-rc.3.0.20231031135002-4c79ea5193f5 github.com/iotaledger/inx/go v1.0.0-rc.2.0.20231031134131-b6ad918dc1ac - github.com/iotaledger/iota.go/v4 v4.0.0-20231102113728-20b8d01e826e + github.com/iotaledger/iota.go/v4 v4.0.0-20231106063525-564529bf7361 github.com/labstack/echo/v4 v4.11.2 github.com/labstack/gommon v0.4.0 github.com/libp2p/go-libp2p v0.32.0 @@ -88,7 +88,7 @@ require ( github.com/huin/goupnp v1.3.0 // indirect github.com/iancoleman/orderedmap v0.3.0 // indirect github.com/iotaledger/grocksdb v1.7.5-0.20230220105546-5162e18885c7 // indirect - github.com/iotaledger/hive.go/log v0.0.0-20231027195901-620bd7470e42 // indirect + github.com/iotaledger/hive.go/log v0.0.0-20231106033111-7f3042d04fc4 // indirect github.com/ipfs/boxo v0.13.1 // indirect github.com/ipfs/go-cid v0.4.1 // indirect github.com/ipfs/go-datastore v0.6.0 // indirect diff --git a/go.sum b/go.sum index 2af6a376f..3d9bf76d3 100644 --- a/go.sum +++ b/go.sum @@ -275,40 +275,40 @@ github.com/iancoleman/orderedmap v0.3.0/go.mod h1:XuLcCUkdL5owUCQeF2Ue9uuw1EptkJ github.com/ianlancetaylor/demangle v0.0.0-20210905161508-09a460cdf81d/go.mod h1:aYm2/VgdVmcIU8iMfdMvDMsRAQjcfZSKFby6HOFvi/w= github.com/iotaledger/grocksdb v1.7.5-0.20230220105546-5162e18885c7 h1:dTrD7X2PTNgli6EbS4tV9qu3QAm/kBU3XaYZV2xdzys= github.com/iotaledger/grocksdb v1.7.5-0.20230220105546-5162e18885c7/go.mod h1:ZRdPu684P0fQ1z8sXz4dj9H5LWHhz4a9oCtvjunkSrw= -github.com/iotaledger/hive.go/ads v0.0.0-20231027195901-620bd7470e42 h1:EOfxTuAiBmED1VHuVh7/UIeB27cCRe13gdSzyioNMBw= -github.com/iotaledger/hive.go/ads v0.0.0-20231027195901-620bd7470e42/go.mod h1:IFh0gDfeMgZtfCo+5afK59IDR4xXh+cTR9YtLnZPcbY= -github.com/iotaledger/hive.go/app v0.0.0-20231027195901-620bd7470e42 h1:xAER9M9Uoz2EOWT43E9wmXRe+RmAk8OBSUoboH4Su8M= -github.com/iotaledger/hive.go/app v0.0.0-20231027195901-620bd7470e42/go.mod h1:8ZbIKR84oQd/3iQ5eeT7xpudO9/ytzXP7veIYnk7Orc= -github.com/iotaledger/hive.go/constraints v0.0.0-20231027195901-620bd7470e42 h1:drmpgLlJy7kZ09Dt1qKSnbILU+27Qu2jp4VdPDNwbFk= -github.com/iotaledger/hive.go/constraints v0.0.0-20231027195901-620bd7470e42/go.mod h1:dOBOM2s4se3HcWefPe8sQLUalGXJ8yVXw58oK8jke3s= -github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231027195901-620bd7470e42 h1:BC5GkIHyXdoJGdw6Tu5ds2kjw9grFLtwQiuMaKfdLU8= -github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231027195901-620bd7470e42/go.mod h1:Mc+ACqBGPxrPMIPUBOm6/HL0J6m0iVMwjtIEKW3uow8= -github.com/iotaledger/hive.go/crypto v0.0.0-20231027195901-620bd7470e42 h1:r8TkdQJB7/bJd8cF8z5GQ+rX/7JpbPdPoN7wMoV1OCM= -github.com/iotaledger/hive.go/crypto v0.0.0-20231027195901-620bd7470e42/go.mod h1:h3o6okvMSEK3KOX6pOp3yq1h9ohTkTfo6X8MzEadeb0= -github.com/iotaledger/hive.go/ds v0.0.0-20231027195901-620bd7470e42 h1:ytzZZPtclAzLfjxv26frbinCGx3Z6ouUENbx5U7lFGg= -github.com/iotaledger/hive.go/ds v0.0.0-20231027195901-620bd7470e42/go.mod h1:3XkUSKfHaVxGbT0XAvjNlVYqPzhfLTGhDtdNA5UBPco= -github.com/iotaledger/hive.go/ierrors v0.0.0-20231027195901-620bd7470e42 h1:QMxd32Y/veVhTDPCiOFgetjUbG7sr9MryF29/rSPkMA= -github.com/iotaledger/hive.go/ierrors v0.0.0-20231027195901-620bd7470e42/go.mod h1:HcE8B5lP96enc/OALTb2/rIIi+yOLouRoHOKRclKmC8= -github.com/iotaledger/hive.go/kvstore v0.0.0-20231027195901-620bd7470e42 h1:/xPwStUckZ2V0XPoY496cXU+c5elpHyvYoT6JAmuvRY= -github.com/iotaledger/hive.go/kvstore v0.0.0-20231027195901-620bd7470e42/go.mod h1:O/U3jtiUDeqqM0MZQFu2UPqS9fUm0C5hNISxlmg/thE= -github.com/iotaledger/hive.go/lo v0.0.0-20231027195901-620bd7470e42 h1:AvNLzONVMspwx7nD/NyYUgb5Hi7/zgzIOegr1uRD/M8= -github.com/iotaledger/hive.go/lo v0.0.0-20231027195901-620bd7470e42/go.mod h1:s4kzx9QY1MVWHJralj+3q5kI0eARtrJhphYD/iBbPfo= -github.com/iotaledger/hive.go/log v0.0.0-20231027195901-620bd7470e42 h1:e1uJAlXE3zeXpa+c4uFOG+/AMFbUlLt2mcrSK5NMxVs= -github.com/iotaledger/hive.go/log v0.0.0-20231027195901-620bd7470e42/go.mod h1:JvokzmpmFZPDskMlUqqjgHtD8usVJU4nAY/TNMGge8M= -github.com/iotaledger/hive.go/logger v0.0.0-20231027195901-620bd7470e42 h1:7wjs4t1snBDJ8LOTl+tZhr2ORywSOTgJMppxiIAMA0A= -github.com/iotaledger/hive.go/logger v0.0.0-20231027195901-620bd7470e42/go.mod h1:aBfAfIB2GO/IblhYt5ipCbyeL9bXSNeAwtYVA3hZaHg= -github.com/iotaledger/hive.go/runtime v0.0.0-20231027195901-620bd7470e42 h1:1QMJ39qXIx/IZVzus3+97IV7Pa++e+d340TvbMjhiBU= -github.com/iotaledger/hive.go/runtime v0.0.0-20231027195901-620bd7470e42/go.mod h1:jRw8yFipiPaqmTPHh7hTcxAP9u6pjRGpByS3REJKkbY= -github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231027195901-620bd7470e42 h1:hZli4E9kJUAEQ7gzZR1XbPcpgqvqMPYq8YBPMbrBuos= -github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231027195901-620bd7470e42/go.mod h1:SdK26z8/VhWtxaqCuQrufm80SELgowQPmu9T/8eUQ8g= -github.com/iotaledger/hive.go/stringify v0.0.0-20231027195901-620bd7470e42 h1:OlDhgvJ48bZxcvTeebJ1b96xtNnJAddejd2Q4rlH1mU= -github.com/iotaledger/hive.go/stringify v0.0.0-20231027195901-620bd7470e42/go.mod h1:FTo/UWzNYgnQ082GI9QVM9HFDERqf9rw9RivNpqrnTs= +github.com/iotaledger/hive.go/ads v0.0.0-20231106033111-7f3042d04fc4 h1:3F60Hx0Oi+4p7V5e+Ap8/aagbk0eSZ8jci4GxGXVLmc= +github.com/iotaledger/hive.go/ads v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:b8w/1e7wk7ZQgTm/2dZPH2pWl7CTlTmgkgaIleaZgFw= +github.com/iotaledger/hive.go/app v0.0.0-20231106033111-7f3042d04fc4 h1:XhqawtbvRagBjd9MTMtzVAnWggXEQF3Mj9cMPhiTXYg= +github.com/iotaledger/hive.go/app v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:iM05Js4OhYlTbQqwxbgMIuWq1TT+lfKntg0PeOE8zkU= +github.com/iotaledger/hive.go/constraints v0.0.0-20231106033111-7f3042d04fc4 h1:GS3d6xi8eiI9rIycajLs4z3vM/u0D9oJ2qEP8f/Mnmw= +github.com/iotaledger/hive.go/constraints v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:dOBOM2s4se3HcWefPe8sQLUalGXJ8yVXw58oK8jke3s= +github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231106033111-7f3042d04fc4 h1:xz1Vy5YujaXLL6Kx2gU7eueWGZPquimCGXBLimtCSak= +github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231106033111-7f3042d04fc4/go.mod h1:oBpjupsGbCg4WlK9HfXaF5RWtZvA4LmtmuLsMEcz+Qg= +github.com/iotaledger/hive.go/crypto v0.0.0-20231106033111-7f3042d04fc4 h1:3FNxPWFuNEdEJ17PoNS5ILTcg2b7wHDkLZx2lL3PhIE= +github.com/iotaledger/hive.go/crypto v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:ePC73xHcQdkbbHApVoF9XfLfjTtCuYJ8+WJepdRoUIw= +github.com/iotaledger/hive.go/ds v0.0.0-20231106033111-7f3042d04fc4 h1:eVNGVSEX/Z8CyTjUXD/QBSlevFSfu5rwdIJkjPULGeM= +github.com/iotaledger/hive.go/ds v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:RnYZNMRIXKt/SXVsFA18uUBNDZMQm0h5BykMXjv8/8A= +github.com/iotaledger/hive.go/ierrors v0.0.0-20231106033111-7f3042d04fc4 h1:yr8sRMURAjVQhWX+HgDm2AwgY2jH1JrZjOf49aUM8CQ= +github.com/iotaledger/hive.go/ierrors v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:HcE8B5lP96enc/OALTb2/rIIi+yOLouRoHOKRclKmC8= +github.com/iotaledger/hive.go/kvstore v0.0.0-20231106033111-7f3042d04fc4 h1:N21PVtaSvtG9Qq+3hLEj6Cca4Thx7YTa5ezKuqj3V0Y= +github.com/iotaledger/hive.go/kvstore v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:gQWd99xA2Wl4DpCqHIeieNUAKbRJDZo1VNnswAbibyA= +github.com/iotaledger/hive.go/lo v0.0.0-20231106033111-7f3042d04fc4 h1:bK0+pb716B9rBuXDp1+xKh5iX5wp00FF47UjTD+KphM= +github.com/iotaledger/hive.go/lo v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:lFKoK3stQVscy4k6+Cqd3Chq6u65JoTRhfhzJsmKyY8= +github.com/iotaledger/hive.go/log v0.0.0-20231106033111-7f3042d04fc4 h1:VJpxS4LePyDXJT1TRAVExm1ELmEH0t79NB08xEGyR/U= +github.com/iotaledger/hive.go/log v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:61LNutuzo3UnIgC9E8fPCIZ1Xwlb6ApbyTZssMl2cvI= +github.com/iotaledger/hive.go/logger v0.0.0-20231106033111-7f3042d04fc4 h1:jEcVfw96tzB8yjcHBIfc0qUXZvYkn4wu9/bWscgdlNc= +github.com/iotaledger/hive.go/logger v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:LOquQmtaz338r5ftNhYMpjcl0lpO6YtpXyVFbvNOrqs= +github.com/iotaledger/hive.go/runtime v0.0.0-20231106033111-7f3042d04fc4 h1:hOGlfCiQxIumcWMFxxAp13Ox//SQK0DGcXY3NJf7kGQ= +github.com/iotaledger/hive.go/runtime v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:6WKyYAkvdY08iW4/w30goNq0GaBTljT0MXXilnQ33wk= +github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231106033111-7f3042d04fc4 h1:CRNZkH8TuRIoCHDkfHGA09hpgT2cFFzj1Dys4ze61tI= +github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231106033111-7f3042d04fc4/go.mod h1:fW/lA6n0C/jf9B9NMX46eJXsJTU8Nzs+9oBWMTNzPzE= +github.com/iotaledger/hive.go/stringify v0.0.0-20231106033111-7f3042d04fc4 h1:xY4tsqeuZq/V8S3vYpuHJT6EdRgMGoFJkyFfxWV0ZPY= +github.com/iotaledger/hive.go/stringify v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:FTo/UWzNYgnQ082GI9QVM9HFDERqf9rw9RivNpqrnTs= github.com/iotaledger/inx-app v1.0.0-rc.3.0.20231031135002-4c79ea5193f5 h1:17JDzMKTMXKF3xys6gPURRddkZhg1LY+xwfhbr/sVqg= github.com/iotaledger/inx-app v1.0.0-rc.3.0.20231031135002-4c79ea5193f5/go.mod h1:LsJvoBUVVnY7tkwwByCVtAwmp5bFXdyJNGU/+KVQJVM= github.com/iotaledger/inx/go v1.0.0-rc.2.0.20231031134131-b6ad918dc1ac h1:c7R33+TQGMYP6pvLUQQaqpdDFl+GZbhAcfGMI0285fo= github.com/iotaledger/inx/go v1.0.0-rc.2.0.20231031134131-b6ad918dc1ac/go.mod h1:qPuMUvCTaghsnYRDnRoRuztTyEKFlmi2S7gb44rH7WM= -github.com/iotaledger/iota.go/v4 v4.0.0-20231102113728-20b8d01e826e h1:ZYRC1MHn/ghsqtjIpYGTxLQrh5n5eUmC0/YWnJiTRhk= -github.com/iotaledger/iota.go/v4 v4.0.0-20231102113728-20b8d01e826e/go.mod h1:jqbLYq4a/FwuiPBqFfkAwwxU8vs3+kReRq2/tyX5qRA= +github.com/iotaledger/iota.go/v4 v4.0.0-20231106063525-564529bf7361 h1:8uHWvSQpTa8FqakKkKwdppk46PUr/FJjFeupi9csa64= +github.com/iotaledger/iota.go/v4 v4.0.0-20231106063525-564529bf7361/go.mod h1:GXUQi5h4MAtPoBkJ/BRFakVbOiJeU76O0HcXl28mwK8= github.com/ipfs/boxo v0.13.1 h1:nQ5oQzcMZR3oL41REJDcTbrvDvuZh3J9ckc9+ILeRQI= github.com/ipfs/boxo v0.13.1/go.mod h1:btrtHy0lmO1ODMECbbEY1pxNtrLilvKSYLoGQt1yYCk= github.com/ipfs/go-cid v0.4.1 h1:A/T3qGvxi4kpKWWcPC/PgbvDA2bjVLO7n4UeVwnbs/s= @@ -507,8 +507,6 @@ github.com/opencontainers/runtime-spec v1.1.0/go.mod h1:jwyrGlmzljRJv/Fgzds9SsS/ github.com/opentracing/opentracing-go v1.2.0 h1:uEJPy/1a5RIPAJ0Ov+OIO8OxWu77jEv+1B0VhjKrZUs= github.com/opentracing/opentracing-go v1.2.0/go.mod h1:GxEUsuufX4nBwe+T+Wl9TAgYrxe9dPLANfrWvHYVTgc= github.com/openzipkin/zipkin-go v0.1.1/go.mod h1:NtoC/o8u3JlF1lSlyPNswIbeQH9bJTmOf0Erfk+hxe8= -github.com/orcaman/writerseeker v0.0.0-20200621085525-1d3f536ff85e h1:s2RNOM/IGdY0Y6qfTeUKhDawdHDpK9RGBdx80qN4Ttw= -github.com/orcaman/writerseeker v0.0.0-20200621085525-1d3f536ff85e/go.mod h1:nBdnFKj15wFbf94Rwfq4m30eAcyY9V/IyKAGQFtqkW0= github.com/otiai10/copy v1.14.0 h1:dCI/t1iTdYGtkvCuBG2BgR6KZa83PTclw4U5n2wAllU= github.com/otiai10/copy v1.14.0/go.mod h1:ECfuL02W+/FkTWZWgQqXPWZgW9oeKCSQ5qVfSc4qc4w= github.com/otiai10/mint v1.5.1 h1:XaPLeE+9vGbuyEHem1JNk3bYc7KKqyI/na0/mLd/Kks= diff --git a/pkg/storage/prunable/slotstore/retainer.go b/pkg/storage/prunable/slotstore/retainer.go index 09ec0de7d..646ed7913 100644 --- a/pkg/storage/prunable/slotstore/retainer.go +++ b/pkg/storage/prunable/slotstore/retainer.go @@ -62,6 +62,7 @@ func (t *TransactionRetainerData) Bytes() ([]byte, error) { if err := stream.Write(byteBuffer, t.FailureReason); err != nil { return nil, ierrors.Wrap(err, "failed to write transaction failure reason") } + return byteBuffer.Bytes() } diff --git a/tools/gendoc/go.mod b/tools/gendoc/go.mod index 4fdc2c0b0..146150577 100644 --- a/tools/gendoc/go.mod +++ b/tools/gendoc/go.mod @@ -5,7 +5,7 @@ go 1.21 replace github.com/iotaledger/iota-core => ../../ require ( - github.com/iotaledger/hive.go/app v0.0.0-20231027195901-620bd7470e42 + github.com/iotaledger/hive.go/app v0.0.0-20231106033111-7f3042d04fc4 github.com/iotaledger/hive.go/apputils v0.0.0-20230829152614-7afc7a4d89b3 github.com/iotaledger/iota-core v0.0.0-00010101000000-000000000000 ) @@ -57,22 +57,22 @@ require ( github.com/huin/goupnp v1.3.0 // indirect github.com/iancoleman/orderedmap v0.3.0 // indirect github.com/iotaledger/grocksdb v1.7.5-0.20230220105546-5162e18885c7 // indirect - github.com/iotaledger/hive.go/ads v0.0.0-20231027195901-620bd7470e42 // indirect - github.com/iotaledger/hive.go/constraints v0.0.0-20231027195901-620bd7470e42 // indirect - github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231027195901-620bd7470e42 // indirect - github.com/iotaledger/hive.go/crypto v0.0.0-20231027195901-620bd7470e42 // indirect - github.com/iotaledger/hive.go/ds v0.0.0-20231027195901-620bd7470e42 // indirect - github.com/iotaledger/hive.go/ierrors v0.0.0-20231027195901-620bd7470e42 // indirect - github.com/iotaledger/hive.go/kvstore v0.0.0-20231027195901-620bd7470e42 // indirect - github.com/iotaledger/hive.go/lo v0.0.0-20231027195901-620bd7470e42 // indirect - github.com/iotaledger/hive.go/log v0.0.0-20231027195901-620bd7470e42 // indirect - github.com/iotaledger/hive.go/logger v0.0.0-20231027195901-620bd7470e42 // indirect - github.com/iotaledger/hive.go/runtime v0.0.0-20231027195901-620bd7470e42 // indirect - github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231027195901-620bd7470e42 // indirect - github.com/iotaledger/hive.go/stringify v0.0.0-20231027195901-620bd7470e42 // indirect + github.com/iotaledger/hive.go/ads v0.0.0-20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/constraints v0.0.0-20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/crypto v0.0.0-20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/ds v0.0.0-20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/ierrors v0.0.0-20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/kvstore v0.0.0-20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/lo v0.0.0-20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/log v0.0.0-20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/logger v0.0.0-20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/runtime v0.0.0-20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/stringify v0.0.0-20231106033111-7f3042d04fc4 // indirect github.com/iotaledger/inx-app v1.0.0-rc.3.0.20231031135002-4c79ea5193f5 // indirect github.com/iotaledger/inx/go v1.0.0-rc.2.0.20231031134131-b6ad918dc1ac // indirect - github.com/iotaledger/iota.go/v4 v4.0.0-20231102113728-20b8d01e826e // indirect + github.com/iotaledger/iota.go/v4 v4.0.0-20231106063525-564529bf7361 // indirect github.com/ipfs/boxo v0.13.1 // indirect github.com/ipfs/go-cid v0.4.1 // indirect github.com/ipfs/go-datastore v0.6.0 // indirect diff --git a/tools/gendoc/go.sum b/tools/gendoc/go.sum index b16ac173a..4ea909f76 100644 --- a/tools/gendoc/go.sum +++ b/tools/gendoc/go.sum @@ -277,42 +277,42 @@ github.com/iancoleman/orderedmap v0.3.0/go.mod h1:XuLcCUkdL5owUCQeF2Ue9uuw1EptkJ github.com/ianlancetaylor/demangle v0.0.0-20210905161508-09a460cdf81d/go.mod h1:aYm2/VgdVmcIU8iMfdMvDMsRAQjcfZSKFby6HOFvi/w= github.com/iotaledger/grocksdb v1.7.5-0.20230220105546-5162e18885c7 h1:dTrD7X2PTNgli6EbS4tV9qu3QAm/kBU3XaYZV2xdzys= github.com/iotaledger/grocksdb v1.7.5-0.20230220105546-5162e18885c7/go.mod h1:ZRdPu684P0fQ1z8sXz4dj9H5LWHhz4a9oCtvjunkSrw= -github.com/iotaledger/hive.go/ads v0.0.0-20231027195901-620bd7470e42 h1:EOfxTuAiBmED1VHuVh7/UIeB27cCRe13gdSzyioNMBw= -github.com/iotaledger/hive.go/ads v0.0.0-20231027195901-620bd7470e42/go.mod h1:IFh0gDfeMgZtfCo+5afK59IDR4xXh+cTR9YtLnZPcbY= -github.com/iotaledger/hive.go/app v0.0.0-20231027195901-620bd7470e42 h1:xAER9M9Uoz2EOWT43E9wmXRe+RmAk8OBSUoboH4Su8M= -github.com/iotaledger/hive.go/app v0.0.0-20231027195901-620bd7470e42/go.mod h1:8ZbIKR84oQd/3iQ5eeT7xpudO9/ytzXP7veIYnk7Orc= +github.com/iotaledger/hive.go/ads v0.0.0-20231106033111-7f3042d04fc4 h1:3F60Hx0Oi+4p7V5e+Ap8/aagbk0eSZ8jci4GxGXVLmc= +github.com/iotaledger/hive.go/ads v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:b8w/1e7wk7ZQgTm/2dZPH2pWl7CTlTmgkgaIleaZgFw= +github.com/iotaledger/hive.go/app v0.0.0-20231106033111-7f3042d04fc4 h1:XhqawtbvRagBjd9MTMtzVAnWggXEQF3Mj9cMPhiTXYg= +github.com/iotaledger/hive.go/app v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:iM05Js4OhYlTbQqwxbgMIuWq1TT+lfKntg0PeOE8zkU= github.com/iotaledger/hive.go/apputils v0.0.0-20230829152614-7afc7a4d89b3 h1:4aVJTc0KS77uEw0Tny4r0n1ORwcbAQDECaCclgf/6lE= github.com/iotaledger/hive.go/apputils v0.0.0-20230829152614-7afc7a4d89b3/go.mod h1:TZeAqieDu+xDOZp2e9+S+8pZp1PrfgcwLUnxmd8IgLU= -github.com/iotaledger/hive.go/constraints v0.0.0-20231027195901-620bd7470e42 h1:drmpgLlJy7kZ09Dt1qKSnbILU+27Qu2jp4VdPDNwbFk= -github.com/iotaledger/hive.go/constraints v0.0.0-20231027195901-620bd7470e42/go.mod h1:dOBOM2s4se3HcWefPe8sQLUalGXJ8yVXw58oK8jke3s= -github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231027195901-620bd7470e42 h1:BC5GkIHyXdoJGdw6Tu5ds2kjw9grFLtwQiuMaKfdLU8= -github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231027195901-620bd7470e42/go.mod h1:Mc+ACqBGPxrPMIPUBOm6/HL0J6m0iVMwjtIEKW3uow8= -github.com/iotaledger/hive.go/crypto v0.0.0-20231027195901-620bd7470e42 h1:r8TkdQJB7/bJd8cF8z5GQ+rX/7JpbPdPoN7wMoV1OCM= -github.com/iotaledger/hive.go/crypto v0.0.0-20231027195901-620bd7470e42/go.mod h1:h3o6okvMSEK3KOX6pOp3yq1h9ohTkTfo6X8MzEadeb0= -github.com/iotaledger/hive.go/ds v0.0.0-20231027195901-620bd7470e42 h1:ytzZZPtclAzLfjxv26frbinCGx3Z6ouUENbx5U7lFGg= -github.com/iotaledger/hive.go/ds v0.0.0-20231027195901-620bd7470e42/go.mod h1:3XkUSKfHaVxGbT0XAvjNlVYqPzhfLTGhDtdNA5UBPco= -github.com/iotaledger/hive.go/ierrors v0.0.0-20231027195901-620bd7470e42 h1:QMxd32Y/veVhTDPCiOFgetjUbG7sr9MryF29/rSPkMA= -github.com/iotaledger/hive.go/ierrors v0.0.0-20231027195901-620bd7470e42/go.mod h1:HcE8B5lP96enc/OALTb2/rIIi+yOLouRoHOKRclKmC8= -github.com/iotaledger/hive.go/kvstore v0.0.0-20231027195901-620bd7470e42 h1:/xPwStUckZ2V0XPoY496cXU+c5elpHyvYoT6JAmuvRY= -github.com/iotaledger/hive.go/kvstore v0.0.0-20231027195901-620bd7470e42/go.mod h1:O/U3jtiUDeqqM0MZQFu2UPqS9fUm0C5hNISxlmg/thE= -github.com/iotaledger/hive.go/lo v0.0.0-20231027195901-620bd7470e42 h1:AvNLzONVMspwx7nD/NyYUgb5Hi7/zgzIOegr1uRD/M8= -github.com/iotaledger/hive.go/lo v0.0.0-20231027195901-620bd7470e42/go.mod h1:s4kzx9QY1MVWHJralj+3q5kI0eARtrJhphYD/iBbPfo= -github.com/iotaledger/hive.go/log v0.0.0-20231027195901-620bd7470e42 h1:e1uJAlXE3zeXpa+c4uFOG+/AMFbUlLt2mcrSK5NMxVs= -github.com/iotaledger/hive.go/log v0.0.0-20231027195901-620bd7470e42/go.mod h1:JvokzmpmFZPDskMlUqqjgHtD8usVJU4nAY/TNMGge8M= -github.com/iotaledger/hive.go/logger v0.0.0-20231027195901-620bd7470e42 h1:7wjs4t1snBDJ8LOTl+tZhr2ORywSOTgJMppxiIAMA0A= -github.com/iotaledger/hive.go/logger v0.0.0-20231027195901-620bd7470e42/go.mod h1:aBfAfIB2GO/IblhYt5ipCbyeL9bXSNeAwtYVA3hZaHg= -github.com/iotaledger/hive.go/runtime v0.0.0-20231027195901-620bd7470e42 h1:1QMJ39qXIx/IZVzus3+97IV7Pa++e+d340TvbMjhiBU= -github.com/iotaledger/hive.go/runtime v0.0.0-20231027195901-620bd7470e42/go.mod h1:jRw8yFipiPaqmTPHh7hTcxAP9u6pjRGpByS3REJKkbY= -github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231027195901-620bd7470e42 h1:hZli4E9kJUAEQ7gzZR1XbPcpgqvqMPYq8YBPMbrBuos= -github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231027195901-620bd7470e42/go.mod h1:SdK26z8/VhWtxaqCuQrufm80SELgowQPmu9T/8eUQ8g= -github.com/iotaledger/hive.go/stringify v0.0.0-20231027195901-620bd7470e42 h1:OlDhgvJ48bZxcvTeebJ1b96xtNnJAddejd2Q4rlH1mU= -github.com/iotaledger/hive.go/stringify v0.0.0-20231027195901-620bd7470e42/go.mod h1:FTo/UWzNYgnQ082GI9QVM9HFDERqf9rw9RivNpqrnTs= +github.com/iotaledger/hive.go/constraints v0.0.0-20231106033111-7f3042d04fc4 h1:GS3d6xi8eiI9rIycajLs4z3vM/u0D9oJ2qEP8f/Mnmw= +github.com/iotaledger/hive.go/constraints v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:dOBOM2s4se3HcWefPe8sQLUalGXJ8yVXw58oK8jke3s= +github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231106033111-7f3042d04fc4 h1:xz1Vy5YujaXLL6Kx2gU7eueWGZPquimCGXBLimtCSak= +github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231106033111-7f3042d04fc4/go.mod h1:oBpjupsGbCg4WlK9HfXaF5RWtZvA4LmtmuLsMEcz+Qg= +github.com/iotaledger/hive.go/crypto v0.0.0-20231106033111-7f3042d04fc4 h1:3FNxPWFuNEdEJ17PoNS5ILTcg2b7wHDkLZx2lL3PhIE= +github.com/iotaledger/hive.go/crypto v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:ePC73xHcQdkbbHApVoF9XfLfjTtCuYJ8+WJepdRoUIw= +github.com/iotaledger/hive.go/ds v0.0.0-20231106033111-7f3042d04fc4 h1:eVNGVSEX/Z8CyTjUXD/QBSlevFSfu5rwdIJkjPULGeM= +github.com/iotaledger/hive.go/ds v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:RnYZNMRIXKt/SXVsFA18uUBNDZMQm0h5BykMXjv8/8A= +github.com/iotaledger/hive.go/ierrors v0.0.0-20231106033111-7f3042d04fc4 h1:yr8sRMURAjVQhWX+HgDm2AwgY2jH1JrZjOf49aUM8CQ= +github.com/iotaledger/hive.go/ierrors v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:HcE8B5lP96enc/OALTb2/rIIi+yOLouRoHOKRclKmC8= +github.com/iotaledger/hive.go/kvstore v0.0.0-20231106033111-7f3042d04fc4 h1:N21PVtaSvtG9Qq+3hLEj6Cca4Thx7YTa5ezKuqj3V0Y= +github.com/iotaledger/hive.go/kvstore v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:gQWd99xA2Wl4DpCqHIeieNUAKbRJDZo1VNnswAbibyA= +github.com/iotaledger/hive.go/lo v0.0.0-20231106033111-7f3042d04fc4 h1:bK0+pb716B9rBuXDp1+xKh5iX5wp00FF47UjTD+KphM= +github.com/iotaledger/hive.go/lo v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:lFKoK3stQVscy4k6+Cqd3Chq6u65JoTRhfhzJsmKyY8= +github.com/iotaledger/hive.go/log v0.0.0-20231106033111-7f3042d04fc4 h1:VJpxS4LePyDXJT1TRAVExm1ELmEH0t79NB08xEGyR/U= +github.com/iotaledger/hive.go/log v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:61LNutuzo3UnIgC9E8fPCIZ1Xwlb6ApbyTZssMl2cvI= +github.com/iotaledger/hive.go/logger v0.0.0-20231106033111-7f3042d04fc4 h1:jEcVfw96tzB8yjcHBIfc0qUXZvYkn4wu9/bWscgdlNc= +github.com/iotaledger/hive.go/logger v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:LOquQmtaz338r5ftNhYMpjcl0lpO6YtpXyVFbvNOrqs= +github.com/iotaledger/hive.go/runtime v0.0.0-20231106033111-7f3042d04fc4 h1:hOGlfCiQxIumcWMFxxAp13Ox//SQK0DGcXY3NJf7kGQ= +github.com/iotaledger/hive.go/runtime v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:6WKyYAkvdY08iW4/w30goNq0GaBTljT0MXXilnQ33wk= +github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231106033111-7f3042d04fc4 h1:CRNZkH8TuRIoCHDkfHGA09hpgT2cFFzj1Dys4ze61tI= +github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231106033111-7f3042d04fc4/go.mod h1:fW/lA6n0C/jf9B9NMX46eJXsJTU8Nzs+9oBWMTNzPzE= +github.com/iotaledger/hive.go/stringify v0.0.0-20231106033111-7f3042d04fc4 h1:xY4tsqeuZq/V8S3vYpuHJT6EdRgMGoFJkyFfxWV0ZPY= +github.com/iotaledger/hive.go/stringify v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:FTo/UWzNYgnQ082GI9QVM9HFDERqf9rw9RivNpqrnTs= github.com/iotaledger/inx-app v1.0.0-rc.3.0.20231031135002-4c79ea5193f5 h1:17JDzMKTMXKF3xys6gPURRddkZhg1LY+xwfhbr/sVqg= github.com/iotaledger/inx-app v1.0.0-rc.3.0.20231031135002-4c79ea5193f5/go.mod h1:LsJvoBUVVnY7tkwwByCVtAwmp5bFXdyJNGU/+KVQJVM= github.com/iotaledger/inx/go v1.0.0-rc.2.0.20231031134131-b6ad918dc1ac h1:c7R33+TQGMYP6pvLUQQaqpdDFl+GZbhAcfGMI0285fo= github.com/iotaledger/inx/go v1.0.0-rc.2.0.20231031134131-b6ad918dc1ac/go.mod h1:qPuMUvCTaghsnYRDnRoRuztTyEKFlmi2S7gb44rH7WM= -github.com/iotaledger/iota.go/v4 v4.0.0-20231102113728-20b8d01e826e h1:ZYRC1MHn/ghsqtjIpYGTxLQrh5n5eUmC0/YWnJiTRhk= -github.com/iotaledger/iota.go/v4 v4.0.0-20231102113728-20b8d01e826e/go.mod h1:jqbLYq4a/FwuiPBqFfkAwwxU8vs3+kReRq2/tyX5qRA= +github.com/iotaledger/iota.go/v4 v4.0.0-20231106063525-564529bf7361 h1:8uHWvSQpTa8FqakKkKwdppk46PUr/FJjFeupi9csa64= +github.com/iotaledger/iota.go/v4 v4.0.0-20231106063525-564529bf7361/go.mod h1:GXUQi5h4MAtPoBkJ/BRFakVbOiJeU76O0HcXl28mwK8= github.com/ipfs/boxo v0.13.1 h1:nQ5oQzcMZR3oL41REJDcTbrvDvuZh3J9ckc9+ILeRQI= github.com/ipfs/boxo v0.13.1/go.mod h1:btrtHy0lmO1ODMECbbEY1pxNtrLilvKSYLoGQt1yYCk= github.com/ipfs/go-cid v0.4.1 h1:A/T3qGvxi4kpKWWcPC/PgbvDA2bjVLO7n4UeVwnbs/s= @@ -511,8 +511,6 @@ github.com/opencontainers/runtime-spec v1.1.0/go.mod h1:jwyrGlmzljRJv/Fgzds9SsS/ github.com/opentracing/opentracing-go v1.2.0 h1:uEJPy/1a5RIPAJ0Ov+OIO8OxWu77jEv+1B0VhjKrZUs= github.com/opentracing/opentracing-go v1.2.0/go.mod h1:GxEUsuufX4nBwe+T+Wl9TAgYrxe9dPLANfrWvHYVTgc= github.com/openzipkin/zipkin-go v0.1.1/go.mod h1:NtoC/o8u3JlF1lSlyPNswIbeQH9bJTmOf0Erfk+hxe8= -github.com/orcaman/writerseeker v0.0.0-20200621085525-1d3f536ff85e h1:s2RNOM/IGdY0Y6qfTeUKhDawdHDpK9RGBdx80qN4Ttw= -github.com/orcaman/writerseeker v0.0.0-20200621085525-1d3f536ff85e/go.mod h1:nBdnFKj15wFbf94Rwfq4m30eAcyY9V/IyKAGQFtqkW0= github.com/otiai10/copy v1.14.0 h1:dCI/t1iTdYGtkvCuBG2BgR6KZa83PTclw4U5n2wAllU= github.com/otiai10/copy v1.14.0/go.mod h1:ECfuL02W+/FkTWZWgQqXPWZgW9oeKCSQ5qVfSc4qc4w= github.com/otiai10/mint v1.5.1 h1:XaPLeE+9vGbuyEHem1JNk3bYc7KKqyI/na0/mLd/Kks= diff --git a/tools/genesis-snapshot/go.mod b/tools/genesis-snapshot/go.mod index 1ec9104e2..ff9d54043 100644 --- a/tools/genesis-snapshot/go.mod +++ b/tools/genesis-snapshot/go.mod @@ -5,12 +5,12 @@ go 1.21 replace github.com/iotaledger/iota-core => ../../ require ( - github.com/iotaledger/hive.go/crypto v0.0.0-20231027195901-620bd7470e42 - github.com/iotaledger/hive.go/ierrors v0.0.0-20231027195901-620bd7470e42 - github.com/iotaledger/hive.go/lo v0.0.0-20231027195901-620bd7470e42 - github.com/iotaledger/hive.go/runtime v0.0.0-20231027195901-620bd7470e42 + github.com/iotaledger/hive.go/crypto v0.0.0-20231106033111-7f3042d04fc4 + github.com/iotaledger/hive.go/ierrors v0.0.0-20231106033111-7f3042d04fc4 + github.com/iotaledger/hive.go/lo v0.0.0-20231106033111-7f3042d04fc4 + github.com/iotaledger/hive.go/runtime v0.0.0-20231106033111-7f3042d04fc4 github.com/iotaledger/iota-core v0.0.0-00010101000000-000000000000 - github.com/iotaledger/iota.go/v4 v4.0.0-20231102113728-20b8d01e826e + github.com/iotaledger/iota.go/v4 v4.0.0-20231106063525-564529bf7361 github.com/mr-tron/base58 v1.2.0 github.com/spf13/pflag v1.0.5 golang.org/x/crypto v0.14.0 @@ -26,14 +26,14 @@ require ( github.com/holiman/uint256 v1.2.3 // indirect github.com/iancoleman/orderedmap v0.3.0 // indirect github.com/iotaledger/grocksdb v1.7.5-0.20230220105546-5162e18885c7 // indirect - github.com/iotaledger/hive.go/ads v0.0.0-20231027195901-620bd7470e42 // indirect - github.com/iotaledger/hive.go/constraints v0.0.0-20231027195901-620bd7470e42 // indirect - github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231027195901-620bd7470e42 // indirect - github.com/iotaledger/hive.go/ds v0.0.0-20231027195901-620bd7470e42 // indirect - github.com/iotaledger/hive.go/kvstore v0.0.0-20231027195901-620bd7470e42 // indirect - github.com/iotaledger/hive.go/log v0.0.0-20231027195901-620bd7470e42 // indirect - github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231027195901-620bd7470e42 // indirect - github.com/iotaledger/hive.go/stringify v0.0.0-20231027195901-620bd7470e42 // indirect + github.com/iotaledger/hive.go/ads v0.0.0-20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/constraints v0.0.0-20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/ds v0.0.0-20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/kvstore v0.0.0-20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/log v0.0.0-20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/stringify v0.0.0-20231106033111-7f3042d04fc4 // indirect github.com/ipfs/go-cid v0.4.1 // indirect github.com/klauspost/cpuid/v2 v2.2.5 // indirect github.com/kr/text v0.2.0 // indirect diff --git a/tools/genesis-snapshot/go.sum b/tools/genesis-snapshot/go.sum index 00953620a..fc84bc411 100644 --- a/tools/genesis-snapshot/go.sum +++ b/tools/genesis-snapshot/go.sum @@ -28,32 +28,32 @@ github.com/iancoleman/orderedmap v0.3.0 h1:5cbR2grmZR/DiVt+VJopEhtVs9YGInGIxAoMJ github.com/iancoleman/orderedmap v0.3.0/go.mod h1:XuLcCUkdL5owUCQeF2Ue9uuw1EptkJDkXXS7VoV7XGE= github.com/iotaledger/grocksdb v1.7.5-0.20230220105546-5162e18885c7 h1:dTrD7X2PTNgli6EbS4tV9qu3QAm/kBU3XaYZV2xdzys= github.com/iotaledger/grocksdb v1.7.5-0.20230220105546-5162e18885c7/go.mod h1:ZRdPu684P0fQ1z8sXz4dj9H5LWHhz4a9oCtvjunkSrw= -github.com/iotaledger/hive.go/ads v0.0.0-20231027195901-620bd7470e42 h1:EOfxTuAiBmED1VHuVh7/UIeB27cCRe13gdSzyioNMBw= -github.com/iotaledger/hive.go/ads v0.0.0-20231027195901-620bd7470e42/go.mod h1:IFh0gDfeMgZtfCo+5afK59IDR4xXh+cTR9YtLnZPcbY= -github.com/iotaledger/hive.go/constraints v0.0.0-20231027195901-620bd7470e42 h1:drmpgLlJy7kZ09Dt1qKSnbILU+27Qu2jp4VdPDNwbFk= -github.com/iotaledger/hive.go/constraints v0.0.0-20231027195901-620bd7470e42/go.mod h1:dOBOM2s4se3HcWefPe8sQLUalGXJ8yVXw58oK8jke3s= -github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231027195901-620bd7470e42 h1:BC5GkIHyXdoJGdw6Tu5ds2kjw9grFLtwQiuMaKfdLU8= -github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231027195901-620bd7470e42/go.mod h1:Mc+ACqBGPxrPMIPUBOm6/HL0J6m0iVMwjtIEKW3uow8= -github.com/iotaledger/hive.go/crypto v0.0.0-20231027195901-620bd7470e42 h1:r8TkdQJB7/bJd8cF8z5GQ+rX/7JpbPdPoN7wMoV1OCM= -github.com/iotaledger/hive.go/crypto v0.0.0-20231027195901-620bd7470e42/go.mod h1:h3o6okvMSEK3KOX6pOp3yq1h9ohTkTfo6X8MzEadeb0= -github.com/iotaledger/hive.go/ds v0.0.0-20231027195901-620bd7470e42 h1:ytzZZPtclAzLfjxv26frbinCGx3Z6ouUENbx5U7lFGg= -github.com/iotaledger/hive.go/ds v0.0.0-20231027195901-620bd7470e42/go.mod h1:3XkUSKfHaVxGbT0XAvjNlVYqPzhfLTGhDtdNA5UBPco= -github.com/iotaledger/hive.go/ierrors v0.0.0-20231027195901-620bd7470e42 h1:QMxd32Y/veVhTDPCiOFgetjUbG7sr9MryF29/rSPkMA= -github.com/iotaledger/hive.go/ierrors v0.0.0-20231027195901-620bd7470e42/go.mod h1:HcE8B5lP96enc/OALTb2/rIIi+yOLouRoHOKRclKmC8= -github.com/iotaledger/hive.go/kvstore v0.0.0-20231027195901-620bd7470e42 h1:/xPwStUckZ2V0XPoY496cXU+c5elpHyvYoT6JAmuvRY= -github.com/iotaledger/hive.go/kvstore v0.0.0-20231027195901-620bd7470e42/go.mod h1:O/U3jtiUDeqqM0MZQFu2UPqS9fUm0C5hNISxlmg/thE= -github.com/iotaledger/hive.go/lo v0.0.0-20231027195901-620bd7470e42 h1:AvNLzONVMspwx7nD/NyYUgb5Hi7/zgzIOegr1uRD/M8= -github.com/iotaledger/hive.go/lo v0.0.0-20231027195901-620bd7470e42/go.mod h1:s4kzx9QY1MVWHJralj+3q5kI0eARtrJhphYD/iBbPfo= -github.com/iotaledger/hive.go/log v0.0.0-20231027195901-620bd7470e42 h1:e1uJAlXE3zeXpa+c4uFOG+/AMFbUlLt2mcrSK5NMxVs= -github.com/iotaledger/hive.go/log v0.0.0-20231027195901-620bd7470e42/go.mod h1:JvokzmpmFZPDskMlUqqjgHtD8usVJU4nAY/TNMGge8M= -github.com/iotaledger/hive.go/runtime v0.0.0-20231027195901-620bd7470e42 h1:1QMJ39qXIx/IZVzus3+97IV7Pa++e+d340TvbMjhiBU= -github.com/iotaledger/hive.go/runtime v0.0.0-20231027195901-620bd7470e42/go.mod h1:jRw8yFipiPaqmTPHh7hTcxAP9u6pjRGpByS3REJKkbY= -github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231027195901-620bd7470e42 h1:hZli4E9kJUAEQ7gzZR1XbPcpgqvqMPYq8YBPMbrBuos= -github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231027195901-620bd7470e42/go.mod h1:SdK26z8/VhWtxaqCuQrufm80SELgowQPmu9T/8eUQ8g= -github.com/iotaledger/hive.go/stringify v0.0.0-20231027195901-620bd7470e42 h1:OlDhgvJ48bZxcvTeebJ1b96xtNnJAddejd2Q4rlH1mU= -github.com/iotaledger/hive.go/stringify v0.0.0-20231027195901-620bd7470e42/go.mod h1:FTo/UWzNYgnQ082GI9QVM9HFDERqf9rw9RivNpqrnTs= -github.com/iotaledger/iota.go/v4 v4.0.0-20231102113728-20b8d01e826e h1:ZYRC1MHn/ghsqtjIpYGTxLQrh5n5eUmC0/YWnJiTRhk= -github.com/iotaledger/iota.go/v4 v4.0.0-20231102113728-20b8d01e826e/go.mod h1:jqbLYq4a/FwuiPBqFfkAwwxU8vs3+kReRq2/tyX5qRA= +github.com/iotaledger/hive.go/ads v0.0.0-20231106033111-7f3042d04fc4 h1:3F60Hx0Oi+4p7V5e+Ap8/aagbk0eSZ8jci4GxGXVLmc= +github.com/iotaledger/hive.go/ads v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:b8w/1e7wk7ZQgTm/2dZPH2pWl7CTlTmgkgaIleaZgFw= +github.com/iotaledger/hive.go/constraints v0.0.0-20231106033111-7f3042d04fc4 h1:GS3d6xi8eiI9rIycajLs4z3vM/u0D9oJ2qEP8f/Mnmw= +github.com/iotaledger/hive.go/constraints v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:dOBOM2s4se3HcWefPe8sQLUalGXJ8yVXw58oK8jke3s= +github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231106033111-7f3042d04fc4 h1:xz1Vy5YujaXLL6Kx2gU7eueWGZPquimCGXBLimtCSak= +github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231106033111-7f3042d04fc4/go.mod h1:oBpjupsGbCg4WlK9HfXaF5RWtZvA4LmtmuLsMEcz+Qg= +github.com/iotaledger/hive.go/crypto v0.0.0-20231106033111-7f3042d04fc4 h1:3FNxPWFuNEdEJ17PoNS5ILTcg2b7wHDkLZx2lL3PhIE= +github.com/iotaledger/hive.go/crypto v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:ePC73xHcQdkbbHApVoF9XfLfjTtCuYJ8+WJepdRoUIw= +github.com/iotaledger/hive.go/ds v0.0.0-20231106033111-7f3042d04fc4 h1:eVNGVSEX/Z8CyTjUXD/QBSlevFSfu5rwdIJkjPULGeM= +github.com/iotaledger/hive.go/ds v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:RnYZNMRIXKt/SXVsFA18uUBNDZMQm0h5BykMXjv8/8A= +github.com/iotaledger/hive.go/ierrors v0.0.0-20231106033111-7f3042d04fc4 h1:yr8sRMURAjVQhWX+HgDm2AwgY2jH1JrZjOf49aUM8CQ= +github.com/iotaledger/hive.go/ierrors v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:HcE8B5lP96enc/OALTb2/rIIi+yOLouRoHOKRclKmC8= +github.com/iotaledger/hive.go/kvstore v0.0.0-20231106033111-7f3042d04fc4 h1:N21PVtaSvtG9Qq+3hLEj6Cca4Thx7YTa5ezKuqj3V0Y= +github.com/iotaledger/hive.go/kvstore v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:gQWd99xA2Wl4DpCqHIeieNUAKbRJDZo1VNnswAbibyA= +github.com/iotaledger/hive.go/lo v0.0.0-20231106033111-7f3042d04fc4 h1:bK0+pb716B9rBuXDp1+xKh5iX5wp00FF47UjTD+KphM= +github.com/iotaledger/hive.go/lo v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:lFKoK3stQVscy4k6+Cqd3Chq6u65JoTRhfhzJsmKyY8= +github.com/iotaledger/hive.go/log v0.0.0-20231106033111-7f3042d04fc4 h1:VJpxS4LePyDXJT1TRAVExm1ELmEH0t79NB08xEGyR/U= +github.com/iotaledger/hive.go/log v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:61LNutuzo3UnIgC9E8fPCIZ1Xwlb6ApbyTZssMl2cvI= +github.com/iotaledger/hive.go/runtime v0.0.0-20231106033111-7f3042d04fc4 h1:hOGlfCiQxIumcWMFxxAp13Ox//SQK0DGcXY3NJf7kGQ= +github.com/iotaledger/hive.go/runtime v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:6WKyYAkvdY08iW4/w30goNq0GaBTljT0MXXilnQ33wk= +github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231106033111-7f3042d04fc4 h1:CRNZkH8TuRIoCHDkfHGA09hpgT2cFFzj1Dys4ze61tI= +github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231106033111-7f3042d04fc4/go.mod h1:fW/lA6n0C/jf9B9NMX46eJXsJTU8Nzs+9oBWMTNzPzE= +github.com/iotaledger/hive.go/stringify v0.0.0-20231106033111-7f3042d04fc4 h1:xY4tsqeuZq/V8S3vYpuHJT6EdRgMGoFJkyFfxWV0ZPY= +github.com/iotaledger/hive.go/stringify v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:FTo/UWzNYgnQ082GI9QVM9HFDERqf9rw9RivNpqrnTs= +github.com/iotaledger/iota.go/v4 v4.0.0-20231106063525-564529bf7361 h1:8uHWvSQpTa8FqakKkKwdppk46PUr/FJjFeupi9csa64= +github.com/iotaledger/iota.go/v4 v4.0.0-20231106063525-564529bf7361/go.mod h1:GXUQi5h4MAtPoBkJ/BRFakVbOiJeU76O0HcXl28mwK8= github.com/ipfs/go-cid v0.4.1 h1:A/T3qGvxi4kpKWWcPC/PgbvDA2bjVLO7n4UeVwnbs/s= github.com/ipfs/go-cid v0.4.1/go.mod h1:uQHwDeX4c6CtyrFwdqyhpNcxVewur1M7l7fNU7LKwZk= github.com/klauspost/cpuid/v2 v2.2.5 h1:0E5MSMDEoAulmXNFquVs//DdoomxaoTY1kUhbc/qbZg= @@ -84,8 +84,6 @@ github.com/multiformats/go-multihash v0.2.3 h1:7Lyc8XfX/IY2jWb/gI7JP+o7JEq9hOa7B github.com/multiformats/go-multihash v0.2.3/go.mod h1:dXgKXCXjBzdscBLk9JkjINiEsCKRVch90MdaGiKsvSM= github.com/multiformats/go-varint v0.0.7 h1:sWSGR+f/eu5ABZA2ZpYKBILXTTs9JWpdEM/nEGOHFS8= github.com/multiformats/go-varint v0.0.7/go.mod h1:r8PUYw/fD/SjBCiKOoDlGF6QawOELpZAu9eioSos/OU= -github.com/orcaman/writerseeker v0.0.0-20200621085525-1d3f536ff85e h1:s2RNOM/IGdY0Y6qfTeUKhDawdHDpK9RGBdx80qN4Ttw= -github.com/orcaman/writerseeker v0.0.0-20200621085525-1d3f536ff85e/go.mod h1:nBdnFKj15wFbf94Rwfq4m30eAcyY9V/IyKAGQFtqkW0= github.com/otiai10/copy v1.14.0 h1:dCI/t1iTdYGtkvCuBG2BgR6KZa83PTclw4U5n2wAllU= github.com/otiai10/copy v1.14.0/go.mod h1:ECfuL02W+/FkTWZWgQqXPWZgW9oeKCSQ5qVfSc4qc4w= github.com/otiai10/mint v1.5.1 h1:XaPLeE+9vGbuyEHem1JNk3bYc7KKqyI/na0/mLd/Kks= From 82f433ea82d846bc9638890d92c925de5ec91baf Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Mon, 6 Nov 2023 15:52:22 +0800 Subject: [PATCH 23/32] Fix bug with wrong serializer.SeriLengthPrefixType --- pkg/network/peer.go | 12 ++++++------ pkg/network/protocols/core/protocol.go | 4 ++-- tools/docker-network/run.sh | 2 +- 3 files changed, 9 insertions(+), 9 deletions(-) diff --git a/pkg/network/peer.go b/pkg/network/peer.go index b52410792..18554f10d 100644 --- a/pkg/network/peer.go +++ b/pkg/network/peer.go @@ -81,15 +81,15 @@ func (p *Peer) SetConnStatus(cs ConnectionStatus) { func (p *Peer) Bytes() ([]byte, error) { byteBuffer := stream.NewByteBuffer() - if err := stream.WriteObjectWithSize(byteBuffer, p.ID, serializer.UInt16ByteSize, func(id peer.ID) ([]byte, error) { + if err := stream.WriteObjectWithSize(byteBuffer, p.ID, serializer.SeriLengthPrefixTypeAsUint16, func(id peer.ID) ([]byte, error) { return []byte(id), nil }); err != nil { return nil, ierrors.Wrap(err, "failed to write peer ID") } - if err := stream.WriteCollection(byteBuffer, serializer.OneByte, func() (elementsCount int, err error) { + if err := stream.WriteCollection(byteBuffer, serializer.SeriLengthPrefixTypeAsByte, func() (elementsCount int, err error) { for _, addr := range p.PeerAddresses { - if err = stream.WriteObjectWithSize(byteBuffer, addr, serializer.UInt16ByteSize, func(m multiaddr.Multiaddr) ([]byte, error) { + if err = stream.WriteObjectWithSize(byteBuffer, addr, serializer.SeriLengthPrefixTypeAsUint16, func(m multiaddr.Multiaddr) ([]byte, error) { return m.Bytes(), nil }); err != nil { return 0, ierrors.Wrap(err, "failed to write peer address") @@ -120,7 +120,7 @@ func peerFromBytes(bytes []byte) (*Peer, error) { var err error byteReader := stream.NewByteReader(bytes) - if p.ID, err = stream.ReadObjectWithSize(byteReader, serializer.UInt16ByteSize, func(bytes []byte) (peer.ID, int, error) { + if p.ID, err = stream.ReadObjectWithSize(byteReader, serializer.SeriLengthPrefixTypeAsUint16, func(bytes []byte) (peer.ID, int, error) { id, err := peer.IDFromBytes(bytes) if err != nil { return "", 0, ierrors.Wrap(err, "failed to parse peerID") @@ -133,8 +133,8 @@ func peerFromBytes(bytes []byte) (*Peer, error) { p.SetConnStatus(ConnStatusDisconnected) - if err = stream.ReadCollection(byteReader, serializer.OneByte, func(i int) error { - addr, err := stream.ReadObjectWithSize(byteReader, serializer.UInt16ByteSize, func(bytes []byte) (multiaddr.Multiaddr, int, error) { + if err = stream.ReadCollection(byteReader, serializer.SeriLengthPrefixTypeAsByte, func(i int) error { + addr, err := stream.ReadObjectWithSize(byteReader, serializer.SeriLengthPrefixTypeAsUint16, func(bytes []byte) (multiaddr.Multiaddr, int, error) { m, err := multiaddr.NewMultiaddrBytes(bytes) if err != nil { return nil, 0, ierrors.Wrap(err, "failed to parse peer address") diff --git a/pkg/network/protocols/core/protocol.go b/pkg/network/protocols/core/protocol.go index b19b168a0..6aa663abc 100644 --- a/pkg/network/protocols/core/protocol.go +++ b/pkg/network/protocols/core/protocol.go @@ -76,9 +76,9 @@ func (p *Protocol) SendSlotCommitment(cm *model.Commitment, to ...peer.ID) { func (p *Protocol) SendAttestations(cm *model.Commitment, attestations []*iotago.Attestation, merkleProof *merklehasher.Proof[iotago.Identifier], to ...peer.ID) { byteBuffer := stream.NewByteBuffer() - if err := stream.WriteCollection(byteBuffer, serializer.UInt32ByteSize, func() (elementsCount int, err error) { + if err := stream.WriteCollection(byteBuffer, serializer.SeriLengthPrefixTypeAsUint32, func() (elementsCount int, err error) { for _, att := range attestations { - if err = stream.WriteObjectWithSize(byteBuffer, att, serializer.UInt16ByteSize, (*iotago.Attestation).Bytes); err != nil { + if err = stream.WriteObjectWithSize(byteBuffer, att, serializer.SeriLengthPrefixTypeAsUint16, (*iotago.Attestation).Bytes); err != nil { return 0, ierrors.Wrapf(err, "failed to write attestation %v", att) } } diff --git a/tools/docker-network/run.sh b/tools/docker-network/run.sh index 323a6bdbb..87697914f 100755 --- a/tools/docker-network/run.sh +++ b/tools/docker-network/run.sh @@ -49,7 +49,7 @@ docker run --rm \ -e GOCACHE="/go-cache" \ -e GOMODCACHE="/go-mod-cache" \ -w "/workspace/tools/genesis-snapshot" \ - golang:1.21 go run -tags=rocksdb . --config docker --seed 7R1itJx5hVuo9w9hjg5cwKFmek4HMSoBDgJZN8hKGxih + golang:1.21-bookworm go run -tags=rocksdb . --config docker --seed 7R1itJx5hVuo9w9hjg5cwKFmek4HMSoBDgJZN8hKGxih # Move and set permissions for the .snapshot file mv -f ../genesis-snapshot/*.snapshot . From 31e1aed457345434936ea82511dab39e3bfb4809 Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Mon, 6 Nov 2023 17:14:40 +0800 Subject: [PATCH 24/32] Fix deserialization of attestations in onAttestations --- pkg/network/protocols/core/protocol.go | 33 +++++++++++++------------- 1 file changed, 17 insertions(+), 16 deletions(-) diff --git a/pkg/network/protocols/core/protocol.go b/pkg/network/protocols/core/protocol.go index 6aa663abc..5841429be 100644 --- a/pkg/network/protocols/core/protocol.go +++ b/pkg/network/protocols/core/protocol.go @@ -1,8 +1,6 @@ package core import ( - "encoding/binary" - "github.com/libp2p/go-libp2p/core/peer" "google.golang.org/protobuf/proto" @@ -208,28 +206,31 @@ func (p *Protocol) onAttestations(commitmentBytes []byte, attestationsBytes []by return } - if len(attestationsBytes) < 4 { - p.Events.Error.Trigger(ierrors.Errorf("failed to deserialize attestations, invalid attestation count"), id) + reader := stream.NewByteReader(attestationsBytes) + + attestationsCount, err := stream.Peek(reader, serializer.SeriLengthPrefixTypeAsUint32) + if err != nil { + p.Events.Error.Trigger(ierrors.Errorf("failed peek attestations count"), id) return } - attestationCount := binary.LittleEndian.Uint32(attestationsBytes[0:4]) - readOffset := 4 - attestations := make([]*iotago.Attestation, attestationCount) - for i := uint32(0); i < attestationCount; i++ { - attestation, consumed, err := iotago.AttestationFromBytes(p.apiProvider)(attestationsBytes[readOffset:]) + attestations := make([]*iotago.Attestation, attestationsCount) + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint32, func(i int) error { + attestations[i], err = stream.ReadObjectWithSize(reader, serializer.SeriLengthPrefixTypeAsUint16, iotago.AttestationFromBytes(p.apiProvider)) if err != nil { - p.Events.Error.Trigger(ierrors.Wrap(err, "failed to deserialize attestations"), id) - - return + return ierrors.Wrapf(err, "failed to deserialize attestation %d", i) } - readOffset += consumed - attestations[i] = attestation + return nil + }); err != nil { + p.Events.Error.Trigger(ierrors.Wrap(err, "failed to deserialize attestations"), id) + + return } - if readOffset != len(attestationsBytes) { - p.Events.Error.Trigger(ierrors.Errorf("failed to deserialize attestations: %d bytes remaining", len(attestationsBytes)-readOffset), id) + + if reader.BytesRead() != len(attestationsBytes) { + p.Events.Error.Trigger(ierrors.Errorf("failed to deserialize attestations: %d bytes remaining", len(attestationsBytes)-reader.BytesRead()), id) return } From d3768e03ec84783a67512d0f3827d84fdc8782d2 Mon Sep 17 00:00:00 2001 From: Piotr Macek <4007944+piotrm50@users.noreply.github.com> Date: Mon, 6 Nov 2023 11:07:13 +0100 Subject: [PATCH 25/32] Print the source block as well. --- pkg/protocol/engine/tipmanager/v1/tipmanager.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pkg/protocol/engine/tipmanager/v1/tipmanager.go b/pkg/protocol/engine/tipmanager/v1/tipmanager.go index 2e5bef0fc..2b12cc40c 100644 --- a/pkg/protocol/engine/tipmanager/v1/tipmanager.go +++ b/pkg/protocol/engine/tipmanager/v1/tipmanager.go @@ -152,7 +152,7 @@ func (t *TipManager) forEachParentByType(block *blocks.Block, consumer func(pare } if parentBlock.ModelBlock() == nil { - fmt.Printf(">> parentBlock exists, but parentBlock.ProtocolBlock() == nil\n %s\n", parentBlock.String()) + fmt.Printf(">> parentBlock exists, but parentBlock.ProtocolBlock() == nil\n ParentBlock: %s\n Block: %s\n", parentBlock.String(), block.String()) } parentMetadata, created := metadataStorage.GetOrCreate(parent.ID, func() *TipMetadata { return NewBlockMetadata(parentBlock) }) From f195974c06d4eb5f59e07effc30d49d754d535d2 Mon Sep 17 00:00:00 2001 From: Andrea V <1577639+karimodm@users.noreply.github.com> Date: Tue, 7 Nov 2023 13:31:40 +0100 Subject: [PATCH 26/32] Always succeed on killing and tearing down network --- .github/workflows/docker-network-health.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/docker-network-health.yml b/.github/workflows/docker-network-health.yml index ee5b1b08b..b2ac8c32b 100644 --- a/.github/workflows/docker-network-health.yml +++ b/.github/workflows/docker-network-health.yml @@ -62,5 +62,5 @@ jobs: - name: Cleanup run: | cd ./tools/docker-network - docker compose kill - docker compose down -v + docker compose kill || true + docker compose down -t 1 -v || true From d9d47ae8af3c48582bd78d460a649f2e7f42ffb3 Mon Sep 17 00:00:00 2001 From: Andrea V <1577639+karimodm@users.noreply.github.com> Date: Tue, 7 Nov 2023 13:44:18 +0100 Subject: [PATCH 27/32] Exit with a failure if we fail to create Docker network snapshot --- tools/docker-network/run.sh | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/tools/docker-network/run.sh b/tools/docker-network/run.sh index 323a6bdbb..74090cc05 100755 --- a/tools/docker-network/run.sh +++ b/tools/docker-network/run.sh @@ -1,6 +1,5 @@ #!/bin/bash - # Create a function to join an array of strings by a given character function join { local IFS="$1"; shift; echo "$*"; } @@ -52,7 +51,11 @@ docker run --rm \ golang:1.21 go run -tags=rocksdb . --config docker --seed 7R1itJx5hVuo9w9hjg5cwKFmek4HMSoBDgJZN8hKGxih # Move and set permissions for the .snapshot file -mv -f ../genesis-snapshot/*.snapshot . +if ! mv -f ../genesis-snapshot/*.snapshot .; then + echo "Failed to create or move snapshot file" + exit 1 +fi + chmod o+r *.snapshot echo "Run iota-core network" From a5a2cd27bc5e965b802944246c3158b4586d720f Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Wed, 8 Nov 2023 13:11:32 +0800 Subject: [PATCH 28/32] Update to latest hive.go --- go.mod | 30 +++++------ go.sum | 60 ++++++++++----------- pkg/network/protocols/core/protocol.go | 2 +- pkg/protocol/engine/utxoledger/slot_diff.go | 4 +- pkg/protocol/engine/utxoledger/snapshot.go | 4 +- tools/gendoc/go.mod | 30 +++++------ tools/gendoc/go.sum | 60 ++++++++++----------- tools/genesis-snapshot/go.mod | 26 ++++----- tools/genesis-snapshot/go.sum | 52 +++++++++--------- 9 files changed, 134 insertions(+), 134 deletions(-) diff --git a/go.mod b/go.mod index 893f1a33c..a9dd74376 100644 --- a/go.mod +++ b/go.mod @@ -10,22 +10,22 @@ require ( github.com/google/uuid v1.4.0 github.com/gorilla/websocket v1.5.0 github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 - github.com/iotaledger/hive.go/ads v0.0.0-20231106033111-7f3042d04fc4 - github.com/iotaledger/hive.go/app v0.0.0-20231106033111-7f3042d04fc4 - github.com/iotaledger/hive.go/constraints v0.0.0-20231106033111-7f3042d04fc4 - github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231106033111-7f3042d04fc4 - github.com/iotaledger/hive.go/crypto v0.0.0-20231106033111-7f3042d04fc4 - github.com/iotaledger/hive.go/ds v0.0.0-20231106033111-7f3042d04fc4 - github.com/iotaledger/hive.go/ierrors v0.0.0-20231106033111-7f3042d04fc4 - github.com/iotaledger/hive.go/kvstore v0.0.0-20231106033111-7f3042d04fc4 - github.com/iotaledger/hive.go/lo v0.0.0-20231106033111-7f3042d04fc4 - github.com/iotaledger/hive.go/logger v0.0.0-20231106033111-7f3042d04fc4 - github.com/iotaledger/hive.go/runtime v0.0.0-20231106033111-7f3042d04fc4 - github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231106033111-7f3042d04fc4 - github.com/iotaledger/hive.go/stringify v0.0.0-20231106033111-7f3042d04fc4 + github.com/iotaledger/hive.go/ads v0.0.0-20231108050255-98e0fa35e936 + github.com/iotaledger/hive.go/app v0.0.0-20231108050255-98e0fa35e936 + github.com/iotaledger/hive.go/constraints v0.0.0-20231108050255-98e0fa35e936 + github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231108050255-98e0fa35e936 + github.com/iotaledger/hive.go/crypto v0.0.0-20231108050255-98e0fa35e936 + github.com/iotaledger/hive.go/ds v0.0.0-20231108050255-98e0fa35e936 + github.com/iotaledger/hive.go/ierrors v0.0.0-20231108050255-98e0fa35e936 + github.com/iotaledger/hive.go/kvstore v0.0.0-20231108050255-98e0fa35e936 + github.com/iotaledger/hive.go/lo v0.0.0-20231108050255-98e0fa35e936 + github.com/iotaledger/hive.go/logger v0.0.0-20231108050255-98e0fa35e936 + github.com/iotaledger/hive.go/runtime v0.0.0-20231108050255-98e0fa35e936 + github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231108050255-98e0fa35e936 + github.com/iotaledger/hive.go/stringify v0.0.0-20231108050255-98e0fa35e936 github.com/iotaledger/inx-app v1.0.0-rc.3.0.20231031135002-4c79ea5193f5 github.com/iotaledger/inx/go v1.0.0-rc.2.0.20231031134131-b6ad918dc1ac - github.com/iotaledger/iota.go/v4 v4.0.0-20231106063525-564529bf7361 + github.com/iotaledger/iota.go/v4 v4.0.0-20231108050608-afce96cfe8a6 github.com/labstack/echo/v4 v4.11.2 github.com/labstack/gommon v0.4.0 github.com/libp2p/go-libp2p v0.32.0 @@ -88,7 +88,7 @@ require ( github.com/huin/goupnp v1.3.0 // indirect github.com/iancoleman/orderedmap v0.3.0 // indirect github.com/iotaledger/grocksdb v1.7.5-0.20230220105546-5162e18885c7 // indirect - github.com/iotaledger/hive.go/log v0.0.0-20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/log v0.0.0-20231108050255-98e0fa35e936 // indirect github.com/ipfs/boxo v0.13.1 // indirect github.com/ipfs/go-cid v0.4.1 // indirect github.com/ipfs/go-datastore v0.6.0 // indirect diff --git a/go.sum b/go.sum index 3d9bf76d3..8ca757948 100644 --- a/go.sum +++ b/go.sum @@ -275,40 +275,40 @@ github.com/iancoleman/orderedmap v0.3.0/go.mod h1:XuLcCUkdL5owUCQeF2Ue9uuw1EptkJ github.com/ianlancetaylor/demangle v0.0.0-20210905161508-09a460cdf81d/go.mod h1:aYm2/VgdVmcIU8iMfdMvDMsRAQjcfZSKFby6HOFvi/w= github.com/iotaledger/grocksdb v1.7.5-0.20230220105546-5162e18885c7 h1:dTrD7X2PTNgli6EbS4tV9qu3QAm/kBU3XaYZV2xdzys= github.com/iotaledger/grocksdb v1.7.5-0.20230220105546-5162e18885c7/go.mod h1:ZRdPu684P0fQ1z8sXz4dj9H5LWHhz4a9oCtvjunkSrw= -github.com/iotaledger/hive.go/ads v0.0.0-20231106033111-7f3042d04fc4 h1:3F60Hx0Oi+4p7V5e+Ap8/aagbk0eSZ8jci4GxGXVLmc= -github.com/iotaledger/hive.go/ads v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:b8w/1e7wk7ZQgTm/2dZPH2pWl7CTlTmgkgaIleaZgFw= -github.com/iotaledger/hive.go/app v0.0.0-20231106033111-7f3042d04fc4 h1:XhqawtbvRagBjd9MTMtzVAnWggXEQF3Mj9cMPhiTXYg= -github.com/iotaledger/hive.go/app v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:iM05Js4OhYlTbQqwxbgMIuWq1TT+lfKntg0PeOE8zkU= -github.com/iotaledger/hive.go/constraints v0.0.0-20231106033111-7f3042d04fc4 h1:GS3d6xi8eiI9rIycajLs4z3vM/u0D9oJ2qEP8f/Mnmw= -github.com/iotaledger/hive.go/constraints v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:dOBOM2s4se3HcWefPe8sQLUalGXJ8yVXw58oK8jke3s= -github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231106033111-7f3042d04fc4 h1:xz1Vy5YujaXLL6Kx2gU7eueWGZPquimCGXBLimtCSak= -github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231106033111-7f3042d04fc4/go.mod h1:oBpjupsGbCg4WlK9HfXaF5RWtZvA4LmtmuLsMEcz+Qg= -github.com/iotaledger/hive.go/crypto v0.0.0-20231106033111-7f3042d04fc4 h1:3FNxPWFuNEdEJ17PoNS5ILTcg2b7wHDkLZx2lL3PhIE= -github.com/iotaledger/hive.go/crypto v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:ePC73xHcQdkbbHApVoF9XfLfjTtCuYJ8+WJepdRoUIw= -github.com/iotaledger/hive.go/ds v0.0.0-20231106033111-7f3042d04fc4 h1:eVNGVSEX/Z8CyTjUXD/QBSlevFSfu5rwdIJkjPULGeM= -github.com/iotaledger/hive.go/ds v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:RnYZNMRIXKt/SXVsFA18uUBNDZMQm0h5BykMXjv8/8A= -github.com/iotaledger/hive.go/ierrors v0.0.0-20231106033111-7f3042d04fc4 h1:yr8sRMURAjVQhWX+HgDm2AwgY2jH1JrZjOf49aUM8CQ= -github.com/iotaledger/hive.go/ierrors v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:HcE8B5lP96enc/OALTb2/rIIi+yOLouRoHOKRclKmC8= -github.com/iotaledger/hive.go/kvstore v0.0.0-20231106033111-7f3042d04fc4 h1:N21PVtaSvtG9Qq+3hLEj6Cca4Thx7YTa5ezKuqj3V0Y= -github.com/iotaledger/hive.go/kvstore v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:gQWd99xA2Wl4DpCqHIeieNUAKbRJDZo1VNnswAbibyA= -github.com/iotaledger/hive.go/lo v0.0.0-20231106033111-7f3042d04fc4 h1:bK0+pb716B9rBuXDp1+xKh5iX5wp00FF47UjTD+KphM= -github.com/iotaledger/hive.go/lo v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:lFKoK3stQVscy4k6+Cqd3Chq6u65JoTRhfhzJsmKyY8= -github.com/iotaledger/hive.go/log v0.0.0-20231106033111-7f3042d04fc4 h1:VJpxS4LePyDXJT1TRAVExm1ELmEH0t79NB08xEGyR/U= -github.com/iotaledger/hive.go/log v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:61LNutuzo3UnIgC9E8fPCIZ1Xwlb6ApbyTZssMl2cvI= -github.com/iotaledger/hive.go/logger v0.0.0-20231106033111-7f3042d04fc4 h1:jEcVfw96tzB8yjcHBIfc0qUXZvYkn4wu9/bWscgdlNc= -github.com/iotaledger/hive.go/logger v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:LOquQmtaz338r5ftNhYMpjcl0lpO6YtpXyVFbvNOrqs= -github.com/iotaledger/hive.go/runtime v0.0.0-20231106033111-7f3042d04fc4 h1:hOGlfCiQxIumcWMFxxAp13Ox//SQK0DGcXY3NJf7kGQ= -github.com/iotaledger/hive.go/runtime v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:6WKyYAkvdY08iW4/w30goNq0GaBTljT0MXXilnQ33wk= -github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231106033111-7f3042d04fc4 h1:CRNZkH8TuRIoCHDkfHGA09hpgT2cFFzj1Dys4ze61tI= -github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231106033111-7f3042d04fc4/go.mod h1:fW/lA6n0C/jf9B9NMX46eJXsJTU8Nzs+9oBWMTNzPzE= -github.com/iotaledger/hive.go/stringify v0.0.0-20231106033111-7f3042d04fc4 h1:xY4tsqeuZq/V8S3vYpuHJT6EdRgMGoFJkyFfxWV0ZPY= -github.com/iotaledger/hive.go/stringify v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:FTo/UWzNYgnQ082GI9QVM9HFDERqf9rw9RivNpqrnTs= +github.com/iotaledger/hive.go/ads v0.0.0-20231108050255-98e0fa35e936 h1:2r4FgIGdc2lHcIbXiUFCCVq4+B0oZk9t6Z0SSLjrzCE= +github.com/iotaledger/hive.go/ads v0.0.0-20231108050255-98e0fa35e936/go.mod h1:gbUvr01B5ha530GnNm8K2OsHXOd2BtzBYOMxyTX3iDg= +github.com/iotaledger/hive.go/app v0.0.0-20231108050255-98e0fa35e936 h1:SnmQt9GxrWIvpW7pgQS049x1b8T+lQutTQbo35FImug= +github.com/iotaledger/hive.go/app v0.0.0-20231108050255-98e0fa35e936/go.mod h1:+riYmeLApkLlj4+EpuJpEJAsj/KGfD7cqLGy7oTsPOM= +github.com/iotaledger/hive.go/constraints v0.0.0-20231108050255-98e0fa35e936 h1:qkq0Wz+Y3J8QYRLd0fwTgHuur/A3k7d82BxOKSfvk8c= +github.com/iotaledger/hive.go/constraints v0.0.0-20231108050255-98e0fa35e936/go.mod h1:dOBOM2s4se3HcWefPe8sQLUalGXJ8yVXw58oK8jke3s= +github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231108050255-98e0fa35e936 h1:GtsYwcCqRomhMo190TPxBrOzs6YnVmqkmQgT/lJrJRo= +github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231108050255-98e0fa35e936/go.mod h1:CdixkrB7VdQzEDlVuwsxPtsiJL/WXrQgz3PELIqlLko= +github.com/iotaledger/hive.go/crypto v0.0.0-20231108050255-98e0fa35e936 h1:Xeb4w0g0Kv2ZjdCZQqz8oiqAU5qAy8OXG8kGTXSPzuY= +github.com/iotaledger/hive.go/crypto v0.0.0-20231108050255-98e0fa35e936/go.mod h1:OQ9EVTTQT1mkO/16BgwSIyQlAhEg+Cptud/yutevWsI= +github.com/iotaledger/hive.go/ds v0.0.0-20231108050255-98e0fa35e936 h1:NtQLSS0Lq5qg/w5nbMpXrlQpmcK3KiOaQmgZWoRc4mM= +github.com/iotaledger/hive.go/ds v0.0.0-20231108050255-98e0fa35e936/go.mod h1:JE8cbZSvzbB5TrwXibg6M0B7ck35YxF30ItHBzQRlgc= +github.com/iotaledger/hive.go/ierrors v0.0.0-20231108050255-98e0fa35e936 h1:o5S4KUAwToOLXoYYRj9ZgqeDsFv1VRM4+Mni0Tdj2Ck= +github.com/iotaledger/hive.go/ierrors v0.0.0-20231108050255-98e0fa35e936/go.mod h1:HcE8B5lP96enc/OALTb2/rIIi+yOLouRoHOKRclKmC8= +github.com/iotaledger/hive.go/kvstore v0.0.0-20231108050255-98e0fa35e936 h1:kXKJQ8UvbA8kI0Jx0EnlXbwDeZFY8pEX0Q6KaOPsYlQ= +github.com/iotaledger/hive.go/kvstore v0.0.0-20231108050255-98e0fa35e936/go.mod h1:ytfKoHr/nF8u0y0G4mamfG0yjFtJiJVk0kgjnPOtsSY= +github.com/iotaledger/hive.go/lo v0.0.0-20231108050255-98e0fa35e936 h1:coXPklQ7JgqTXIUXh3b4OHml1VIvI8x7pQsjsES/u/s= +github.com/iotaledger/hive.go/lo v0.0.0-20231108050255-98e0fa35e936/go.mod h1:6Ee7i6b4tuTHuRYnPP8VUb0wr9XFI5qlqtnttBd9jRg= +github.com/iotaledger/hive.go/log v0.0.0-20231108050255-98e0fa35e936 h1:VBvGnsVwqhoT9zMyMIlK5fPmz6fsbiPZOwdU1E8WU7o= +github.com/iotaledger/hive.go/log v0.0.0-20231108050255-98e0fa35e936/go.mod h1:vzO4/wRkEJDEZb/9fD10oKU9k1bj4qLir2Uhl5U1FkM= +github.com/iotaledger/hive.go/logger v0.0.0-20231108050255-98e0fa35e936 h1:05EbTaladbyo7mD8yBaWYJh9P8u/TUTmrjVmcUjoW8A= +github.com/iotaledger/hive.go/logger v0.0.0-20231108050255-98e0fa35e936/go.mod h1:w1psHM2MuKsen1WdsPKrpqElYH7ZOQ+YdQIgJZg4HTo= +github.com/iotaledger/hive.go/runtime v0.0.0-20231108050255-98e0fa35e936 h1:XbC1fmY87UJ/yMs8U2YqlUdJsqb0Xqj/ZYQKlZ7AUG8= +github.com/iotaledger/hive.go/runtime v0.0.0-20231108050255-98e0fa35e936/go.mod h1:DrZPvUvLarK8C2qb+3H2vdypp/MuhpQmB3iMJbDCr/Q= +github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231108050255-98e0fa35e936 h1:LXhLW2cN9bQYoHQsgmJRb/jiRBRU5s2rLoCNjZfgHdg= +github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231108050255-98e0fa35e936/go.mod h1:FoH3T6yKlZJp8xm8K+zsQiibSynp32v21CpWx8xkek8= +github.com/iotaledger/hive.go/stringify v0.0.0-20231108050255-98e0fa35e936 h1:Y4HgL5gm9S27usg5M2t6wi1BSdCxVorM62lwnpKuMd4= +github.com/iotaledger/hive.go/stringify v0.0.0-20231108050255-98e0fa35e936/go.mod h1:FTo/UWzNYgnQ082GI9QVM9HFDERqf9rw9RivNpqrnTs= github.com/iotaledger/inx-app v1.0.0-rc.3.0.20231031135002-4c79ea5193f5 h1:17JDzMKTMXKF3xys6gPURRddkZhg1LY+xwfhbr/sVqg= github.com/iotaledger/inx-app v1.0.0-rc.3.0.20231031135002-4c79ea5193f5/go.mod h1:LsJvoBUVVnY7tkwwByCVtAwmp5bFXdyJNGU/+KVQJVM= github.com/iotaledger/inx/go v1.0.0-rc.2.0.20231031134131-b6ad918dc1ac h1:c7R33+TQGMYP6pvLUQQaqpdDFl+GZbhAcfGMI0285fo= github.com/iotaledger/inx/go v1.0.0-rc.2.0.20231031134131-b6ad918dc1ac/go.mod h1:qPuMUvCTaghsnYRDnRoRuztTyEKFlmi2S7gb44rH7WM= -github.com/iotaledger/iota.go/v4 v4.0.0-20231106063525-564529bf7361 h1:8uHWvSQpTa8FqakKkKwdppk46PUr/FJjFeupi9csa64= -github.com/iotaledger/iota.go/v4 v4.0.0-20231106063525-564529bf7361/go.mod h1:GXUQi5h4MAtPoBkJ/BRFakVbOiJeU76O0HcXl28mwK8= +github.com/iotaledger/iota.go/v4 v4.0.0-20231108050608-afce96cfe8a6 h1:4kvG+BB4GOBsNYPY/enPo3xeC65A133L9cD73Kf1p9Q= +github.com/iotaledger/iota.go/v4 v4.0.0-20231108050608-afce96cfe8a6/go.mod h1:8iDORW4/e4NztyAGqjW07uSMjbhs7snbxw+81IWOczY= github.com/ipfs/boxo v0.13.1 h1:nQ5oQzcMZR3oL41REJDcTbrvDvuZh3J9ckc9+ILeRQI= github.com/ipfs/boxo v0.13.1/go.mod h1:btrtHy0lmO1ODMECbbEY1pxNtrLilvKSYLoGQt1yYCk= github.com/ipfs/go-cid v0.4.1 h1:A/T3qGvxi4kpKWWcPC/PgbvDA2bjVLO7n4UeVwnbs/s= diff --git a/pkg/network/protocols/core/protocol.go b/pkg/network/protocols/core/protocol.go index 5841429be..ac9426f05 100644 --- a/pkg/network/protocols/core/protocol.go +++ b/pkg/network/protocols/core/protocol.go @@ -208,7 +208,7 @@ func (p *Protocol) onAttestations(commitmentBytes []byte, attestationsBytes []by reader := stream.NewByteReader(attestationsBytes) - attestationsCount, err := stream.Peek(reader, serializer.SeriLengthPrefixTypeAsUint32) + attestationsCount, err := stream.PeekSize(reader, serializer.SeriLengthPrefixTypeAsUint32) if err != nil { p.Events.Error.Trigger(ierrors.Errorf("failed peek attestations count"), id) diff --git a/pkg/protocol/engine/utxoledger/slot_diff.go b/pkg/protocol/engine/utxoledger/slot_diff.go index 07b05c7a8..be304e321 100644 --- a/pkg/protocol/engine/utxoledger/slot_diff.go +++ b/pkg/protocol/engine/utxoledger/slot_diff.go @@ -69,7 +69,7 @@ func (sd *SlotDiff) kvStorableLoad(manager *Manager, key []byte, value []byte) e byteReader := stream.NewByteReader(value) - outputsCount, err := stream.Peek(byteReader, serializer.SeriLengthPrefixTypeAsUint32) + outputsCount, err := stream.PeekSize(byteReader, serializer.SeriLengthPrefixTypeAsUint32) if err != nil { return ierrors.Wrap(err, "unable to peek outputs count") } @@ -93,7 +93,7 @@ func (sd *SlotDiff) kvStorableLoad(manager *Manager, key []byte, value []byte) e return ierrors.Wrapf(err, "unable to read slot diff outputs") } - spentsCount, err := stream.Peek(byteReader, serializer.SeriLengthPrefixTypeAsUint32) + spentsCount, err := stream.PeekSize(byteReader, serializer.SeriLengthPrefixTypeAsUint32) if err != nil { return ierrors.Wrap(err, "unable to peek spents count") } diff --git a/pkg/protocol/engine/utxoledger/snapshot.go b/pkg/protocol/engine/utxoledger/snapshot.go index c94a115f4..7d70fb525 100644 --- a/pkg/protocol/engine/utxoledger/snapshot.go +++ b/pkg/protocol/engine/utxoledger/snapshot.go @@ -95,7 +95,7 @@ func ReadSlotDiffToSnapshotReader(reader io.ReadSeeker, apiProvider iotago.APIPr return nil, ierrors.Wrap(err, "unable to read slot diff index") } - createdCount, err := stream.Peek(reader, serializer.SeriLengthPrefixTypeAsUint64) + createdCount, err := stream.PeekSize(reader, serializer.SeriLengthPrefixTypeAsUint64) if err != nil { return nil, ierrors.Wrap(err, "unable to peek slot diff created count") } @@ -112,7 +112,7 @@ func ReadSlotDiffToSnapshotReader(reader io.ReadSeeker, apiProvider iotago.APIPr return nil, ierrors.Wrap(err, "unable to read slot diff created collection") } - consumedCount, err := stream.Peek(reader, serializer.SeriLengthPrefixTypeAsUint64) + consumedCount, err := stream.PeekSize(reader, serializer.SeriLengthPrefixTypeAsUint64) if err != nil { return nil, ierrors.Wrap(err, "unable to peek slot diff consumed count") } diff --git a/tools/gendoc/go.mod b/tools/gendoc/go.mod index 146150577..7e15edb04 100644 --- a/tools/gendoc/go.mod +++ b/tools/gendoc/go.mod @@ -5,7 +5,7 @@ go 1.21 replace github.com/iotaledger/iota-core => ../../ require ( - github.com/iotaledger/hive.go/app v0.0.0-20231106033111-7f3042d04fc4 + github.com/iotaledger/hive.go/app v0.0.0-20231108050255-98e0fa35e936 github.com/iotaledger/hive.go/apputils v0.0.0-20230829152614-7afc7a4d89b3 github.com/iotaledger/iota-core v0.0.0-00010101000000-000000000000 ) @@ -57,22 +57,22 @@ require ( github.com/huin/goupnp v1.3.0 // indirect github.com/iancoleman/orderedmap v0.3.0 // indirect github.com/iotaledger/grocksdb v1.7.5-0.20230220105546-5162e18885c7 // indirect - github.com/iotaledger/hive.go/ads v0.0.0-20231106033111-7f3042d04fc4 // indirect - github.com/iotaledger/hive.go/constraints v0.0.0-20231106033111-7f3042d04fc4 // indirect - github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231106033111-7f3042d04fc4 // indirect - github.com/iotaledger/hive.go/crypto v0.0.0-20231106033111-7f3042d04fc4 // indirect - github.com/iotaledger/hive.go/ds v0.0.0-20231106033111-7f3042d04fc4 // indirect - github.com/iotaledger/hive.go/ierrors v0.0.0-20231106033111-7f3042d04fc4 // indirect - github.com/iotaledger/hive.go/kvstore v0.0.0-20231106033111-7f3042d04fc4 // indirect - github.com/iotaledger/hive.go/lo v0.0.0-20231106033111-7f3042d04fc4 // indirect - github.com/iotaledger/hive.go/log v0.0.0-20231106033111-7f3042d04fc4 // indirect - github.com/iotaledger/hive.go/logger v0.0.0-20231106033111-7f3042d04fc4 // indirect - github.com/iotaledger/hive.go/runtime v0.0.0-20231106033111-7f3042d04fc4 // indirect - github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231106033111-7f3042d04fc4 // indirect - github.com/iotaledger/hive.go/stringify v0.0.0-20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/ads v0.0.0-20231108050255-98e0fa35e936 // indirect + github.com/iotaledger/hive.go/constraints v0.0.0-20231108050255-98e0fa35e936 // indirect + github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231108050255-98e0fa35e936 // indirect + github.com/iotaledger/hive.go/crypto v0.0.0-20231108050255-98e0fa35e936 // indirect + github.com/iotaledger/hive.go/ds v0.0.0-20231108050255-98e0fa35e936 // indirect + github.com/iotaledger/hive.go/ierrors v0.0.0-20231108050255-98e0fa35e936 // indirect + github.com/iotaledger/hive.go/kvstore v0.0.0-20231108050255-98e0fa35e936 // indirect + github.com/iotaledger/hive.go/lo v0.0.0-20231108050255-98e0fa35e936 // indirect + github.com/iotaledger/hive.go/log v0.0.0-20231108050255-98e0fa35e936 // indirect + github.com/iotaledger/hive.go/logger v0.0.0-20231108050255-98e0fa35e936 // indirect + github.com/iotaledger/hive.go/runtime v0.0.0-20231108050255-98e0fa35e936 // indirect + github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231108050255-98e0fa35e936 // indirect + github.com/iotaledger/hive.go/stringify v0.0.0-20231108050255-98e0fa35e936 // indirect github.com/iotaledger/inx-app v1.0.0-rc.3.0.20231031135002-4c79ea5193f5 // indirect github.com/iotaledger/inx/go v1.0.0-rc.2.0.20231031134131-b6ad918dc1ac // indirect - github.com/iotaledger/iota.go/v4 v4.0.0-20231106063525-564529bf7361 // indirect + github.com/iotaledger/iota.go/v4 v4.0.0-20231108050608-afce96cfe8a6 // indirect github.com/ipfs/boxo v0.13.1 // indirect github.com/ipfs/go-cid v0.4.1 // indirect github.com/ipfs/go-datastore v0.6.0 // indirect diff --git a/tools/gendoc/go.sum b/tools/gendoc/go.sum index 4ea909f76..17f6c8f9f 100644 --- a/tools/gendoc/go.sum +++ b/tools/gendoc/go.sum @@ -277,42 +277,42 @@ github.com/iancoleman/orderedmap v0.3.0/go.mod h1:XuLcCUkdL5owUCQeF2Ue9uuw1EptkJ github.com/ianlancetaylor/demangle v0.0.0-20210905161508-09a460cdf81d/go.mod h1:aYm2/VgdVmcIU8iMfdMvDMsRAQjcfZSKFby6HOFvi/w= github.com/iotaledger/grocksdb v1.7.5-0.20230220105546-5162e18885c7 h1:dTrD7X2PTNgli6EbS4tV9qu3QAm/kBU3XaYZV2xdzys= github.com/iotaledger/grocksdb v1.7.5-0.20230220105546-5162e18885c7/go.mod h1:ZRdPu684P0fQ1z8sXz4dj9H5LWHhz4a9oCtvjunkSrw= -github.com/iotaledger/hive.go/ads v0.0.0-20231106033111-7f3042d04fc4 h1:3F60Hx0Oi+4p7V5e+Ap8/aagbk0eSZ8jci4GxGXVLmc= -github.com/iotaledger/hive.go/ads v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:b8w/1e7wk7ZQgTm/2dZPH2pWl7CTlTmgkgaIleaZgFw= -github.com/iotaledger/hive.go/app v0.0.0-20231106033111-7f3042d04fc4 h1:XhqawtbvRagBjd9MTMtzVAnWggXEQF3Mj9cMPhiTXYg= -github.com/iotaledger/hive.go/app v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:iM05Js4OhYlTbQqwxbgMIuWq1TT+lfKntg0PeOE8zkU= +github.com/iotaledger/hive.go/ads v0.0.0-20231108050255-98e0fa35e936 h1:2r4FgIGdc2lHcIbXiUFCCVq4+B0oZk9t6Z0SSLjrzCE= +github.com/iotaledger/hive.go/ads v0.0.0-20231108050255-98e0fa35e936/go.mod h1:gbUvr01B5ha530GnNm8K2OsHXOd2BtzBYOMxyTX3iDg= +github.com/iotaledger/hive.go/app v0.0.0-20231108050255-98e0fa35e936 h1:SnmQt9GxrWIvpW7pgQS049x1b8T+lQutTQbo35FImug= +github.com/iotaledger/hive.go/app v0.0.0-20231108050255-98e0fa35e936/go.mod h1:+riYmeLApkLlj4+EpuJpEJAsj/KGfD7cqLGy7oTsPOM= github.com/iotaledger/hive.go/apputils v0.0.0-20230829152614-7afc7a4d89b3 h1:4aVJTc0KS77uEw0Tny4r0n1ORwcbAQDECaCclgf/6lE= github.com/iotaledger/hive.go/apputils v0.0.0-20230829152614-7afc7a4d89b3/go.mod h1:TZeAqieDu+xDOZp2e9+S+8pZp1PrfgcwLUnxmd8IgLU= -github.com/iotaledger/hive.go/constraints v0.0.0-20231106033111-7f3042d04fc4 h1:GS3d6xi8eiI9rIycajLs4z3vM/u0D9oJ2qEP8f/Mnmw= -github.com/iotaledger/hive.go/constraints v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:dOBOM2s4se3HcWefPe8sQLUalGXJ8yVXw58oK8jke3s= -github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231106033111-7f3042d04fc4 h1:xz1Vy5YujaXLL6Kx2gU7eueWGZPquimCGXBLimtCSak= -github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231106033111-7f3042d04fc4/go.mod h1:oBpjupsGbCg4WlK9HfXaF5RWtZvA4LmtmuLsMEcz+Qg= -github.com/iotaledger/hive.go/crypto v0.0.0-20231106033111-7f3042d04fc4 h1:3FNxPWFuNEdEJ17PoNS5ILTcg2b7wHDkLZx2lL3PhIE= -github.com/iotaledger/hive.go/crypto v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:ePC73xHcQdkbbHApVoF9XfLfjTtCuYJ8+WJepdRoUIw= -github.com/iotaledger/hive.go/ds v0.0.0-20231106033111-7f3042d04fc4 h1:eVNGVSEX/Z8CyTjUXD/QBSlevFSfu5rwdIJkjPULGeM= -github.com/iotaledger/hive.go/ds v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:RnYZNMRIXKt/SXVsFA18uUBNDZMQm0h5BykMXjv8/8A= -github.com/iotaledger/hive.go/ierrors v0.0.0-20231106033111-7f3042d04fc4 h1:yr8sRMURAjVQhWX+HgDm2AwgY2jH1JrZjOf49aUM8CQ= -github.com/iotaledger/hive.go/ierrors v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:HcE8B5lP96enc/OALTb2/rIIi+yOLouRoHOKRclKmC8= -github.com/iotaledger/hive.go/kvstore v0.0.0-20231106033111-7f3042d04fc4 h1:N21PVtaSvtG9Qq+3hLEj6Cca4Thx7YTa5ezKuqj3V0Y= -github.com/iotaledger/hive.go/kvstore v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:gQWd99xA2Wl4DpCqHIeieNUAKbRJDZo1VNnswAbibyA= -github.com/iotaledger/hive.go/lo v0.0.0-20231106033111-7f3042d04fc4 h1:bK0+pb716B9rBuXDp1+xKh5iX5wp00FF47UjTD+KphM= -github.com/iotaledger/hive.go/lo v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:lFKoK3stQVscy4k6+Cqd3Chq6u65JoTRhfhzJsmKyY8= -github.com/iotaledger/hive.go/log v0.0.0-20231106033111-7f3042d04fc4 h1:VJpxS4LePyDXJT1TRAVExm1ELmEH0t79NB08xEGyR/U= -github.com/iotaledger/hive.go/log v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:61LNutuzo3UnIgC9E8fPCIZ1Xwlb6ApbyTZssMl2cvI= -github.com/iotaledger/hive.go/logger v0.0.0-20231106033111-7f3042d04fc4 h1:jEcVfw96tzB8yjcHBIfc0qUXZvYkn4wu9/bWscgdlNc= -github.com/iotaledger/hive.go/logger v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:LOquQmtaz338r5ftNhYMpjcl0lpO6YtpXyVFbvNOrqs= -github.com/iotaledger/hive.go/runtime v0.0.0-20231106033111-7f3042d04fc4 h1:hOGlfCiQxIumcWMFxxAp13Ox//SQK0DGcXY3NJf7kGQ= -github.com/iotaledger/hive.go/runtime v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:6WKyYAkvdY08iW4/w30goNq0GaBTljT0MXXilnQ33wk= -github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231106033111-7f3042d04fc4 h1:CRNZkH8TuRIoCHDkfHGA09hpgT2cFFzj1Dys4ze61tI= -github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231106033111-7f3042d04fc4/go.mod h1:fW/lA6n0C/jf9B9NMX46eJXsJTU8Nzs+9oBWMTNzPzE= -github.com/iotaledger/hive.go/stringify v0.0.0-20231106033111-7f3042d04fc4 h1:xY4tsqeuZq/V8S3vYpuHJT6EdRgMGoFJkyFfxWV0ZPY= -github.com/iotaledger/hive.go/stringify v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:FTo/UWzNYgnQ082GI9QVM9HFDERqf9rw9RivNpqrnTs= +github.com/iotaledger/hive.go/constraints v0.0.0-20231108050255-98e0fa35e936 h1:qkq0Wz+Y3J8QYRLd0fwTgHuur/A3k7d82BxOKSfvk8c= +github.com/iotaledger/hive.go/constraints v0.0.0-20231108050255-98e0fa35e936/go.mod h1:dOBOM2s4se3HcWefPe8sQLUalGXJ8yVXw58oK8jke3s= +github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231108050255-98e0fa35e936 h1:GtsYwcCqRomhMo190TPxBrOzs6YnVmqkmQgT/lJrJRo= +github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231108050255-98e0fa35e936/go.mod h1:CdixkrB7VdQzEDlVuwsxPtsiJL/WXrQgz3PELIqlLko= +github.com/iotaledger/hive.go/crypto v0.0.0-20231108050255-98e0fa35e936 h1:Xeb4w0g0Kv2ZjdCZQqz8oiqAU5qAy8OXG8kGTXSPzuY= +github.com/iotaledger/hive.go/crypto v0.0.0-20231108050255-98e0fa35e936/go.mod h1:OQ9EVTTQT1mkO/16BgwSIyQlAhEg+Cptud/yutevWsI= +github.com/iotaledger/hive.go/ds v0.0.0-20231108050255-98e0fa35e936 h1:NtQLSS0Lq5qg/w5nbMpXrlQpmcK3KiOaQmgZWoRc4mM= +github.com/iotaledger/hive.go/ds v0.0.0-20231108050255-98e0fa35e936/go.mod h1:JE8cbZSvzbB5TrwXibg6M0B7ck35YxF30ItHBzQRlgc= +github.com/iotaledger/hive.go/ierrors v0.0.0-20231108050255-98e0fa35e936 h1:o5S4KUAwToOLXoYYRj9ZgqeDsFv1VRM4+Mni0Tdj2Ck= +github.com/iotaledger/hive.go/ierrors v0.0.0-20231108050255-98e0fa35e936/go.mod h1:HcE8B5lP96enc/OALTb2/rIIi+yOLouRoHOKRclKmC8= +github.com/iotaledger/hive.go/kvstore v0.0.0-20231108050255-98e0fa35e936 h1:kXKJQ8UvbA8kI0Jx0EnlXbwDeZFY8pEX0Q6KaOPsYlQ= +github.com/iotaledger/hive.go/kvstore v0.0.0-20231108050255-98e0fa35e936/go.mod h1:ytfKoHr/nF8u0y0G4mamfG0yjFtJiJVk0kgjnPOtsSY= +github.com/iotaledger/hive.go/lo v0.0.0-20231108050255-98e0fa35e936 h1:coXPklQ7JgqTXIUXh3b4OHml1VIvI8x7pQsjsES/u/s= +github.com/iotaledger/hive.go/lo v0.0.0-20231108050255-98e0fa35e936/go.mod h1:6Ee7i6b4tuTHuRYnPP8VUb0wr9XFI5qlqtnttBd9jRg= +github.com/iotaledger/hive.go/log v0.0.0-20231108050255-98e0fa35e936 h1:VBvGnsVwqhoT9zMyMIlK5fPmz6fsbiPZOwdU1E8WU7o= +github.com/iotaledger/hive.go/log v0.0.0-20231108050255-98e0fa35e936/go.mod h1:vzO4/wRkEJDEZb/9fD10oKU9k1bj4qLir2Uhl5U1FkM= +github.com/iotaledger/hive.go/logger v0.0.0-20231108050255-98e0fa35e936 h1:05EbTaladbyo7mD8yBaWYJh9P8u/TUTmrjVmcUjoW8A= +github.com/iotaledger/hive.go/logger v0.0.0-20231108050255-98e0fa35e936/go.mod h1:w1psHM2MuKsen1WdsPKrpqElYH7ZOQ+YdQIgJZg4HTo= +github.com/iotaledger/hive.go/runtime v0.0.0-20231108050255-98e0fa35e936 h1:XbC1fmY87UJ/yMs8U2YqlUdJsqb0Xqj/ZYQKlZ7AUG8= +github.com/iotaledger/hive.go/runtime v0.0.0-20231108050255-98e0fa35e936/go.mod h1:DrZPvUvLarK8C2qb+3H2vdypp/MuhpQmB3iMJbDCr/Q= +github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231108050255-98e0fa35e936 h1:LXhLW2cN9bQYoHQsgmJRb/jiRBRU5s2rLoCNjZfgHdg= +github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231108050255-98e0fa35e936/go.mod h1:FoH3T6yKlZJp8xm8K+zsQiibSynp32v21CpWx8xkek8= +github.com/iotaledger/hive.go/stringify v0.0.0-20231108050255-98e0fa35e936 h1:Y4HgL5gm9S27usg5M2t6wi1BSdCxVorM62lwnpKuMd4= +github.com/iotaledger/hive.go/stringify v0.0.0-20231108050255-98e0fa35e936/go.mod h1:FTo/UWzNYgnQ082GI9QVM9HFDERqf9rw9RivNpqrnTs= github.com/iotaledger/inx-app v1.0.0-rc.3.0.20231031135002-4c79ea5193f5 h1:17JDzMKTMXKF3xys6gPURRddkZhg1LY+xwfhbr/sVqg= github.com/iotaledger/inx-app v1.0.0-rc.3.0.20231031135002-4c79ea5193f5/go.mod h1:LsJvoBUVVnY7tkwwByCVtAwmp5bFXdyJNGU/+KVQJVM= github.com/iotaledger/inx/go v1.0.0-rc.2.0.20231031134131-b6ad918dc1ac h1:c7R33+TQGMYP6pvLUQQaqpdDFl+GZbhAcfGMI0285fo= github.com/iotaledger/inx/go v1.0.0-rc.2.0.20231031134131-b6ad918dc1ac/go.mod h1:qPuMUvCTaghsnYRDnRoRuztTyEKFlmi2S7gb44rH7WM= -github.com/iotaledger/iota.go/v4 v4.0.0-20231106063525-564529bf7361 h1:8uHWvSQpTa8FqakKkKwdppk46PUr/FJjFeupi9csa64= -github.com/iotaledger/iota.go/v4 v4.0.0-20231106063525-564529bf7361/go.mod h1:GXUQi5h4MAtPoBkJ/BRFakVbOiJeU76O0HcXl28mwK8= +github.com/iotaledger/iota.go/v4 v4.0.0-20231108050608-afce96cfe8a6 h1:4kvG+BB4GOBsNYPY/enPo3xeC65A133L9cD73Kf1p9Q= +github.com/iotaledger/iota.go/v4 v4.0.0-20231108050608-afce96cfe8a6/go.mod h1:8iDORW4/e4NztyAGqjW07uSMjbhs7snbxw+81IWOczY= github.com/ipfs/boxo v0.13.1 h1:nQ5oQzcMZR3oL41REJDcTbrvDvuZh3J9ckc9+ILeRQI= github.com/ipfs/boxo v0.13.1/go.mod h1:btrtHy0lmO1ODMECbbEY1pxNtrLilvKSYLoGQt1yYCk= github.com/ipfs/go-cid v0.4.1 h1:A/T3qGvxi4kpKWWcPC/PgbvDA2bjVLO7n4UeVwnbs/s= diff --git a/tools/genesis-snapshot/go.mod b/tools/genesis-snapshot/go.mod index ff9d54043..edbf18aae 100644 --- a/tools/genesis-snapshot/go.mod +++ b/tools/genesis-snapshot/go.mod @@ -5,12 +5,12 @@ go 1.21 replace github.com/iotaledger/iota-core => ../../ require ( - github.com/iotaledger/hive.go/crypto v0.0.0-20231106033111-7f3042d04fc4 - github.com/iotaledger/hive.go/ierrors v0.0.0-20231106033111-7f3042d04fc4 - github.com/iotaledger/hive.go/lo v0.0.0-20231106033111-7f3042d04fc4 - github.com/iotaledger/hive.go/runtime v0.0.0-20231106033111-7f3042d04fc4 + github.com/iotaledger/hive.go/crypto v0.0.0-20231108050255-98e0fa35e936 + github.com/iotaledger/hive.go/ierrors v0.0.0-20231108050255-98e0fa35e936 + github.com/iotaledger/hive.go/lo v0.0.0-20231108050255-98e0fa35e936 + github.com/iotaledger/hive.go/runtime v0.0.0-20231108050255-98e0fa35e936 github.com/iotaledger/iota-core v0.0.0-00010101000000-000000000000 - github.com/iotaledger/iota.go/v4 v4.0.0-20231106063525-564529bf7361 + github.com/iotaledger/iota.go/v4 v4.0.0-20231108050608-afce96cfe8a6 github.com/mr-tron/base58 v1.2.0 github.com/spf13/pflag v1.0.5 golang.org/x/crypto v0.14.0 @@ -26,14 +26,14 @@ require ( github.com/holiman/uint256 v1.2.3 // indirect github.com/iancoleman/orderedmap v0.3.0 // indirect github.com/iotaledger/grocksdb v1.7.5-0.20230220105546-5162e18885c7 // indirect - github.com/iotaledger/hive.go/ads v0.0.0-20231106033111-7f3042d04fc4 // indirect - github.com/iotaledger/hive.go/constraints v0.0.0-20231106033111-7f3042d04fc4 // indirect - github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231106033111-7f3042d04fc4 // indirect - github.com/iotaledger/hive.go/ds v0.0.0-20231106033111-7f3042d04fc4 // indirect - github.com/iotaledger/hive.go/kvstore v0.0.0-20231106033111-7f3042d04fc4 // indirect - github.com/iotaledger/hive.go/log v0.0.0-20231106033111-7f3042d04fc4 // indirect - github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231106033111-7f3042d04fc4 // indirect - github.com/iotaledger/hive.go/stringify v0.0.0-20231106033111-7f3042d04fc4 // indirect + github.com/iotaledger/hive.go/ads v0.0.0-20231108050255-98e0fa35e936 // indirect + github.com/iotaledger/hive.go/constraints v0.0.0-20231108050255-98e0fa35e936 // indirect + github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231108050255-98e0fa35e936 // indirect + github.com/iotaledger/hive.go/ds v0.0.0-20231108050255-98e0fa35e936 // indirect + github.com/iotaledger/hive.go/kvstore v0.0.0-20231108050255-98e0fa35e936 // indirect + github.com/iotaledger/hive.go/log v0.0.0-20231108050255-98e0fa35e936 // indirect + github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231108050255-98e0fa35e936 // indirect + github.com/iotaledger/hive.go/stringify v0.0.0-20231108050255-98e0fa35e936 // indirect github.com/ipfs/go-cid v0.4.1 // indirect github.com/klauspost/cpuid/v2 v2.2.5 // indirect github.com/kr/text v0.2.0 // indirect diff --git a/tools/genesis-snapshot/go.sum b/tools/genesis-snapshot/go.sum index fc84bc411..0a0bf91ab 100644 --- a/tools/genesis-snapshot/go.sum +++ b/tools/genesis-snapshot/go.sum @@ -28,32 +28,32 @@ github.com/iancoleman/orderedmap v0.3.0 h1:5cbR2grmZR/DiVt+VJopEhtVs9YGInGIxAoMJ github.com/iancoleman/orderedmap v0.3.0/go.mod h1:XuLcCUkdL5owUCQeF2Ue9uuw1EptkJDkXXS7VoV7XGE= github.com/iotaledger/grocksdb v1.7.5-0.20230220105546-5162e18885c7 h1:dTrD7X2PTNgli6EbS4tV9qu3QAm/kBU3XaYZV2xdzys= github.com/iotaledger/grocksdb v1.7.5-0.20230220105546-5162e18885c7/go.mod h1:ZRdPu684P0fQ1z8sXz4dj9H5LWHhz4a9oCtvjunkSrw= -github.com/iotaledger/hive.go/ads v0.0.0-20231106033111-7f3042d04fc4 h1:3F60Hx0Oi+4p7V5e+Ap8/aagbk0eSZ8jci4GxGXVLmc= -github.com/iotaledger/hive.go/ads v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:b8w/1e7wk7ZQgTm/2dZPH2pWl7CTlTmgkgaIleaZgFw= -github.com/iotaledger/hive.go/constraints v0.0.0-20231106033111-7f3042d04fc4 h1:GS3d6xi8eiI9rIycajLs4z3vM/u0D9oJ2qEP8f/Mnmw= -github.com/iotaledger/hive.go/constraints v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:dOBOM2s4se3HcWefPe8sQLUalGXJ8yVXw58oK8jke3s= -github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231106033111-7f3042d04fc4 h1:xz1Vy5YujaXLL6Kx2gU7eueWGZPquimCGXBLimtCSak= -github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231106033111-7f3042d04fc4/go.mod h1:oBpjupsGbCg4WlK9HfXaF5RWtZvA4LmtmuLsMEcz+Qg= -github.com/iotaledger/hive.go/crypto v0.0.0-20231106033111-7f3042d04fc4 h1:3FNxPWFuNEdEJ17PoNS5ILTcg2b7wHDkLZx2lL3PhIE= -github.com/iotaledger/hive.go/crypto v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:ePC73xHcQdkbbHApVoF9XfLfjTtCuYJ8+WJepdRoUIw= -github.com/iotaledger/hive.go/ds v0.0.0-20231106033111-7f3042d04fc4 h1:eVNGVSEX/Z8CyTjUXD/QBSlevFSfu5rwdIJkjPULGeM= -github.com/iotaledger/hive.go/ds v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:RnYZNMRIXKt/SXVsFA18uUBNDZMQm0h5BykMXjv8/8A= -github.com/iotaledger/hive.go/ierrors v0.0.0-20231106033111-7f3042d04fc4 h1:yr8sRMURAjVQhWX+HgDm2AwgY2jH1JrZjOf49aUM8CQ= -github.com/iotaledger/hive.go/ierrors v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:HcE8B5lP96enc/OALTb2/rIIi+yOLouRoHOKRclKmC8= -github.com/iotaledger/hive.go/kvstore v0.0.0-20231106033111-7f3042d04fc4 h1:N21PVtaSvtG9Qq+3hLEj6Cca4Thx7YTa5ezKuqj3V0Y= -github.com/iotaledger/hive.go/kvstore v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:gQWd99xA2Wl4DpCqHIeieNUAKbRJDZo1VNnswAbibyA= -github.com/iotaledger/hive.go/lo v0.0.0-20231106033111-7f3042d04fc4 h1:bK0+pb716B9rBuXDp1+xKh5iX5wp00FF47UjTD+KphM= -github.com/iotaledger/hive.go/lo v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:lFKoK3stQVscy4k6+Cqd3Chq6u65JoTRhfhzJsmKyY8= -github.com/iotaledger/hive.go/log v0.0.0-20231106033111-7f3042d04fc4 h1:VJpxS4LePyDXJT1TRAVExm1ELmEH0t79NB08xEGyR/U= -github.com/iotaledger/hive.go/log v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:61LNutuzo3UnIgC9E8fPCIZ1Xwlb6ApbyTZssMl2cvI= -github.com/iotaledger/hive.go/runtime v0.0.0-20231106033111-7f3042d04fc4 h1:hOGlfCiQxIumcWMFxxAp13Ox//SQK0DGcXY3NJf7kGQ= -github.com/iotaledger/hive.go/runtime v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:6WKyYAkvdY08iW4/w30goNq0GaBTljT0MXXilnQ33wk= -github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231106033111-7f3042d04fc4 h1:CRNZkH8TuRIoCHDkfHGA09hpgT2cFFzj1Dys4ze61tI= -github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231106033111-7f3042d04fc4/go.mod h1:fW/lA6n0C/jf9B9NMX46eJXsJTU8Nzs+9oBWMTNzPzE= -github.com/iotaledger/hive.go/stringify v0.0.0-20231106033111-7f3042d04fc4 h1:xY4tsqeuZq/V8S3vYpuHJT6EdRgMGoFJkyFfxWV0ZPY= -github.com/iotaledger/hive.go/stringify v0.0.0-20231106033111-7f3042d04fc4/go.mod h1:FTo/UWzNYgnQ082GI9QVM9HFDERqf9rw9RivNpqrnTs= -github.com/iotaledger/iota.go/v4 v4.0.0-20231106063525-564529bf7361 h1:8uHWvSQpTa8FqakKkKwdppk46PUr/FJjFeupi9csa64= -github.com/iotaledger/iota.go/v4 v4.0.0-20231106063525-564529bf7361/go.mod h1:GXUQi5h4MAtPoBkJ/BRFakVbOiJeU76O0HcXl28mwK8= +github.com/iotaledger/hive.go/ads v0.0.0-20231108050255-98e0fa35e936 h1:2r4FgIGdc2lHcIbXiUFCCVq4+B0oZk9t6Z0SSLjrzCE= +github.com/iotaledger/hive.go/ads v0.0.0-20231108050255-98e0fa35e936/go.mod h1:gbUvr01B5ha530GnNm8K2OsHXOd2BtzBYOMxyTX3iDg= +github.com/iotaledger/hive.go/constraints v0.0.0-20231108050255-98e0fa35e936 h1:qkq0Wz+Y3J8QYRLd0fwTgHuur/A3k7d82BxOKSfvk8c= +github.com/iotaledger/hive.go/constraints v0.0.0-20231108050255-98e0fa35e936/go.mod h1:dOBOM2s4se3HcWefPe8sQLUalGXJ8yVXw58oK8jke3s= +github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231108050255-98e0fa35e936 h1:GtsYwcCqRomhMo190TPxBrOzs6YnVmqkmQgT/lJrJRo= +github.com/iotaledger/hive.go/core v1.0.0-rc.3.0.20231108050255-98e0fa35e936/go.mod h1:CdixkrB7VdQzEDlVuwsxPtsiJL/WXrQgz3PELIqlLko= +github.com/iotaledger/hive.go/crypto v0.0.0-20231108050255-98e0fa35e936 h1:Xeb4w0g0Kv2ZjdCZQqz8oiqAU5qAy8OXG8kGTXSPzuY= +github.com/iotaledger/hive.go/crypto v0.0.0-20231108050255-98e0fa35e936/go.mod h1:OQ9EVTTQT1mkO/16BgwSIyQlAhEg+Cptud/yutevWsI= +github.com/iotaledger/hive.go/ds v0.0.0-20231108050255-98e0fa35e936 h1:NtQLSS0Lq5qg/w5nbMpXrlQpmcK3KiOaQmgZWoRc4mM= +github.com/iotaledger/hive.go/ds v0.0.0-20231108050255-98e0fa35e936/go.mod h1:JE8cbZSvzbB5TrwXibg6M0B7ck35YxF30ItHBzQRlgc= +github.com/iotaledger/hive.go/ierrors v0.0.0-20231108050255-98e0fa35e936 h1:o5S4KUAwToOLXoYYRj9ZgqeDsFv1VRM4+Mni0Tdj2Ck= +github.com/iotaledger/hive.go/ierrors v0.0.0-20231108050255-98e0fa35e936/go.mod h1:HcE8B5lP96enc/OALTb2/rIIi+yOLouRoHOKRclKmC8= +github.com/iotaledger/hive.go/kvstore v0.0.0-20231108050255-98e0fa35e936 h1:kXKJQ8UvbA8kI0Jx0EnlXbwDeZFY8pEX0Q6KaOPsYlQ= +github.com/iotaledger/hive.go/kvstore v0.0.0-20231108050255-98e0fa35e936/go.mod h1:ytfKoHr/nF8u0y0G4mamfG0yjFtJiJVk0kgjnPOtsSY= +github.com/iotaledger/hive.go/lo v0.0.0-20231108050255-98e0fa35e936 h1:coXPklQ7JgqTXIUXh3b4OHml1VIvI8x7pQsjsES/u/s= +github.com/iotaledger/hive.go/lo v0.0.0-20231108050255-98e0fa35e936/go.mod h1:6Ee7i6b4tuTHuRYnPP8VUb0wr9XFI5qlqtnttBd9jRg= +github.com/iotaledger/hive.go/log v0.0.0-20231108050255-98e0fa35e936 h1:VBvGnsVwqhoT9zMyMIlK5fPmz6fsbiPZOwdU1E8WU7o= +github.com/iotaledger/hive.go/log v0.0.0-20231108050255-98e0fa35e936/go.mod h1:vzO4/wRkEJDEZb/9fD10oKU9k1bj4qLir2Uhl5U1FkM= +github.com/iotaledger/hive.go/runtime v0.0.0-20231108050255-98e0fa35e936 h1:XbC1fmY87UJ/yMs8U2YqlUdJsqb0Xqj/ZYQKlZ7AUG8= +github.com/iotaledger/hive.go/runtime v0.0.0-20231108050255-98e0fa35e936/go.mod h1:DrZPvUvLarK8C2qb+3H2vdypp/MuhpQmB3iMJbDCr/Q= +github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231108050255-98e0fa35e936 h1:LXhLW2cN9bQYoHQsgmJRb/jiRBRU5s2rLoCNjZfgHdg= +github.com/iotaledger/hive.go/serializer/v2 v2.0.0-rc.1.0.20231108050255-98e0fa35e936/go.mod h1:FoH3T6yKlZJp8xm8K+zsQiibSynp32v21CpWx8xkek8= +github.com/iotaledger/hive.go/stringify v0.0.0-20231108050255-98e0fa35e936 h1:Y4HgL5gm9S27usg5M2t6wi1BSdCxVorM62lwnpKuMd4= +github.com/iotaledger/hive.go/stringify v0.0.0-20231108050255-98e0fa35e936/go.mod h1:FTo/UWzNYgnQ082GI9QVM9HFDERqf9rw9RivNpqrnTs= +github.com/iotaledger/iota.go/v4 v4.0.0-20231108050608-afce96cfe8a6 h1:4kvG+BB4GOBsNYPY/enPo3xeC65A133L9cD73Kf1p9Q= +github.com/iotaledger/iota.go/v4 v4.0.0-20231108050608-afce96cfe8a6/go.mod h1:8iDORW4/e4NztyAGqjW07uSMjbhs7snbxw+81IWOczY= github.com/ipfs/go-cid v0.4.1 h1:A/T3qGvxi4kpKWWcPC/PgbvDA2bjVLO7n4UeVwnbs/s= github.com/ipfs/go-cid v0.4.1/go.mod h1:uQHwDeX4c6CtyrFwdqyhpNcxVewur1M7l7fNU7LKwZk= github.com/klauspost/cpuid/v2 v2.2.5 h1:0E5MSMDEoAulmXNFquVs//DdoomxaoTY1kUhbc/qbZg= From c868f9229cb1eff4c40d8ff0e0e014b160b1651a Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Wed, 8 Nov 2023 13:24:37 +0800 Subject: [PATCH 29/32] Change utxo ledger snapshot diff to uint32 --- pkg/protocol/engine/utxoledger/snapshot.go | 16 ++++++------- .../engine/utxoledger/snapshot_test.go | 24 +++++++++---------- 2 files changed, 20 insertions(+), 20 deletions(-) diff --git a/pkg/protocol/engine/utxoledger/snapshot.go b/pkg/protocol/engine/utxoledger/snapshot.go index 7d70fb525..a6af13e95 100644 --- a/pkg/protocol/engine/utxoledger/snapshot.go +++ b/pkg/protocol/engine/utxoledger/snapshot.go @@ -95,13 +95,13 @@ func ReadSlotDiffToSnapshotReader(reader io.ReadSeeker, apiProvider iotago.APIPr return nil, ierrors.Wrap(err, "unable to read slot diff index") } - createdCount, err := stream.PeekSize(reader, serializer.SeriLengthPrefixTypeAsUint64) + createdCount, err := stream.PeekSize(reader, serializer.SeriLengthPrefixTypeAsUint32) if err != nil { return nil, ierrors.Wrap(err, "unable to peek slot diff created count") } slotDiff.Outputs = make(Outputs, createdCount) - if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(i int) error { + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint32, func(i int) error { slotDiff.Outputs[i], err = OutputFromSnapshotReader(reader, apiProvider) if err != nil { return ierrors.Wrap(err, "unable to read slot diff output") @@ -112,13 +112,13 @@ func ReadSlotDiffToSnapshotReader(reader io.ReadSeeker, apiProvider iotago.APIPr return nil, ierrors.Wrap(err, "unable to read slot diff created collection") } - consumedCount, err := stream.PeekSize(reader, serializer.SeriLengthPrefixTypeAsUint64) + consumedCount, err := stream.PeekSize(reader, serializer.SeriLengthPrefixTypeAsUint32) if err != nil { return nil, ierrors.Wrap(err, "unable to peek slot diff consumed count") } slotDiff.Spents = make(Spents, consumedCount) - if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(i int) error { + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint32, func(i int) error { slotDiff.Spents[i], err = SpentFromSnapshotReader(reader, apiProvider, slotDiff.Slot) if err != nil { return ierrors.Wrap(err, "unable to read slot diff spent") @@ -137,7 +137,7 @@ func WriteSlotDiffToSnapshotWriter(writer io.WriteSeeker, diff *SlotDiff) error return ierrors.Wrap(err, "unable to write slot diff index") } - if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (elementsCount int, err error) { + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint32, func() (elementsCount int, err error) { for _, output := range diff.sortedOutputs() { if err := stream.WriteBytes(writer, output.SnapshotBytes()); err != nil { return 0, ierrors.Wrap(err, "unable to write slot diff created output") @@ -149,7 +149,7 @@ func WriteSlotDiffToSnapshotWriter(writer io.WriteSeeker, diff *SlotDiff) error return ierrors.Wrap(err, "unable to write slot diff created collection") } - if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (elementsCount int, err error) { + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint32, func() (elementsCount int, err error) { for _, spent := range diff.sortedSpents() { if err := stream.WriteBytes(writer, spent.SnapshotBytes()); err != nil { return 0, ierrors.Wrap(err, "unable to write slot diff spent output") @@ -192,7 +192,7 @@ func (m *Manager) Import(reader io.ReadSeeker) error { return ierrors.Wrap(err, "unable to read LS output collection") } - if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(i int) error { + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint32, func(i int) error { slotDiff, err := ReadSlotDiffToSnapshotReader(reader, m.apiProvider) if err != nil { return ierrors.Wrapf(err, "unable to read LS slot diff at index %d", i) @@ -258,7 +258,7 @@ func (m *Manager) Export(writer io.WriteSeeker, targetIndex iotago.SlotIndex) er return ierrors.Wrap(err, "unable to write unspent output collection") } - if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (int, error) { + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint32, func() (int, error) { var slotDiffCount int for diffIndex := ledgerIndex; diffIndex > targetIndex; diffIndex-- { slotDiff, err := m.SlotDiffWithoutLocking(diffIndex) diff --git a/pkg/protocol/engine/utxoledger/snapshot_test.go b/pkg/protocol/engine/utxoledger/snapshot_test.go index 1331bbab3..4f24112bc 100644 --- a/pkg/protocol/engine/utxoledger/snapshot_test.go +++ b/pkg/protocol/engine/utxoledger/snapshot_test.go @@ -189,9 +189,9 @@ func TestWriteSlotDiffToSnapshotWriter(t *testing.T) { require.NoError(t, binary.Read(reader, binary.LittleEndian, &readSlot)) require.Equal(t, slot, readSlot) - var createdCount uint64 + var createdCount uint32 require.NoError(t, binary.Read(reader, binary.LittleEndian, &createdCount)) - require.Equal(t, uint64(len(slotDiff.Outputs)), createdCount) + require.Equal(t, uint32(len(slotDiff.Outputs)), createdCount) var snapshotOutputs utxoledger.Outputs for i := 0; i < len(slotDiff.Outputs); i++ { @@ -202,9 +202,9 @@ func TestWriteSlotDiffToSnapshotWriter(t *testing.T) { tpkg.EqualOutputs(t, slotDiff.Outputs, snapshotOutputs) - var consumedCount uint64 + var consumedCount uint32 require.NoError(t, binary.Read(reader, binary.LittleEndian, &consumedCount)) - require.Equal(t, uint64(len(slotDiff.Spents)), consumedCount) + require.Equal(t, uint32(len(slotDiff.Spents)), consumedCount) var snapshotSpents utxoledger.Spents for i := 0; i < len(slotDiff.Spents); i++ { @@ -380,9 +380,9 @@ func TestManager_Export(t *testing.T) { tpkg.EqualOutputs(t, unspentOutputs, snapshotOutputs) - var slotDiffCount uint64 + var slotDiffCount uint32 require.NoError(t, binary.Read(reader, binary.LittleEndian, &slotDiffCount)) - require.Equal(t, uint64(0), slotDiffCount) + require.Equal(t, uint32(0), slotDiffCount) } // Test exporting at slot 1 @@ -412,11 +412,11 @@ func TestManager_Export(t *testing.T) { tpkg.EqualOutputs(t, unspentOutputs, snapshotOutputs) - var slotDiffCount uint64 + var slotDiffCount uint32 require.NoError(t, binary.Read(reader, binary.LittleEndian, &slotDiffCount)) - require.Equal(t, uint64(1), slotDiffCount) + require.Equal(t, uint32(1), slotDiffCount) - for i := uint64(0); i < slotDiffCount; i++ { + for i := uint32(0); i < slotDiffCount; i++ { diff, err := utxoledger.ReadSlotDiffToSnapshotReader(reader, api.SingleVersionProvider(iotago_tpkg.TestAPI)) require.NoError(t, err) require.Equal(t, snapshotLedgerSlot-iotago.SlotIndex(i), diff.Slot) @@ -450,11 +450,11 @@ func TestManager_Export(t *testing.T) { tpkg.EqualOutputs(t, unspentOutputs, snapshotOutputs) - var slotDiffCount uint64 + var slotDiffCount uint32 require.NoError(t, binary.Read(reader, binary.LittleEndian, &slotDiffCount)) - require.Equal(t, uint64(2), slotDiffCount) + require.Equal(t, uint32(2), slotDiffCount) - for i := uint64(0); i < slotDiffCount; i++ { + for i := uint32(0); i < slotDiffCount; i++ { diff, err := utxoledger.ReadSlotDiffToSnapshotReader(reader, api.SingleVersionProvider(iotago_tpkg.TestAPI)) require.NoError(t, err) require.Equal(t, snapshotLedgerSlot-iotago.SlotIndex(i), diff.Slot) From 50aba2825fcedaffcd0c4d4007707396f2d75cd1 Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Wed, 8 Nov 2023 13:29:58 +0800 Subject: [PATCH 30/32] Change performance snapshot to uint32 where possible --- .../sybilprotectionv1/performance/snapshot.go | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/pkg/protocol/sybilprotection/sybilprotectionv1/performance/snapshot.go b/pkg/protocol/sybilprotection/sybilprotectionv1/performance/snapshot.go index c75d49618..585aff575 100644 --- a/pkg/protocol/sybilprotection/sybilprotectionv1/performance/snapshot.go +++ b/pkg/protocol/sybilprotection/sybilprotectionv1/performance/snapshot.go @@ -72,7 +72,7 @@ func (t *Tracker) Export(writer io.WriteSeeker, targetSlotIndex iotago.SlotIndex } func (t *Tracker) importPerformanceFactor(reader io.ReadSeeker) error { - if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(i int) error { + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint32, func(i int) error { slot, err := stream.Read[iotago.SlotIndex](reader) if err != nil { return ierrors.Wrapf(err, "unable to read slot index at index %d", i) @@ -110,7 +110,7 @@ func (t *Tracker) importPerformanceFactor(reader io.ReadSeeker) error { } func (t *Tracker) importPoolRewards(reader io.ReadSeeker) error { - if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(int) error { + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint32, func(int) error { epoch, err := stream.Read[iotago.EpochIndex](reader) if err != nil { return ierrors.Wrap(err, "unable to read epoch") @@ -154,7 +154,7 @@ func (t *Tracker) importPoolRewards(reader io.ReadSeeker) error { } func (t *Tracker) importPoolsStats(reader io.ReadSeeker) error { - if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(int) error { + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint32, func(int) error { epoch, err := stream.Read[iotago.EpochIndex](reader) if err != nil { return ierrors.Wrap(err, "unable to read epoch") @@ -178,7 +178,7 @@ func (t *Tracker) importPoolsStats(reader io.ReadSeeker) error { } func (t *Tracker) importCommittees(reader io.ReadSeeker) error { - if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(int) error { + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint32, func(int) error { epoch, err := stream.Read[iotago.EpochIndex](reader) if err != nil { return ierrors.Wrap(err, "unable to read epoch index") @@ -205,7 +205,7 @@ func (t *Tracker) exportPerformanceFactor(writer io.WriteSeeker, startSlot, targ t.performanceFactorsMutex.RLock() defer t.performanceFactorsMutex.RUnlock() - if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (int, error) { + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint32, func() (int, error) { var slotCount int for currentSlot := startSlot; currentSlot <= targetSlot; currentSlot++ { @@ -257,7 +257,7 @@ func (t *Tracker) exportPoolRewards(writer io.WriteSeeker, targetEpoch iotago.Ep // export all stored pools // in theory we could save the epoch count only once, because stats and rewards should be the same length - if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (int, error) { + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint32, func() (int, error) { var epochCount int for epoch := targetEpoch; epoch > iotago.EpochIndex(lo.Max(0, int(targetEpoch)-daysInYear)); epoch-- { @@ -310,7 +310,7 @@ func (t *Tracker) exportPoolRewards(writer io.WriteSeeker, targetEpoch iotago.Ep } func (t *Tracker) exportPoolsStats(writer io.WriteSeeker, targetEpoch iotago.EpochIndex) error { - if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (int, error) { + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint32, func() (int, error) { var epochCount int // export all stored pools @@ -354,7 +354,7 @@ func (t *Tracker) exportCommittees(writer io.WriteSeeker, targetSlot iotago.Slot pointOfNoReturn := apiForSlot.TimeProvider().EpochEnd(epochFromTargetSlot) - apiForSlot.ProtocolParameters().MaxCommittableAge() - if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (int, error) { + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint32, func() (int, error) { var epochCount int if err := t.committeeStore.StreamBytes(func(epochBytes []byte, committeeBytes []byte) error { From 68a36c7457686b577c5e98eeae935056ce4dee2e Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Wed, 8 Nov 2023 13:30:50 +0800 Subject: [PATCH 31/32] Change commitments snapshot to uint32 --- pkg/storage/permanent/commitments.go | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/pkg/storage/permanent/commitments.go b/pkg/storage/permanent/commitments.go index e4dff5157..430f13288 100644 --- a/pkg/storage/permanent/commitments.go +++ b/pkg/storage/permanent/commitments.go @@ -38,7 +38,7 @@ func (c *Commitments) Load(slot iotago.SlotIndex) (commitment *model.Commitment, } func (c *Commitments) Export(writer io.WriteSeeker, targetSlot iotago.SlotIndex) (err error) { - if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint64, func() (elementsCount int, err error) { + if err := stream.WriteCollection(writer, serializer.SeriLengthPrefixTypeAsUint32, func() (elementsCount int, err error) { var count int for slot := iotago.SlotIndex(0); slot <= targetSlot; slot++ { commitmentBytes, err := c.store.KVStore().Get(lo.PanicOnErr(slot.Bytes())) @@ -62,7 +62,7 @@ func (c *Commitments) Export(writer io.WriteSeeker, targetSlot iotago.SlotIndex) } func (c *Commitments) Import(reader io.ReadSeeker) (err error) { - if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint64, func(i int) error { + if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint32, func(i int) error { commitment, err := stream.ReadObjectWithSize[*model.Commitment](reader, serializer.SeriLengthPrefixTypeAsUint16, func(bytes []byte) (*model.Commitment, int, error) { return model.CommitmentFromBytes(bytes, c.apiProvider) }) From d8aaf2f7dedf5b246b40913afb8ef64b3c00209f Mon Sep 17 00:00:00 2001 From: jonastheis <4181434+jonastheis@users.noreply.github.com> Date: Wed, 8 Nov 2023 14:17:18 +0800 Subject: [PATCH 32/32] Address review comments --- pkg/model/commitment.go | 66 +++++++++---------- pkg/model/validator_performance.go | 12 ++-- pkg/network/protocols/core/protocol.go | 5 +- .../performance/performance.go | 6 +- pkg/storage/permanent/commitments.go | 6 +- pkg/storage/permanent/settings.go | 4 +- 6 files changed, 46 insertions(+), 53 deletions(-) diff --git a/pkg/model/commitment.go b/pkg/model/commitment.go index bade9cb63..d7cafb979 100644 --- a/pkg/model/commitment.go +++ b/pkg/model/commitment.go @@ -50,45 +50,41 @@ func CommitmentFromCommitment(iotaCommitment *iotago.Commitment, api iotago.API, return newCommitment(commitmentID, iotaCommitment, data, api) } -func CommitmentFromBytesFactory(apiProvider iotago.APIProvider, opts ...serix.Option) func(bytes []byte) (*Commitment, int, error) { +func CommitmentFromBytes(apiProvider iotago.APIProvider) func([]byte) (*Commitment, int, error) { return func(bytes []byte) (*Commitment, int, error) { - return CommitmentFromBytes(bytes, apiProvider, opts...) + totalBytesRead := 0 + + // We read the version byte here to determine the API to use, but then we decode the entire commitment again. + // Thus, we don't count the version byte as read bytes. + version, _, err := iotago.VersionFromBytes(bytes) + if err != nil { + return nil, 0, ierrors.Wrap(err, "failed to determine version") + } + + apiForVersion, err := apiProvider.APIForVersion(version) + if err != nil { + return nil, 0, ierrors.Wrapf(err, "failed to get API for version %d", version) + } + + iotaCommitment := new(iotago.Commitment) + if totalBytesRead, err = apiForVersion.Decode(bytes, iotaCommitment, serix.WithValidation()); err != nil { + return nil, 0, ierrors.Wrap(err, "failed to decode commitment") + } + + commitmentID, err := iotaCommitment.ID() + if err != nil { + return nil, 0, ierrors.Wrap(err, "failed to determine commitment ID") + } + + commitment, err := newCommitment(commitmentID, iotaCommitment, bytes, apiForVersion) + if err != nil { + return nil, 0, ierrors.Wrap(err, "failed to create commitment") + } + + return commitment, totalBytesRead, nil } } -func CommitmentFromBytes(data []byte, apiProvider iotago.APIProvider, opts ...serix.Option) (*Commitment, int, error) { - totalBytesRead := 0 - - // We read the version byte here to determine the API to use, but then we decode the entire commitment again. - // Thus, we don't count the version byte as read bytes. - version, _, err := iotago.VersionFromBytes(data) - if err != nil { - return nil, 0, ierrors.Wrap(err, "failed to determine version") - } - - apiForVersion, err := apiProvider.APIForVersion(version) - if err != nil { - return nil, 0, ierrors.Wrapf(err, "failed to get API for version %d", version) - } - - iotaCommitment := new(iotago.Commitment) - if totalBytesRead, err = apiForVersion.Decode(data, iotaCommitment, opts...); err != nil { - return nil, 0, ierrors.Wrap(err, "failed to decode commitment") - } - - commitmentID, err := iotaCommitment.ID() - if err != nil { - return nil, 0, ierrors.Wrap(err, "failed to determine commitment ID") - } - - commitment, err := newCommitment(commitmentID, iotaCommitment, data, apiForVersion) - if err != nil { - return nil, 0, ierrors.Wrap(err, "failed to create commitment") - } - - return commitment, totalBytesRead, nil -} - func (c *Commitment) ID() iotago.CommitmentID { return c.commitmentID } diff --git a/pkg/model/validator_performance.go b/pkg/model/validator_performance.go index 4569f4f65..c121cfc23 100644 --- a/pkg/model/validator_performance.go +++ b/pkg/model/validator_performance.go @@ -11,14 +11,14 @@ type ValidatorPerformance struct { // works if ValidatorBlocksPerSlot is less than 32 because we use it as bit vector SlotActivityVector uint32 // can be uint8 because max count per slot is maximally ValidatorBlocksPerSlot + 1 - BlockIssuedCount uint8 + BlocksIssuedCount uint8 HighestSupportedVersionAndHash VersionAndHash } func NewValidatorPerformance() *ValidatorPerformance { return &ValidatorPerformance{ SlotActivityVector: 0, - BlockIssuedCount: 0, + BlocksIssuedCount: 0, HighestSupportedVersionAndHash: VersionAndHash{}, } } @@ -41,8 +41,8 @@ func ValidatorPerformanceFromReader(reader io.ReadSeeker) (*ValidatorPerformance if v.SlotActivityVector, err = stream.Read[uint32](reader); err != nil { return nil, ierrors.Wrap(err, "failed to read SlotActivityVector") } - if v.BlockIssuedCount, err = stream.Read[uint8](reader); err != nil { - return nil, ierrors.Wrap(err, "failed to read BlockIssuedCount") + if v.BlocksIssuedCount, err = stream.Read[uint8](reader); err != nil { + return nil, ierrors.Wrap(err, "failed to read BlocksIssuedCount") } if v.HighestSupportedVersionAndHash, err = stream.ReadObject(reader, VersionAndHashSize, VersionAndHashFromBytes); err != nil { return nil, ierrors.Wrap(err, "failed to read HighestSupportedVersionAndHash") @@ -57,8 +57,8 @@ func (p *ValidatorPerformance) Bytes() ([]byte, error) { if err := stream.Write(byteBuffer, p.SlotActivityVector); err != nil { return nil, ierrors.Wrap(err, "failed to write SlotActivityVector") } - if err := stream.Write(byteBuffer, p.BlockIssuedCount); err != nil { - return nil, ierrors.Wrap(err, "failed to write BlockIssuedCount") + if err := stream.Write(byteBuffer, p.BlocksIssuedCount); err != nil { + return nil, ierrors.Wrap(err, "failed to write BlocksIssuedCount") } if err := stream.WriteObject(byteBuffer, p.HighestSupportedVersionAndHash, VersionAndHash.Bytes); err != nil { return nil, ierrors.Wrap(err, "failed to write HighestSupportedVersionAndHash") diff --git a/pkg/network/protocols/core/protocol.go b/pkg/network/protocols/core/protocol.go index ac9426f05..cdf696117 100644 --- a/pkg/network/protocols/core/protocol.go +++ b/pkg/network/protocols/core/protocol.go @@ -13,7 +13,6 @@ import ( "github.com/iotaledger/hive.go/runtime/syncutils" "github.com/iotaledger/hive.go/runtime/workerpool" "github.com/iotaledger/hive.go/serializer/v2" - "github.com/iotaledger/hive.go/serializer/v2/serix" "github.com/iotaledger/hive.go/serializer/v2/stream" "github.com/iotaledger/iota-core/pkg/model" "github.com/iotaledger/iota-core/pkg/network" @@ -178,7 +177,7 @@ func (p *Protocol) onBlockRequest(idBytes []byte, id peer.ID) { } func (p *Protocol) onSlotCommitment(commitmentBytes []byte, id peer.ID) { - receivedCommitment, _, err := model.CommitmentFromBytes(commitmentBytes, p.apiProvider, serix.WithValidation()) + receivedCommitment, err := lo.DropCount(model.CommitmentFromBytes(p.apiProvider)(commitmentBytes)) if err != nil { p.Events.Error.Trigger(ierrors.Wrap(err, "failed to deserialize slot commitment"), id) @@ -199,7 +198,7 @@ func (p *Protocol) onSlotCommitmentRequest(idBytes []byte, id peer.ID) { } func (p *Protocol) onAttestations(commitmentBytes []byte, attestationsBytes []byte, merkleProof []byte, id peer.ID) { - cm, _, err := model.CommitmentFromBytes(commitmentBytes, p.apiProvider, serix.WithValidation()) + cm, err := lo.DropCount(model.CommitmentFromBytes(p.apiProvider)(commitmentBytes)) if err != nil { p.Events.Error.Trigger(ierrors.Wrap(err, "failed to deserialize commitment"), id) diff --git a/pkg/protocol/sybilprotection/sybilprotectionv1/performance/performance.go b/pkg/protocol/sybilprotection/sybilprotectionv1/performance/performance.go index f5f024a56..ceac2fdf5 100644 --- a/pkg/protocol/sybilprotection/sybilprotectionv1/performance/performance.go +++ b/pkg/protocol/sybilprotection/sybilprotectionv1/performance/performance.go @@ -296,7 +296,7 @@ func (t *Tracker) aggregatePerformanceFactors(slotActivityVector []*model.Valida // we reward not only total number of blocks issued, but also regularity based on block timestamp slotPerformanceFactor := bits.OnesCount32(pf.SlotActivityVector) - if pf.BlockIssuedCount > protoParamsForEpoch.ValidationBlocksPerSlot() { + if pf.BlocksIssuedCount > protoParamsForEpoch.ValidationBlocksPerSlot() { // we harshly punish validators that issue any blocks more than allowed return 0 @@ -345,8 +345,8 @@ func (t *Tracker) trackCommitteeMemberPerformance(validationBlock *iotago.Valida // we restrict the number up to ValidatorBlocksPerSlot + 1 to know later if the validator issued more blocks than allowed and be able to punish for it // also it can fint into uint8 - if validatorPerformance.BlockIssuedCount < apiForSlot.ProtocolParameters().ValidationBlocksPerSlot()+1 { - validatorPerformance.BlockIssuedCount++ + if validatorPerformance.BlocksIssuedCount < apiForSlot.ProtocolParameters().ValidationBlocksPerSlot()+1 { + validatorPerformance.BlocksIssuedCount++ } validatorPerformance.HighestSupportedVersionAndHash = model.VersionAndHash{ diff --git a/pkg/storage/permanent/commitments.go b/pkg/storage/permanent/commitments.go index 430f13288..4f832ee22 100644 --- a/pkg/storage/permanent/commitments.go +++ b/pkg/storage/permanent/commitments.go @@ -24,7 +24,7 @@ func NewCommitments(store kvstore.KVStore, apiProvider iotago.APIProvider) *Comm iotago.SlotIndex.Bytes, iotago.SlotIndexFromBytes, (*model.Commitment).Bytes, - model.CommitmentFromBytesFactory(apiProvider), + model.CommitmentFromBytes(apiProvider), ), } } @@ -63,9 +63,7 @@ func (c *Commitments) Export(writer io.WriteSeeker, targetSlot iotago.SlotIndex) func (c *Commitments) Import(reader io.ReadSeeker) (err error) { if err := stream.ReadCollection(reader, serializer.SeriLengthPrefixTypeAsUint32, func(i int) error { - commitment, err := stream.ReadObjectWithSize[*model.Commitment](reader, serializer.SeriLengthPrefixTypeAsUint16, func(bytes []byte) (*model.Commitment, int, error) { - return model.CommitmentFromBytes(bytes, c.apiProvider) - }) + commitment, err := stream.ReadObjectWithSize[*model.Commitment](reader, serializer.SeriLengthPrefixTypeAsUint16, model.CommitmentFromBytes(c.apiProvider)) if err != nil { return ierrors.Wrapf(err, "failed to read commitment at index %d", i) } diff --git a/pkg/storage/permanent/settings.go b/pkg/storage/permanent/settings.go index cca9807cd..be4459ed1 100644 --- a/pkg/storage/permanent/settings.go +++ b/pkg/storage/permanent/settings.go @@ -67,7 +67,7 @@ func NewSettings(store kvstore.KVStore, opts ...options.Option[api.EpochBasedPro store, []byte{latestCommitmentKey}, (*model.Commitment).Bytes, - model.CommitmentFromBytesFactory(apiProvider), + model.CommitmentFromBytes(apiProvider), ), storeLatestFinalizedSlot: kvstore.NewTypedValue( store, @@ -542,7 +542,7 @@ func (s *Settings) Import(reader io.ReadSeeker) (err error) { } // Now that we parsed the protocol parameters, we can parse the commitment since there will be an API available - commitment, _, err := model.CommitmentFromBytes(commitmentBytes, s.apiProvider) + commitment, err := lo.DropCount(model.CommitmentFromBytes(s.apiProvider)(commitmentBytes)) if err != nil { return ierrors.Wrap(err, "failed to parse commitment") }