client

package
v1.1.1 Latest Latest
Warning

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

Go to latest
Published: Oct 30, 2024 License: AGPL-3.0 Imports: 15 Imported by: 3

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type ApiClient

type ApiClient struct {
	NodeSet               *NodeSetRequester
	NodeSet_StakeWise     *NodeSetStakeWiseRequester
	NodeSet_Constellation *NodeSetConstellationRequester
	Service               *ServiceRequester
	Tx                    *TxRequester
	Utils                 *UtilsRequester
	Wallet                *WalletRequester
	// contains filtered or unexported fields
}

Binder for the Hyperdrive daemon API server

func NewApiClient

func NewApiClient(apiUrl *url.URL, logger *slog.Logger, tracer *httptrace.ClientTrace, authMgr *auth.AuthorizationManager) *ApiClient

Creates a new API client instance

func (*ApiClient) SetLogger

func (c *ApiClient) SetLogger(logger *slog.Logger)

Set debug mode

type NodeSetConstellationRequester added in v1.1.0

type NodeSetConstellationRequester struct {
	// contains filtered or unexported fields
}

Requester for Constellation module calls to the nodeset.io service

func NewNodeSetConstellationRequester added in v1.1.0

func NewNodeSetConstellationRequester(context client.IRequesterContext) *NodeSetConstellationRequester

func (*NodeSetConstellationRequester) GetContext added in v1.1.0

func (*NodeSetConstellationRequester) GetDepositSignature added in v1.1.0

func (r *NodeSetConstellationRequester) GetDepositSignature(deployment string, minipoolAddress common.Address, salt *big.Int) (*types.ApiResponse[api.NodeSetConstellation_GetDepositSignatureData], error)

Gets the deposit signature for a minipool from the Constellation contracts

func (*NodeSetConstellationRequester) GetName added in v1.1.0

func (*NodeSetConstellationRequester) GetRegisteredAddress added in v1.1.0

Gets the address the node's user has assigned as the registered Constellation address

func (*NodeSetConstellationRequester) GetRegistrationSignature added in v1.1.0

Gets a signature for registering / whitelisting the node with the Constellation contracts

func (*NodeSetConstellationRequester) GetRoute added in v1.1.0

func (r *NodeSetConstellationRequester) GetRoute() string

func (*NodeSetConstellationRequester) GetValidators added in v1.1.0

Gets the validators that have been registered with the NodeSet service for this node as part of Constellation

func (*NodeSetConstellationRequester) UploadSignedExits added in v1.1.0

Uploads signed exit messages to the NodeSet service

type NodeSetRequester added in v1.1.0

type NodeSetRequester struct {
	// contains filtered or unexported fields
}

Requester for core calls to the nodeset.io service

func NewNodeSetRequester added in v1.1.0

func NewNodeSetRequester(context client.IRequesterContext) *NodeSetRequester

func (*NodeSetRequester) GetContext added in v1.1.0

func (r *NodeSetRequester) GetContext() client.IRequesterContext

func (*NodeSetRequester) GetName added in v1.1.0

func (r *NodeSetRequester) GetName() string

func (*NodeSetRequester) GetRegistrationStatus added in v1.1.0

Gets the node's registration status with the NodeSet service

func (*NodeSetRequester) GetRoute added in v1.1.0

func (r *NodeSetRequester) GetRoute() string

func (*NodeSetRequester) RegisterNode added in v1.1.0

Registers the node with the NodeSet service

type NodeSetStakeWiseRequester added in v1.1.0

type NodeSetStakeWiseRequester struct {
	// contains filtered or unexported fields
}

Requester for StakeWise module calls to the nodeset.io service

func NewNodeSetStakeWiseRequester added in v1.1.0

func NewNodeSetStakeWiseRequester(context client.IRequesterContext) *NodeSetStakeWiseRequester

func (*NodeSetStakeWiseRequester) GetContext added in v1.1.0

func (*NodeSetStakeWiseRequester) GetDepositDataSet added in v1.1.0

Gets the latest deposit data set on the server for the provided vault

func (*NodeSetStakeWiseRequester) GetDepositDataSetVersion added in v1.1.0

Gets the version of the latest deposit data set on the server for the provided vault

func (*NodeSetStakeWiseRequester) GetName added in v1.1.0

func (r *NodeSetStakeWiseRequester) GetName() string

func (*NodeSetStakeWiseRequester) GetRegisteredValidators added in v1.1.0

Gets the list of validators that the node has registered with the provided vault

func (*NodeSetStakeWiseRequester) GetRoute added in v1.1.0

func (r *NodeSetStakeWiseRequester) GetRoute() string

func (*NodeSetStakeWiseRequester) UploadDepositData added in v1.1.0

Uploads new validator deposit data to the NodeSet service

func (*NodeSetStakeWiseRequester) UploadSignedExits added in v1.1.0

Uploads signed exit messages to the NodeSet service

type ServiceRequester

type ServiceRequester struct {
	// contains filtered or unexported fields
}

func NewServiceRequester

func NewServiceRequester(context client.IRequesterContext) *ServiceRequester

func (*ServiceRequester) ClientStatus

Gets the status of the configured Execution and Beacon clients

func (*ServiceRequester) GetConfig

Gets the Hyperdrive configuration

func (*ServiceRequester) GetContext

func (r *ServiceRequester) GetContext() client.IRequesterContext

func (*ServiceRequester) GetName

func (r *ServiceRequester) GetName() string

func (*ServiceRequester) GetNetworkSettings added in v1.1.0

Gets the network settings for the daemon's selected network

func (*ServiceRequester) GetResources added in v1.1.0

Gets the resources for the daemon's selected network

func (*ServiceRequester) GetRoute

func (r *ServiceRequester) GetRoute() string

func (*ServiceRequester) RestartContainer

func (r *ServiceRequester) RestartContainer(container string) (*types.ApiResponse[types.SuccessData], error)

Restarts a Docker container

func (*ServiceRequester) TerminateDataFolder

Deletes the data folder including the wallet file, password file, and all validator keys. Don't use this unless you have a very good reason to do it (such as switching from Prater to Mainnet).

func (*ServiceRequester) Version

Gets the version of the daemon

type TxRequester

type TxRequester struct {
	// contains filtered or unexported fields
}

func NewTxRequester

func NewTxRequester(context client.IRequesterContext) *TxRequester

func (*TxRequester) GetContext

func (r *TxRequester) GetContext() client.IRequesterContext

func (*TxRequester) GetName

func (r *TxRequester) GetName() string

func (*TxRequester) GetRoute

func (r *TxRequester) GetRoute() string

func (*TxRequester) SignTx

func (r *TxRequester) SignTx(txSubmission *eth.TransactionSubmission, nonce *big.Int, maxFee *big.Int, maxPriorityFee *big.Int) (*types.ApiResponse[api.TxSignTxData], error)

Use the node private key to sign a transaction without submitting it

func (*TxRequester) SignTxBatch

func (r *TxRequester) SignTxBatch(txSubmissions []*eth.TransactionSubmission, firstNonce *big.Int, maxFee *big.Int, maxPriorityFee *big.Int) (*types.ApiResponse[api.TxBatchSignTxData], error)

Use the node private key to sign a batch of transactions without submitting them

func (*TxRequester) SubmitTx

func (r *TxRequester) SubmitTx(txSubmission *eth.TransactionSubmission, nonce *big.Int, maxFee *big.Int, maxPriorityFee *big.Int) (*types.ApiResponse[api.TxData], error)

Submit a transaction

func (*TxRequester) SubmitTxBatch

func (r *TxRequester) SubmitTxBatch(txSubmissions []*eth.TransactionSubmission, firstNonce *big.Int, maxFee *big.Int, maxPriorityFee *big.Int) (*types.ApiResponse[api.BatchTxData], error)

Submit a batch of transactions

func (*TxRequester) WaitForTransaction

func (r *TxRequester) WaitForTransaction(txHash common.Hash) (*types.ApiResponse[types.SuccessData], error)

Wait for a transaction

type UtilsRequester

type UtilsRequester struct {
	// contains filtered or unexported fields
}

func NewUtilsRequester

func NewUtilsRequester(context client.IRequesterContext) *UtilsRequester

func (*UtilsRequester) GetContext

func (r *UtilsRequester) GetContext() client.IRequesterContext

func (*UtilsRequester) GetName

func (r *UtilsRequester) GetName() string

func (*UtilsRequester) GetRoute

func (r *UtilsRequester) GetRoute() string

func (*UtilsRequester) ResolveEns

func (r *UtilsRequester) ResolveEns(address common.Address, name string) (*types.ApiResponse[api.UtilsResolveEnsData], error)

Resolves an ENS name or reserve resolves an address

type WalletRequester

type WalletRequester struct {
	// contains filtered or unexported fields
}

func NewWalletRequester

func NewWalletRequester(context client.IRequesterContext) *WalletRequester

func (*WalletRequester) Balance

Get the node address's ETH balance

func (*WalletRequester) DeletePassword

func (r *WalletRequester) DeletePassword() (*types.ApiResponse[types.SuccessData], error)

Delete the wallet keystore's password from disk

func (*WalletRequester) Export

Export wallet

func (*WalletRequester) ExportEthKey

Export the wallet in encrypted ETH key format

func (*WalletRequester) GenerateValidatorKey

func (r *WalletRequester) GenerateValidatorKey(path string) (*types.ApiResponse[api.WalletGenerateValidatorKeyData], error)

Generate a validator key derived from the node wallet's seed

func (*WalletRequester) GetContext

func (r *WalletRequester) GetContext() client.IRequesterContext

func (*WalletRequester) GetName

func (r *WalletRequester) GetName() string

func (*WalletRequester) GetRoute

func (r *WalletRequester) GetRoute() string

func (*WalletRequester) Initialize

func (r *WalletRequester) Initialize(derivationPath *string, index *uint64, saveWallet bool, password string, savePassword bool) (*types.ApiResponse[api.WalletInitializeData], error)

Initialize the wallet with a new key

func (*WalletRequester) Masquerade

func (r *WalletRequester) Masquerade(address common.Address) (*types.ApiResponse[types.SuccessData], error)

Set the node address to an arbitrary address

func (*WalletRequester) Recover

func (r *WalletRequester) Recover(derivationPath *string, mnemonic string, index *uint64, password string, save bool) (*types.ApiResponse[api.WalletRecoverData], error)

Recover wallet

func (*WalletRequester) RestoreAddress

func (r *WalletRequester) RestoreAddress() (*types.ApiResponse[types.SuccessData], error)

Set the node address back to the wallet address

func (*WalletRequester) SearchAndRecover

func (r *WalletRequester) SearchAndRecover(mnemonic string, address common.Address, password string, save bool) (*types.ApiResponse[api.WalletSearchAndRecoverData], error)

Search and recover wallet

func (*WalletRequester) Send

func (r *WalletRequester) Send(amount *big.Int, token string, recipient common.Address) (*types.ApiResponse[api.WalletSendData], error)

Send tokens from the wallet to an address

func (*WalletRequester) SendMessage

func (r *WalletRequester) SendMessage(message []byte, address common.Address) (*types.ApiResponse[types.TxInfoData], error)

Sends a zero-value message with a payload

func (*WalletRequester) SetEnsName

Set an ENS reverse record to a name

func (*WalletRequester) SetPassword

func (r *WalletRequester) SetPassword(password string, save bool) (*types.ApiResponse[types.SuccessData], error)

Sets the wallet keystore's password

func (*WalletRequester) SignMessage

func (r *WalletRequester) SignMessage(message []byte) (*types.ApiResponse[api.WalletSignMessageData], error)

Use the node private key to sign an arbitrary message

func (*WalletRequester) SignTx

func (r *WalletRequester) SignTx(message []byte) (*types.ApiResponse[api.WalletSignTxData], error)

Use the node private key to sign a transaction

func (*WalletRequester) Status

Get wallet status

func (*WalletRequester) TestRecover

func (r *WalletRequester) TestRecover(derivationPath *string, mnemonic string, index *uint64) (*types.ApiResponse[api.WalletRecoverData], error)

Recover wallet in test-mode so none of the artifacts are saved

func (*WalletRequester) TestSearchAndRecover

func (r *WalletRequester) TestSearchAndRecover(mnemonic string, address common.Address) (*types.ApiResponse[api.WalletSearchAndRecoverData], error)

Search for and recover the wallet in test-mode so none of the artifacts are saved

Jump to

Keyboard shortcuts

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