obsclient

package
v0.28.0 Latest Latest
Warning

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

Go to latest
Published: Nov 8, 2024 License: AGPL-3.0 Imports: 20 Imported by: 0

README

This package is analogous to the ethclient package in go-ethereum.

It provides a higher level, standard way to interact with an TEN network programmatically.

It aims to provide all the same methods that the geth ethclient provides for compatibility/familiarity, as well as TEN-specific methods.

There are two clients, ObsClient and AuthObsClient

ObsClient just requires a Client and provides access to general TEN functionality that doesn't require viewing keys.

AuthObsClient requires a EncRPCClient, which is an RPC client with an account and a signed Viewing Key for authentication. It provides full TEN functionality, authenticating with the node and encrypting/decrypting sensitive requests.

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func ToCallArg

func ToCallArg(msg ethereum.CallMsg) interface{}

Types

type AuthObsClient

type AuthObsClient struct {
	ObsClient
	// contains filtered or unexported fields
}

AuthObsClient extends the functionality of the ObsClient for all methods that require encryption when communicating with the enclave It is created with an EncRPCClient rather than basic RPC client so encryption/decryption is supported

The methods in this client are analogous to the methods in geth's EthClient and should behave the same unless noted otherwise.

func DialWithAuth

func DialWithAuth(rpcurl string, wal wallet.Wallet, logger gethlog.Logger) (*AuthObsClient, error)

DialWithAuth will generate and sign a viewing key for given wallet, then initiate a connection with the RPC node and register the viewing key

func NewAuthObsClient

func NewAuthObsClient(client *rpc.EncRPCClient) *AuthObsClient

NewAuthObsClient constructs an AuthObsClient for sensitive communication with an enclave.

It requires an EncRPCClient specifically even though the AuthObsClient uses a Client interface in its struct because the Client interface makes testing easy but an EncRPCClient is required for the actual encrypted communication

func (*AuthObsClient) Address

func (ac *AuthObsClient) Address() gethcommon.Address

func (*AuthObsClient) BalanceAt

func (ac *AuthObsClient) BalanceAt(ctx context.Context, blockNumber *big.Int) (*big.Int, error)

BalanceAt retrieves the native balance for the account registered on this client (due to obscuro privacy restrictions, balance cannot be requested for other accounts)

func (*AuthObsClient) CallContract

func (ac *AuthObsClient) CallContract(ctx context.Context, msg ethereum.CallMsg, blockNumber *big.Int) ([]byte, error)

func (*AuthObsClient) CodeAt added in v0.28.0

func (ac *AuthObsClient) CodeAt(ctx context.Context, address gethcommon.Address, number *big.Int) ([]byte, error)

func (*AuthObsClient) EstimateGas

func (ac *AuthObsClient) EstimateGas(ctx context.Context, msg ethereum.CallMsg) (uint64, error)

func (*AuthObsClient) EstimateGasAndGasPrice

func (ac *AuthObsClient) EstimateGasAndGasPrice(txData types.TxData) types.TxData

func (*AuthObsClient) FilterLogs added in v0.28.0

func (ac *AuthObsClient) FilterLogs(context.Context, ethereum.FilterQuery) ([]types.Log, error)

func (*AuthObsClient) GasPrice added in v0.21.0

func (ac *AuthObsClient) GasPrice(ctx context.Context) (*big.Int, error)

func (*AuthObsClient) GetLogs

func (ac *AuthObsClient) GetLogs(ctx context.Context, filterCriteria common.FilterCriteria) ([]*types.Log, error)

func (*AuthObsClient) GetPrivateTransactions added in v0.25.0

func (ac *AuthObsClient) GetPrivateTransactions(ctx context.Context, address *gethcommon.Address, pagination common.QueryPagination) (types.Receipts, uint64, error)

GetPrivateTransactions retrieves the receipts for the specified account (must be registered on this client), returns requested range of receipts and the total number of receipts for that acc

func (*AuthObsClient) HeaderByNumber added in v0.28.0

func (ac *AuthObsClient) HeaderByNumber(_ context.Context, number *big.Int) (*types.Header, error)

func (*AuthObsClient) NonceAt

func (ac *AuthObsClient) NonceAt(ctx context.Context, blockNumber *big.Int) (uint64, error)

NonceAt retrieves the nonce for the account registered on this client (due to obscuro privacy restrictions, nonce cannot be requested for other accounts)

func (*AuthObsClient) PendingCodeAt added in v0.28.0

func (ac *AuthObsClient) PendingCodeAt(ctx context.Context, address gethcommon.Address) ([]byte, error)

func (*AuthObsClient) PendingNonceAt added in v0.28.0

func (ac *AuthObsClient) PendingNonceAt(ctx context.Context, address gethcommon.Address) (uint64, error)

func (*AuthObsClient) SendTransaction

func (ac *AuthObsClient) SendTransaction(ctx context.Context, signedTx *types.Transaction) error

func (*AuthObsClient) SubscribeFilterLogs

func (ac *AuthObsClient) SubscribeFilterLogs(ctx context.Context, filterCriteria ethereum.FilterQuery, ch chan<- types.Log) (ethereum.Subscription, error)

Workaround for creating a ETH client interface to be used in generated contracts interacting. Obviously any usage should avoid subscriptions as it will not work.

func (*AuthObsClient) SubscribeFilterLogsTEN added in v0.28.0

func (ac *AuthObsClient) SubscribeFilterLogsTEN(ctx context.Context, filterCriteria common.FilterCriteria, ch chan types.Log) (ethereum.Subscription, error)

Real method that we have used in TEN for subscription

func (*AuthObsClient) SuggestGasPrice added in v0.28.0

func (ac *AuthObsClient) SuggestGasPrice(ctx context.Context) (*big.Int, error)

func (*AuthObsClient) SuggestGasTipCap added in v0.28.0

func (ac *AuthObsClient) SuggestGasTipCap(ctx context.Context) (*big.Int, error)

SuggestGasTipCap implements bind.ContractBackend.

func (*AuthObsClient) TransactionByHash

func (ac *AuthObsClient) TransactionByHash(ctx context.Context, hash gethcommon.Hash) (tx *types.Transaction, isPending bool, err error)

TransactionByHash returns transaction (if found), isPending (always false currently as we don't search the mempool), error

func (*AuthObsClient) TransactionReceipt

func (ac *AuthObsClient) TransactionReceipt(ctx context.Context, txHash gethcommon.Hash) (*types.Receipt, error)

type ObsClient

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

ObsClient provides access to general Obscuro functionality that doesn't require viewing keys.

The methods in this client are analogous to the methods in geth's EthClient and should behave the same unless noted otherwise.

func Dial

func Dial(rawurl string) (*ObsClient, error)

func NewObsClient

func NewObsClient(c rpc.Client) *ObsClient

func (*ObsClient) BatchNumber

func (oc *ObsClient) BatchNumber() (uint64, error)

BatchNumber returns the height of the head rollup

func (*ObsClient) ChainID

func (oc *ObsClient) ChainID() (*big.Int, error)

ChainID retrieves the current chain ID for transaction replay protection.

func (*ObsClient) Close

func (oc *ObsClient) Close()

func (*ObsClient) GetBatchByHash added in v0.24.1

func (oc *ObsClient) GetBatchByHash(hash gethcommon.Hash) (*common.ExtBatch, error)

GetBatchByHash returns the batch with the given hash.

func (*ObsClient) GetBatchByHeight added in v0.24.1

func (oc *ObsClient) GetBatchByHeight(height *big.Int) (*common.PublicBatch, error)

GetBatchByHeight returns the batch with the given height.

func (*ObsClient) GetBatchHeaderByHash added in v0.24.1

func (oc *ObsClient) GetBatchHeaderByHash(hash gethcommon.Hash) (*common.BatchHeader, error)

GetBatchHeaderByHash returns the block header with the given hash.

func (*ObsClient) GetBatchHeaderByNumber added in v0.24.1

func (oc *ObsClient) GetBatchHeaderByNumber(number *big.Int) (*common.BatchHeader, error)

GetBatchHeaderByNumber returns the header of the rollup with the given number

func (*ObsClient) GetBatchTransactions added in v0.24.1

func (oc *ObsClient) GetBatchTransactions(hash gethcommon.Hash) (*common.TransactionListingResponse, error)

GetBatchTransactions returns a list of public transaction data within a given batch has

func (*ObsClient) GetBatchesListing

func (oc *ObsClient) GetBatchesListing(pagination *common.QueryPagination) (*common.BatchListingResponse, error)

GetBatchesListing returns a list of batches

func (*ObsClient) GetBatchesListingDeprecated added in v0.24.0

func (oc *ObsClient) GetBatchesListingDeprecated(pagination *common.QueryPagination) (*common.BatchListingResponseDeprecated, error)

GetBatchesListingDeprecated returns a list of batches

func (*ObsClient) GetBlockListing

func (oc *ObsClient) GetBlockListing(pagination *common.QueryPagination) (*common.BlockListingResponse, error)

GetBlockListing returns a list of block headers

func (*ObsClient) GetConfig

func (oc *ObsClient) GetConfig() (*common.TenNetworkInfo, error)

GetConfig returns the network config for obscuro

func (*ObsClient) GetLatestBatch added in v0.24.0

func (oc *ObsClient) GetLatestBatch() (*common.BatchHeader, error)

GetLatestBatch returns the header of the latest rollup at tip

func (*ObsClient) GetLatestRollupHeader

func (oc *ObsClient) GetLatestRollupHeader() (*common.RollupHeader, error)

GetLatestRollupHeader returns the header of the latest rollup

func (*ObsClient) GetPublicTxListing

func (oc *ObsClient) GetPublicTxListing(pagination *common.QueryPagination) (*common.TransactionListingResponse, error)

GetPublicTxListing returns a list of public transactions

func (*ObsClient) GetRollupBatches added in v0.24.1

func (oc *ObsClient) GetRollupBatches(hash gethcommon.Hash) (*common.BatchListingResponse, error)

GetRollupBatches returns a list of public batch data within a given rollup hash

func (*ObsClient) GetRollupByHash added in v0.24.1

func (oc *ObsClient) GetRollupByHash(hash gethcommon.Hash) (*common.PublicRollup, error)

GetRollupByHash returns the public rollup data given its hash

func (*ObsClient) GetRollupBySeqNo added in v0.24.1

func (oc *ObsClient) GetRollupBySeqNo(seqNo uint64) (*common.PublicRollup, error)

GetRollupBySeqNo returns the batch with the given height.

func (*ObsClient) GetRollupListing added in v0.24.0

func (oc *ObsClient) GetRollupListing(pagination *common.QueryPagination) (*common.RollupListingResponse, error)

GetRollupListing returns a list of Rollups

func (*ObsClient) GetTotalContractCount

func (oc *ObsClient) GetTotalContractCount() (int, error)

GetTotalContractCount returns the total count of created contracts

func (*ObsClient) GetTotalTransactionCount

func (oc *ObsClient) GetTotalTransactionCount() (int, error)

GetTotalTransactionCount returns the total count of executed transactions

func (*ObsClient) GetTransaction added in v0.24.1

func (oc *ObsClient) GetTransaction(hash gethcommon.Hash) (*common.PublicTransaction, error)

GetTransaction returns the transaction.

func (*ObsClient) Health

func (oc *ObsClient) Health() (bool, error)

Health returns the health of the node.

Directories

Path Synopsis

Jump to

Keyboard shortcuts

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