bd10bdf99a
* build: Bump version to v1.17.3-dev * build: set version to v1.18.0-dev * chore: actors: Allow builtin-actors to return a map of methods (#9342) * Allow builtin-actors to return a map of methods * go mod * Fix tests * Fix tests, check carefully please * Delete lotus-pond (#9352) * feat: add StateNetworkVersion to mpool API * chore: refactor: rename NewestNetworkVersion * feat: actors: Integrate datacap actor into lotus (#9348) * Integrate datacap actor * Implement datacap actor in chain/builtin * feat: support typed errors over RPC * chore: deps: update to go-jsonrpc 0.1.8 * remove duplicate import * fix: itest: check for closed connection * chore: refactor: move retry test to API * address magik supernit * Add ability to only have single partition per msg for partitions with recovery sectors * doc gen * Address comments * Return beneficiary info from miner state Info() * Update builtin-actors to dev/20220922-v9 which includes FIP-0045 changes in progress * Integrate verifreg changes to lotus * Setup datacap actor * Update builtin-actors to dev/20220922-v9-1 * Update datacap actor to query datacap instead of verifreg * update gst * update markets * update actors with hamt fix * update gst * Update datacap to parse tokens * Update bundles * datacap and verifreg actors use ID addresses without protocol byte * update builtin-actors to rc1 * update go-fil-markets * Update bundles to rc2 * Integrate the v9 migration * Add api for getting allocation * Add upgrade epoch for butterfly * Tweak PreSeal struct to be infra-friendly * docsgen * More tweaking of PreSeal for genesis * review fixes * Use fake cid for test * add butterfly artifacts for oct 5 upgrade * check datacaps for v8 verifreg match v9 datacap actor * Remove print statements * Update to go-state-types master * Update to go-state-types v0.9.0-rc1 * review fixes * use go-fil-markets v1.24.0-v17 * Add accessors for allocations and claims maps * fix: missing permissions tag * butterfly * update butterfly artifacts * sealing pipeline: Prepare deal assigning logic for FIP-45 * sealing pipeline: Get allocationId with StateApi * use NoAllocationID instead of nil AllocationId * address review * Add datacap actor to registry.go * Add cli for listing allocations and removing expired allocations * Update to go-state-types master * deps: upgrade go-merkledag to 0.8.0 * shark params * Update cli/filplus.go Co-authored-by: Aayush Rajasekaran <arajasek94@gmail.com> * revert change to verifreg util * docsgen-cli * miss the stuff * Update FFI * Update go-state-types to v0.9.0 * Update builtin-actors to v9.0.0 * add calib upgrade epcoh * update the upgrade envvar * kill shark * Remove fvm splash banner from nv17 upgrade * check invariance for pending deals and allocations * check pending verified deal proposal migrated to allocation * Add check for unsealed CID in precommit sectors * Fix counting of allocations in nv17 migration test * make gen * pass state trees as pointers * Add assertion that migrations with & without cache are the same * compare allocation to verified deal proposal * Fix miner state precommit info * fix migration test tool * add changelog * Update to go-state-types v0.9.1 * Integrate builtin-actors v9.0.1 * chore: ver: bump version for rc3 (#9512) * Bump version to 1.18.0-rc3 * Update CHANGELOG.md * Update CHANGELOG.md Co-authored-by: Aayush Rajasekaran <arajasek94@gmail.com> * Update CHANGELOG.md Co-authored-by: Aayush Rajasekaran <arajasek94@gmail.com> Co-authored-by: Jiaying Wang <42981373+jennijuju@users.noreply.github.com> Co-authored-by: Aayush Rajasekaran <arajasek94@gmail.com> * Migration: Use autobatch bs * Fix autobatch Signed-off-by: Jakub Sztandera <kubuxu@protocol.ai> * Invoker: Use MethodMeta from go-state-types * Add a second premigration for nv17 * Add more shed tools for migration checking * address review * Lotus release v1.18.0-rc4 * fix: ci: fix app-image build on ci (#9527) * Remove old go version first * Add GO_VERSION file * Use GO_VERSION to set / verify go version * mv GO_VERSION GO_VERSION_MIN * Use GO_VERSION_MIN in Makefile check Co-authored-by: Ian Davis <jungziege@gmail.com> * Update to latest go-state-types for migration fixes * go mod tidy * fix: use api.ErrActorNotFound instead of types.ErrActorNotFound * fix: add fields to ForkUpgradeParams * docs: update actors_version_checklist.md * chore: fix lint * update to go state type v0.9.6 with market migration fix (#9545) * update go-state-types to v-0.9.7 * Add invariant checks to migration * fix invariant check: number of entries in datacap actor should include verifreg * Invariant checks: Only include not-activated deals * test: nv17 migration * Address review * add lotus-shed invariance method * Migration cli takes a stateroot cid and a height * make gen * Update to builtin-actors v9.0.2 * Failing test that shows that notaries can remove datacap from the verifreg actor * Test that should pass when the problem is solved * make gen * Review fixes * statemanager call function will return call information even if call errors * update go-state-types * update builtin-actors * bubble up errors properly from ApplyImplicitMessage * bump to rc5 * set new upgrade heights for calibnet * set new upgrade height for butterfly * tweak calibnet upgrade schedule * clarify changelog note about calibnet * butterfly * update calibnet artifacts * Allow setting local bundles for Debug FVM for av 9+ * fix: autobatch: remove potential deadlock when a block is missing Check the _underlying_ blockstore instead of recursing. Also, drop the lock before we do that. * fix imports * build: set shark mainnet epoch (#9640) * chore: build: Lotus release v1.18.0 (#9641) * Lotus release v1.18.0 * add changelog * address review * changelog improvement Co-authored-by: Jennifer Wang <jiayingw703@gmail.com> Co-authored-by: Jiaying Wang <42981373+jennijuju@users.noreply.github.com> Signed-off-by: Jakub Sztandera <kubuxu@protocol.ai> Co-authored-by: Łukasz Magiera <magik6k@gmail.com> Co-authored-by: Łukasz Magiera <magik6k@users.noreply.github.com> Co-authored-by: Aayush <arajasek94@gmail.com> Co-authored-by: Geoff Stuart <geoff.vball@gmail.com> Co-authored-by: Shrenuj Bansal <shrenuj.bansal@protocol.ai> Co-authored-by: simlecode <69969590+simlecode@users.noreply.github.com> Co-authored-by: Rod Vagg <rod@vagg.org> Co-authored-by: Jakub Sztandera <kubuxu@protocol.ai> Co-authored-by: Ian Davis <jungziege@gmail.com> Co-authored-by: zenground0 <ZenGround0@users.noreply.github.com> Co-authored-by: Steven Allen <steven@stebalien.com>
1288 lines
26 KiB
Go
1288 lines
26 KiB
Go
// Code generated by github.com/whyrusleeping/cbor-gen. DO NOT EDIT.
|
|
|
|
package api
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
"math"
|
|
"sort"
|
|
|
|
cid "github.com/ipfs/go-cid"
|
|
cbg "github.com/whyrusleeping/cbor-gen"
|
|
xerrors "golang.org/x/xerrors"
|
|
|
|
abi "github.com/filecoin-project/go-state-types/abi"
|
|
paych "github.com/filecoin-project/go-state-types/builtin/v8/paych"
|
|
market "github.com/filecoin-project/go-state-types/builtin/v9/market"
|
|
)
|
|
|
|
var _ = xerrors.Errorf
|
|
var _ = cid.Undef
|
|
var _ = math.E
|
|
var _ = sort.Sort
|
|
|
|
func (t *PaymentInfo) MarshalCBOR(w io.Writer) error {
|
|
if t == nil {
|
|
_, err := w.Write(cbg.CborNull)
|
|
return err
|
|
}
|
|
|
|
cw := cbg.NewCborWriter(w)
|
|
|
|
if _, err := cw.Write([]byte{163}); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.Channel (address.Address) (struct)
|
|
if len("Channel") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"Channel\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("Channel"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("Channel")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := t.Channel.MarshalCBOR(cw); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.WaitSentinel (cid.Cid) (struct)
|
|
if len("WaitSentinel") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"WaitSentinel\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("WaitSentinel"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("WaitSentinel")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := cbg.WriteCid(cw, t.WaitSentinel); err != nil {
|
|
return xerrors.Errorf("failed to write cid field t.WaitSentinel: %w", err)
|
|
}
|
|
|
|
// t.Vouchers ([]*paych.SignedVoucher) (slice)
|
|
if len("Vouchers") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"Vouchers\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("Vouchers"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("Vouchers")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if len(t.Vouchers) > cbg.MaxLength {
|
|
return xerrors.Errorf("Slice value in field t.Vouchers was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajArray, uint64(len(t.Vouchers))); err != nil {
|
|
return err
|
|
}
|
|
for _, v := range t.Vouchers {
|
|
if err := v.MarshalCBOR(cw); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (t *PaymentInfo) UnmarshalCBOR(r io.Reader) (err error) {
|
|
*t = PaymentInfo{}
|
|
|
|
cr := cbg.NewCborReader(r)
|
|
|
|
maj, extra, err := cr.ReadHeader()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer func() {
|
|
if err == io.EOF {
|
|
err = io.ErrUnexpectedEOF
|
|
}
|
|
}()
|
|
|
|
if maj != cbg.MajMap {
|
|
return fmt.Errorf("cbor input should be of type map")
|
|
}
|
|
|
|
if extra > cbg.MaxLength {
|
|
return fmt.Errorf("PaymentInfo: map struct too large (%d)", extra)
|
|
}
|
|
|
|
var name string
|
|
n := extra
|
|
|
|
for i := uint64(0); i < n; i++ {
|
|
|
|
{
|
|
sval, err := cbg.ReadString(cr)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
name = string(sval)
|
|
}
|
|
|
|
switch name {
|
|
// t.Channel (address.Address) (struct)
|
|
case "Channel":
|
|
|
|
{
|
|
|
|
if err := t.Channel.UnmarshalCBOR(cr); err != nil {
|
|
return xerrors.Errorf("unmarshaling t.Channel: %w", err)
|
|
}
|
|
|
|
}
|
|
// t.WaitSentinel (cid.Cid) (struct)
|
|
case "WaitSentinel":
|
|
|
|
{
|
|
|
|
c, err := cbg.ReadCid(cr)
|
|
if err != nil {
|
|
return xerrors.Errorf("failed to read cid field t.WaitSentinel: %w", err)
|
|
}
|
|
|
|
t.WaitSentinel = c
|
|
|
|
}
|
|
// t.Vouchers ([]*paych.SignedVoucher) (slice)
|
|
case "Vouchers":
|
|
|
|
maj, extra, err = cr.ReadHeader()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if extra > cbg.MaxLength {
|
|
return fmt.Errorf("t.Vouchers: array too large (%d)", extra)
|
|
}
|
|
|
|
if maj != cbg.MajArray {
|
|
return fmt.Errorf("expected cbor array")
|
|
}
|
|
|
|
if extra > 0 {
|
|
t.Vouchers = make([]*paych.SignedVoucher, extra)
|
|
}
|
|
|
|
for i := 0; i < int(extra); i++ {
|
|
|
|
var v paych.SignedVoucher
|
|
if err := v.UnmarshalCBOR(cr); err != nil {
|
|
return err
|
|
}
|
|
|
|
t.Vouchers[i] = &v
|
|
}
|
|
|
|
default:
|
|
// Field doesn't exist on this type, so ignore it
|
|
cbg.ScanForLinks(r, func(cid.Cid) {})
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
func (t *SealedRef) MarshalCBOR(w io.Writer) error {
|
|
if t == nil {
|
|
_, err := w.Write(cbg.CborNull)
|
|
return err
|
|
}
|
|
|
|
cw := cbg.NewCborWriter(w)
|
|
|
|
if _, err := cw.Write([]byte{163}); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.SectorID (abi.SectorNumber) (uint64)
|
|
if len("SectorID") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"SectorID\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("SectorID"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("SectorID")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajUnsignedInt, uint64(t.SectorID)); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.Offset (abi.PaddedPieceSize) (uint64)
|
|
if len("Offset") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"Offset\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("Offset"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("Offset")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajUnsignedInt, uint64(t.Offset)); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.Size (abi.UnpaddedPieceSize) (uint64)
|
|
if len("Size") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"Size\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("Size"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("Size")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajUnsignedInt, uint64(t.Size)); err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (t *SealedRef) UnmarshalCBOR(r io.Reader) (err error) {
|
|
*t = SealedRef{}
|
|
|
|
cr := cbg.NewCborReader(r)
|
|
|
|
maj, extra, err := cr.ReadHeader()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer func() {
|
|
if err == io.EOF {
|
|
err = io.ErrUnexpectedEOF
|
|
}
|
|
}()
|
|
|
|
if maj != cbg.MajMap {
|
|
return fmt.Errorf("cbor input should be of type map")
|
|
}
|
|
|
|
if extra > cbg.MaxLength {
|
|
return fmt.Errorf("SealedRef: map struct too large (%d)", extra)
|
|
}
|
|
|
|
var name string
|
|
n := extra
|
|
|
|
for i := uint64(0); i < n; i++ {
|
|
|
|
{
|
|
sval, err := cbg.ReadString(cr)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
name = string(sval)
|
|
}
|
|
|
|
switch name {
|
|
// t.SectorID (abi.SectorNumber) (uint64)
|
|
case "SectorID":
|
|
|
|
{
|
|
|
|
maj, extra, err = cr.ReadHeader()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if maj != cbg.MajUnsignedInt {
|
|
return fmt.Errorf("wrong type for uint64 field")
|
|
}
|
|
t.SectorID = abi.SectorNumber(extra)
|
|
|
|
}
|
|
// t.Offset (abi.PaddedPieceSize) (uint64)
|
|
case "Offset":
|
|
|
|
{
|
|
|
|
maj, extra, err = cr.ReadHeader()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if maj != cbg.MajUnsignedInt {
|
|
return fmt.Errorf("wrong type for uint64 field")
|
|
}
|
|
t.Offset = abi.PaddedPieceSize(extra)
|
|
|
|
}
|
|
// t.Size (abi.UnpaddedPieceSize) (uint64)
|
|
case "Size":
|
|
|
|
{
|
|
|
|
maj, extra, err = cr.ReadHeader()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if maj != cbg.MajUnsignedInt {
|
|
return fmt.Errorf("wrong type for uint64 field")
|
|
}
|
|
t.Size = abi.UnpaddedPieceSize(extra)
|
|
|
|
}
|
|
|
|
default:
|
|
// Field doesn't exist on this type, so ignore it
|
|
cbg.ScanForLinks(r, func(cid.Cid) {})
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
func (t *SealedRefs) MarshalCBOR(w io.Writer) error {
|
|
if t == nil {
|
|
_, err := w.Write(cbg.CborNull)
|
|
return err
|
|
}
|
|
|
|
cw := cbg.NewCborWriter(w)
|
|
|
|
if _, err := cw.Write([]byte{161}); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.Refs ([]api.SealedRef) (slice)
|
|
if len("Refs") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"Refs\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("Refs"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("Refs")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if len(t.Refs) > cbg.MaxLength {
|
|
return xerrors.Errorf("Slice value in field t.Refs was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajArray, uint64(len(t.Refs))); err != nil {
|
|
return err
|
|
}
|
|
for _, v := range t.Refs {
|
|
if err := v.MarshalCBOR(cw); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (t *SealedRefs) UnmarshalCBOR(r io.Reader) (err error) {
|
|
*t = SealedRefs{}
|
|
|
|
cr := cbg.NewCborReader(r)
|
|
|
|
maj, extra, err := cr.ReadHeader()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer func() {
|
|
if err == io.EOF {
|
|
err = io.ErrUnexpectedEOF
|
|
}
|
|
}()
|
|
|
|
if maj != cbg.MajMap {
|
|
return fmt.Errorf("cbor input should be of type map")
|
|
}
|
|
|
|
if extra > cbg.MaxLength {
|
|
return fmt.Errorf("SealedRefs: map struct too large (%d)", extra)
|
|
}
|
|
|
|
var name string
|
|
n := extra
|
|
|
|
for i := uint64(0); i < n; i++ {
|
|
|
|
{
|
|
sval, err := cbg.ReadString(cr)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
name = string(sval)
|
|
}
|
|
|
|
switch name {
|
|
// t.Refs ([]api.SealedRef) (slice)
|
|
case "Refs":
|
|
|
|
maj, extra, err = cr.ReadHeader()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if extra > cbg.MaxLength {
|
|
return fmt.Errorf("t.Refs: array too large (%d)", extra)
|
|
}
|
|
|
|
if maj != cbg.MajArray {
|
|
return fmt.Errorf("expected cbor array")
|
|
}
|
|
|
|
if extra > 0 {
|
|
t.Refs = make([]SealedRef, extra)
|
|
}
|
|
|
|
for i := 0; i < int(extra); i++ {
|
|
|
|
var v SealedRef
|
|
if err := v.UnmarshalCBOR(cr); err != nil {
|
|
return err
|
|
}
|
|
|
|
t.Refs[i] = v
|
|
}
|
|
|
|
default:
|
|
// Field doesn't exist on this type, so ignore it
|
|
cbg.ScanForLinks(r, func(cid.Cid) {})
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
func (t *SealTicket) MarshalCBOR(w io.Writer) error {
|
|
if t == nil {
|
|
_, err := w.Write(cbg.CborNull)
|
|
return err
|
|
}
|
|
|
|
cw := cbg.NewCborWriter(w)
|
|
|
|
if _, err := cw.Write([]byte{162}); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.Value (abi.SealRandomness) (slice)
|
|
if len("Value") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"Value\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("Value"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("Value")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if len(t.Value) > cbg.ByteArrayMaxLen {
|
|
return xerrors.Errorf("Byte array in field t.Value was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajByteString, uint64(len(t.Value))); err != nil {
|
|
return err
|
|
}
|
|
|
|
if _, err := cw.Write(t.Value[:]); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.Epoch (abi.ChainEpoch) (int64)
|
|
if len("Epoch") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"Epoch\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("Epoch"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("Epoch")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if t.Epoch >= 0 {
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajUnsignedInt, uint64(t.Epoch)); err != nil {
|
|
return err
|
|
}
|
|
} else {
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajNegativeInt, uint64(-t.Epoch-1)); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (t *SealTicket) UnmarshalCBOR(r io.Reader) (err error) {
|
|
*t = SealTicket{}
|
|
|
|
cr := cbg.NewCborReader(r)
|
|
|
|
maj, extra, err := cr.ReadHeader()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer func() {
|
|
if err == io.EOF {
|
|
err = io.ErrUnexpectedEOF
|
|
}
|
|
}()
|
|
|
|
if maj != cbg.MajMap {
|
|
return fmt.Errorf("cbor input should be of type map")
|
|
}
|
|
|
|
if extra > cbg.MaxLength {
|
|
return fmt.Errorf("SealTicket: map struct too large (%d)", extra)
|
|
}
|
|
|
|
var name string
|
|
n := extra
|
|
|
|
for i := uint64(0); i < n; i++ {
|
|
|
|
{
|
|
sval, err := cbg.ReadString(cr)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
name = string(sval)
|
|
}
|
|
|
|
switch name {
|
|
// t.Value (abi.SealRandomness) (slice)
|
|
case "Value":
|
|
|
|
maj, extra, err = cr.ReadHeader()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if extra > cbg.ByteArrayMaxLen {
|
|
return fmt.Errorf("t.Value: byte array too large (%d)", extra)
|
|
}
|
|
if maj != cbg.MajByteString {
|
|
return fmt.Errorf("expected byte array")
|
|
}
|
|
|
|
if extra > 0 {
|
|
t.Value = make([]uint8, extra)
|
|
}
|
|
|
|
if _, err := io.ReadFull(cr, t.Value[:]); err != nil {
|
|
return err
|
|
}
|
|
// t.Epoch (abi.ChainEpoch) (int64)
|
|
case "Epoch":
|
|
{
|
|
maj, extra, err := cr.ReadHeader()
|
|
var extraI int64
|
|
if err != nil {
|
|
return err
|
|
}
|
|
switch maj {
|
|
case cbg.MajUnsignedInt:
|
|
extraI = int64(extra)
|
|
if extraI < 0 {
|
|
return fmt.Errorf("int64 positive overflow")
|
|
}
|
|
case cbg.MajNegativeInt:
|
|
extraI = int64(extra)
|
|
if extraI < 0 {
|
|
return fmt.Errorf("int64 negative oveflow")
|
|
}
|
|
extraI = -1 - extraI
|
|
default:
|
|
return fmt.Errorf("wrong type for int64 field: %d", maj)
|
|
}
|
|
|
|
t.Epoch = abi.ChainEpoch(extraI)
|
|
}
|
|
|
|
default:
|
|
// Field doesn't exist on this type, so ignore it
|
|
cbg.ScanForLinks(r, func(cid.Cid) {})
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
func (t *SealSeed) MarshalCBOR(w io.Writer) error {
|
|
if t == nil {
|
|
_, err := w.Write(cbg.CborNull)
|
|
return err
|
|
}
|
|
|
|
cw := cbg.NewCborWriter(w)
|
|
|
|
if _, err := cw.Write([]byte{162}); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.Value (abi.InteractiveSealRandomness) (slice)
|
|
if len("Value") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"Value\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("Value"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("Value")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if len(t.Value) > cbg.ByteArrayMaxLen {
|
|
return xerrors.Errorf("Byte array in field t.Value was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajByteString, uint64(len(t.Value))); err != nil {
|
|
return err
|
|
}
|
|
|
|
if _, err := cw.Write(t.Value[:]); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.Epoch (abi.ChainEpoch) (int64)
|
|
if len("Epoch") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"Epoch\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("Epoch"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("Epoch")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if t.Epoch >= 0 {
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajUnsignedInt, uint64(t.Epoch)); err != nil {
|
|
return err
|
|
}
|
|
} else {
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajNegativeInt, uint64(-t.Epoch-1)); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (t *SealSeed) UnmarshalCBOR(r io.Reader) (err error) {
|
|
*t = SealSeed{}
|
|
|
|
cr := cbg.NewCborReader(r)
|
|
|
|
maj, extra, err := cr.ReadHeader()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer func() {
|
|
if err == io.EOF {
|
|
err = io.ErrUnexpectedEOF
|
|
}
|
|
}()
|
|
|
|
if maj != cbg.MajMap {
|
|
return fmt.Errorf("cbor input should be of type map")
|
|
}
|
|
|
|
if extra > cbg.MaxLength {
|
|
return fmt.Errorf("SealSeed: map struct too large (%d)", extra)
|
|
}
|
|
|
|
var name string
|
|
n := extra
|
|
|
|
for i := uint64(0); i < n; i++ {
|
|
|
|
{
|
|
sval, err := cbg.ReadString(cr)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
name = string(sval)
|
|
}
|
|
|
|
switch name {
|
|
// t.Value (abi.InteractiveSealRandomness) (slice)
|
|
case "Value":
|
|
|
|
maj, extra, err = cr.ReadHeader()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if extra > cbg.ByteArrayMaxLen {
|
|
return fmt.Errorf("t.Value: byte array too large (%d)", extra)
|
|
}
|
|
if maj != cbg.MajByteString {
|
|
return fmt.Errorf("expected byte array")
|
|
}
|
|
|
|
if extra > 0 {
|
|
t.Value = make([]uint8, extra)
|
|
}
|
|
|
|
if _, err := io.ReadFull(cr, t.Value[:]); err != nil {
|
|
return err
|
|
}
|
|
// t.Epoch (abi.ChainEpoch) (int64)
|
|
case "Epoch":
|
|
{
|
|
maj, extra, err := cr.ReadHeader()
|
|
var extraI int64
|
|
if err != nil {
|
|
return err
|
|
}
|
|
switch maj {
|
|
case cbg.MajUnsignedInt:
|
|
extraI = int64(extra)
|
|
if extraI < 0 {
|
|
return fmt.Errorf("int64 positive overflow")
|
|
}
|
|
case cbg.MajNegativeInt:
|
|
extraI = int64(extra)
|
|
if extraI < 0 {
|
|
return fmt.Errorf("int64 negative oveflow")
|
|
}
|
|
extraI = -1 - extraI
|
|
default:
|
|
return fmt.Errorf("wrong type for int64 field: %d", maj)
|
|
}
|
|
|
|
t.Epoch = abi.ChainEpoch(extraI)
|
|
}
|
|
|
|
default:
|
|
// Field doesn't exist on this type, so ignore it
|
|
cbg.ScanForLinks(r, func(cid.Cid) {})
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
func (t *PieceDealInfo) MarshalCBOR(w io.Writer) error {
|
|
if t == nil {
|
|
_, err := w.Write(cbg.CborNull)
|
|
return err
|
|
}
|
|
|
|
cw := cbg.NewCborWriter(w)
|
|
|
|
if _, err := cw.Write([]byte{165}); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.PublishCid (cid.Cid) (struct)
|
|
if len("PublishCid") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"PublishCid\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("PublishCid"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("PublishCid")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if t.PublishCid == nil {
|
|
if _, err := cw.Write(cbg.CborNull); err != nil {
|
|
return err
|
|
}
|
|
} else {
|
|
if err := cbg.WriteCid(cw, *t.PublishCid); err != nil {
|
|
return xerrors.Errorf("failed to write cid field t.PublishCid: %w", err)
|
|
}
|
|
}
|
|
|
|
// t.DealID (abi.DealID) (uint64)
|
|
if len("DealID") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"DealID\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("DealID"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("DealID")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajUnsignedInt, uint64(t.DealID)); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.DealProposal (market.DealProposal) (struct)
|
|
if len("DealProposal") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"DealProposal\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("DealProposal"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("DealProposal")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := t.DealProposal.MarshalCBOR(cw); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.DealSchedule (api.DealSchedule) (struct)
|
|
if len("DealSchedule") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"DealSchedule\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("DealSchedule"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("DealSchedule")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := t.DealSchedule.MarshalCBOR(cw); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.KeepUnsealed (bool) (bool)
|
|
if len("KeepUnsealed") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"KeepUnsealed\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("KeepUnsealed"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("KeepUnsealed")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := cbg.WriteBool(w, t.KeepUnsealed); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (t *PieceDealInfo) UnmarshalCBOR(r io.Reader) (err error) {
|
|
*t = PieceDealInfo{}
|
|
|
|
cr := cbg.NewCborReader(r)
|
|
|
|
maj, extra, err := cr.ReadHeader()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer func() {
|
|
if err == io.EOF {
|
|
err = io.ErrUnexpectedEOF
|
|
}
|
|
}()
|
|
|
|
if maj != cbg.MajMap {
|
|
return fmt.Errorf("cbor input should be of type map")
|
|
}
|
|
|
|
if extra > cbg.MaxLength {
|
|
return fmt.Errorf("PieceDealInfo: map struct too large (%d)", extra)
|
|
}
|
|
|
|
var name string
|
|
n := extra
|
|
|
|
for i := uint64(0); i < n; i++ {
|
|
|
|
{
|
|
sval, err := cbg.ReadString(cr)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
name = string(sval)
|
|
}
|
|
|
|
switch name {
|
|
// t.PublishCid (cid.Cid) (struct)
|
|
case "PublishCid":
|
|
|
|
{
|
|
|
|
b, err := cr.ReadByte()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if b != cbg.CborNull[0] {
|
|
if err := cr.UnreadByte(); err != nil {
|
|
return err
|
|
}
|
|
|
|
c, err := cbg.ReadCid(cr)
|
|
if err != nil {
|
|
return xerrors.Errorf("failed to read cid field t.PublishCid: %w", err)
|
|
}
|
|
|
|
t.PublishCid = &c
|
|
}
|
|
|
|
}
|
|
// t.DealID (abi.DealID) (uint64)
|
|
case "DealID":
|
|
|
|
{
|
|
|
|
maj, extra, err = cr.ReadHeader()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if maj != cbg.MajUnsignedInt {
|
|
return fmt.Errorf("wrong type for uint64 field")
|
|
}
|
|
t.DealID = abi.DealID(extra)
|
|
|
|
}
|
|
// t.DealProposal (market.DealProposal) (struct)
|
|
case "DealProposal":
|
|
|
|
{
|
|
|
|
b, err := cr.ReadByte()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if b != cbg.CborNull[0] {
|
|
if err := cr.UnreadByte(); err != nil {
|
|
return err
|
|
}
|
|
t.DealProposal = new(market.DealProposal)
|
|
if err := t.DealProposal.UnmarshalCBOR(cr); err != nil {
|
|
return xerrors.Errorf("unmarshaling t.DealProposal pointer: %w", err)
|
|
}
|
|
}
|
|
|
|
}
|
|
// t.DealSchedule (api.DealSchedule) (struct)
|
|
case "DealSchedule":
|
|
|
|
{
|
|
|
|
if err := t.DealSchedule.UnmarshalCBOR(cr); err != nil {
|
|
return xerrors.Errorf("unmarshaling t.DealSchedule: %w", err)
|
|
}
|
|
|
|
}
|
|
// t.KeepUnsealed (bool) (bool)
|
|
case "KeepUnsealed":
|
|
|
|
maj, extra, err = cr.ReadHeader()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if maj != cbg.MajOther {
|
|
return fmt.Errorf("booleans must be major type 7")
|
|
}
|
|
switch extra {
|
|
case 20:
|
|
t.KeepUnsealed = false
|
|
case 21:
|
|
t.KeepUnsealed = true
|
|
default:
|
|
return fmt.Errorf("booleans are either major type 7, value 20 or 21 (got %d)", extra)
|
|
}
|
|
|
|
default:
|
|
// Field doesn't exist on this type, so ignore it
|
|
cbg.ScanForLinks(r, func(cid.Cid) {})
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
func (t *SectorPiece) MarshalCBOR(w io.Writer) error {
|
|
if t == nil {
|
|
_, err := w.Write(cbg.CborNull)
|
|
return err
|
|
}
|
|
|
|
cw := cbg.NewCborWriter(w)
|
|
|
|
if _, err := cw.Write([]byte{162}); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.Piece (abi.PieceInfo) (struct)
|
|
if len("Piece") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"Piece\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("Piece"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("Piece")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := t.Piece.MarshalCBOR(cw); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.DealInfo (api.PieceDealInfo) (struct)
|
|
if len("DealInfo") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"DealInfo\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("DealInfo"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("DealInfo")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := t.DealInfo.MarshalCBOR(cw); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (t *SectorPiece) UnmarshalCBOR(r io.Reader) (err error) {
|
|
*t = SectorPiece{}
|
|
|
|
cr := cbg.NewCborReader(r)
|
|
|
|
maj, extra, err := cr.ReadHeader()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer func() {
|
|
if err == io.EOF {
|
|
err = io.ErrUnexpectedEOF
|
|
}
|
|
}()
|
|
|
|
if maj != cbg.MajMap {
|
|
return fmt.Errorf("cbor input should be of type map")
|
|
}
|
|
|
|
if extra > cbg.MaxLength {
|
|
return fmt.Errorf("SectorPiece: map struct too large (%d)", extra)
|
|
}
|
|
|
|
var name string
|
|
n := extra
|
|
|
|
for i := uint64(0); i < n; i++ {
|
|
|
|
{
|
|
sval, err := cbg.ReadString(cr)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
name = string(sval)
|
|
}
|
|
|
|
switch name {
|
|
// t.Piece (abi.PieceInfo) (struct)
|
|
case "Piece":
|
|
|
|
{
|
|
|
|
if err := t.Piece.UnmarshalCBOR(cr); err != nil {
|
|
return xerrors.Errorf("unmarshaling t.Piece: %w", err)
|
|
}
|
|
|
|
}
|
|
// t.DealInfo (api.PieceDealInfo) (struct)
|
|
case "DealInfo":
|
|
|
|
{
|
|
|
|
b, err := cr.ReadByte()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if b != cbg.CborNull[0] {
|
|
if err := cr.UnreadByte(); err != nil {
|
|
return err
|
|
}
|
|
t.DealInfo = new(PieceDealInfo)
|
|
if err := t.DealInfo.UnmarshalCBOR(cr); err != nil {
|
|
return xerrors.Errorf("unmarshaling t.DealInfo pointer: %w", err)
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
default:
|
|
// Field doesn't exist on this type, so ignore it
|
|
cbg.ScanForLinks(r, func(cid.Cid) {})
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
func (t *DealSchedule) MarshalCBOR(w io.Writer) error {
|
|
if t == nil {
|
|
_, err := w.Write(cbg.CborNull)
|
|
return err
|
|
}
|
|
|
|
cw := cbg.NewCborWriter(w)
|
|
|
|
if _, err := cw.Write([]byte{162}); err != nil {
|
|
return err
|
|
}
|
|
|
|
// t.StartEpoch (abi.ChainEpoch) (int64)
|
|
if len("StartEpoch") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"StartEpoch\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("StartEpoch"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("StartEpoch")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if t.StartEpoch >= 0 {
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajUnsignedInt, uint64(t.StartEpoch)); err != nil {
|
|
return err
|
|
}
|
|
} else {
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajNegativeInt, uint64(-t.StartEpoch-1)); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
// t.EndEpoch (abi.ChainEpoch) (int64)
|
|
if len("EndEpoch") > cbg.MaxLength {
|
|
return xerrors.Errorf("Value in field \"EndEpoch\" was too long")
|
|
}
|
|
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajTextString, uint64(len("EndEpoch"))); err != nil {
|
|
return err
|
|
}
|
|
if _, err := io.WriteString(w, string("EndEpoch")); err != nil {
|
|
return err
|
|
}
|
|
|
|
if t.EndEpoch >= 0 {
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajUnsignedInt, uint64(t.EndEpoch)); err != nil {
|
|
return err
|
|
}
|
|
} else {
|
|
if err := cw.WriteMajorTypeHeader(cbg.MajNegativeInt, uint64(-t.EndEpoch-1)); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (t *DealSchedule) UnmarshalCBOR(r io.Reader) (err error) {
|
|
*t = DealSchedule{}
|
|
|
|
cr := cbg.NewCborReader(r)
|
|
|
|
maj, extra, err := cr.ReadHeader()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer func() {
|
|
if err == io.EOF {
|
|
err = io.ErrUnexpectedEOF
|
|
}
|
|
}()
|
|
|
|
if maj != cbg.MajMap {
|
|
return fmt.Errorf("cbor input should be of type map")
|
|
}
|
|
|
|
if extra > cbg.MaxLength {
|
|
return fmt.Errorf("DealSchedule: map struct too large (%d)", extra)
|
|
}
|
|
|
|
var name string
|
|
n := extra
|
|
|
|
for i := uint64(0); i < n; i++ {
|
|
|
|
{
|
|
sval, err := cbg.ReadString(cr)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
name = string(sval)
|
|
}
|
|
|
|
switch name {
|
|
// t.StartEpoch (abi.ChainEpoch) (int64)
|
|
case "StartEpoch":
|
|
{
|
|
maj, extra, err := cr.ReadHeader()
|
|
var extraI int64
|
|
if err != nil {
|
|
return err
|
|
}
|
|
switch maj {
|
|
case cbg.MajUnsignedInt:
|
|
extraI = int64(extra)
|
|
if extraI < 0 {
|
|
return fmt.Errorf("int64 positive overflow")
|
|
}
|
|
case cbg.MajNegativeInt:
|
|
extraI = int64(extra)
|
|
if extraI < 0 {
|
|
return fmt.Errorf("int64 negative oveflow")
|
|
}
|
|
extraI = -1 - extraI
|
|
default:
|
|
return fmt.Errorf("wrong type for int64 field: %d", maj)
|
|
}
|
|
|
|
t.StartEpoch = abi.ChainEpoch(extraI)
|
|
}
|
|
// t.EndEpoch (abi.ChainEpoch) (int64)
|
|
case "EndEpoch":
|
|
{
|
|
maj, extra, err := cr.ReadHeader()
|
|
var extraI int64
|
|
if err != nil {
|
|
return err
|
|
}
|
|
switch maj {
|
|
case cbg.MajUnsignedInt:
|
|
extraI = int64(extra)
|
|
if extraI < 0 {
|
|
return fmt.Errorf("int64 positive overflow")
|
|
}
|
|
case cbg.MajNegativeInt:
|
|
extraI = int64(extra)
|
|
if extraI < 0 {
|
|
return fmt.Errorf("int64 negative oveflow")
|
|
}
|
|
extraI = -1 - extraI
|
|
default:
|
|
return fmt.Errorf("wrong type for int64 field: %d", maj)
|
|
}
|
|
|
|
t.EndEpoch = abi.ChainEpoch(extraI)
|
|
}
|
|
|
|
default:
|
|
// Field doesn't exist on this type, so ignore it
|
|
cbg.ScanForLinks(r, func(cid.Cid) {})
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|