bc

package
v0.0.0-...-829742f Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 28, 2022 License: AGPL-3.0 Imports: 14 Imported by: 0

Documentation

Overview

Package bc is a generated protocol buffer package.

It is generated from these files:

bc.proto

It has these top-level messages:

Hash
Program
AssetID
AssetAmount
AssetDefinition
ValueSource
ValueDestination
BlockHeader
TxHeader
Mux
Coinbase
OriginalOutput
VoteOutput
VetoInput
Retirement
Issuance
Spend

Index

Constants

This section is empty.

Variables

View Source
var (
	ErrEntryType    = errors.New("invalid entry type")
	ErrMissingEntry = errors.New("missing entry")
)

Convenience routines for accessing entries of specific types by ID.

View Source
var EmptyStringHash = NewHash(sha3.Sum256(nil))

EmptyStringHash represents a 256-bit hash.

Functions

This section is empty.

Types

type AssetAmount

type AssetAmount struct {
	AssetId *AssetID `protobuf:"bytes,1,opt,name=asset_id,json=assetId" json:"asset_id,omitempty"`
	Amount  uint64   `protobuf:"varint,2,opt,name=amount" json:"amount,omitempty"`
}

func (*AssetAmount) Descriptor

func (*AssetAmount) Descriptor() ([]byte, []int)

func (*AssetAmount) Equal

func (a *AssetAmount) Equal(other *AssetAmount) (eq bool, err error)

Equal check does two AssetAmount have same assetID and amount

func (*AssetAmount) GetAmount

func (m *AssetAmount) GetAmount() uint64

func (*AssetAmount) GetAssetId

func (m *AssetAmount) GetAssetId() *AssetID

func (*AssetAmount) ProtoMessage

func (*AssetAmount) ProtoMessage()

func (*AssetAmount) ReadFrom

func (a *AssetAmount) ReadFrom(r *blockchain.Reader) (err error)

ReadFrom read the AssetAmount from the bytes

func (*AssetAmount) Reset

func (m *AssetAmount) Reset()

func (*AssetAmount) String

func (m *AssetAmount) String() string

func (AssetAmount) WriteTo

func (a AssetAmount) WriteTo(w io.Writer) (int64, error)

WriteTo convert struct to byte and write to io

type AssetDefinition

type AssetDefinition struct {
	IssuanceProgram *Program `protobuf:"bytes,1,opt,name=issuance_program,json=issuanceProgram" json:"issuance_program,omitempty"`
	Data            *Hash    `protobuf:"bytes,2,opt,name=data" json:"data,omitempty"`
}

func (*AssetDefinition) ComputeAssetID

func (ad *AssetDefinition) ComputeAssetID() (assetID AssetID)

ComputeAssetID calculate the asset id from AssetDefinition

func (*AssetDefinition) Descriptor

func (*AssetDefinition) Descriptor() ([]byte, []int)

func (*AssetDefinition) GetData

func (m *AssetDefinition) GetData() *Hash

func (*AssetDefinition) GetIssuanceProgram

func (m *AssetDefinition) GetIssuanceProgram() *Program

func (*AssetDefinition) ProtoMessage

func (*AssetDefinition) ProtoMessage()

func (*AssetDefinition) Reset

func (m *AssetDefinition) Reset()

func (*AssetDefinition) String

func (m *AssetDefinition) String() string

type AssetID

type AssetID struct {
	V0 uint64 `protobuf:"fixed64,1,opt,name=v0" json:"v0,omitempty"`
	V1 uint64 `protobuf:"fixed64,2,opt,name=v1" json:"v1,omitempty"`
	V2 uint64 `protobuf:"fixed64,3,opt,name=v2" json:"v2,omitempty"`
	V3 uint64 `protobuf:"fixed64,4,opt,name=v3" json:"v3,omitempty"`
}

This message type duplicates Hash, above. One alternative is to embed a Hash inside an AssetID. But it's useful for AssetID to be plain old data (without pointers). Another alternative is use Hash in any protobuf types where an AssetID is called for, but it's preferable to have type safety.

func ComputeAssetID

func ComputeAssetID(prog []byte, vmVersion uint64, data *Hash) AssetID

ComputeAssetID implement the assetID calculate logic

func NewAssetID

func NewAssetID(b [32]byte) (a AssetID)

NewAssetID convert byte array to aseet id

func (AssetID) Byte32

func (a AssetID) Byte32() (b32 [32]byte)

Byte32 return the byte array representation

func (AssetID) Bytes

func (a AssetID) Bytes() []byte

Bytes returns the byte representation.

func (*AssetID) Descriptor

func (*AssetID) Descriptor() ([]byte, []int)

func (*AssetID) GetV0

func (m *AssetID) GetV0() uint64

func (*AssetID) GetV1

func (m *AssetID) GetV1() uint64

func (*AssetID) GetV2

func (m *AssetID) GetV2() uint64

func (*AssetID) GetV3

func (m *AssetID) GetV3() uint64

func (*AssetID) IsZero

func (a *AssetID) IsZero() bool

IsZero tells whether a Asset pointer is nil or points to an all-zero hash.

func (AssetID) MarshalText

func (a AssetID) MarshalText() ([]byte, error)

MarshalText satisfies the TextMarshaler interface.

func (*AssetID) ProtoMessage

func (*AssetID) ProtoMessage()

func (*AssetID) ReadFrom

func (a *AssetID) ReadFrom(r io.Reader) (int64, error)

ReadFrom satisfies the io.ReaderFrom interface.

func (*AssetID) Reset

func (m *AssetID) Reset()

func (*AssetID) String

func (m *AssetID) String() string

func (*AssetID) UnmarshalJSON

func (a *AssetID) UnmarshalJSON(b []byte) error

UnmarshalJSON satisfies the json.Unmarshaler interface.

func (*AssetID) UnmarshalText

func (a *AssetID) UnmarshalText(b []byte) error

UnmarshalText satisfies the TextUnmarshaler interface.

func (AssetID) WriteTo

func (a AssetID) WriteTo(w io.Writer) (int64, error)

WriteTo satisfies the io.WriterTo interface.

type Block

type Block struct {
	*BlockHeader
	ID           Hash
	Transactions []*Tx
}

Block is block struct in bc level

type BlockHeader

type BlockHeader struct {
	Version          uint64 `protobuf:"varint,1,opt,name=version" json:"version,omitempty"`
	Height           uint64 `protobuf:"varint,2,opt,name=height" json:"height,omitempty"`
	PreviousBlockId  *Hash  `protobuf:"bytes,3,opt,name=previous_block_id,json=previousBlockId" json:"previous_block_id,omitempty"`
	Timestamp        uint64 `protobuf:"varint,4,opt,name=timestamp" json:"timestamp,omitempty"`
	TransactionsRoot *Hash  `protobuf:"bytes,5,opt,name=transactions_root,json=transactionsRoot" json:"transactions_root,omitempty"`
}

func NewBlockHeader

func NewBlockHeader(version, height uint64, previousBlockID *Hash, timestamp uint64, transactionsRoot *Hash) *BlockHeader

NewBlockHeader creates a new BlockHeader and populates its body.

func (*BlockHeader) Descriptor

func (*BlockHeader) Descriptor() ([]byte, []int)

func (*BlockHeader) GetHeight

func (m *BlockHeader) GetHeight() uint64

func (*BlockHeader) GetPreviousBlockId

func (m *BlockHeader) GetPreviousBlockId() *Hash

func (*BlockHeader) GetTimestamp

func (m *BlockHeader) GetTimestamp() uint64

func (*BlockHeader) GetTransactionsRoot

func (m *BlockHeader) GetTransactionsRoot() *Hash

func (*BlockHeader) GetVersion

func (m *BlockHeader) GetVersion() uint64

func (*BlockHeader) ProtoMessage

func (*BlockHeader) ProtoMessage()

func (*BlockHeader) Reset

func (m *BlockHeader) Reset()

func (*BlockHeader) String

func (m *BlockHeader) String() string

type Coinbase

type Coinbase struct {
	WitnessDestination *ValueDestination `protobuf:"bytes,1,opt,name=witness_destination,json=witnessDestination" json:"witness_destination,omitempty"`
	Arbitrary          []byte            `protobuf:"bytes,2,opt,name=arbitrary,proto3" json:"arbitrary,omitempty"`
}

func NewCoinbase

func NewCoinbase(arbitrary []byte) *Coinbase

NewCoinbase creates a new Coinbase.

func (*Coinbase) Descriptor

func (*Coinbase) Descriptor() ([]byte, []int)

func (*Coinbase) GetArbitrary

func (m *Coinbase) GetArbitrary() []byte

func (*Coinbase) GetWitnessDestination

func (m *Coinbase) GetWitnessDestination() *ValueDestination

func (*Coinbase) ProtoMessage

func (*Coinbase) ProtoMessage()

func (*Coinbase) Reset

func (m *Coinbase) Reset()

func (*Coinbase) SetDestination

func (c *Coinbase) SetDestination(id *Hash, val *AssetAmount, pos uint64)

SetDestination is support function for map tx

func (*Coinbase) String

func (m *Coinbase) String() string

type Entry

type Entry interface {
	proto.Message
	// contains filtered or unexported methods
}

Entry is the interface implemented by each addressable unit in a blockchain: transaction components such as spends, issuances, outputs, and retirements (among others), plus blockheaders.

type Hash

type Hash struct {
	V0 uint64 `protobuf:"fixed64,1,opt,name=v0" json:"v0,omitempty"`
	V1 uint64 `protobuf:"fixed64,2,opt,name=v1" json:"v1,omitempty"`
	V2 uint64 `protobuf:"fixed64,3,opt,name=v2" json:"v2,omitempty"`
	V3 uint64 `protobuf:"fixed64,4,opt,name=v3" json:"v3,omitempty"`
}

func EntryID

func EntryID(e Entry) (hash Hash)

EntryID computes the identifier of an entry, as the hash of its body plus some metadata.

func NewHash

func NewHash(b32 [32]byte) (h Hash)

NewHash convert the input byte array to hash

func (Hash) Byte32

func (h Hash) Byte32() (b32 [32]byte)

Byte32 return the byte array representation

func (Hash) Bytes

func (h Hash) Bytes() []byte

Bytes returns the byte representation

func (*Hash) Descriptor

func (*Hash) Descriptor() ([]byte, []int)

func (*Hash) GetV0

func (m *Hash) GetV0() uint64

func (*Hash) GetV1

func (m *Hash) GetV1() uint64

func (*Hash) GetV2

func (m *Hash) GetV2() uint64

func (*Hash) GetV3

func (m *Hash) GetV3() uint64

func (*Hash) IsZero

func (h *Hash) IsZero() bool

IsZero tells whether a Hash pointer is nil or points to an all-zero hash.

func (Hash) MarshalText

func (h Hash) MarshalText() ([]byte, error)

MarshalText satisfies the TextMarshaler interface. It returns the bytes of h encoded in hex, for formats that can't hold arbitrary binary data. It never returns an error.

func (*Hash) ProtoMessage

func (*Hash) ProtoMessage()

func (*Hash) ReadFrom

func (h *Hash) ReadFrom(r io.Reader) (int64, error)

ReadFrom satisfies the io.ReaderFrom interface.

func (*Hash) Reset

func (m *Hash) Reset()

func (*Hash) String

func (m *Hash) String() string

func (*Hash) UnmarshalJSON

func (h *Hash) UnmarshalJSON(b []byte) error

UnmarshalJSON satisfies the json.Unmarshaler interface. If b is a JSON-encoded null, it copies the zero-value into h. Othwerwise, it decodes hex data from b into h.

func (*Hash) UnmarshalText

func (h *Hash) UnmarshalText(v []byte) error

UnmarshalText satisfies the TextUnmarshaler interface. It decodes hex data from b into h.

func (Hash) WriteTo

func (h Hash) WriteTo(w io.Writer) (int64, error)

WriteTo satisfies the io.WriterTo interface.

type Issuance

type Issuance struct {
	NonceHash              *Hash             `protobuf:"bytes,1,opt,name=nonce_hash,json=nonceHash" json:"nonce_hash,omitempty"`
	Value                  *AssetAmount      `protobuf:"bytes,2,opt,name=value" json:"value,omitempty"`
	WitnessDestination     *ValueDestination `protobuf:"bytes,3,opt,name=witness_destination,json=witnessDestination" json:"witness_destination,omitempty"`
	WitnessAssetDefinition *AssetDefinition  `protobuf:"bytes,4,opt,name=witness_asset_definition,json=witnessAssetDefinition" json:"witness_asset_definition,omitempty"`
	WitnessArguments       [][]byte          `protobuf:"bytes,5,rep,name=witness_arguments,json=witnessArguments,proto3" json:"witness_arguments,omitempty"`
	Ordinal                uint64            `protobuf:"varint,6,opt,name=ordinal" json:"ordinal,omitempty"`
}

func NewIssuance

func NewIssuance(nonceHash *Hash, value *AssetAmount, ordinal uint64) *Issuance

NewIssuance creates a new Issuance.

func (*Issuance) Descriptor

func (*Issuance) Descriptor() ([]byte, []int)

func (*Issuance) GetNonceHash

func (m *Issuance) GetNonceHash() *Hash

func (*Issuance) GetOrdinal

func (m *Issuance) GetOrdinal() uint64

func (*Issuance) GetValue

func (m *Issuance) GetValue() *AssetAmount

func (*Issuance) GetWitnessArguments

func (m *Issuance) GetWitnessArguments() [][]byte

func (*Issuance) GetWitnessAssetDefinition

func (m *Issuance) GetWitnessAssetDefinition() *AssetDefinition

func (*Issuance) GetWitnessDestination

func (m *Issuance) GetWitnessDestination() *ValueDestination

func (*Issuance) ProtoMessage

func (*Issuance) ProtoMessage()

func (*Issuance) Reset

func (m *Issuance) Reset()

func (*Issuance) SetDestination

func (iss *Issuance) SetDestination(id *Hash, val *AssetAmount, pos uint64)

SetDestination will link the issuance to the output

func (*Issuance) String

func (m *Issuance) String() string

type Mux

type Mux struct {
	Sources             []*ValueSource      `protobuf:"bytes,1,rep,name=sources" json:"sources,omitempty"`
	Program             *Program            `protobuf:"bytes,2,opt,name=program" json:"program,omitempty"`
	WitnessDestinations []*ValueDestination `protobuf:"bytes,3,rep,name=witness_destinations,json=witnessDestinations" json:"witness_destinations,omitempty"`
	WitnessArguments    [][]byte            `protobuf:"bytes,4,rep,name=witness_arguments,json=witnessArguments,proto3" json:"witness_arguments,omitempty"`
}

func NewMux

func NewMux(sources []*ValueSource, program *Program) *Mux

NewMux creates a new Mux.

func (*Mux) Descriptor

func (*Mux) Descriptor() ([]byte, []int)

func (*Mux) GetProgram

func (m *Mux) GetProgram() *Program

func (*Mux) GetSources

func (m *Mux) GetSources() []*ValueSource

func (*Mux) GetWitnessArguments

func (m *Mux) GetWitnessArguments() [][]byte

func (*Mux) GetWitnessDestinations

func (m *Mux) GetWitnessDestinations() []*ValueDestination

func (*Mux) ProtoMessage

func (*Mux) ProtoMessage()

func (*Mux) Reset

func (m *Mux) Reset()

func (*Mux) String

func (m *Mux) String() string

type OriginalOutput

type OriginalOutput struct {
	Source         *ValueSource `protobuf:"bytes,1,opt,name=source" json:"source,omitempty"`
	ControlProgram *Program     `protobuf:"bytes,2,opt,name=control_program,json=controlProgram" json:"control_program,omitempty"`
	Ordinal        uint64       `protobuf:"varint,3,opt,name=ordinal" json:"ordinal,omitempty"`
	StateData      [][]byte     `protobuf:"bytes,4,rep,name=state_data,json=stateData,proto3" json:"state_data,omitempty"`
}

func NewOriginalOutput

func NewOriginalOutput(source *ValueSource, controlProgram *Program, stateData [][]byte, ordinal uint64) *OriginalOutput

NewOriginalOutput creates a new OriginalOutput.

func (*OriginalOutput) Descriptor

func (*OriginalOutput) Descriptor() ([]byte, []int)

func (*OriginalOutput) GetControlProgram

func (m *OriginalOutput) GetControlProgram() *Program

func (*OriginalOutput) GetOrdinal

func (m *OriginalOutput) GetOrdinal() uint64

func (*OriginalOutput) GetSource

func (m *OriginalOutput) GetSource() *ValueSource

func (*OriginalOutput) GetStateData

func (m *OriginalOutput) GetStateData() [][]byte

func (*OriginalOutput) ProtoMessage

func (*OriginalOutput) ProtoMessage()

func (*OriginalOutput) Reset

func (m *OriginalOutput) Reset()

func (*OriginalOutput) String

func (m *OriginalOutput) String() string

type Program

type Program struct {
	VmVersion uint64 `protobuf:"varint,1,opt,name=vm_version,json=vmVersion" json:"vm_version,omitempty"`
	Code      []byte `protobuf:"bytes,2,opt,name=code,proto3" json:"code,omitempty"`
}

func (*Program) Descriptor

func (*Program) Descriptor() ([]byte, []int)

func (*Program) GetCode

func (m *Program) GetCode() []byte

func (*Program) GetVmVersion

func (m *Program) GetVmVersion() uint64

func (*Program) ProtoMessage

func (*Program) ProtoMessage()

func (*Program) Reset

func (m *Program) Reset()

func (*Program) String

func (m *Program) String() string

type Retirement

type Retirement struct {
	Source  *ValueSource `protobuf:"bytes,1,opt,name=source" json:"source,omitempty"`
	Ordinal uint64       `protobuf:"varint,2,opt,name=ordinal" json:"ordinal,omitempty"`
}

func NewRetirement

func NewRetirement(source *ValueSource, ordinal uint64) *Retirement

NewRetirement creates a new Retirement.

func (*Retirement) Descriptor

func (*Retirement) Descriptor() ([]byte, []int)

func (*Retirement) GetOrdinal

func (m *Retirement) GetOrdinal() uint64

func (*Retirement) GetSource

func (m *Retirement) GetSource() *ValueSource

func (*Retirement) ProtoMessage

func (*Retirement) ProtoMessage()

func (*Retirement) Reset

func (m *Retirement) Reset()

func (*Retirement) String

func (m *Retirement) String() string

type Spend

type Spend struct {
	SpentOutputId      *Hash             `protobuf:"bytes,1,opt,name=spent_output_id,json=spentOutputId" json:"spent_output_id,omitempty"`
	WitnessDestination *ValueDestination `protobuf:"bytes,2,opt,name=witness_destination,json=witnessDestination" json:"witness_destination,omitempty"`
	WitnessArguments   [][]byte          `protobuf:"bytes,3,rep,name=witness_arguments,json=witnessArguments,proto3" json:"witness_arguments,omitempty"`
	Ordinal            uint64            `protobuf:"varint,4,opt,name=ordinal" json:"ordinal,omitempty"`
}

func NewSpend

func NewSpend(spentOutputID *Hash, ordinal uint64) *Spend

NewSpend creates a new Spend.

func (*Spend) Descriptor

func (*Spend) Descriptor() ([]byte, []int)

func (*Spend) GetOrdinal

func (m *Spend) GetOrdinal() uint64

func (*Spend) GetSpentOutputId

func (m *Spend) GetSpentOutputId() *Hash

func (*Spend) GetWitnessArguments

func (m *Spend) GetWitnessArguments() [][]byte

func (*Spend) GetWitnessDestination

func (m *Spend) GetWitnessDestination() *ValueDestination

func (*Spend) ProtoMessage

func (*Spend) ProtoMessage()

func (*Spend) Reset

func (m *Spend) Reset()

func (*Spend) SetDestination

func (s *Spend) SetDestination(id *Hash, val *AssetAmount, pos uint64)

SetDestination will link the spend to the output

func (*Spend) String

func (m *Spend) String() string

type Tx

type Tx struct {
	*TxHeader
	ID       Hash
	Entries  map[Hash]Entry
	InputIDs []Hash // 1:1 correspondence with TxData.Inputs

	SpentOutputIDs []Hash
}

Tx is a wrapper for the entries-based representation of a transaction.

func (*Tx) Issuance

func (tx *Tx) Issuance(id Hash) (*Issuance, error)

Issuance try to get the issuance entry by given hash

func (*Tx) OriginalOutput

func (tx *Tx) OriginalOutput(id Hash) (*OriginalOutput, error)

OriginalOutput try to get the output entry by given hash

func (*Tx) SigHash

func (tx *Tx) SigHash(n uint32) (hash Hash)

SigHash ...

func (*Tx) Spend

func (tx *Tx) Spend(id Hash) (*Spend, error)

Spend try to get the spend entry by given hash

func (*Tx) VetoInput

func (tx *Tx) VetoInput(id Hash) (*VetoInput, error)

VetoInput try to get the veto entry by given hash

func (*Tx) VoteOutput

func (tx *Tx) VoteOutput(id Hash) (*VoteOutput, error)

VoteOutput try to get the vote output entry by given hash

type TxHeader

type TxHeader struct {
	Version        uint64  `protobuf:"varint,1,opt,name=version" json:"version,omitempty"`
	SerializedSize uint64  `protobuf:"varint,2,opt,name=serialized_size,json=serializedSize" json:"serialized_size,omitempty"`
	TimeRange      uint64  `protobuf:"varint,3,opt,name=time_range,json=timeRange" json:"time_range,omitempty"`
	ResultIds      []*Hash `protobuf:"bytes,4,rep,name=result_ids,json=resultIds" json:"result_ids,omitempty"`
}

func NewTxHeader

func NewTxHeader(version, serializedSize, timeRange uint64, resultIDs []*Hash) *TxHeader

NewTxHeader creates an new TxHeader.

func (*TxHeader) Descriptor

func (*TxHeader) Descriptor() ([]byte, []int)

func (*TxHeader) GetResultIds

func (m *TxHeader) GetResultIds() []*Hash

func (*TxHeader) GetSerializedSize

func (m *TxHeader) GetSerializedSize() uint64

func (*TxHeader) GetTimeRange

func (m *TxHeader) GetTimeRange() uint64

func (*TxHeader) GetVersion

func (m *TxHeader) GetVersion() uint64

func (*TxHeader) ProtoMessage

func (*TxHeader) ProtoMessage()

func (*TxHeader) Reset

func (m *TxHeader) Reset()

func (*TxHeader) String

func (m *TxHeader) String() string

type ValueDestination

type ValueDestination struct {
	Ref      *Hash        `protobuf:"bytes,1,opt,name=ref" json:"ref,omitempty"`
	Value    *AssetAmount `protobuf:"bytes,2,opt,name=value" json:"value,omitempty"`
	Position uint64       `protobuf:"varint,3,opt,name=position" json:"position,omitempty"`
}

func (*ValueDestination) Descriptor

func (*ValueDestination) Descriptor() ([]byte, []int)

func (*ValueDestination) GetPosition

func (m *ValueDestination) GetPosition() uint64

func (*ValueDestination) GetRef

func (m *ValueDestination) GetRef() *Hash

func (*ValueDestination) GetValue

func (m *ValueDestination) GetValue() *AssetAmount

func (*ValueDestination) ProtoMessage

func (*ValueDestination) ProtoMessage()

func (*ValueDestination) Reset

func (m *ValueDestination) Reset()

func (*ValueDestination) String

func (m *ValueDestination) String() string

type ValueSource

type ValueSource struct {
	Ref      *Hash        `protobuf:"bytes,1,opt,name=ref" json:"ref,omitempty"`
	Value    *AssetAmount `protobuf:"bytes,2,opt,name=value" json:"value,omitempty"`
	Position uint64       `protobuf:"varint,3,opt,name=position" json:"position,omitempty"`
}

func (*ValueSource) Descriptor

func (*ValueSource) Descriptor() ([]byte, []int)

func (*ValueSource) GetPosition

func (m *ValueSource) GetPosition() uint64

func (*ValueSource) GetRef

func (m *ValueSource) GetRef() *Hash

func (*ValueSource) GetValue

func (m *ValueSource) GetValue() *AssetAmount

func (*ValueSource) ProtoMessage

func (*ValueSource) ProtoMessage()

func (*ValueSource) Reset

func (m *ValueSource) Reset()

func (*ValueSource) String

func (m *ValueSource) String() string

type VetoInput

type VetoInput struct {
	SpentOutputId      *Hash             `protobuf:"bytes,1,opt,name=spent_output_id,json=spentOutputId" json:"spent_output_id,omitempty"`
	WitnessDestination *ValueDestination `protobuf:"bytes,2,opt,name=witness_destination,json=witnessDestination" json:"witness_destination,omitempty"`
	WitnessArguments   [][]byte          `protobuf:"bytes,3,rep,name=witness_arguments,json=witnessArguments,proto3" json:"witness_arguments,omitempty"`
	Ordinal            uint64            `protobuf:"varint,4,opt,name=ordinal" json:"ordinal,omitempty"`
}

func NewVetoInput

func NewVetoInput(spentOutputID *Hash, ordinal uint64) *VetoInput

NewVetoInput creates a new VetoInput.

func (*VetoInput) Descriptor

func (*VetoInput) Descriptor() ([]byte, []int)

func (*VetoInput) GetOrdinal

func (m *VetoInput) GetOrdinal() uint64

func (*VetoInput) GetSpentOutputId

func (m *VetoInput) GetSpentOutputId() *Hash

func (*VetoInput) GetWitnessArguments

func (m *VetoInput) GetWitnessArguments() [][]byte

func (*VetoInput) GetWitnessDestination

func (m *VetoInput) GetWitnessDestination() *ValueDestination

func (*VetoInput) ProtoMessage

func (*VetoInput) ProtoMessage()

func (*VetoInput) Reset

func (m *VetoInput) Reset()

func (*VetoInput) SetDestination

func (s *VetoInput) SetDestination(id *Hash, val *AssetAmount, pos uint64)

SetDestination will link the spend to the output

func (*VetoInput) String

func (m *VetoInput) String() string

type VoteOutput

type VoteOutput struct {
	Source         *ValueSource `protobuf:"bytes,1,opt,name=source" json:"source,omitempty"`
	ControlProgram *Program     `protobuf:"bytes,2,opt,name=control_program,json=controlProgram" json:"control_program,omitempty"`
	Ordinal        uint64       `protobuf:"varint,3,opt,name=ordinal" json:"ordinal,omitempty"`
	Vote           []byte       `protobuf:"bytes,4,opt,name=vote,proto3" json:"vote,omitempty"`
	StateData      [][]byte     `protobuf:"bytes,5,rep,name=state_data,json=stateData,proto3" json:"state_data,omitempty"`
}

func NewVoteOutput

func NewVoteOutput(source *ValueSource, controlProgram *Program, stateData [][]byte, ordinal uint64, vote []byte) *VoteOutput

NewCrossChainOutput creates a new CrossChainOutput.

func (*VoteOutput) Descriptor

func (*VoteOutput) Descriptor() ([]byte, []int)

func (*VoteOutput) GetControlProgram

func (m *VoteOutput) GetControlProgram() *Program

func (*VoteOutput) GetOrdinal

func (m *VoteOutput) GetOrdinal() uint64

func (*VoteOutput) GetSource

func (m *VoteOutput) GetSource() *ValueSource

func (*VoteOutput) GetStateData

func (m *VoteOutput) GetStateData() [][]byte

func (*VoteOutput) GetVote

func (m *VoteOutput) GetVote() []byte

func (*VoteOutput) ProtoMessage

func (*VoteOutput) ProtoMessage()

func (*VoteOutput) Reset

func (m *VoteOutput) Reset()

func (*VoteOutput) String

func (m *VoteOutput) String() string

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL