The Event
functionality is used to make users or developers subscribe interested events. These events are generated during the execution of the blockchain, and they record the key execution steps and execution results of the chain. To query and verify the execution results of transactions and smart contracts, we record these two types of events into a trie and save them to the chain.
Event structure:
type Event struct {
Topic string // event topic, subscribe keyword
Data string // event content, a json string
}
After a event is generated, it will be collected for processing in eventEmitter. Users can use the emitter subscription event. If the event is not subscribed, it will be discarded, and for the event that has been subscribed, the new event will be discarded because of the non-blocking mechanism, if the channel is not blocked in time.
- TopicNewTailBlock
- TopicRevertBlock
- TopicLibBlock
- TopicPendingTransaction
- TopicTransactionExecutionResult
- EventNameSpaceContract
This event occurs when the tail block of the chain is updated.
- Topic:
chain.newTailBlock
- Data:
height
: block heighthash
: block hashparent_hash
: block parent hashacc_root
: account state root hashtimestamp
: block timestamptx
: transaction state root hashminer
: block miner
This event occurs when a block is revert on the chain.
- Topic:
chain.revertBlock
- Data: The content of this topic is like TopicNewTailBlock data.
This event occurs when the latest irreversible block change.
- Topic:
chain.latestIrreversibleBlock
- Data: The content of this topic is like TopicNewTailBlock data.
This event occurs when a transaction is pushed into the transaction pool.
- Topic:
chain.pendingTransaction
- Data:
chainID
: transaction chain idhash
: transaction hashfrom
: transaction from address stringto
: transaction to address stringnonce
: transaction noncevalue
: transaction valuetimestamp
: transaction timestampgasprice
: transaction gas pricegaslimit
: transaction gas limittype
: trsnaction type
This event occurs when the end of a transaction is executed. This event will be recorded on the chain, and users can query with RPC interface GetEventsByHash.
This event records the execution results of the transaction and is very important.
- Topic:
chain.transactionResult
- Data:
hash
: transaction hashstatus
: transaction status, 0 failed, 1success, 2 pendinggasUsed
: transaction gas usederror
: transaction execution error. If the transaction is executed successfully, the field is empty.
This event occurs when the contract is executed. When the contract is executed, the contract can record several events in the execution process. If the contract is successful, these events will be recorded on the chain and can be subscribed, and the event of the contract will not be recorded at the time of the failure. This event will also be recorded on the chain, and users can query with RPC interface GetEventsByHash.
- Topic:
chain.contract.[topic]
The topic of the contract event has a prefixchain.contract.
, the content is defined by the contract writer. - Data: The content of contract event is defined by contract writer.
All events can be subscribed and the cloud chain provides a subscription RPC interface Subscribe. It should be noted that the event subscription is a non-blocking mechanism. New events will be discarded when the RPC interface is not handled in time.
Only events recorded on the chain can be queried using the RPC interface GetEventsByHash. Current events that can be queried include: