providers

package
v0.1.3 Latest Latest
Warning

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

Go to latest
Published: Feb 21, 2024 License: AGPL-3.0 Imports: 9 Imported by: 1

Documentation

Index

Constants

View Source
const (
	// CONTRACT TYPES
	CONTRACT_TYPE_UNKNOWN uint64 = iota
	CONTRACT_TYPE_ERC20
	CONTRACT_TYPE_ERC721
	CONTRACT_TYPE_ERC777
	CONTRACT_TYPE_POAP
	CONTRACT_TYPE_GITCOIN
	CONTRACT_TYPE_FARCASTER
	// CONTRACT NAMES
	CONTRACT_NAME_UNKNOWN   = "unknown"
	CONTRACT_NAME_ERC20     = "erc20"
	CONTRACT_NAME_ERC721    = "erc721"
	CONTRACT_NAME_ERC777    = "erc777"
	CONTRACT_NAME_POAP      = "poap"
	CONTRACT_NAME_GITCOIN   = "gitcoinpassport"
	CONTRACT_NAME_FARCASTER = "farcaster"
)

Variables

This section is empty.

Functions

func CalcPartialHolders

func CalcPartialHolders(currentHolders, newHolders map[common.Address]*big.Int) map[common.Address]*big.Int

CalcPartialHolders calculates the partial holders from the current and new holders maps. It returns a map with the partial holders and their balances. The final holders are calculated as:

  1. Holders that are in the new holders map but not in the current holders map. They are created with the balance of the new holders.
  2. Holders that are in the new and the current holders maps and have a different balance. They are updated with difference between the new and the current balances.
  3. Holders that are in the current holders map but not in the new holders map. They are updated with the balance of the current holders negated.

func ClientSupportsGetCode

func ClientSupportsGetCode(ctx context.Context, cli *ethclient.Client, controlAddr common.Address) bool

ClientSupportsGetCode checks if the given client supports the `eth_getCode` method. It returns true if it is supported and false otherwise.

func ServeTestStaticFiles

func ServeTestStaticFiles(ctx context.Context, port int, files map[string]string) map[string]string

ServeTestStaticFiles serves the given files in the given port and returns a map with the URIs of the served files. The server is shutdown when the given context is done. It is useful for testing external providers to emulate external API services.

func TokenTypeID

func TokenTypeID(name string) uint64

TokenTypeID returns the id of the token type for the given name. If the name is not found, it returns CONTRACT_TYPE_UNKNOWN.

func TokenTypeName

func TokenTypeName(id uint64) string

TokenTypeName returns the name of the token type for the given id. If the id is not found, it returns CONTRACT_NAME_UNKNOWN.

Types

type HolderProvider

type HolderProvider interface {
	// Init initializes the provider and its internal structures. Initial
	// attributes values must be defined in the struct that implements this
	// interface before calling this method.
	Init(conf any) error
	// SetRef sets the reference to the provider. It is used to define the
	// required token information to interact with the provider.
	SetRef(ref any) error
	// SetLastBalances sets the balances of the token holders for the given
	// id and from point in time and store it in a snapshot. It is used to
	// calculate the delta balances in the next call to HoldersBalances from
	// the given from point in time.
	SetLastBalances(ctx context.Context, id []byte, balances map[common.Address]*big.Int, from uint64) error
	// SetLastBlockNumber sets the last block number of the token set in the
	// provider. It is used to calculate the delta balances in the next call
	// to HoldersBalances from the given from point in time. It helps to avoid
	// GetBlockNumber calls to the provider.
	SetLastBlockNumber(blockNumber uint64)
	// HoldersBalances returns the balances of the token holders for the given
	// id and delta point in time, from the stored last snapshot. It also
	// returns the total supply of tokens as a *big.Int.
	HoldersBalances(ctx context.Context, id []byte, to uint64) (map[common.Address]*big.Int, uint64, uint64, bool, *big.Int, error)
	// Close closes the provider and its internal structures.
	Close() error
	// IsExternal returns true if the provider is an external API.
	IsExternal() bool
	// IsSynced returns true if the current state of the provider is synced. It
	// also receives an external ID to be used if it is required by the provider.
	IsSynced(id []byte) bool
	// Address returns the address of the current token set in the provider. It
	// also receives an external ID to be used if it is required by the
	// provider.
	Address(id []byte) common.Address
	// Type returns the type of the current token set in the provider
	Type() uint64
	// TypeName returns the type name of the current token set in the provider
	TypeName() string
	// ChainID returns the chain ID of the current token set in the provider
	ChainID() uint64
	// Name returns the name of the current token set in the provider. It also
	// receives an external ID to be used if it is required by the provider.
	Name(id []byte) (string, error)
	// Symbol returns the symbol of the current token set in the provider. It
	// also receives an external ID to be used if it is required by the provider.
	Symbol(id []byte) (string, error)
	// Decimals returns the decimals of the current token set in the provider.
	// It also receives an external ID to be used if it is required by the
	// provider.
	Decimals(id []byte) (uint64, error)
	// TotalSupply returns the total supply of the current token set in the
	// provider. It also receives an external ID to be used if it is required
	// by the provider.
	TotalSupply(id []byte) (*big.Int, error)
	// BalanceOf returns the balance of the given address for the current token
	// set in the provider. It also receives an external ID to be used if it is
	// required by the provider.
	BalanceOf(addr common.Address, id []byte) (*big.Int, error)
	// BalanceAt returns the balance of the given address for the current token
	// at the given block number for the current token set in the provider. It
	// also receives an external ID to be used if it is required by the provider.
	BalanceAt(ctx context.Context, addr common.Address, id []byte, blockNumber uint64) (*big.Int, error)
	// BlockTimestamp returns the timestamp of the given block number for the
	// current token set in the provider
	BlockTimestamp(ctx context.Context, blockNumber uint64) (string, error)
	// BlockRootHash returns the root hash of the given block number for the
	// current token set in the provider
	BlockRootHash(ctx context.Context, blockNumber uint64) ([]byte, error)
	// LatestBlockNumber returns the latest block number for the network of the
	// current token set in the provider
	LatestBlockNumber(ctx context.Context, id []byte) (uint64, error)
	// CreationBlock returns the creation block number for the contract of the
	// current token set in the provider
	CreationBlock(ctx context.Context, id []byte) (uint64, error)
	// IconURI returns the icon URI of the icon asset of the current token set
	// in the provider.
	IconURI(id []byte) (string, error)
	// CensusKeys method returns the holders and balances provided transformed.
	// The transformation strategy is defined by the provider. The returned
	// map will be used to build the census.
	CensusKeys(holders map[common.Address]*big.Int) (map[common.Address]*big.Int, error)
}

HolderProvider is the interface that wraps the basic methods to interact with a holders provider. It is used by the HoldersScanner to get the balances of the token holders. It allows to implement different providers, such as external API's, Web3 RPC endpoints, etc.

Directories

Path Synopsis
db

Jump to

Keyboard shortcuts

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