Documentation ¶
Index ¶
- Variables
- type APIBlockchain
- type APIClaimable
- type APIDeposit
- type APIDepositOffer
- type APISubnet
- type AddDelegatorArgs
- type AddSubnetValidatorArgs
- type AddValidatorArgs
- type CaminoClient
- type CaminoService
- func (s *CaminoService) Claim(_ *http.Request, args *ClaimArgs, reply *api.JSONTxID) error
- func (s *CaminoService) GetAddressStates(_ *http.Request, args *api.JSONAddress, response *utilsjson.Uint64) error
- func (s *CaminoService) GetAllDepositOffers(_ *http.Request, args *GetAllDepositOffersArgs, ...) error
- func (s *CaminoService) GetBalance(_ *http.Request, args *GetBalanceRequest, response *GetBalanceResponseWrapper) error
- func (s *CaminoService) GetBlockAtHeight(r *http.Request, args *GetBlockAtHeightArgs, reply *api.GetBlockResponse) error
- func (s *CaminoService) GetClaimables(_ *http.Request, args *GetClaimablesArgs, response *GetClaimablesReply) error
- func (s *CaminoService) GetConfiguration(_ *http.Request, _ *struct{}, reply *GetConfigurationReply) error
- func (s *CaminoService) GetCurrentSupply(_ *http.Request, args *GetCurrentSupplyArgs, reply *GetCurrentSupplyReply) error
- func (s *CaminoService) GetDeposits(_ *http.Request, args *GetDepositsArgs, reply *GetDepositsReply) error
- func (s *CaminoService) GetLastAcceptedBlock(r *http.Request, args *api.Encoding, reply *api.GetBlockResponse) error
- func (s *CaminoService) GetMultisigAlias(_ *http.Request, args *api.JSONAddress, response *GetMultisigAliasReply) error
- func (s *CaminoService) GetRegisteredShortIDLink(_ *http.Request, args *api.JSONAddress, response *api.JSONAddress) error
- func (s *CaminoService) GetUpgradePhases(_ *http.Request, _ *struct{}, response *GetUpgradePhasesReply) error
- func (s *CaminoService) GetValidatorsAt(r *http.Request, args *GetValidatorsAtArgs, reply *GetValidatorsAtReply2) error
- func (s *CaminoService) RegisterNode(_ *http.Request, args *RegisterNodeArgs, reply *api.JSONTxID) error
- func (s *CaminoService) SetAddressState(_ *http.Request, args *SetAddressStateArgs, response *api.JSONTxID) error
- func (s *CaminoService) Spend(_ *http.Request, args *SpendArgs, response *SpendReply) error
- func (s *CaminoService) Transfer(_ *http.Request, args *TransferArgs, reply *api.JSONTxID) error
- type ClaimArgs
- type ClaimedAmount
- type Client
- type ClientDelegator
- type ClientOwner
- type ClientPermissionlessValidator
- type ClientStaker
- type ClientSubnet
- type ConsortiumMemberValidator
- type CreateBlockchainArgs
- type CreateSubnetArgs
- type ExportAVAXArgs
- type ExportKeyArgs
- type ExportKeyReply
- type Factory
- type GetAllDepositOffersArgs
- type GetAllDepositOffersReply
- type GetBalanceRequest
- type GetBalanceResponse
- type GetBalanceResponseV2
- type GetBalanceResponseWrapper
- type GetBlockAtHeightArgs
- type GetBlockchainStatusArgs
- type GetBlockchainStatusReply
- type GetBlockchainsResponse
- type GetClaimablesArgs
- type GetClaimablesReply
- type GetConfigurationReply
- type GetCurrentSupplyArgs
- type GetCurrentSupplyReply
- type GetCurrentValidatorsArgs
- type GetCurrentValidatorsReply
- type GetDepositsArgs
- type GetDepositsReply
- type GetMaxStakeAmountArgs
- type GetMaxStakeAmountReply
- type GetMinStakeArgs
- type GetMinStakeReply
- type GetMultisigAliasReply
- type GetPendingValidatorsArgs
- type GetPendingValidatorsReply
- type GetRewardUTXOsReply
- type GetStakeArgs
- type GetStakeReply
- type GetStakingAssetIDArgs
- type GetStakingAssetIDResponse
- type GetSubnetsArgs
- type GetSubnetsResponse
- type GetTimestampReply
- type GetTotalStakeArgs
- type GetTotalStakeReply
- type GetTxStatusArgs
- type GetTxStatusResponse
- type GetUpgradePhasesReply
- type GetValidatorsAtArgs
- type GetValidatorsAtReply
- type GetValidatorsAtReply2
- type ImportAVAXArgs
- type ImportKeyArgs
- type Index
- type RegisterNodeArgs
- type SampleValidatorsArgs
- type SampleValidatorsReply
- type Service
- func (s *Service) AddDelegator(_ *http.Request, args *AddDelegatorArgs, reply *api.JSONTxIDChangeAddr) error
- func (s *Service) AddSubnetValidator(_ *http.Request, args *AddSubnetValidatorArgs, ...) error
- func (s *Service) AddValidator(_ *http.Request, args *AddValidatorArgs, reply *api.JSONTxIDChangeAddr) error
- func (s *Service) CreateAddress(_ *http.Request, args *api.UserPass, response *api.JSONAddress) error
- func (s *Service) CreateBlockchain(_ *http.Request, args *CreateBlockchainArgs, response *api.JSONTxIDChangeAddr) error
- func (s *Service) CreateSubnet(_ *http.Request, args *CreateSubnetArgs, response *api.JSONTxIDChangeAddr) error
- func (s *Service) ExportAVAX(_ *http.Request, args *ExportAVAXArgs, response *api.JSONTxIDChangeAddr) error
- func (s *Service) ExportKey(_ *http.Request, args *ExportKeyArgs, reply *ExportKeyReply) error
- func (s *Service) GetBalance(_ *http.Request, args *GetBalanceRequest, response *GetBalanceResponse) error
- func (s *Service) GetBlock(_ *http.Request, args *api.GetBlockArgs, response *api.GetBlockResponse) error
- func (s *Service) GetBlockchainStatus(r *http.Request, args *GetBlockchainStatusArgs, ...) error
- func (s *Service) GetBlockchains(_ *http.Request, _ *struct{}, response *GetBlockchainsResponse) error
- func (s *Service) GetCurrentSupply(_ *http.Request, args *GetCurrentSupplyArgs, reply *GetCurrentSupplyReply) error
- func (s *Service) GetCurrentValidators(_ *http.Request, args *GetCurrentValidatorsArgs, ...) error
- func (s *Service) GetHeight(r *http.Request, _ *struct{}, response *api.GetHeightResponse) error
- func (s *Service) GetMaxStakeAmount(_ *http.Request, args *GetMaxStakeAmountArgs, reply *GetMaxStakeAmountReply) error
- func (s *Service) GetMinStake(_ *http.Request, args *GetMinStakeArgs, reply *GetMinStakeReply) error
- func (s *Service) GetPendingValidators(_ *http.Request, args *GetPendingValidatorsArgs, ...) error
- func (s *Service) GetRewardUTXOs(_ *http.Request, args *api.GetTxArgs, reply *GetRewardUTXOsReply) error
- func (s *Service) GetStake(_ *http.Request, args *GetStakeArgs, response *GetStakeReply) error
- func (s *Service) GetStakingAssetID(_ *http.Request, args *GetStakingAssetIDArgs, ...) error
- func (s *Service) GetSubnets(_ *http.Request, args *GetSubnetsArgs, response *GetSubnetsResponse) error
- func (s *Service) GetTimestamp(_ *http.Request, _ *struct{}, reply *GetTimestampReply) error
- func (s *Service) GetTotalStake(_ *http.Request, args *GetTotalStakeArgs, reply *GetTotalStakeReply) error
- func (s *Service) GetTx(_ *http.Request, args *api.GetTxArgs, response *api.GetTxReply) error
- func (s *Service) GetTxStatus(_ *http.Request, args *GetTxStatusArgs, response *GetTxStatusResponse) error
- func (s *Service) GetUTXOs(_ *http.Request, args *api.GetUTXOsArgs, response *api.GetUTXOsReply) error
- func (s *Service) GetValidatorsAt(r *http.Request, args *GetValidatorsAtArgs, reply *GetValidatorsAtReply) error
- func (s *Service) ImportAVAX(_ *http.Request, args *ImportAVAXArgs, response *api.JSONTxIDChangeAddr) error
- func (s *Service) ImportKey(_ *http.Request, args *ImportKeyArgs, reply *api.JSONAddress) error
- func (s *Service) IssueTx(_ *http.Request, args *api.FormattedTx, response *api.JSONTxID) error
- func (s *Service) ListAddresses(_ *http.Request, args *api.UserPass, response *api.JSONAddresses) error
- func (s *Service) SampleValidators(_ *http.Request, args *SampleValidatorsArgs, reply *SampleValidatorsReply) error
- func (s *Service) ValidatedBy(r *http.Request, args *ValidatedByArgs, response *ValidatedByResponse) error
- func (s *Service) Validates(_ *http.Request, args *ValidatesArgs, response *ValidatesResponse) error
- type SetAddressStateArgs
- type SpendArgs
- type SpendReply
- type TransferArgs
- type VM
- func (vm *VM) Clock() *mockable.Clock
- func (vm *VM) CodecRegistry() codec.Registry
- func (vm *VM) Connected(_ context.Context, nodeID ids.NodeID, _ *version.Application) error
- func (vm *VM) ConnectedSubnet(_ context.Context, nodeID ids.NodeID, subnetID ids.ID) error
- func (vm *VM) CreateHandlers(context.Context) (map[string]*common.HTTPHandler, error)
- func (*VM) CreateStaticHandlers(context.Context) (map[string]*common.HTTPHandler, error)
- func (vm *VM) Disconnected(_ context.Context, nodeID ids.NodeID) error
- func (vm *VM) GetBlock(_ context.Context, blkID ids.ID) (snowman.Block, error)
- func (vm *VM) GetCurrentHeight(context.Context) (uint64, error)
- func (vm *VM) GetFeeAssetID() ids.ID
- func (vm *VM) GetMinimumHeight(ctx context.Context) (uint64, error)
- func (vm *VM) GetSubnetID(_ context.Context, chainID ids.ID) (ids.ID, error)
- func (vm *VM) GetValidatorSet(ctx context.Context, height uint64, subnetID ids.ID) (map[ids.NodeID]*validators.GetValidatorOutput, error)
- func (vm *VM) HealthCheck(context.Context) (interface{}, error)
- func (vm *VM) Initialize(ctx context.Context, chainCtx *snow.Context, dbManager manager.Manager, ...) error
- func (vm *VM) LastAccepted(context.Context) (ids.ID, error)
- func (vm *VM) Logger() logging.Logger
- func (vm *VM) ParseBlock(_ context.Context, b []byte) (snowman.Block, error)
- func (vm *VM) SetPreference(_ context.Context, blkID ids.ID) error
- func (vm *VM) SetState(_ context.Context, state snow.State) error
- func (vm *VM) Shutdown(context.Context) error
- func (*VM) Version(context.Context) (string, error)
- type ValidatedByArgs
- type ValidatedByResponse
- type ValidatesArgs
- type ValidatesResponse
Constants ¶
This section is empty.
Variables ¶
var (
ErrWrongOwnerType = errors.New("wrong owner type")
)
Functions ¶
This section is empty.
Types ¶
type APIBlockchain ¶
type APIBlockchain struct { // Blockchain's ID ID ids.ID `json:"id"` // Blockchain's (non-unique) human-readable name Name string `json:"name"` // Subnet that validates the blockchain SubnetID ids.ID `json:"subnetID"` // Virtual Machine the blockchain runs VMID ids.ID `json:"vmID"` }
APIBlockchain is the representation of a blockchain used in API calls
type APIClaimable ¶
type APIDeposit ¶
type APIDeposit struct { DepositTxID ids.ID `json:"depositTxID"` DepositOfferID ids.ID `json:"depositOfferID"` UnlockedAmount utilsjson.Uint64 `json:"unlockedAmount"` UnlockableAmount utilsjson.Uint64 `json:"unlockableAmount"` ClaimedRewardAmount utilsjson.Uint64 `json:"claimedRewardAmount"` Start utilsjson.Uint64 `json:"start"` Duration uint32 `json:"duration"` Amount utilsjson.Uint64 `json:"amount"` RewardOwner platformapi.Owner `json:"rewardOwner"` }
type APIDepositOffer ¶
type APIDepositOffer struct { UpgradeVersion uint16 `json:"upgradeVersion"` // codec upgrade version ID ids.ID `json:"id"` // offer id InterestRateNominator utilsjson.Uint64 `json:"interestRateNominator"` // deposit.Amount * (interestRateNominator / interestRateDenominator) == reward for deposit with 1 year duration Start utilsjson.Uint64 `json:"start"` // Unix time in seconds, when this offer becomes active (can be used to create new deposits) End utilsjson.Uint64 `json:"end"` // Unix time in seconds, when this offer becomes inactive (can't be used to create new deposits) MinAmount utilsjson.Uint64 `json:"minAmount"` // Minimum amount that can be deposited with this offer TotalMaxAmount utilsjson.Uint64 `json:"totalMaxAmount"` // Maximum amount that can be deposited with this offer in total (across all deposits) DepositedAmount utilsjson.Uint64 `json:"depositedAmount"` // Amount that was already deposited with this offer MinDuration uint32 `json:"minDuration"` // Minimum duration of deposit created with this offer MaxDuration uint32 `json:"maxDuration"` // Maximum duration of deposit created with this offer UnlockPeriodDuration uint32 `json:"unlockPeriodDuration"` // Duration of period during which tokens deposited with this offer will be unlocked. The unlock period starts at the end of deposit minus unlockPeriodDuration NoRewardsPeriodDuration uint32 `json:"noRewardsPeriodDuration"` // Duration of period during which rewards won't be accumulated. No rewards period starts at the end of deposit minus unlockPeriodDuration Memo types.JSONByteSlice `json:"memo"` // Arbitrary offer memo Flags utilsjson.Uint64 `json:"flags"` // Bitfield with flags TotalMaxRewardAmount utilsjson.Uint64 `json:"totalMaxRewardAmount"` // Maximum amount that can be rewarded for all deposits created with this offer in total RewardedAmount utilsjson.Uint64 `json:"rewardedAmount"` // Amount that was already rewarded (including potential rewards) for deposits created with this offer OwnerAddress ids.ShortID `json:"ownerAddress"` // Address that can sign deposit-creator permission }
type APISubnet ¶
type APISubnet struct { // ID of the subnet ID ids.ID `json:"id"` // Each element of [ControlKeys] the address of a public key. // A transaction to add a validator to this subnet requires // signatures from [Threshold] of these keys to be valid. ControlKeys []string `json:"controlKeys"` Threshold json.Uint32 `json:"threshold"` }
APISubnet is a representation of a subnet used in API calls
type AddDelegatorArgs ¶
type AddDelegatorArgs struct { // User, password, from addrs, change addr api.JSONSpendHeader platformapi.Staker RewardAddress string `json:"rewardAddress"` }
AddDelegatorArgs are the arguments to AddDelegator
type AddSubnetValidatorArgs ¶
type AddSubnetValidatorArgs struct { // User, password, from addrs, change addr api.JSONSpendHeader platformapi.Staker // ID of subnet to validate SubnetID string `json:"subnetID"` }
AddSubnetValidatorArgs are the arguments to AddSubnetValidator
type AddValidatorArgs ¶
type AddValidatorArgs struct { // User, password, from addrs, change addr api.JSONSpendHeader platformapi.Staker // The address the staking reward, if applicable, will go to NodeOwnerAddress string `json:"nodeOwnerAddress"` RewardAddress string `json:"rewardAddress"` DelegationFeeRate json.Float32 `json:"delegationFeeRate"` }
AddValidatorArgs are the arguments to AddValidator
type CaminoClient ¶
type CaminoClient interface { // GetConfiguration returns genesis information of the primary network GetConfiguration(ctx context.Context, options ...rpc.Option) (*GetConfigurationReply, error) // GetMultisigAlias returns the alias definition of the given multisig address GetMultisigAlias(ctx context.Context, multisigAddress string, options ...rpc.Option) (*GetMultisigAliasReply, error) GetAllDepositOffers(ctx context.Context, getAllDepositOffersArgs *GetAllDepositOffersArgs, options ...rpc.Option) (*GetAllDepositOffersReply, error) GetRegisteredShortIDLink(ctx context.Context, addrStr ids.ShortID, options ...rpc.Option) (string, error) GetLastAcceptedBlock(ctx context.Context, encoding formatting.Encoding, options ...rpc.Option) (any, error) GetBlockAtHeight(ctx context.Context, height uint32, encoding formatting.Encoding, options ...rpc.Option) (any, error) GetClaimables(ctx context.Context, owners []*secp256k1fx.OutputOwners, options ...rpc.Option) ([]*state.Claimable, error) GetAddressStates(ctx context.Context, addr ids.ShortID, options ...rpc.Option) (as.AddressState, error) }
type CaminoService ¶
type CaminoService struct {
Service
}
CaminoService defines the API calls that can be made to the platform chain
func (*CaminoService) GetAddressStates ¶
func (s *CaminoService) GetAddressStates(_ *http.Request, args *api.JSONAddress, response *utilsjson.Uint64) error
GetAddressStates retrieves the state applied to an address (see setAddressState)
func (*CaminoService) GetAllDepositOffers ¶
func (s *CaminoService) GetAllDepositOffers(_ *http.Request, args *GetAllDepositOffersArgs, response *GetAllDepositOffersReply) error
GetAllDepositOffers returns an array of all deposit offers that are active at given timestamp
func (*CaminoService) GetBalance ¶
func (s *CaminoService) GetBalance(_ *http.Request, args *GetBalanceRequest, response *GetBalanceResponseWrapper) error
GetBalance gets the balance of an address
func (*CaminoService) GetBlockAtHeight ¶
func (s *CaminoService) GetBlockAtHeight(r *http.Request, args *GetBlockAtHeightArgs, reply *api.GetBlockResponse) error
GetBlockAtHeight returns block at given height
func (*CaminoService) GetClaimables ¶
func (s *CaminoService) GetClaimables(_ *http.Request, args *GetClaimablesArgs, response *GetClaimablesReply) error
GetClaimables returns the amount of claimable tokens for given owner
func (*CaminoService) GetConfiguration ¶
func (s *CaminoService) GetConfiguration(_ *http.Request, _ *struct{}, reply *GetConfigurationReply) error
GetConfiguration returns platformVM configuration
func (*CaminoService) GetCurrentSupply ¶
func (s *CaminoService) GetCurrentSupply(_ *http.Request, args *GetCurrentSupplyArgs, reply *GetCurrentSupplyReply) error
GetCurrentSupply returns an upper bound on the supply of CAM in the system including potential rewards from not expired or not-locked deposit offers. Overrides avax service GetCurrentSupply.
func (*CaminoService) GetDeposits ¶
func (s *CaminoService) GetDeposits(_ *http.Request, args *GetDepositsArgs, reply *GetDepositsReply) error
GetDeposits returns deposits by IDs
func (*CaminoService) GetLastAcceptedBlock ¶
func (s *CaminoService) GetLastAcceptedBlock(r *http.Request, args *api.Encoding, reply *api.GetBlockResponse) error
GetLastAcceptedBlock returns the last accepted block
func (*CaminoService) GetMultisigAlias ¶
func (s *CaminoService) GetMultisigAlias(_ *http.Request, args *api.JSONAddress, response *GetMultisigAliasReply) error
GetMultisigAlias retrieves the owners and threshold for a given multisig alias
func (*CaminoService) GetRegisteredShortIDLink ¶
func (s *CaminoService) GetRegisteredShortIDLink(_ *http.Request, args *api.JSONAddress, response *api.JSONAddress) error
func (*CaminoService) GetUpgradePhases ¶
func (s *CaminoService) GetUpgradePhases(_ *http.Request, _ *struct{}, response *GetUpgradePhasesReply) error
func (*CaminoService) GetValidatorsAt ¶
func (s *CaminoService) GetValidatorsAt(r *http.Request, args *GetValidatorsAtArgs, reply *GetValidatorsAtReply2) error
Overrides avax service GetValidatorsAt
func (*CaminoService) RegisterNode ¶
func (s *CaminoService) RegisterNode(_ *http.Request, args *RegisterNodeArgs, reply *api.JSONTxID) error
RegisterNode issues an RegisterNodeTx
func (*CaminoService) SetAddressState ¶
func (s *CaminoService) SetAddressState(_ *http.Request, args *SetAddressStateArgs, response *api.JSONTxID) error
AddAdressState issues an AddAdressStateTx
func (*CaminoService) Spend ¶
func (s *CaminoService) Spend(_ *http.Request, args *SpendArgs, response *SpendReply) error
func (*CaminoService) Transfer ¶
func (s *CaminoService) Transfer(_ *http.Request, args *TransferArgs, reply *api.JSONTxID) error
Transfer issues an BaseTx
type ClaimArgs ¶
type ClaimArgs struct { api.UserPass api.JSONFromAddrs Claimables []ClaimedAmount `json:"claimables"` ClaimTo platformapi.Owner `json:"claimTo"` Change platformapi.Owner `json:"change"` }
type ClaimedAmount ¶
type Client ¶
type Client interface { CaminoClient // GetHeight returns the current block height of the P Chain GetHeight(ctx context.Context, options ...rpc.Option) (uint64, error) // ExportKey returns the private key corresponding to [address] from [user]'s account // // Deprecated: Keys should no longer be stored on the node. ExportKey(ctx context.Context, user api.UserPass, address ids.ShortID, options ...rpc.Option) (*secp256k1.PrivateKey, error) // ImportKey imports the specified [privateKey] to [user]'s keystore // // Deprecated: Keys should no longer be stored on the node. ImportKey(ctx context.Context, user api.UserPass, privateKey *secp256k1.PrivateKey, options ...rpc.Option) (ids.ShortID, error) // GetBalance returns the balance of [addrs] on the P Chain // // Deprecated: GetUTXOs should be used instead. GetBalance(ctx context.Context, addrs []ids.ShortID, options ...rpc.Option) (*GetBalanceResponse, error) // CreateAddress creates a new address for [user] // // Deprecated: Keys should no longer be stored on the node. CreateAddress(ctx context.Context, user api.UserPass, options ...rpc.Option) (ids.ShortID, error) // ListAddresses returns an array of platform addresses controlled by [user] // // Deprecated: Keys should no longer be stored on the node. ListAddresses(ctx context.Context, user api.UserPass, options ...rpc.Option) ([]ids.ShortID, error) // GetUTXOs returns the byte representation of the UTXOs controlled by [addrs] GetUTXOs( ctx context.Context, addrs []ids.ShortID, limit uint32, startAddress ids.ShortID, startUTXOID ids.ID, options ...rpc.Option, ) ([][]byte, ids.ShortID, ids.ID, error) // GetAtomicUTXOs returns the byte representation of the atomic UTXOs controlled by [addrs] // from [sourceChain] GetAtomicUTXOs( ctx context.Context, addrs []ids.ShortID, sourceChain string, limit uint32, startAddress ids.ShortID, startUTXOID ids.ID, options ...rpc.Option, ) ([][]byte, ids.ShortID, ids.ID, error) // GetSubnets returns information about the specified subnets // // Deprecated: Subnets should be fetched from a dedicated indexer. GetSubnets(ctx context.Context, subnetIDs []ids.ID, options ...rpc.Option) ([]ClientSubnet, error) // GetStakingAssetID returns the assetID of the asset used for staking on // subnet corresponding to [subnetID] GetStakingAssetID(ctx context.Context, subnetID ids.ID, options ...rpc.Option) (ids.ID, error) // GetCurrentValidators returns the list of current validators for subnet with ID [subnetID] GetCurrentValidators(ctx context.Context, subnetID ids.ID, nodeIDs []ids.NodeID, options ...rpc.Option) ([]ClientPermissionlessValidator, error) // GetPendingValidators returns the list of pending validators for subnet with ID [subnetID] GetPendingValidators(ctx context.Context, subnetID ids.ID, nodeIDs []ids.NodeID, options ...rpc.Option) ([]interface{}, []interface{}, error) // GetCurrentSupply returns an upper bound on the supply of AVAX in the system GetCurrentSupply(ctx context.Context, subnetID ids.ID, options ...rpc.Option) (uint64, error) // SampleValidators returns the nodeIDs of a sample of [sampleSize] validators from the current validator set for subnet with ID [subnetID] SampleValidators(ctx context.Context, subnetID ids.ID, sampleSize uint16, options ...rpc.Option) ([]ids.NodeID, error) // AddValidator issues a transaction to add a validator to the primary network // and returns the txID // // Deprecated: Transactions should be issued using the // `avalanchego/wallet/chain/p.Wallet` utility. AddValidator( ctx context.Context, user api.UserPass, from []ids.ShortID, changeAddr ids.ShortID, rewardAddress ids.ShortID, nodeID ids.NodeID, stakeAmount, startTime, endTime uint64, delegationFeeRate float32, options ...rpc.Option, ) (ids.ID, error) // AddDelegator issues a transaction to add a delegator to the primary network // and returns the txID // // Deprecated: Transactions should be issued using the // `avalanchego/wallet/chain/p.Wallet` utility. AddDelegator( ctx context.Context, user api.UserPass, from []ids.ShortID, changeAddr ids.ShortID, rewardAddress ids.ShortID, nodeID ids.NodeID, stakeAmount, startTime, endTime uint64, options ...rpc.Option, ) (ids.ID, error) // AddSubnetValidator issues a transaction to add validator [nodeID] to subnet // with ID [subnetID] and returns the txID // // Deprecated: Transactions should be issued using the // `avalanchego/wallet/chain/p.Wallet` utility. AddSubnetValidator( ctx context.Context, user api.UserPass, from []ids.ShortID, changeAddr ids.ShortID, subnetID ids.ID, nodeID ids.NodeID, stakeAmount, startTime, endTime uint64, options ...rpc.Option, ) (ids.ID, error) // CreateSubnet issues a transaction to create [subnet] and returns the txID // // Deprecated: Transactions should be issued using the // `avalanchego/wallet/chain/p.Wallet` utility. CreateSubnet( ctx context.Context, user api.UserPass, from []ids.ShortID, changeAddr ids.ShortID, controlKeys []ids.ShortID, threshold uint32, options ...rpc.Option, ) (ids.ID, error) // ExportAVAX issues an ExportTx transaction and returns the txID // // Deprecated: Transactions should be issued using the // `avalanchego/wallet/chain/p.Wallet` utility. ExportAVAX( ctx context.Context, user api.UserPass, from []ids.ShortID, changeAddr ids.ShortID, to ids.ShortID, toChainIDAlias string, amount uint64, options ...rpc.Option, ) (ids.ID, error) // ImportAVAX issues an ImportTx transaction and returns the txID // // Deprecated: Transactions should be issued using the // `avalanchego/wallet/chain/p.Wallet` utility. ImportAVAX( ctx context.Context, user api.UserPass, from []ids.ShortID, changeAddr ids.ShortID, to ids.ShortID, sourceChain string, options ...rpc.Option, ) (ids.ID, error) // CreateBlockchain issues a CreateBlockchain transaction and returns the txID // // Deprecated: Transactions should be issued using the // `avalanchego/wallet/chain/p.Wallet` utility. CreateBlockchain( ctx context.Context, user api.UserPass, from []ids.ShortID, changeAddr ids.ShortID, subnetID ids.ID, vmID string, fxIDs []string, name string, genesisData []byte, options ...rpc.Option, ) (ids.ID, error) // GetBlockchainStatus returns the current status of blockchain with ID: [blockchainID] GetBlockchainStatus(ctx context.Context, blockchainID string, options ...rpc.Option) (status.BlockchainStatus, error) // ValidatedBy returns the ID of the Subnet that validates [blockchainID] ValidatedBy(ctx context.Context, blockchainID ids.ID, options ...rpc.Option) (ids.ID, error) // Validates returns the list of blockchains that are validated by the subnet with ID [subnetID] Validates(ctx context.Context, subnetID ids.ID, options ...rpc.Option) ([]ids.ID, error) // GetBlockchains returns the list of blockchains on the platform // // Deprecated: Blockchains should be fetched from a dedicated indexer. GetBlockchains(ctx context.Context, options ...rpc.Option) ([]APIBlockchain, error) // IssueTx issues the transaction and returns its txID IssueTx(ctx context.Context, tx []byte, options ...rpc.Option) (ids.ID, error) // GetTx returns the byte representation of the transaction corresponding to [txID] GetTx(ctx context.Context, txID ids.ID, options ...rpc.Option) ([]byte, error) // GetTxStatus returns the status of the transaction corresponding to [txID] GetTxStatus(ctx context.Context, txID ids.ID, options ...rpc.Option) (*GetTxStatusResponse, error) // AwaitTxDecided polls [GetTxStatus] until a status is returned that // implies the tx may be decided. // TODO: Move this function off of the Client interface into a utility // function. AwaitTxDecided( ctx context.Context, txID ids.ID, freq time.Duration, options ...rpc.Option, ) (*GetTxStatusResponse, error) // GetStake returns the amount of nAVAX that [addrs] have cumulatively // staked on the Primary Network. // // Deprecated: Stake should be calculated using GetTx, GetCurrentValidators, // and GetPendingValidators. GetStake(ctx context.Context, addrs []ids.ShortID, options ...rpc.Option) (map[ids.ID]uint64, [][]byte, error) // GetMinStake returns the minimum staking amount in nAVAX for validators // and delegators respectively GetMinStake(ctx context.Context, subnetID ids.ID, options ...rpc.Option) (uint64, uint64, error) // GetTotalStake returns the total amount (in nAVAX) staked on the network GetTotalStake(ctx context.Context, subnetID ids.ID, options ...rpc.Option) (uint64, error) // GetMaxStakeAmount returns the maximum amount of nAVAX staking to the named // node during the time period. // // Deprecated: The MaxStakeAmount should be calculated using // GetCurrentValidators, and GetPendingValidators. GetMaxStakeAmount( ctx context.Context, subnetID ids.ID, nodeID ids.NodeID, startTime uint64, endTime uint64, options ...rpc.Option, ) (uint64, error) // GetRewardUTXOs returns the reward UTXOs for a transaction // // Deprecated: GetRewardUTXOs should be fetched from a dedicated indexer. GetRewardUTXOs(context.Context, *api.GetTxArgs, ...rpc.Option) ([][]byte, error) // GetTimestamp returns the current chain timestamp GetTimestamp(ctx context.Context, options ...rpc.Option) (time.Time, error) // GetValidatorsAt returns the weights of the validator set of a provided subnet // at the specified height. GetValidatorsAt(ctx context.Context, subnetID ids.ID, height uint64, options ...rpc.Option) (map[ids.NodeID]uint64, error) // GetBlock returns the block with the given id. GetBlock(ctx context.Context, blockID ids.ID, options ...rpc.Option) ([]byte, error) }
Client interface for interacting with the P Chain endpoint
type ClientDelegator ¶
type ClientDelegator struct { ClientStaker RewardOwner *ClientOwner PotentialReward *uint64 }
ClientDelegator is the repr. of a delegator sent over client
type ClientOwner ¶
ClientOwner is the repr. of a reward owner sent over client
type ClientPermissionlessValidator ¶
type ClientPermissionlessValidator struct { ClientStaker ValidationRewardOwner *ClientOwner DelegationRewardOwner *ClientOwner PotentialReward *uint64 AccruedDelegateeReward *uint64 DelegationFee float32 Uptime *float32 Connected *bool Signer *signer.ProofOfPossession // The delegators delegating to this validator DelegatorCount *uint64 DelegatorWeight *uint64 Delegators []ClientDelegator }
ClientPermissionlessValidator is the repr. of a permissionless validator sent over client
type ClientStaker ¶
type ClientStaker struct { // the txID of the transaction that added this staker. TxID ids.ID // the Unix time when they start staking StartTime uint64 // the Unix time when they are done staking EndTime uint64 // the validator weight when sampling validators Weight uint64 // the amount of tokens being staked. StakeAmount *uint64 // the node ID of the staker NodeID ids.NodeID }
ClientStaker is the representation of a staker sent via client.
type ClientSubnet ¶
type ClientSubnet struct { // ID of the subnet ID ids.ID // Each element of [ControlKeys] the address of a public key. // A transaction to add a validator to this subnet requires // signatures from [Threshold] of these keys to be valid. ControlKeys []ids.ShortID Threshold uint32 }
ClientSubnet is a representation of a subnet used in client methods
type CreateBlockchainArgs ¶
type CreateBlockchainArgs struct { // User, password, from addrs, change addr api.JSONSpendHeader // ID of Subnet that validates the new blockchain SubnetID ids.ID `json:"subnetID"` // ID of the VM the new blockchain is running VMID string `json:"vmID"` // IDs of the FXs the VM is running FxIDs []string `json:"fxIDs"` // Human-readable name for the new blockchain, not necessarily unique Name string `json:"name"` // Genesis state of the blockchain being created GenesisData string `json:"genesisData"` // Encoding format to use for genesis data Encoding formatting.Encoding `json:"encoding"` }
CreateBlockchainArgs is the arguments for calling CreateBlockchain
type CreateSubnetArgs ¶
type CreateSubnetArgs struct { // User, password, from addrs, change addr api.JSONSpendHeader // The ID member of APISubnet is ignored APISubnet }
CreateSubnetArgs are the arguments to CreateSubnet
type ExportAVAXArgs ¶
type ExportAVAXArgs struct { // User, password, from addrs, change addr api.JSONSpendHeader // Amount of AVAX to send Amount json.Uint64 `json:"amount"` // Chain the funds are going to. Optional. Used if To address does not include the chainID. TargetChain string `json:"targetChain"` // ID of the address that will receive the AVAX. This address may include the // chainID, which is used to determine what the destination chain is. To string `json:"to"` }
ExportAVAXArgs are the arguments to ExportAVAX
type ExportKeyArgs ¶
ExportKeyArgs are arguments for ExportKey
type ExportKeyReply ¶
type ExportKeyReply struct { // The decrypted PrivateKey for the Address provided in the arguments PrivateKey *secp256k1.PrivateKey `json:"privateKey"` }
ExportKeyReply is the response for ExportKey
type GetAllDepositOffersArgs ¶
type GetAllDepositOffersReply ¶
type GetAllDepositOffersReply struct {
DepositOffers []*APIDepositOffer `json:"depositOffers"`
}
type GetBalanceRequest ¶
type GetBalanceRequest struct {
Addresses []string `json:"addresses"`
}
type GetBalanceResponse ¶
type GetBalanceResponse struct { // Balance, in nAVAX, of the address Balance json.Uint64 `json:"balance"` Unlocked json.Uint64 `json:"unlocked"` LockedStakeable json.Uint64 `json:"lockedStakeable"` LockedNotStakeable json.Uint64 `json:"lockedNotStakeable"` Balances map[ids.ID]json.Uint64 `json:"balances"` Unlockeds map[ids.ID]json.Uint64 `json:"unlockeds"` LockedStakeables map[ids.ID]json.Uint64 `json:"lockedStakeables"` LockedNotStakeables map[ids.ID]json.Uint64 `json:"lockedNotStakeables"` UTXOIDs []*avax.UTXOID `json:"utxoIDs"` }
Note: We explicitly duplicate AVAX out of the maps to ensure backwards compatibility.
type GetBalanceResponseV2 ¶
type GetBalanceResponseV2 struct { Balances map[ids.ID]utilsjson.Uint64 `json:"balances"` UnlockedOutputs map[ids.ID]utilsjson.Uint64 `json:"unlockedOutputs"` BondedOutputs map[ids.ID]utilsjson.Uint64 `json:"bondedOutputs"` DepositedOutputs map[ids.ID]utilsjson.Uint64 `json:"depositedOutputs"` DepositedBondedOutputs map[ids.ID]utilsjson.Uint64 `json:"bondedDepositedOutputs"` UTXOIDs []*avax.UTXOID `json:"utxoIDs"` }
type GetBalanceResponseWrapper ¶
type GetBalanceResponseWrapper struct { LockModeBondDeposit bool // contains filtered or unexported fields }
func (GetBalanceResponseWrapper) MarshalJSON ¶
func (response GetBalanceResponseWrapper) MarshalJSON() ([]byte, error)
type GetBlockAtHeightArgs ¶
type GetBlockAtHeightArgs struct { Encoding formatting.Encoding `json:"encoding"` Height uint32 `json:"height"` }
type GetBlockchainStatusArgs ¶
type GetBlockchainStatusArgs struct {
BlockchainID string `json:"blockchainID"`
}
GetBlockchainStatusArgs is the arguments for calling GetBlockchainStatus [BlockchainID] is the ID of or an alias of the blockchain to get the status of.
type GetBlockchainStatusReply ¶
type GetBlockchainStatusReply struct {
Status status.BlockchainStatus `json:"status"`
}
GetBlockchainStatusReply is the reply from calling GetBlockchainStatus [Status] is the blockchain's status.
type GetBlockchainsResponse ¶
type GetBlockchainsResponse struct { // blockchains that exist Blockchains []APIBlockchain `json:"blockchains"` }
GetBlockchainsResponse is the response from a call to GetBlockchains
type GetClaimablesArgs ¶
type GetClaimablesArgs struct {
Owners []platformapi.Owner `json:"owners"`
}
type GetClaimablesReply ¶
type GetClaimablesReply struct {
Claimables []APIClaimable `json:"claimables"`
}
type GetConfigurationReply ¶
type GetConfigurationReply struct { // The NetworkID NetworkID utilsjson.Uint32 `json:"networkID"` // The fee asset ID AssetID ids.ID `json:"assetID"` // The symbol of the fee asset ID AssetSymbol string `json:"assetSymbol"` // beech32HRP use in addresses Hrp string `json:"hrp"` // Primary network blockchains Blockchains []APIBlockchain `json:"blockchains"` // The minimum duration a validator has to stake MinStakeDuration utilsjson.Uint64 `json:"minStakeDuration"` // The maximum duration a validator can stake MaxStakeDuration utilsjson.Uint64 `json:"maxStakeDuration"` // The minimum amount of tokens one must bond to be a validator MinValidatorStake utilsjson.Uint64 `json:"minValidatorStake"` // The maximum amount of tokens bondable to a validator MaxValidatorStake utilsjson.Uint64 `json:"maxValidatorStake"` // The minimum delegation fee MinDelegationFee utilsjson.Uint32 `json:"minDelegationFee"` // Minimum stake, in nAVAX, that can be delegated on the primary network MinDelegatorStake utilsjson.Uint64 `json:"minDelegatorStake"` // The minimum consumption rate MinConsumptionRate utilsjson.Uint64 `json:"minConsumptionRate"` // The maximum consumption rate MaxConsumptionRate utilsjson.Uint64 `json:"maxConsumptionRate"` // The supply cap for the native token (AVAX) SupplyCap utilsjson.Uint64 `json:"supplyCap"` // The codec version used for serializing CodecVersion utilsjson.Uint16 `json:"codecVersion"` // Camino VerifyNodeSignature VerifyNodeSignature bool `json:"verifyNodeSignature"` // Camino LockModeBondDeposit LockModeBondDeposit bool `json:"lockModeBondDeposit"` }
GetConfigurationReply is the response from calling GetConfiguration.
type GetCurrentSupplyArgs ¶
GetCurrentSupplyArgs are the arguments for calling GetCurrentSupply
type GetCurrentSupplyReply ¶
GetCurrentSupplyReply are the results from calling GetCurrentSupply
type GetCurrentValidatorsArgs ¶
type GetCurrentValidatorsArgs struct { // Subnet we're listing the validators of // If omitted, defaults to primary network SubnetID ids.ID `json:"subnetID"` // NodeIDs of validators to request. If [NodeIDs] // is empty, it fetches all current validators. If // some nodeIDs are not currently validators, they // will be omitted from the response. NodeIDs []ids.NodeID `json:"nodeIDs"` }
GetCurrentValidatorsArgs are the arguments for calling GetCurrentValidators
type GetCurrentValidatorsReply ¶
type GetCurrentValidatorsReply struct {
Validators []interface{} `json:"validators"`
}
GetCurrentValidatorsReply are the results from calling GetCurrentValidators. Each validator contains a list of delegators to itself.
type GetDepositsArgs ¶
type GetDepositsReply ¶
type GetDepositsReply struct { Deposits []*APIDeposit `json:"deposits"` AvailableRewards []utilsjson.Uint64 `json:"availableRewards"` Timestamp utilsjson.Uint64 `json:"timestamp"` }
type GetMaxStakeAmountArgs ¶
type GetMaxStakeAmountArgs struct { SubnetID ids.ID `json:"subnetID"` NodeID ids.NodeID `json:"nodeID"` StartTime json.Uint64 `json:"startTime"` EndTime json.Uint64 `json:"endTime"` }
GetMaxStakeAmountArgs is the request for calling GetMaxStakeAmount.
type GetMaxStakeAmountReply ¶
GetMaxStakeAmountReply is the response from calling GetMaxStakeAmount.
type GetMinStakeArgs ¶
GetMinStakeArgs are the arguments for calling GetMinStake.
type GetMinStakeReply ¶
type GetMinStakeReply struct { // The minimum amount of tokens one must bond to be a validator MinValidatorStake json.Uint64 `json:"minValidatorStake"` // Minimum stake, in nAVAX, that can be delegated on the primary network MinDelegatorStake json.Uint64 `json:"minDelegatorStake"` }
GetMinStakeReply is the response from calling GetMinStake.
type GetMultisigAliasReply ¶
type GetMultisigAliasReply struct { Memo types.JSONByteSlice `json:"memo"` platformapi.Owner }
type GetPendingValidatorsArgs ¶
type GetPendingValidatorsArgs struct { // Subnet we're getting the pending validators of // If omitted, defaults to primary network SubnetID ids.ID `json:"subnetID"` // NodeIDs of validators to request. If [NodeIDs] // is empty, it fetches all pending validators. If // some requested nodeIDs are not pending validators, // they are omitted from the response. NodeIDs []ids.NodeID `json:"nodeIDs"` }
GetPendingValidatorsArgs are the arguments for calling GetPendingValidators
type GetPendingValidatorsReply ¶
type GetPendingValidatorsReply struct { Validators []interface{} `json:"validators"` Delegators []interface{} `json:"delegators"` }
GetPendingValidatorsReply are the results from calling GetPendingValidators.
type GetRewardUTXOsReply ¶
type GetRewardUTXOsReply struct { // Number of UTXOs returned NumFetched json.Uint64 `json:"numFetched"` // The UTXOs UTXOs []string `json:"utxos"` // Encoding specifies the encoding format the UTXOs are returned in Encoding formatting.Encoding `json:"encoding"` }
GetRewardUTXOsReply defines the GetRewardUTXOs replies returned from the API
type GetStakeArgs ¶
type GetStakeArgs struct { api.JSONAddresses Encoding formatting.Encoding `json:"encoding"` }
type GetStakeReply ¶
type GetStakeReply struct { Staked json.Uint64 `json:"staked"` Stakeds map[ids.ID]json.Uint64 `json:"stakeds"` // String representation of staked outputs // Each is of type avax.TransferableOutput Outputs []string `json:"stakedOutputs"` // Encoding of [Outputs] Encoding formatting.Encoding `json:"encoding"` }
GetStakeReply is the response from calling GetStake.
type GetStakingAssetIDArgs ¶
GetStakingAssetIDArgs are the arguments to GetStakingAssetID
type GetStakingAssetIDResponse ¶
GetStakingAssetIDResponse is the response from calling GetStakingAssetID
type GetSubnetsArgs ¶
type GetSubnetsArgs struct { // IDs of the subnets to retrieve information about // If omitted, gets all subnets IDs []ids.ID `json:"ids"` }
GetSubnetsArgs are the arguments to GetSubnet
type GetSubnetsResponse ¶
type GetSubnetsResponse struct { // Each element is a subnet that exists // Null if there are no subnets other than the primary network Subnets []APISubnet `json:"subnets"` }
GetSubnetsResponse is the response from calling GetSubnets
type GetTimestampReply ¶
GetTimestampReply is the response from GetTimestamp
type GetTotalStakeArgs ¶
type GetTotalStakeArgs struct { // Subnet we're getting the total stake // If omitted returns Primary network weight SubnetID ids.ID `json:"subnetID"` }
GetTotalStakeArgs are the arguments for calling GetTotalStake
type GetTotalStakeReply ¶
type GetTotalStakeReply struct { // Deprecated: Use Weight instead. Stake json.Uint64 `json:"stake"` Weight json.Uint64 `json:"weight"` }
GetTotalStakeReply is the response from calling GetTotalStake.
type GetTxStatusArgs ¶
type GetTxStatusResponse ¶
type GetUpgradePhasesReply ¶
type GetValidatorsAtArgs ¶
type GetValidatorsAtArgs struct { Height json.Uint64 `json:"height"` SubnetID ids.ID `json:"subnetID"` }
GetValidatorsAtArgs is the response from GetValidatorsAt
type GetValidatorsAtReply ¶
type GetValidatorsAtReply struct { // TODO should we change this to map[ids.NodeID]*validators.Validator? // We'd have to add a MarshalJSON method to validators.Validator. Validators map[ids.NodeID]uint64 `json:"validators"` }
GetValidatorsAtReply is the response from GetValidatorsAt
type GetValidatorsAtReply2 ¶
type GetValidatorsAtReply2 struct {
Validators map[ids.NodeID]ConsortiumMemberValidator `json:"validators"`
}
type ImportAVAXArgs ¶
type ImportAVAXArgs struct { // User, password, from addrs, change addr api.JSONSpendHeader // Chain the funds are coming from SourceChain string `json:"sourceChain"` // The address that will receive the imported funds To string `json:"to"` }
ImportAVAXArgs are the arguments to ImportAVAX
type ImportKeyArgs ¶
type ImportKeyArgs struct { api.UserPass PrivateKey *secp256k1.PrivateKey `json:"privateKey"` }
ImportKeyArgs are arguments for ImportKey
type Index ¶
type Index struct { Address string `json:"address"` // The address as a string UTXO string `json:"utxo"` // The UTXO ID as a string }
Index is an address and an associated UTXO. Marks a starting or stopping point when fetching UTXOs. Used for pagination.
type RegisterNodeArgs ¶
type SampleValidatorsArgs ¶
type SampleValidatorsArgs struct { // Number of validators in the sample Size json.Uint16 `json:"size"` // ID of subnet to sample validators from // If omitted, defaults to the primary network SubnetID ids.ID `json:"subnetID"` }
SampleValidatorsArgs are the arguments for calling SampleValidators
type SampleValidatorsReply ¶
SampleValidatorsReply are the results from calling Sample
type Service ¶
type Service struct {
// contains filtered or unexported fields
}
Service defines the API calls that can be made to the platform chain
func (*Service) AddDelegator ¶
func (s *Service) AddDelegator(_ *http.Request, args *AddDelegatorArgs, reply *api.JSONTxIDChangeAddr) error
AddDelegator creates and signs and issues a transaction to add a delegator to the primary network
func (*Service) AddSubnetValidator ¶
func (s *Service) AddSubnetValidator(_ *http.Request, args *AddSubnetValidatorArgs, response *api.JSONTxIDChangeAddr) error
AddSubnetValidator creates and signs and issues a transaction to add a validator to a subnet other than the primary network
func (*Service) AddValidator ¶
func (s *Service) AddValidator(_ *http.Request, args *AddValidatorArgs, reply *api.JSONTxIDChangeAddr) error
AddValidator creates and signs and issues a transaction to add a validator to the primary network
func (*Service) CreateAddress ¶
func (s *Service) CreateAddress(_ *http.Request, args *api.UserPass, response *api.JSONAddress) error
CreateAddress creates an address controlled by [args.Username] Returns the newly created address
func (*Service) CreateBlockchain ¶
func (s *Service) CreateBlockchain(_ *http.Request, args *CreateBlockchainArgs, response *api.JSONTxIDChangeAddr) error
CreateBlockchain issues a transaction to create a new blockchain
func (*Service) CreateSubnet ¶
func (s *Service) CreateSubnet(_ *http.Request, args *CreateSubnetArgs, response *api.JSONTxIDChangeAddr) error
CreateSubnet creates and signs and issues a transaction to create a new subnet
func (*Service) ExportAVAX ¶
func (s *Service) ExportAVAX(_ *http.Request, args *ExportAVAXArgs, response *api.JSONTxIDChangeAddr) error
ExportAVAX exports AVAX from the P-Chain to the X-Chain It must be imported on the X-Chain to complete the transfer
func (*Service) ExportKey ¶
func (s *Service) ExportKey(_ *http.Request, args *ExportKeyArgs, reply *ExportKeyReply) error
ExportKey returns a private key from the provided user
func (*Service) GetBalance ¶
func (s *Service) GetBalance(_ *http.Request, args *GetBalanceRequest, response *GetBalanceResponse) error
GetBalance gets the balance of an address
func (*Service) GetBlock ¶
func (s *Service) GetBlock(_ *http.Request, args *api.GetBlockArgs, response *api.GetBlockResponse) error
func (*Service) GetBlockchainStatus ¶
func (s *Service) GetBlockchainStatus(r *http.Request, args *GetBlockchainStatusArgs, reply *GetBlockchainStatusReply) error
GetBlockchainStatus gets the status of a blockchain with the ID [args.BlockchainID].
func (*Service) GetBlockchains ¶
func (s *Service) GetBlockchains(_ *http.Request, _ *struct{}, response *GetBlockchainsResponse) error
GetBlockchains returns all of the blockchains that exist
func (*Service) GetCurrentSupply ¶
func (s *Service) GetCurrentSupply(_ *http.Request, args *GetCurrentSupplyArgs, reply *GetCurrentSupplyReply) error
GetCurrentSupply returns an upper bound on the supply of AVAX in the system
func (*Service) GetCurrentValidators ¶
func (s *Service) GetCurrentValidators(_ *http.Request, args *GetCurrentValidatorsArgs, reply *GetCurrentValidatorsReply) error
GetCurrentValidators returns the current validators. If a single nodeID is provided, full delegators information is also returned. Otherwise only delegators' number and total weight is returned.
func (*Service) GetMaxStakeAmount ¶
func (s *Service) GetMaxStakeAmount(_ *http.Request, args *GetMaxStakeAmountArgs, reply *GetMaxStakeAmountReply) error
GetMaxStakeAmount returns the maximum amount of nAVAX staking to the named node during the time period.
func (*Service) GetMinStake ¶
func (s *Service) GetMinStake(_ *http.Request, args *GetMinStakeArgs, reply *GetMinStakeReply) error
GetMinStake returns the minimum staking amount in nAVAX.
func (*Service) GetPendingValidators ¶
func (s *Service) GetPendingValidators(_ *http.Request, args *GetPendingValidatorsArgs, reply *GetPendingValidatorsReply) error
GetPendingValidators returns the lists of pending validators and delegators.
func (*Service) GetRewardUTXOs ¶
func (s *Service) GetRewardUTXOs(_ *http.Request, args *api.GetTxArgs, reply *GetRewardUTXOsReply) error
GetRewardUTXOs returns the UTXOs that were rewarded after the provided transaction's staking period ended.
func (*Service) GetStake ¶
func (s *Service) GetStake(_ *http.Request, args *GetStakeArgs, response *GetStakeReply) error
GetStake returns the amount of nAVAX that [args.Addresses] have cumulatively staked on the Primary Network.
This method assumes that each stake output has only owner This method assumes only AVAX can be staked This method only concerns itself with the Primary Network, not subnets TODO: Improve the performance of this method by maintaining this data in a data structure rather than re-calculating it by iterating over stakers
func (*Service) GetStakingAssetID ¶
func (s *Service) GetStakingAssetID(_ *http.Request, args *GetStakingAssetIDArgs, response *GetStakingAssetIDResponse) error
GetStakingAssetID returns the assetID of the token used to stake on the provided subnet
func (*Service) GetSubnets ¶
func (s *Service) GetSubnets(_ *http.Request, args *GetSubnetsArgs, response *GetSubnetsResponse) error
GetSubnets returns the subnets whose ID are in [args.IDs] The response will include the primary network
func (*Service) GetTimestamp ¶
func (s *Service) GetTimestamp(_ *http.Request, _ *struct{}, reply *GetTimestampReply) error
GetTimestamp returns the current timestamp on chain.
func (*Service) GetTotalStake ¶
func (s *Service) GetTotalStake(_ *http.Request, args *GetTotalStakeArgs, reply *GetTotalStakeReply) error
GetTotalStake returns the total amount staked on the Primary Network
func (*Service) GetTxStatus ¶
func (s *Service) GetTxStatus(_ *http.Request, args *GetTxStatusArgs, response *GetTxStatusResponse) error
GetTxStatus gets a tx's status
func (*Service) GetUTXOs ¶
func (s *Service) GetUTXOs(_ *http.Request, args *api.GetUTXOsArgs, response *api.GetUTXOsReply) error
GetUTXOs returns the UTXOs controlled by the given addresses
func (*Service) GetValidatorsAt ¶
func (s *Service) GetValidatorsAt(r *http.Request, args *GetValidatorsAtArgs, reply *GetValidatorsAtReply) error
GetValidatorsAt returns the weights of the validator set of a provided subnet at the specified height.
func (*Service) ImportAVAX ¶
func (s *Service) ImportAVAX(_ *http.Request, args *ImportAVAXArgs, response *api.JSONTxIDChangeAddr) error
ImportAVAX issues a transaction to import AVAX from the X-chain. The AVAX must have already been exported from the X-Chain.
func (*Service) ImportKey ¶
func (s *Service) ImportKey(_ *http.Request, args *ImportKeyArgs, reply *api.JSONAddress) error
ImportKey adds a private key to the provided user
func (*Service) ListAddresses ¶
func (s *Service) ListAddresses(_ *http.Request, args *api.UserPass, response *api.JSONAddresses) error
ListAddresses returns the addresses controlled by [args.Username]
func (*Service) SampleValidators ¶
func (s *Service) SampleValidators(_ *http.Request, args *SampleValidatorsArgs, reply *SampleValidatorsReply) error
SampleValidators returns a sampling of the list of current validators
func (*Service) ValidatedBy ¶
func (s *Service) ValidatedBy(r *http.Request, args *ValidatedByArgs, response *ValidatedByResponse) error
ValidatedBy returns the ID of the Subnet that validates [args.BlockchainID]
func (*Service) Validates ¶
func (s *Service) Validates(_ *http.Request, args *ValidatesArgs, response *ValidatesResponse) error
Validates returns the IDs of the blockchains validated by [args.SubnetID]
type SetAddressStateArgs ¶
type SetAddressStateArgs struct { api.UserPass api.JSONFromAddrs Change platformapi.Owner `json:"change"` Address string `json:"address"` State as.AddressStateBit `json:"state"` Remove bool `json:"remove"` }
type SpendArgs ¶
type SpendArgs struct { api.JSONFromAddrs To platformapi.Owner `json:"to"` Change platformapi.Owner `json:"change"` LockMode byte `json:"lockMode"` AmountToLock utilsjson.Uint64 `json:"amountToLock"` AmountToBurn utilsjson.Uint64 `json:"amountToBurn"` AsOf utilsjson.Uint64 `json:"asOf"` Encoding formatting.Encoding `json:"encoding"` }
type SpendReply ¶
type TransferArgs ¶
type TransferArgs struct { api.UserPass api.JSONFromAddrs Change platformapi.Owner `json:"change"` TransferTo platformapi.Owner `json:"transferTo"` Amount utilsjson.Uint64 `json:"amount"` }
type VM ¶
type VM struct { config.Config blockbuilder.Builder // contains filtered or unexported fields }
func (*VM) CodecRegistry ¶
func (*VM) ConnectedSubnet ¶
func (*VM) CreateHandlers ¶
CreateHandlers returns a map where: * keys are API endpoint extensions * values are API handlers
func (*VM) CreateStaticHandlers ¶
CreateStaticHandlers returns a map where: * keys are API endpoint extensions * values are API handlers
func (*VM) GetCurrentHeight ¶
GetCurrentHeight returns the height of the last accepted block
func (*VM) GetFeeAssetID ¶
func (*VM) GetMinimumHeight ¶
GetMinimumHeight returns the height of the most recent block beyond the horizon of our recentlyAccepted window.
Because the time between blocks is arbitrary, we're only guaranteed that the window's configured TTL amount of time has passed once an element expires from the window.
To try to always return a block older than the window's TTL, we return the parent of the oldest element in the window (as an expired element is always guaranteed to be sufficiently stale). If we haven't expired an element yet in the case of a process restart, we default to the lastAccepted block's height which is likely (but not guaranteed) to also be older than the window's configured TTL.
If [UseCurrentHeight] is true, we will always return the last accepted block height as the minimum. This is used to trigger the proposervm on recently created subnets before [recentlyAcceptedWindowTTL].
func (*VM) GetSubnetID ¶
GetCurrentHeight returns the height of the last accepted block
func (*VM) GetValidatorSet ¶
func (vm *VM) GetValidatorSet(ctx context.Context, height uint64, subnetID ids.ID) (map[ids.NodeID]*validators.GetValidatorOutput, error)
GetValidatorSet returns the validator set at the specified height for the provided subnetID.
func (*VM) Initialize ¶
func (vm *VM) Initialize( ctx context.Context, chainCtx *snow.Context, dbManager manager.Manager, genesisBytes []byte, _ []byte, _ []byte, toEngine chan<- common.Message, _ []*common.Fx, appSender common.AppSender, ) error
Initialize this blockchain. [vm.ChainManager] and [vm.vdrMgr] must be set before this function is called.
func (*VM) LastAccepted ¶
LastAccepted returns the block most recently accepted
func (*VM) ParseBlock ¶
func (*VM) SetPreference ¶
SetPreference sets the preferred block to be the one with ID [blkID]
type ValidatedByArgs ¶
type ValidatedByArgs struct { // ValidatedBy returns the ID of the Subnet validating the blockchain with this ID BlockchainID ids.ID `json:"blockchainID"` }
ValidatedByArgs is the arguments for calling ValidatedBy
type ValidatedByResponse ¶
type ValidatedByResponse struct { // ID of the Subnet validating the specified blockchain SubnetID ids.ID `json:"subnetID"` }
ValidatedByResponse is the reply from calling ValidatedBy
type ValidatesArgs ¶
ValidatesArgs are the arguments to Validates
type ValidatesResponse ¶
ValidatesResponse is the response from calling Validates
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
Package blocks is a generated GoMock package.
|
Package blocks is a generated GoMock package. |
executor
Package executor is a generated GoMock package.
|
Package executor is a generated GoMock package. |
Package dac is a generated GoMock package.
|
Package dac is a generated GoMock package. |
Package fx is a generated GoMock package.
|
Package fx is a generated GoMock package. |
Package state is a generated GoMock package.
|
Package state is a generated GoMock package. |
Package txs is a generated GoMock package.
|
Package txs is a generated GoMock package. |
builder
Package builder is a generated GoMock package.
|
Package builder is a generated GoMock package. |
mempool
Package mempool is a generated GoMock package.
|
Package mempool is a generated GoMock package. |
Package utxo is a generated GoMock package.
|
Package utxo is a generated GoMock package. |