Documentation ¶
Index ¶
- func NewServer(w *wallet.SeedWallet, tp TransactionPool) http.Handler
- type Client
- func (c *Client) AddAddress(info wallet.SeedAddressInfo) error
- func (c *Client) AddToLimbo(txn types.Transaction) (err error)
- func (c *Client) AddressInfo(addr types.UnlockHash) (info wallet.SeedAddressInfo, err error)
- func (c *Client) Addresses() (addrs []types.UnlockHash, err error)
- func (c *Client) Balance(limbo bool) (bal types.Currency, err error)
- func (c *Client) BlockRewards(max int) (rewards []wallet.BlockReward, err error)
- func (c *Client) Broadcast(txnSet []types.Transaction) error
- func (c *Client) ConsensusInfo() (info ResponseConsensus, err error)
- func (c *Client) FileContractHistory(id types.FileContractID) (history []wallet.FileContract, err error)
- func (c *Client) FileContracts(max int) (contracts []wallet.FileContract, err error)
- func (c *Client) LimboTransactions() (txns []wallet.LimboTransaction, err error)
- func (c *Client) Memo(txid types.TransactionID) (memo []byte, err error)
- func (c *Client) RecommendedFee() (fee types.Currency, err error)
- func (c *Client) RemoveAddress(addr types.UnlockHash) error
- func (c *Client) RemoveFromLimbo(txid types.TransactionID) (err error)
- func (c *Client) SeedIndex() (index uint64, err error)
- func (c *Client) SetMemo(txid types.TransactionID, memo []byte) (err error)
- func (c *Client) Transaction(txid types.TransactionID) (txn ResponseTransactionsID, err error)
- func (c *Client) Transactions(max int) (txids []types.TransactionID, err error)
- func (c *Client) TransactionsByAddress(addr types.UnlockHash, max int) (txids []types.TransactionID, err error)
- func (c *Client) UnconfirmedParents(txn types.Transaction) (parents []wallet.LimboTransaction, err error)
- func (c *Client) UnspentOutputs(limbo bool) (utxos []wallet.UnspentOutput, err error)
- type ResponseConsensus
- type ResponseTransactionsID
- type TransactionPool
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func NewServer ¶ added in v0.5.0
func NewServer(w *wallet.SeedWallet, tp TransactionPool) http.Handler
NewServer returns an HTTP handler that serves the walrus API.
Types ¶
type Client ¶ added in v0.5.0
type Client struct {
// contains filtered or unexported fields
}
func NewClient ¶ added in v0.5.0
NewClient returns a client that communicates with a walrus server listening on the specified address.
func (*Client) AddAddress ¶ added in v0.5.0
func (c *Client) AddAddress(info wallet.SeedAddressInfo) error
AddAddress adds a set of address metadata to the wallet. Future transactions and outputs relevant to this address will be considered relevant to the wallet.
Importing an address does NOT import transactions and outputs relevant to that address that are already in the blockchain.
func (*Client) AddToLimbo ¶ added in v0.5.0
func (c *Client) AddToLimbo(txn types.Transaction) (err error)
AddToLimbo places a transaction in Limbo. The output will no longer be returned by Outputs or contribute to the wallet's balance.
Manually adding transactions to Limbo is typically unnecessary. Calling Broadcast will move all transactions in the set to Limbo automatically.
func (*Client) AddressInfo ¶ added in v0.5.0
func (c *Client) AddressInfo(addr types.UnlockHash) (info wallet.SeedAddressInfo, err error)
AddressInfo returns information about a specific address, including its unlock conditions and the index it was derived from.
func (*Client) Addresses ¶ added in v0.5.0
func (c *Client) Addresses() (addrs []types.UnlockHash, err error)
Addresses returns all addresses known to the wallet.
func (*Client) Balance ¶ added in v0.5.0
Balance returns the current wallet balance. If the limbo flag is true, the balance will reflect any transactions currently in Limbo.
func (*Client) BlockRewards ¶ added in v0.5.0
func (c *Client) BlockRewards(max int) (rewards []wallet.BlockReward, err error)
BlockRewards returns the block rewards tracked by the wallet. If max < 0, all rewards are returned; otherwise, at most max rewards are returned. The rewards are ordered newest-to-oldest.
func (*Client) Broadcast ¶ added in v0.5.0
func (c *Client) Broadcast(txnSet []types.Transaction) error
Broadcast broadcasts the supplied transaction set to all connected peers.
func (*Client) ConsensusInfo ¶ added in v0.5.0
func (c *Client) ConsensusInfo() (info ResponseConsensus, err error)
ConsensusInfo returns the current blockchain height and consensus change ID. The latter is a unique ID that changes whenever blocks are added to the blockchain.
func (*Client) FileContractHistory ¶ added in v0.5.0
func (c *Client) FileContractHistory(id types.FileContractID) (history []wallet.FileContract, err error)
FileContractHistory returns the revision history of the specified file contract, which must be a contract tracked by the wallet.
func (*Client) FileContracts ¶ added in v0.5.0
func (c *Client) FileContracts(max int) (contracts []wallet.FileContract, err error)
FileContracts returns the file contracts tracked by the wallet. If max < 0, all contracts are returned; otherwise, at most max contracts are returned. The contracts are ordered newest-to-oldest.
func (*Client) LimboTransactions ¶ added in v0.5.0
func (c *Client) LimboTransactions() (txns []wallet.LimboTransaction, err error)
LimboTransactions returns transactions that are in Limbo.
func (*Client) Memo ¶ added in v0.5.0
func (c *Client) Memo(txid types.TransactionID) (memo []byte, err error)
Memo retrieves the memo for a transaction.
func (*Client) RecommendedFee ¶ added in v0.5.0
RecommendedFee returns the current recommended transaction fee in hastings per byte of the Sia-encoded transaction.
func (*Client) RemoveAddress ¶ added in v0.5.0
func (c *Client) RemoveAddress(addr types.UnlockHash) error
RemoveAddress removes an address from the wallet. Future transactions and outputs relevant to this address will not be considered relevant to the wallet.
Removing an address does NOT remove transactions and outputs relevant to that address that are already recorded in the wallet.
func (*Client) RemoveFromLimbo ¶ added in v0.5.0
func (c *Client) RemoveFromLimbo(txid types.TransactionID) (err error)
RemoveFromLimbo removes a transaction from Limbo.
Manually removing transactions from Limbo is typically unnecessary. When a transaction appears in a valid block, it will be removed from Limbo automatically.
func (*Client) SeedIndex ¶ added in v0.5.0
SeedIndex returns the index that should be used to derive the next address.
func (*Client) SetMemo ¶ added in v0.5.0
func (c *Client) SetMemo(txid types.TransactionID, memo []byte) (err error)
SetMemo adds a memo for a transaction, overwriting the previous memo if it exists.
Memos are not stored on the blockchain. They exist only in the local wallet.
func (*Client) Transaction ¶ added in v0.5.0
func (c *Client) Transaction(txid types.TransactionID) (txn ResponseTransactionsID, err error)
Transaction returns the transaction with the specified ID, as well as inflow, outflow, and fee information. The transaction must be relevant to the wallet.
func (*Client) Transactions ¶ added in v0.5.0
func (c *Client) Transactions(max int) (txids []types.TransactionID, err error)
Transactions lists the IDs of transactions relevant to the wallet. If max < 0, all such IDs are returned; otherwise, at most max IDs are returned. The IDs are ordered newest-to-oldest.
func (*Client) TransactionsByAddress ¶ added in v0.5.0
func (c *Client) TransactionsByAddress(addr types.UnlockHash, max int) (txids []types.TransactionID, err error)
Transactions lists the IDs of transactions relevant to the specified address, which must be owned by the wallet. If max < 0, all such IDs are returned; otherwise, at most max IDs are returned. The IDs are ordered newest-to-oldest.
func (*Client) UnconfirmedParents ¶ added in v0.5.0
func (c *Client) UnconfirmedParents(txn types.Transaction) (parents []wallet.LimboTransaction, err error)
UnconfirmedParents returns any parents of txn that are in Limbo. These transactions will need to be included in the transaction set passed to Broadcast.
func (*Client) UnspentOutputs ¶ added in v0.5.0
func (c *Client) UnspentOutputs(limbo bool) (utxos []wallet.UnspentOutput, err error)
UnspentOutputs returns the outputs that the wallet can spend. If the limbo flag is true, the outputs will reflect any transactions currently in Limbo.
type ResponseConsensus ¶
type ResponseConsensus struct { Height types.BlockHeight `json:"height"` CCID crypto.Hash `json:"ccid"` }
ResponseConsensus is the response type for the /consensus endpoint.
type ResponseTransactionsID ¶
type ResponseTransactionsID struct { Transaction types.Transaction `json:"transaction"` Inflow types.Currency `json:"inflow"` Outflow types.Currency `json:"outflow"` FeePerByte types.Currency `json:"feePerByte"` }
ResponseTransactionsID is the response type for the /transactions/:id endpoint.
func (ResponseTransactionsID) MarshalJSON ¶
func (r ResponseTransactionsID) MarshalJSON() ([]byte, error)
MarshalJSON implements json.Marshaler.
type TransactionPool ¶ added in v0.4.0
type TransactionPool interface { AcceptTransactionSet([]types.Transaction) error FeeEstimation() (min types.Currency, max types.Currency) }
A TransactionPool can broadcast transactions and estimate transaction fees.