Documentation
¶
Index ¶
Constants ¶
View Source
const (
// TokensConfigPlugin is the connector plugin used for this token type (deprecated)
TokensConfigPlugin = "plugin"
)
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Callbacks ¶
type Callbacks interface {
// TokenPoolCreated notifies on the creation of a new token pool, which might have been
// submitted by us, or by any other authorized party in the network.
//
// Error should only be returned in shutdown scenarios
TokenPoolCreated(plugin Plugin, pool *TokenPool) error
// TokensTransferred notifies on a transfer between token accounts.
//
// Error should only be returned in shutdown scenarios
TokensTransferred(plugin Plugin, transfer *TokenTransfer) error
// TokensApproved notifies on a token approval
//
// Error should will only be returned in shutdown scenarios
TokensApproved(plugin Plugin, approval *TokenApproval) error
}
Callbacks is the interface provided to the tokens plugin, to allow it to pass events back to firefly.
Events must be delivered sequentially, such that event 2 is not delivered until the callback invoked for event 1 has completed. However, it does not matter if these events are workload balance between the firefly core cluster instances of the node.
type Capabilities ¶
type Capabilities struct {
}
Capabilities is the supported featureset of the tokens interface implemented by the plugin, with the specified config
type Plugin ¶
type Plugin interface {
core.Named
// InitConfig initializes the set of configuration options that are valid, with defaults. Called on all plugins.
InitConfig(config config.KeySet)
// Init initializes the plugin, with configuration
Init(ctx context.Context, name string, config config.Section) error
// SetHandler registers a handler to receive callbacks
// Plugin will attempt (but is not guaranteed) to deliver events only for the given namespace
SetHandler(namespace string, handler Callbacks)
// SetOperationHandler registers a handler to receive async operation status
// If namespace is set, plugin will attempt to deliver only events for that namespace
SetOperationHandler(namespace string, handler core.OperationCallbacks)
// Blockchain interface must not deliver any events until start is called
Start() error
// Capabilities returns capabilities - not called until after Init
Capabilities() *Capabilities
// CreateTokenPool creates a new (fungible or non-fungible) pool of tokens
CreateTokenPool(ctx context.Context, nsOpID string, pool *core.TokenPool) (complete bool, err error)
// ActivateTokenPool activates a pool in order to begin receiving events
ActivateTokenPool(ctx context.Context, nsOpID string, pool *core.TokenPool) (complete bool, err error)
// MintTokens mints new tokens in a pool and adds them to the recipient's account
MintTokens(ctx context.Context, nsOpID string, poolLocator string, mint *core.TokenTransfer) error
// BurnTokens burns tokens from an account
BurnTokens(ctx context.Context, nsOpID string, poolLocator string, burn *core.TokenTransfer) error
// TransferTokens transfers tokens within a pool from one account to another
TransferTokens(ctx context.Context, nsOpID string, poolLocator string, transfer *core.TokenTransfer) error
// TokenApproval approves an operator to transfer tokens on the owner's behalf
TokensApproval(ctx context.Context, nsOpID string, poolLocator string, approval *core.TokenApproval) error
}
Plugin is the interface implemented by each tokens plugin
type TokenApproval ¶ added in v0.13.1
type TokenApproval struct {
core.TokenApproval
// PoolLocator is the ID assigned to the token pool by the connector
PoolLocator string
// Event contains info on the underlying blockchain event for this transfer
Event *blockchain.Event
}
type TokenPool ¶ added in v0.11.0
type TokenPool struct {
// Type is the type of tokens (fungible, non-fungible, etc) in this pool
Type core.TokenType
// PoolLocator is the ID assigned to this pool by the connector (must be unique for this connector)
PoolLocator string
// TX is the FireFly-assigned information to correlate this to a transaction (optional)
TX core.TransactionRef
// Connector is the configured name of this connector
Connector string
// Standard is the well-defined token standard that this pool conforms to (optional)
Standard string
// Decimals is the number of decimal places that this token has
Decimals int
// Symbol is the short token symbol, if the connector uses one (optional)
Symbol string
// Info is any other connector-specific info on the pool that may be worth saving (optional)
Info fftypes.JSONObject
// Event contains info on the underlying blockchain event for this pool creation
Event *blockchain.Event
}
TokenPool is the set of data returned from the connector when a token pool is created.
type TokenTransfer ¶ added in v0.12.0
type TokenTransfer struct {
// Although not every field will be filled in, embed core.TokenTransfer to avoid duplicating lots of fields
// Notable fields NOT expected to be populated by plugins: Namespace, LocalID, Pool
core.TokenTransfer
// PoolLocator is the ID assigned to the token pool by the connector
PoolLocator string
// Event contains info on the underlying blockchain event for this transfer
Event *blockchain.Event
}
Click to show internal directories.
Click to hide internal directories.