result

package
v0.76.1-pre Latest Latest
Warning

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

Go to latest
Published: Jun 25, 2020 License: MIT Imports: 17 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var GlobalAssets = map[string]string{
	"c56f33fc6ecfcd0c225c4ab356fee59390af8560be0e930faebe74a6daff7c9b": "NEO",
	"602c79718b16e442de58778e148d0b1084e3b2dffd5de6b7b16cee7969282de7": "GAS",
}

GlobalAssets stores a map of asset IDs to user-friendly strings ("NEO"/"GAS").

Functions

This section is empty.

Types

type AccountState

type AccountState struct {
	Version    uint8             `json:"version"`
	ScriptHash util.Uint160      `json:"script_hash"`
	IsFrozen   bool              `json:"frozen"`
	Votes      []*keys.PublicKey `json:"votes"`
	Balances   []Balance         `json:"balances"`
}

AccountState wrapper used for the representation of state.Account on the RPC Server.

func NewAccountState

func NewAccountState(a *state.Account) AccountState

NewAccountState creates a new Account wrapper.

type ApplicationLog

type ApplicationLog struct {
	TxHash     util.Uint256 `json:"txid"`
	Executions []Execution  `json:"executions"`
}

ApplicationLog wrapper used for the representation of the state.AppExecResult based on the specific tx on the RPC Server.

func NewApplicationLog

func NewApplicationLog(appExecRes *state.AppExecResult, scriptHash util.Uint160) ApplicationLog

NewApplicationLog creates a new ApplicationLog wrapper.

type AssetState

type AssetState struct {
	ID         util.Uint256          `json:"id"`
	AssetType  transaction.AssetType `json:"type"`
	Name       string                `json:"name"`
	Amount     util.Fixed8           `json:"amount"`
	Available  util.Fixed8           `json:"available"`
	Precision  uint8                 `json:"precision"`
	Owner      string                `json:"owner"`
	Admin      string                `json:"admin"`
	Issuer     string                `json:"issuer"`
	Expiration uint32                `json:"expiration"`
	IsFrozen   bool                  `json:"is_frozen"`
}

AssetState wrapper used for the representation of state.Asset on the RPC Server.

func NewAssetState

func NewAssetState(a *state.Asset) AssetState

NewAssetState creates a new Asset wrapper.

type Balance

type Balance struct {
	Asset util.Uint256 `json:"asset"`
	Value util.Fixed8  `json:"value"`
}

Balance response wrapper.

type Balances

type Balances []Balance

Balances type for sorting balances in rpc response.

func (Balances) Len

func (b Balances) Len() int

func (Balances) Less

func (b Balances) Less(i, j int) bool

func (Balances) Swap

func (b Balances) Swap(i, j int)

type Block

type Block struct {
	*block.Base
	BlockMetadataAndTx
}

Block wrapper used for the representation of block.Block / block.Base on the RPC Server.

func NewBlock

func NewBlock(b *block.Block, chain core.Blockchainer) Block

NewBlock creates a new Block wrapper.

func (Block) MarshalJSON added in v0.75.0

func (b Block) MarshalJSON() ([]byte, error)

MarshalJSON implements json.Marshaler interface.

func (*Block) UnmarshalJSON added in v0.75.0

func (b *Block) UnmarshalJSON(data []byte) error

UnmarshalJSON implements json.Unmarshaler interface.

type BlockMetadataAndTx added in v0.75.0

type BlockMetadataAndTx struct {
	Size          int           `json:"size"`
	NextBlockHash *util.Uint256 `json:"nextblockhash,omitempty"`
	Confirmations uint32        `json:"confirmations"`
	Tx            []Tx          `json:"tx"`
}

BlockMetadataAndTx is an additional metadata added to standard block.Base plus specially encoded transactions.

type Claimable

type Claimable struct {
	Tx          util.Uint256 `json:"txid"`
	N           int          `json:"n"`
	Value       util.Fixed8  `json:"value"`
	StartHeight uint32       `json:"start_height"`
	EndHeight   uint32       `json:"end_height"`
	Generated   util.Fixed8  `json:"generated"`
	SysFee      util.Fixed8  `json:"sys_fee"`
	Unclaimed   util.Fixed8  `json:"unclaimed"`
}

Claimable represents spent outputs which can be claimed.

type ClaimableInfo

type ClaimableInfo struct {
	Spents    []Claimable `json:"claimable"`
	Address   string      `json:"address"`
	Unclaimed util.Fixed8 `json:"unclaimed"`
}

ClaimableInfo is a result of a getclaimable RPC call.

type ContractState

type ContractState struct {
	Version     byte                      `json:"version"`
	ScriptHash  util.Uint160              `json:"hash"`
	Script      []byte                    `json:"script"`
	ParamList   []smartcontract.ParamType `json:"parameters"`
	ReturnType  smartcontract.ParamType   `json:"returntype"`
	Name        string                    `json:"name"`
	CodeVersion string                    `json:"code_version"`
	Author      string                    `json:"author"`
	Email       string                    `json:"email"`
	Description string                    `json:"description"`
	Properties  Properties                `json:"properties"`
}

ContractState wrapper used for the representation of state.Contract on the RPC Server.

func NewContractState

func NewContractState(c *state.Contract) ContractState

NewContractState creates a new Contract wrapper.

func (ContractState) MarshalJSON added in v0.75.0

func (c ContractState) MarshalJSON() ([]byte, error)

MarshalJSON implements json.Marshaler interface.

func (*ContractState) UnmarshalJSON added in v0.75.0

func (c *ContractState) UnmarshalJSON(data []byte) error

UnmarshalJSON implements json.Unmarshaler interface.

type Execution

type Execution struct {
	Trigger     string                    `json:"trigger"`
	ScriptHash  util.Uint160              `json:"contract"`
	VMState     string                    `json:"vmstate"`
	GasConsumed util.Fixed8               `json:"gas_consumed"`
	Stack       []smartcontract.Parameter `json:"stack"`
	Events      []NotificationEvent       `json:"notifications"`
}

Execution response wrapper

type Fees added in v0.75.0

type Fees struct {
	SysFee util.Fixed8 `json:"sys_fee"`
	NetFee util.Fixed8 `json:"net_fee"`
}

Fees is an auxilliary struct for proper Tx marshaling.

type GetPeers

type GetPeers struct {
	Unconnected Peers `json:"unconnected"`
	Connected   Peers `json:"connected"`
	Bad         Peers `json:"bad"`
}

GetPeers payload for outputting peers in `getpeers` RPC call.

func NewGetPeers

func NewGetPeers() GetPeers

NewGetPeers creates a new GetPeers structure.

func (*GetPeers) AddBad

func (g *GetPeers) AddBad(addrs []string)

AddBad adds a set of peers to the bad peers slice.

func (*GetPeers) AddConnected

func (g *GetPeers) AddConnected(addrs []string)

AddConnected adds a set of peers to the connected peers slice.

func (*GetPeers) AddUnconnected

func (g *GetPeers) AddUnconnected(addrs []string)

AddUnconnected adds a set of peers to the unconnected peers slice.

type GetProof added in v0.76.0

type GetProof struct {
	Result  ProofWithKey `json:"proof"`
	Success bool         `json:"success"`
}

GetProof is a result of getproof RPC.

type Header struct {
	Hash          util.Uint256        `json:"hash"`
	Size          int                 `json:"size"`
	Version       uint32              `json:"version"`
	PrevBlockHash util.Uint256        `json:"previousblockhash"`
	MerkleRoot    util.Uint256        `json:"merkleroot"`
	Timestamp     uint32              `json:"time"`
	Index         uint32              `json:"index"`
	Nonce         string              `json:"nonce"`
	NextConsensus string              `json:"nextconsensus"`
	Script        transaction.Witness `json:"script"`
	Confirmations uint32              `json:"confirmations"`
	NextBlockHash *util.Uint256       `json:"nextblockhash,omitempty"`
}

Header wrapper used for the representation of block header on the RPC Server.

func NewHeader

func NewHeader(h *block.Header, chain core.Blockchainer) Header

NewHeader creates a new Header wrapper.

type Invoke

type Invoke struct {
	State       string                    `json:"state"`
	GasConsumed string                    `json:"gas_consumed"`
	Script      string                    `json:"script"`
	Stack       []smartcontract.Parameter `json:"stack"`
}

Invoke represents code invocation result and is used by several RPC calls that invoke functions, scripts and generic bytecode.

type NEP5Balance

type NEP5Balance struct {
	Asset       util.Uint160 `json:"asset_hash"`
	Amount      string       `json:"amount"`
	LastUpdated uint32       `json:"last_updated_block"`
}

NEP5Balance represents balance for the single token contract.

func (*NEP5Balance) MarshalJSON

func (b *NEP5Balance) MarshalJSON() ([]byte, error)

MarshalJSON implements json.Marshaler interface.

func (*NEP5Balance) UnmarshalJSON

func (b *NEP5Balance) UnmarshalJSON(data []byte) error

UnmarshalJSON implements json.Unmarshaler interface.

type NEP5Balances

type NEP5Balances struct {
	Balances []NEP5Balance `json:"balance"`
	Address  string        `json:"address"`
}

NEP5Balances is a result for the getnep5balances RPC call.

type NEP5Transfer

type NEP5Transfer struct {
	Timestamp   uint32       `json:"timestamp"`
	Asset       util.Uint160 `json:"asset_hash"`
	Address     string       `json:"transfer_address,omitempty"`
	Amount      string       `json:"amount"`
	Index       uint32       `json:"block_index"`
	NotifyIndex uint32       `json:"transfer_notify_index"`
	TxHash      util.Uint256 `json:"tx_hash"`
}

NEP5Transfer represents single NEP5 transfer event.

type NEP5Transfers

type NEP5Transfers struct {
	Sent     []NEP5Transfer `json:"sent"`
	Received []NEP5Transfer `json:"received"`
	Address  string         `json:"address"`
}

NEP5Transfers is a result for the getnep5transfers RPC.

type NotificationEvent

type NotificationEvent struct {
	Contract util.Uint160            `json:"contract"`
	Item     smartcontract.Parameter `json:"state"`
}

NotificationEvent response wrapper

func StateEventToResultNotification added in v0.75.0

func StateEventToResultNotification(event state.NotificationEvent) NotificationEvent

StateEventToResultNotification converts state.NotificationEvent to result.NotificationEvent.

type Peer

type Peer struct {
	Address string `json:"address"`
	Port    string `json:"port"`
}

Peer represents the peer.

type Peers

type Peers []Peer

Peers represent a slice of peers.

type ProofWithKey added in v0.76.0

type ProofWithKey struct {
	Key   []byte
	Proof [][]byte
}

ProofWithKey represens key-proof pair.

func (*ProofWithKey) DecodeBinary added in v0.76.0

func (p *ProofWithKey) DecodeBinary(r *io.BinReader)

DecodeBinary implements io.Serializable.

func (*ProofWithKey) EncodeBinary added in v0.76.0

func (p *ProofWithKey) EncodeBinary(w *io.BinWriter)

EncodeBinary implements io.Serializable.

func (*ProofWithKey) FromString added in v0.76.0

func (p *ProofWithKey) FromString(s string) error

FromString decodes p from hex-encoded string.

func (*ProofWithKey) MarshalJSON added in v0.76.0

func (p *ProofWithKey) MarshalJSON() ([]byte, error)

MarshalJSON implements json.Marshaler.

func (*ProofWithKey) String added in v0.76.0

func (p *ProofWithKey) String() string

String implements fmt.Stringer.

func (*ProofWithKey) UnmarshalJSON added in v0.76.0

func (p *ProofWithKey) UnmarshalJSON(data []byte) error

UnmarshalJSON implements json.Unmarshaler.

type Properties

type Properties struct {
	HasStorage       bool `json:"storage"`
	HasDynamicInvoke bool `json:"dynamic_invoke"`
	IsPayable        bool `json:"is_payable"`
}

Properties response wrapper.

type StateHeight added in v0.76.0

type StateHeight struct {
	BlockHeight uint32 `json:"blockHeight"`
	StateHeight uint32 `json:"stateHeight"`
}

StateHeight is a result of getstateheight RPC.

type TransactionMetadata added in v0.75.0

type TransactionMetadata struct {
	SysFee        util.Fixed8  `json:"sys_fee"`
	NetFee        util.Fixed8  `json:"net_fee"`
	Blockhash     util.Uint256 `json:"blockhash,omitempty"`
	Confirmations int          `json:"confirmations,omitempty"`
	Timestamp     uint32       `json:"blocktime,omitempty"`
}

TransactionMetadata is an auxilliary struct for proper TransactionOutputRaw marshaling.

type TransactionOutput

type TransactionOutput struct {
	N       int         `json:"n"`
	Asset   string      `json:"asset"`
	Value   util.Fixed8 `json:"value"`
	Address string      `json:"address"`
}

TransactionOutput is a wrapper to represent transaction's output.

func NewTxOutput

func NewTxOutput(out *transaction.Output) *TransactionOutput

NewTxOutput converts out to a TransactionOutput.

type TransactionOutputRaw

type TransactionOutputRaw struct {
	*transaction.Transaction
	TransactionMetadata
}

TransactionOutputRaw is used as a wrapper to represents a Transaction.

func NewTransactionOutputRaw

func NewTransactionOutputRaw(tx *transaction.Transaction, header *block.Header, chain core.Blockchainer) TransactionOutputRaw

NewTransactionOutputRaw returns a new ransactionOutputRaw object.

func (TransactionOutputRaw) MarshalJSON added in v0.75.0

func (t TransactionOutputRaw) MarshalJSON() ([]byte, error)

MarshalJSON implements json.Marshaler interface.

func (*TransactionOutputRaw) UnmarshalJSON added in v0.75.0

func (t *TransactionOutputRaw) UnmarshalJSON(data []byte) error

UnmarshalJSON implements json.Marshaler interface.

type Tx

type Tx struct {
	*transaction.Transaction
	Fees
}

Tx wrapper used for the representation of transaction on the RPC Server.

func (Tx) MarshalJSON added in v0.75.0

func (t Tx) MarshalJSON() ([]byte, error)

MarshalJSON implements json.Marshaler interface.

func (*Tx) UnmarshalJSON added in v0.75.0

func (t *Tx) UnmarshalJSON(data []byte) error

UnmarshalJSON implements json.Marshaler interface.

type Unclaimed

type Unclaimed struct {
	Available   util.Fixed8 `json:"available"`
	Unavailable util.Fixed8 `json:"unavailable"`
	Unclaimed   util.Fixed8 `json:"unclaimed"`
}

Unclaimed wrapper is used to represent getunclaimed return result.

func NewUnclaimed

func NewUnclaimed(a *state.Account, chain core.Blockchainer) (*Unclaimed, error)

NewUnclaimed creates a new Unclaimed wrapper using given Blockchainer.

type UnspentBalanceInfo

type UnspentBalanceInfo struct {
	Unspents    []state.UnspentBalance `json:"unspent"`
	AssetHash   util.Uint256           `json:"asset_hash"`
	Asset       string                 `json:"asset"`
	AssetSymbol string                 `json:"asset_symbol"`
	Amount      util.Fixed8            `json:"amount"`
}

UnspentBalanceInfo wrapper is used to represent single unspent asset entry in `getunspents` output.

type Unspents

type Unspents struct {
	Balance []UnspentBalanceInfo `json:"balance"`
	Address string               `json:"address"`
}

Unspents wrapper is used to represent getunspents return result.

func NewUnspents

func NewUnspents(a *state.Account, chain core.Blockchainer, addr string) Unspents

NewUnspents creates a new Account wrapper using given Blockchainer.

type ValidateAddress

type ValidateAddress struct {
	Address interface{} `json:"address"`
	IsValid bool        `json:"isvalid"`
}

ValidateAddress represents result of the `validateaddress` call. Notice that Address is an interface{} here because server echoes back whatever address value user has sent to it, even if it's not a string.

type Validator

type Validator struct {
	PublicKey keys.PublicKey `json:"publickey"`
	Votes     util.Fixed8    `json:"votes"`
	Active    bool           `json:"active"`
}

Validator used for the representation of state.Validator on the RPC Server.

type VerifyProof added in v0.76.0

type VerifyProof struct {
	Value []byte
}

VerifyProof is a result of verifyproof RPC. nil Value is considered invalid.

func (*VerifyProof) MarshalJSON added in v0.76.0

func (p *VerifyProof) MarshalJSON() ([]byte, error)

MarshalJSON implements json.Marshaler.

func (*VerifyProof) UnmarshalJSON added in v0.76.0

func (p *VerifyProof) UnmarshalJSON(data []byte) error

UnmarshalJSON implements json.Unmarshaler.

type Version

type Version struct {
	Port      uint16 `json:"port"`
	Nonce     uint32 `json:"nonce"`
	UserAgent string `json:"useragent"`
}

Version model used for reporting server version info.

Jump to

Keyboard shortcuts

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