Documentation ¶
Overview ¶
sequence-relayer v0.4.1 1e27d0fd295aa5897878939595ef0c6adc54b1a3 -- Code generated by webrpc-gen@v0.18.6 with golang generator. DO NOT EDIT.
webrpc-gen -schema=relayer.ridl -target=golang -pkg=proto -client -out=./clients/relayer.gen.go
Index ¶
- Constants
- Variables
- func HTTPRequestHeaders(ctx context.Context) (http.Header, bool)
- func MethodNameFromContext(ctx context.Context) string
- func RequestFromContext(ctx context.Context) *http.Request
- func ServiceNameFromContext(ctx context.Context) string
- func WebRPCSchemaHash() string
- func WebRPCSchemaVersion() string
- func WebRPCVersion() string
- func WithHTTPRequestHeaders(ctx context.Context, h http.Header) (context.Context, error)
- type ETHTxnStatus
- type FeeOption
- type FeeToken
- type FeeTokenType
- type GasSponsor
- type GasSponsorUsage
- type GasTank
- type GasTankBalanceAdjustment
- type HTTPClient
- type MetaTxn
- type MetaTxnEntry
- type MetaTxnLog
- type MetaTxnReceipt
- type MetaTxnReceiptLog
- type NumTxnsRelayed
- type Page
- type Relayer
- type RelayerClient
- type RuntimeChecks
- type RuntimeStatus
- type SenderStatus
- type SentTransactionsFilter
- type SequenceContext
- type SimulateResult
- type SortBy
- type SortOrder
- type Transaction
- type TransferType
- type TxnLogTransfer
- type TxnLogUser
- type Version
- type WebRPCError
Constants ¶
const RelayerPathPrefix = "/rpc/Relayer/"
Variables ¶
var ( HTTPClientRequestHeadersCtxKey = &contextKey{"HTTPClientRequestHeaders"} HTTPRequestCtxKey = &contextKey{"HTTPRequest"} ServiceNameCtxKey = &contextKey{"ServiceName"} MethodNameCtxKey = &contextKey{"MethodName"} )
var ( ErrWebrpcEndpoint = WebRPCError{Code: 0, Name: "WebrpcEndpoint", Message: "endpoint error", HTTPStatus: 400} ErrWebrpcRequestFailed = WebRPCError{Code: -1, Name: "WebrpcRequestFailed", Message: "request failed", HTTPStatus: 400} ErrWebrpcBadRoute = WebRPCError{Code: -2, Name: "WebrpcBadRoute", Message: "bad route", HTTPStatus: 404} ErrWebrpcBadMethod = WebRPCError{Code: -3, Name: "WebrpcBadMethod", Message: "bad method", HTTPStatus: 405} ErrWebrpcBadRequest = WebRPCError{Code: -4, Name: "WebrpcBadRequest", Message: "bad request", HTTPStatus: 400} ErrWebrpcBadResponse = WebRPCError{Code: -5, Name: "WebrpcBadResponse", Message: "bad response", HTTPStatus: 500} ErrWebrpcServerPanic = WebRPCError{Code: -6, Name: "WebrpcServerPanic", Message: "server panic", HTTPStatus: 500} ErrWebrpcInternalError = WebRPCError{Code: -7, Name: "WebrpcInternalError", Message: "internal error", HTTPStatus: 500} ErrWebrpcClientDisconnected = WebRPCError{Code: -8, Name: "WebrpcClientDisconnected", Message: "client disconnected", HTTPStatus: 400} ErrWebrpcStreamLost = WebRPCError{Code: -9, Name: "WebrpcStreamLost", Message: "stream lost", HTTPStatus: 400} ErrWebrpcStreamFinished = WebRPCError{Code: -10, Name: "WebrpcStreamFinished", Message: "stream finished", HTTPStatus: 200} )
Webrpc errors
var ( ErrPermissionDenied = WebRPCError{Code: 1001, Name: "PermissionDenied", Message: "Permission denied", HTTPStatus: 403} ErrMethodNotFound = WebRPCError{Code: 1003, Name: "MethodNotFound", Message: "Method not found", HTTPStatus: 404} ErrAborted = WebRPCError{Code: 1005, Name: "Aborted", Message: "Request aborted", HTTPStatus: 400} ErrInvalidArgument = WebRPCError{Code: 2001, Name: "InvalidArgument", Message: "Invalid argument", HTTPStatus: 400} ErrQueryFailed = WebRPCError{Code: 2003, Name: "QueryFailed", Message: "Query failed", HTTPStatus: 400} ErrNotFound = WebRPCError{Code: 3000, Name: "NotFound", Message: "Resource not found", HTTPStatus: 400} )
Schema errors
var ETHTxnStatus_name = map[uint]string{
0: "UNKNOWN",
1: "DROPPED",
2: "QUEUED",
3: "SENT",
4: "SUCCEEDED",
5: "PARTIALLY_FAILED",
6: "FAILED",
}
var ETHTxnStatus_value = map[string]uint{
"UNKNOWN": 0,
"DROPPED": 1,
"QUEUED": 2,
"SENT": 3,
"SUCCEEDED": 4,
"PARTIALLY_FAILED": 5,
"FAILED": 6,
}
var FeeTokenType_name = map[uint32]string{
0: "UNKNOWN",
1: "ERC20_TOKEN",
2: "ERC1155_TOKEN",
}
var FeeTokenType_value = map[string]uint32{
"UNKNOWN": 0,
"ERC20_TOKEN": 1,
"ERC1155_TOKEN": 2,
}
var SortOrder_name = map[uint32]string{
0: "DESC",
1: "ASC",
}
var SortOrder_value = map[string]uint32{
"DESC": 0,
"ASC": 1,
}
var TransferType_name = map[uint32]string{
0: "SEND",
1: "RECEIVE",
2: "BRIDGE_DEPOSIT",
3: "BRIDGE_WITHDRAW",
4: "BURN",
5: "UNKNOWN",
}
var TransferType_value = map[string]uint32{
"SEND": 0,
"RECEIVE": 1,
"BRIDGE_DEPOSIT": 2,
"BRIDGE_WITHDRAW": 3,
"BURN": 4,
"UNKNOWN": 5,
}
var WebRPCServices = map[string][]string{
"Relayer": {
"Ping",
"Version",
"RuntimeStatus",
"GetSequenceContext",
"GetChainID",
"SendMetaTxn",
"GetMetaTxnNonce",
"GetMetaTxnReceipt",
"Simulate",
"UpdateMetaTxnGasLimits",
"FeeTokens",
"FeeOptions",
"GetMetaTxnNetworkFeeOptions",
"GetMetaTransactions",
"SentTransactions",
"PendingTransactions",
"GetGasTank",
"AddGasTank",
"UpdateGasTank",
"GetGasSponsor",
"AddressGasSponsors",
"ListGasSponsors",
"AddGasSponsor",
"UpdateGasSponsor",
"RemoveGasSponsor",
"ReportGasSponsorUsage",
"NextGasTankBalanceAdjustmentNonce",
"AdjustGasTankBalance",
"GetGasTankBalanceAdjustment",
"ListGasTankBalanceAdjustments",
},
}
Functions ¶
func MethodNameFromContext ¶ added in v0.31.0
func RequestFromContext ¶ added in v0.31.0
func ServiceNameFromContext ¶ added in v0.31.0
Types ¶
type ETHTxnStatus ¶
type ETHTxnStatus uint
const ( ETHTxnStatus_UNKNOWN ETHTxnStatus = 0 // txn rejected by relayer ETHTxnStatus_DROPPED ETHTxnStatus = 1 // txn accepted by relayer, waiting to be sent ETHTxnStatus_QUEUED ETHTxnStatus = 2 // txn sent, waiting for txn to be mined ETHTxnStatus_SENT ETHTxnStatus = 3 // txn mined, all txns in the bundle succeeded ETHTxnStatus_SUCCEEDED ETHTxnStatus = 4 // txn mined, but some txns in the bundle failed ETHTxnStatus_PARTIALLY_FAILED ETHTxnStatus = 5 // txn mined, but all txns in the bundle failed ETHTxnStatus_FAILED ETHTxnStatus = 6 )
func (*ETHTxnStatus) Is ¶ added in v0.31.0
func (x *ETHTxnStatus) Is(values ...ETHTxnStatus) bool
func (ETHTxnStatus) MarshalText ¶ added in v0.31.0
func (x ETHTxnStatus) MarshalText() ([]byte, error)
func (ETHTxnStatus) String ¶
func (x ETHTxnStatus) String() string
func (*ETHTxnStatus) UnmarshalText ¶ added in v0.31.0
func (x *ETHTxnStatus) UnmarshalText(b []byte) error
type FeeTokenType ¶ added in v0.4.12
type FeeTokenType uint32
const ( FeeTokenType_UNKNOWN FeeTokenType = 0 FeeTokenType_ERC20_TOKEN FeeTokenType = 1 FeeTokenType_ERC1155_TOKEN FeeTokenType = 2 )
func (*FeeTokenType) Is ¶ added in v0.31.0
func (x *FeeTokenType) Is(values ...FeeTokenType) bool
func (FeeTokenType) MarshalText ¶ added in v0.31.0
func (x FeeTokenType) MarshalText() ([]byte, error)
func (FeeTokenType) String ¶ added in v0.4.12
func (x FeeTokenType) String() string
func (*FeeTokenType) UnmarshalText ¶ added in v0.31.0
func (x *FeeTokenType) UnmarshalText(b []byte) error
type GasSponsor ¶ added in v0.13.0
type GasSponsor struct { ID uint64 `json:"id" db:"id,omitempty"` GasTankID uint64 `json:"gasTankId" db:"gas_tank_id,omitempty"` ProjectID uint64 `json:"projectId" db:"project_id"` Address prototyp.Hash `json:"address" db:"address"` Name string `json:"name" db:"name"` Active bool `json:"active" db:"active"` UpdatedAt *time.Time `json:"updatedAt" db:"updated_at,omitempty"` CreatedAt *time.Time `json:"createdAt" db:"created_at,omitempty"` DeletedAt *time.Time `json:"-" db:"deleted_at,omitempty"` }
type GasSponsorUsage ¶ added in v0.13.0
type GasSponsorUsage struct { Name string `json:"name" db:"name"` ID uint64 `json:"id" db:"gas_sponsor_id,omitempty"` TotalGasUsed int64 `json:"totalGasUsed" db:"total_gas_used"` TotalTxnFees float64 `json:"totalTxnFees" db:"total_txn_fees"` TotalTxnFeesUSD decimal.Decimal `json:"totalTxnFeesUsd" db:"total_txn_fees_usd"` AvgGasPrice float64 `json:"avgGasPrice" db:"avg_gas_price"` TotalTxns int64 `json:"totalTxns" db:"total_txns"` StartTime *time.Time `json:"startTime"` EndTime *time.Time `json:"endTime"` }
type GasTank ¶ added in v0.29.1
type GasTank struct { ID uint64 `json:"id" db:"id,omitempty"` Name string `json:"name" db:"name"` CurrentBalance decimal.Decimal `json:"currentBalance" db:"current_balance"` Unlimited bool `json:"unlimited" db:"unlimited"` FeeMarkupFactor decimal.Decimal `json:"feeMarkupFactor" db:"fee_markup_factor"` UpdatedAt *time.Time `json:"updatedAt" db:"updated_at,omitempty"` CreatedAt *time.Time `json:"createdAt" db:"created_at,omitempty"` }
type GasTankBalanceAdjustment ¶ added in v0.29.1
type GasTankBalanceAdjustment struct { GasTankID uint64 `json:"gasTankId" db:"gas_tank_id"` Nonce uint64 `json:"nonce" db:"nonce"` Amount decimal.Decimal `json:"amount" db:"amount"` TotalBalance decimal.Decimal `json:"totalBalance" db:"total_balance"` BalanceTimestamp time.Time `json:"balanceTimestamp" db:"balance_timestamp"` CreatedAt *time.Time `json:"createdAt" db:"created_at,omitempty"` }
type HTTPClient ¶
HTTPClient is the interface used by generated clients to send HTTP requests. It is fulfilled by *(net/http).Client, which is sufficient for most users. Users can provide their own implementation for special retry policies.
type MetaTxn ¶
type MetaTxn struct { WalletAddress string `json:"walletAddress" db:"wallet_address"` // TODO (later): rename this to `to: string` Contract string `json:"contract" db:"to_address"` // TODO: rename to 'execdata' Input string `json:"input" db:"tx_data"` }
TODO: rename this to MetaTxnRaw (eventually), we can leave it for now to not break compat or name it, MetaTxnArgs ..?
type MetaTxnEntry ¶ added in v0.4.12
type MetaTxnEntry struct { ID uint64 `json:"id" db:"id,omitempty"` MetaTxnID string `json:"metaTxnID" db:"metatx_logs_id"` TxnStatus ETHTxnStatus `json:"txnStatus" db:"status"` TxnRevertReason string `json:"txnRevertReason" db:"revert_reason"` Index uint64 `json:"index" db:"index"` Logs []interface{} `json:"logs" db:"logs,omitempty"` UpdatedAt *time.Time `json:"updatedAt" db:"updated_at,omitempty"` CreatedAt *time.Time `json:"createdAt" db:"created_at,omitempty"` }
TODO: review
type MetaTxnLog ¶ added in v0.4.12
type MetaTxnLog struct { ID uint64 `json:"id" db:"id,omitempty"` ProjectID uint64 `json:"projectId" db:"project_id"` // this is optional, but we don't specify txnHash?: string, // otherwise it sets go.field.type to pointer-type which we dont want. TxnHash prototyp.HashMaybe `json:"txnHash" db:"txn_hash"` // TODO: this should be txnNonce?: string, but pgx giving issues // with *prototyp.BigInt scanning TxnNonce prototyp.BigInt `json:"txnNonce" db:"txn_nonce"` MetaTxnID *string `json:"metaTxnID" db:"meta_txn_id"` TxnStatus ETHTxnStatus `json:"txnStatus" db:"txn_status"` TxnRevertReason string `json:"txnRevertReason" db:"txn_revert_reason"` Requeues uint `json:"requeues" db:"requeues"` QueuedAt *time.Time `json:"queuedAt" db:"queued_at,omitempty"` SentAt *time.Time `json:"sentAt" db:"sent_at,omitempty"` MinedAt *time.Time `json:"minedAt" db:"mined_at,omitempty"` Target prototyp.Hash `json:"target" db:"target"` Input prototyp.Hash `json:"input" db:"input"` // TODO: review this field.. we may not want it.. what goes in here..? is it just // the input/target from MetaTxn above? we already have these as separate columns.. TxnArgs map[string]interface{} `json:"txnArgs" db:"txn_args"` TxnReceipt map[string]interface{} `json:"txnReceipt" db:"txn_receipt,omitempty"` WalletAddress prototyp.Hash `json:"walletAddress" db:"wallet_address"` MetaTxnNonce prototyp.BigInt `json:"metaTxnNonce" db:"metatx_nonce"` GasLimit uint64 `json:"gasLimit" db:"gas_limit"` GasPrice prototyp.BigInt `json:"gasPrice" db:"gas_price"` GasUsed uint64 `json:"gasUsed" db:"gas_used"` GasEstimated uint64 `json:"gasEstimated" db:"gas_estimated"` GasFeeMarkup *uint64 `json:"gasFeeMarkup" db:"gas_fee_markup"` UsdRate prototyp.BigInt `json:"usdRate" db:"usd_rate"` CreditsUsed uint64 `json:"creditsUsed" db:"credits_used"` IsWhitelisted bool `json:"isWhitelisted" db:"is_whitelisted,omitempty"` GasSponsor *uint64 `json:"gasSponsor" db:"gas_sponsor_id,omitempty"` GasTank *uint64 `json:"gasTank" db:"gas_tank_id,omitempty"` UpdatedAt *time.Time `json:"updatedAt" db:"updated_at,omitempty"` CreatedAt *time.Time `json:"createdAt" db:"created_at,omitempty"` }
TODO: review
type MetaTxnReceipt ¶
type MetaTxnReceipt struct { ID string `json:"id"` Status string `json:"status"` RevertReason *string `json:"revertReason"` Index uint `json:"index"` Logs []*MetaTxnReceiptLog `json:"logs"` Receipts []*MetaTxnReceipt `json:"receipts"` TxnReceipt string `json:"txnReceipt"` }
type MetaTxnReceiptLog ¶ added in v0.4.12
type NumTxnsRelayed ¶ added in v0.29.1
type Page ¶ added in v0.4.12
type Page struct { // Common for both numbered pages and cursor: Number of items per page PageSize *uint32 `json:"pageSize"` // Numbered pages: Page number, this is multiplied by the value of the <pageSize> parameter. Page *uint32 `json:"page"` More *bool `json:"more"` // Number of total items on this query. TotalRecords *uint64 `json:"totalRecords"` // Cursor: column to compare before/after to Column *string `json:"column"` // Cursor: return column < before - include to get previous page Before *interface{} `json:"before"` // Cursor: return column > after - include to get next page After *interface{} `json:"after"` // Sorting filter Sort []*SortBy `json:"sort"` }
Page represents a results page. This can be used both to request a page and to store the state of a page.
type Relayer ¶
type Relayer interface { Ping(ctx context.Context) (bool, error) Version(ctx context.Context) (*Version, error) RuntimeStatus(ctx context.Context) (*RuntimeStatus, error) GetSequenceContext(ctx context.Context) (*SequenceContext, error) // TODO: return a string instead GetChainID(ctx context.Context) (uint64, error) // // Transactions // // TODO (future): rename this to just, 'SendTransaction(txn: MetaTransaction)' or 'SendTransaction(txn: SignedTransaction)', or something.. // TODO: rename return txnHash: string to metaTxnID: string SendMetaTxn(ctx context.Context, call *MetaTxn, quote *string) (bool, string, error) GetMetaTxnNonce(ctx context.Context, walletContractAddress string, space *string) (string, error) // TODO: one day, make GetMetaTxnReceipt respond immediately with receipt or not // and add WaitTransactionReceipt method, which will block and wait, similar to how GetMetaTxnReceipt // is implemented now. // For backwards compat, we can leave the current GetMetaTxnReceipt how it is, an deprecate it, and introduce // new, GetTransactionReceipt and WaitTransactionReceipt methods // we can also accept metaTxnId and txnHash .. so can take either or.. I wonder if ERC-4337 has any convention on this? GetMetaTxnReceipt(ctx context.Context, metaTxID string) (*MetaTxnReceipt, error) Simulate(ctx context.Context, wallet string, transactions string) ([]*SimulateResult, error) // TODO: deprecated, to be removed by https://github.com/0xsequence/stack/pull/356 at a later date UpdateMetaTxnGasLimits(ctx context.Context, walletAddress string, walletConfig interface{}, payload string) (string, error) FeeTokens(ctx context.Context) (bool, []*FeeToken, error) FeeOptions(ctx context.Context, wallet string, to string, data string, simulate *bool) ([]*FeeOption, bool, *string, error) // TODO: deprecated, to be removed by https://github.com/0xsequence/stack/pull/356 at a later date GetMetaTxnNetworkFeeOptions(ctx context.Context, walletConfig interface{}, payload string) ([]*FeeOption, error) GetMetaTransactions(ctx context.Context, projectId uint64, gasTankId uint64, page *Page) (*Page, []*MetaTxnLog, error) // Sent transactions from an account. If filter is omitted then it will return all transactions. SentTransactions(ctx context.Context, filter *SentTransactionsFilter, page *Page) (*Page, []*Transaction, error) // Pending transactions waiting to be mined for an account. This endpoint is just a sugar of `SentTransactions` // with the filter set to pending: true. PendingTransactions(ctx context.Context, page *Page) (*Page, []*Transaction, error) GetGasTank(ctx context.Context, id uint64) (*GasTank, error) AddGasTank(ctx context.Context, name string, feeMarkupFactor float64, unlimited *bool) (bool, *GasTank, error) UpdateGasTank(ctx context.Context, id uint64, name *string, feeMarkupFactor *float64, unlimited *bool) (bool, *GasTank, error) GetGasSponsor(ctx context.Context, id uint64) (*GasSponsor, error) AddressGasSponsors(ctx context.Context, address string, page *Page) (*Page, []*GasSponsor, error) ListGasSponsors(ctx context.Context, projectId uint64, gasTankId uint64, page *Page) (*Page, []*GasSponsor, error) AddGasSponsor(ctx context.Context, projectId uint64, gasTankId uint64, address string, name *string, active *bool) (bool, *GasSponsor, error) UpdateGasSponsor(ctx context.Context, id uint64, name *string, active *bool) (bool, *GasSponsor, error) RemoveGasSponsor(ctx context.Context, id uint64) (bool, error) ReportGasSponsorUsage(ctx context.Context, projectId uint64, gasTankId uint64, startTime *time.Time, endTime *time.Time) ([]*GasSponsorUsage, error) NextGasTankBalanceAdjustmentNonce(ctx context.Context, id uint64) (uint64, error) AdjustGasTankBalance(ctx context.Context, id uint64, nonce uint64, amount float64) (bool, *GasTankBalanceAdjustment, error) GetGasTankBalanceAdjustment(ctx context.Context, id uint64, nonce uint64) (*GasTankBalanceAdjustment, error) ListGasTankBalanceAdjustments(ctx context.Context, id uint64, page *Page) (*Page, []*GasTankBalanceAdjustment, error) }
type RelayerClient ¶ added in v0.31.0
type RelayerClient interface { Ping(ctx context.Context) (bool, error) Version(ctx context.Context) (*Version, error) RuntimeStatus(ctx context.Context) (*RuntimeStatus, error) GetSequenceContext(ctx context.Context) (*SequenceContext, error) // TODO: return a string instead GetChainID(ctx context.Context) (uint64, error) // // Transactions // // TODO (future): rename this to just, 'SendTransaction(txn: MetaTransaction)' or 'SendTransaction(txn: SignedTransaction)', or something.. // TODO: rename return txnHash: string to metaTxnID: string SendMetaTxn(ctx context.Context, call *MetaTxn, quote *string) (bool, string, error) GetMetaTxnNonce(ctx context.Context, walletContractAddress string, space *string) (string, error) // TODO: one day, make GetMetaTxnReceipt respond immediately with receipt or not // and add WaitTransactionReceipt method, which will block and wait, similar to how GetMetaTxnReceipt // is implemented now. // For backwards compat, we can leave the current GetMetaTxnReceipt how it is, an deprecate it, and introduce // new, GetTransactionReceipt and WaitTransactionReceipt methods // we can also accept metaTxnId and txnHash .. so can take either or.. I wonder if ERC-4337 has any convention on this? GetMetaTxnReceipt(ctx context.Context, metaTxID string) (*MetaTxnReceipt, error) Simulate(ctx context.Context, wallet string, transactions string) ([]*SimulateResult, error) // TODO: deprecated, to be removed by https://github.com/0xsequence/stack/pull/356 at a later date UpdateMetaTxnGasLimits(ctx context.Context, walletAddress string, walletConfig interface{}, payload string) (string, error) FeeTokens(ctx context.Context) (bool, []*FeeToken, error) FeeOptions(ctx context.Context, wallet string, to string, data string, simulate *bool) ([]*FeeOption, bool, *string, error) // TODO: deprecated, to be removed by https://github.com/0xsequence/stack/pull/356 at a later date GetMetaTxnNetworkFeeOptions(ctx context.Context, walletConfig interface{}, payload string) ([]*FeeOption, error) GetMetaTransactions(ctx context.Context, projectId uint64, gasTankId uint64, page *Page) (*Page, []*MetaTxnLog, error) // Sent transactions from an account. If filter is omitted then it will return all transactions. SentTransactions(ctx context.Context, filter *SentTransactionsFilter, page *Page) (*Page, []*Transaction, error) // Pending transactions waiting to be mined for an account. This endpoint is just a sugar of `SentTransactions` // with the filter set to pending: true. PendingTransactions(ctx context.Context, page *Page) (*Page, []*Transaction, error) GetGasTank(ctx context.Context, id uint64) (*GasTank, error) AddGasTank(ctx context.Context, name string, feeMarkupFactor float64, unlimited *bool) (bool, *GasTank, error) UpdateGasTank(ctx context.Context, id uint64, name *string, feeMarkupFactor *float64, unlimited *bool) (bool, *GasTank, error) GetGasSponsor(ctx context.Context, id uint64) (*GasSponsor, error) AddressGasSponsors(ctx context.Context, address string, page *Page) (*Page, []*GasSponsor, error) ListGasSponsors(ctx context.Context, projectId uint64, gasTankId uint64, page *Page) (*Page, []*GasSponsor, error) AddGasSponsor(ctx context.Context, projectId uint64, gasTankId uint64, address string, name *string, active *bool) (bool, *GasSponsor, error) UpdateGasSponsor(ctx context.Context, id uint64, name *string, active *bool) (bool, *GasSponsor, error) RemoveGasSponsor(ctx context.Context, id uint64) (bool, error) ReportGasSponsorUsage(ctx context.Context, projectId uint64, gasTankId uint64, startTime *time.Time, endTime *time.Time) ([]*GasSponsorUsage, error) NextGasTankBalanceAdjustmentNonce(ctx context.Context, id uint64) (uint64, error) AdjustGasTankBalance(ctx context.Context, id uint64, nonce uint64, amount float64) (bool, *GasTankBalanceAdjustment, error) GetGasTankBalanceAdjustment(ctx context.Context, id uint64, nonce uint64) (*GasTankBalanceAdjustment, error) ListGasTankBalanceAdjustments(ctx context.Context, id uint64, page *Page) (*Page, []*GasTankBalanceAdjustment, error) }
func NewRelayerClient ¶
func NewRelayerClient(addr string, client HTTPClient) RelayerClient
type RuntimeChecks ¶ added in v0.5.6
type RuntimeChecks struct { }
type RuntimeStatus ¶
type RuntimeStatus struct { // overall status, true/false HealthOK bool `json:"healthOK"` StartTime time.Time `json:"startTime"` Uptime uint64 `json:"uptime"` Ver string `json:"ver"` Branch string `json:"branch"` CommitHash string `json:"commitHash"` UseEIP1559 bool `json:"useEIP1559"` Senders []*SenderStatus `json:"senders"` Checks *RuntimeChecks `json:"checks"` NumTxnsRelayed *NumTxnsRelayed `json:"numTxnsRelayed"` }
type SenderStatus ¶ added in v0.5.6
type SentTransactionsFilter ¶ added in v0.4.12
type SequenceContext ¶
type SimulateResult ¶ added in v0.13.0
type SortOrder ¶ added in v0.4.12
type SortOrder uint32
func (SortOrder) MarshalText ¶ added in v0.31.0
func (*SortOrder) UnmarshalText ¶ added in v0.31.0
type Transaction ¶ added in v0.4.12
type Transaction struct { TxnHash *string `json:"txnHash"` BlockNumber uint64 `json:"blockNumber"` ChainId uint64 `json:"chainId"` MetaTxnID *string `json:"metaTxnID"` Transfers []*TxnLogTransfer `json:"transfers"` // TODO: review .. Users map[string]*TxnLogUser `json:"users"` // - contracts?: map<string, Contract> TODO: review.. this gives us contract metadata which is useful // - tokenMetadata?: map<string,map<string,TokenMetadata>> Timestamp *time.Time `json:"timestamp" db:"ts,omitempty"` }
TODO: review and update this type ..
type TransferType ¶ added in v0.4.12
type TransferType uint32
const ( TransferType_SEND TransferType = 0 TransferType_RECEIVE TransferType = 1 TransferType_BRIDGE_DEPOSIT TransferType = 2 TransferType_BRIDGE_WITHDRAW TransferType = 3 TransferType_BURN TransferType = 4 TransferType_UNKNOWN TransferType = 5 )
func (*TransferType) Is ¶ added in v0.31.0
func (x *TransferType) Is(values ...TransferType) bool
func (TransferType) MarshalText ¶ added in v0.31.0
func (x TransferType) MarshalText() ([]byte, error)
func (TransferType) String ¶ added in v0.4.12
func (x TransferType) String() string
func (*TransferType) UnmarshalText ¶ added in v0.31.0
func (x *TransferType) UnmarshalText(b []byte) error
type TxnLogTransfer ¶ added in v0.4.12
type TxnLogUser ¶ added in v0.4.12
type TxnLogUser struct {
Username string `json:"username"`
}
TODO: remove this.. we're not going to include username here anymore, the client will have to do it.
type WebRPCError ¶ added in v0.31.0
type WebRPCError struct { Name string `json:"error"` Code int `json:"code"` Message string `json:"msg"` Cause string `json:"cause,omitempty"` HTTPStatus int `json:"status"` // contains filtered or unexported fields }
func ErrorWithCause
deprecated
added in
v0.31.0
func ErrorWithCause(rpcErr WebRPCError, cause error) WebRPCError
Deprecated: Use .WithCause() method on WebRPCError.
func (WebRPCError) Error ¶ added in v0.31.0
func (e WebRPCError) Error() string
func (WebRPCError) Is ¶ added in v0.31.0
func (e WebRPCError) Is(target error) bool
func (WebRPCError) Unwrap ¶ added in v0.31.0
func (e WebRPCError) Unwrap() error
func (WebRPCError) WithCause ¶ added in v0.31.0
func (e WebRPCError) WithCause(cause error) WebRPCError
func (WebRPCError) WithCausef ¶ added in v0.31.0
func (e WebRPCError) WithCausef(format string, args ...interface{}) WebRPCError