Skip to main content
Version: Next

Environment Information

Transaction Information

To get the addresses of the signers of a transaction, use the address field of each signing AuthAccount that is passed to the transaction's prepare phase.

There is currently no API that allows getting other transaction information. Please let us know if your use-case demands it by request this feature in an issue.

Block Information

To get information about a block, the functions getCurrentBlock and getBlock can be used:


  • _10
    fun getCurrentBlock(): Block

    Returns the current block, i.e. the block which contains the currently executed transaction.


  • _10
    fun getBlock(at: UInt64): Block?

    Returns the block at the given height. If the given block does not exist the function returns nil.

The Block type contains the identifier, height, and timestamp:


_30
access(all) struct Block {
_30
/// The ID of the block.
_30
///
_30
/// It is essentially the hash of the block.
_30
///
_30
access(all) let id: [UInt8; 32]
_30
_30
/// The height of the block.
_30
///
_30
/// If the blockchain is viewed as a tree with the genesis block at the root,
_30
// the height of a node is the number of edges between the node and the genesis block
_30
///
_30
access(all) let height: UInt64
_30
_30
/// The view of the block.
_30
///
_30
/// It is a detail of the consensus algorithm. It is a monotonically increasing integer
_30
/// and counts rounds in the consensus algorithm. It is reset to zero at each spork.
_30
///
_30
access(all) let view: UInt64
_30
_30
/// The timestamp of the block.
_30
///
_30
/// Unix timestamp of when the proposer claims it constructed the block.
_30
///
_30
/// NOTE: It is included by the proposer, there are no guarantees on how much the time stamp can deviate from the true time the block was published.
_30
/// Consider observing blocks’ status changes off-chain yourself to get a more reliable value.
_30
///
_30
access(all) let timestamp: UFix64
_30
}