Crate cosmwasm_std

source ·

Modules

Macros

  • Asserts that two expressions are approximately equal to each other.
  • Quick check for a guard. If the condition (first argument) is false, then return the second argument x wrapped in Err(x).
  • Quick check for a guard. Like assert_eq!, but rather than panic, it returns the third argument x wrapped in Err(x).
  • Quick check for a guard. Like assert_ne!, but rather than panic, it returns the third argument x wrapped in Err(x).
  • Given an implementation of T == U, implements:

Structs

  • A human readable address.
  • DelegationsResponse is data format returned from StakingRequest::AllDelegations query
  • The data format returned from StakingRequest::AllValidators query
  • An key value pair that is used in the context of event attributes in logs
  • Binary is a wrapper around Vec to add base64 de/serialization with serde. It also adds some helper methods to help encode inline.
  • BondedDenomResponse is data format returned from StakingRequest::BondedDenom query
  • A blockchain address in its binary form.
  • The essential data from wasmd’s CodeInfo/CodeInfoResponse.
  • The error returned by TryFrom conversions that overflow, for example when converting from Uint256 to Uint128.
  • A fixed-point decimal value with 18 fractional digits, i.e. Decimal(1_000_000_000_000_000_000) == 1.0
  • A fixed-point decimal value with 18 fractional digits, i.e. Decimal256(1_000_000_000_000_000_000) == 1.0
  • Delegation is basic (cheap to query) data about a delegation.
  • DelegationResponse is data format returned from StakingRequest::Delegation query
  • An empty struct that serves as a placeholder in different places, such as contracts that don’t set a custom message.
  • FullDelegation is all the info on the delegation, some (like accumulated_reward and can_redelegate) is expensive to query.
  • This is a wrapper around Vec to add hex de/serialization with serde. It also adds some helper methods to help encode inline.
  • This is the return value for the majority of the ibc handlers. That are able to dispatch messages / events on their own, but have no meaningful return value to the calling code.
  • IbcChannel defines all information on a channel. This is generally used in the hand-shake process, but can be queried directly.
  • The message that is passed into ibc_packet_ack
  • The message that is passed into ibc_packet_receive
  • The message that is passed into ibc_packet_timeout
  • In IBC each package must set at least one type of timeout: the timestamp or the block height. Using this rather complex enum instead of two timeout fields we ensure that at least one timeout is set.
  • IBCTimeoutHeight Height is a monotonically increasing data type that can be compared against another Height for the purposes of updating and freezing clients. Ordering is (revision_number, timeout_height)
  • Additional information from MsgInstantiateContract and MsgExecuteContract, which is passed along with the contract execution message into the instantiate and execute entry points.
  • Holds all external dependencies of the contract. Designed to allow easy dependency injection at runtime. This cannot be copied or cloned since it would behave differently for mock storages and a bridge storage in the VM.
  • The result object returned to reply. We always get the ID from the submessage back and then must handle success and error cases ourselves.
  • A response of a contract entry point, such as instantiate, execute or migrate.
  • A submessage that will guarantee a reply call on success or error, depending on the reply_on setting. If you do not need to process the result, use regular messages instead.
  • The information we get back from a successful sub message execution, with full Cosmos SDK events.
  • A point in time in nanosecond precision.
  • A thin wrapper around u64 that is using strings for JSON encoding/decoding, such that the full u64 range can be used for clients that convert JSON numbers to floats, like JavaScript and jq.
  • A thin wrapper around u128 that is using strings for JSON encoding/decoding, such that the full u128 range can be used for clients that convert JSON numbers to floats, like JavaScript and jq.
  • An implementation of u256 that is using strings for JSON encoding/decoding, such that the full u256 range can be used for clients that convert JSON numbers to floats, like JavaScript and jq.
  • An implementation of u512 that is using strings for JSON encoding/decoding, such that the full u512 range can be used for clients that convert JSON numbers to floats, like JavaScript and jq.
  • Instances are created in the querier.
  • The data format returned from StakingRequest::Validator query

Enums

  • The message types of the bank module.
  • This is the final result type that is created and serialized in a contract for every init/execute/migrate call. The VM then deserializes this type to distinguish between successful and failed executions.
  • The message types of the distribution module.
  • This message type allows the contract interact with the x/gov module in order to cast votes.
  • The message that is passed into ibc_channel_close
  • The message that is passed into ibc_channel_connect
  • The message that is passed into ibc_channel_open
  • These are messages in the IBC lifecycle. Only usable by IBC-enabled contracts (contracts that directly speak the IBC protocol via 6 entry points)
  • IbcOrder defines if a channel is ORDERED or UNORDERED Values come from https://github.com/cosmos/cosmos-sdk/blob/v0.40.0/proto/ibc/core/channel/v1/channel.proto#L69-L80 Naming comes from the protobuf files and go translations.
  • These are queries to the various IBC modules to see the state of the contract’s IBC connection. These will return errors if the contract is not “ibc enabled”
  • Never can never be instantiated. This can be used in places where we want to ensure that no error is returned, such as the ibc_packet_receive entry point.
  • Use this to define when the contract gets a response callback. If you only need it for errors or success you can select just those in order to save gas.
  • The message types of the staking module.
  • Structured error type for init, execute and query.
  • This is the result type that is returned from a sub message execution.
  • SystemError is used for errors inside the VM and is API friendly (i.e. serializable).
  • This is the outer result type returned by a querier to the contract.
  • The message types of the wasm module.

Traits

  • Api are callbacks to system functions implemented outside of the wasm modules. Currently it just supports address conversion but we could add eg. crypto functions here.
  • Like CustomQuery for better type clarity. Also makes it shorter to use as a trait bound.
  • A trait that is required to avoid conflicts with other query types like BankQuery and WasmQuery in generic implementations. You need to implement it in your custom query type.
  • A fraction p/q with integers p and q.
  • A trait for calculating the integer square root.
  • Storage provides read and write access to a persistent storage. If you only want to provide read access, provide &Storage

Functions

  • Creates a new Attribute. Attribute::new is an alias for this.
  • A shorthand constructor for Coin
  • A shortcut constructor for a set of one denomination of coins
  • has_coins returns true if the list of coins has at least the required amount
  • Creates a contract address using the predictable address format introduced with wasmd 0.29. When using instantiate2, this is a way to precompute the address. When using instantiate, the contract address will use a different algorithm and cannot be pre-computed as it contains inputs from the chain’s state at the time of message execution.
  • Shortcut helper as the construction of WasmMsg::Instantiate can be quite verbose in contract code
  • Shortcut helper as the construction of WasmMsg::Instantiate can be quite verbose in contract code.

Type Definitions

  • This serializes either as “null” or a JSON object.
  • A short-hand alias for the two-level query result (1. accessing the contract, 2. executing query in the contract)
  • A record of a key-value storage that is created through an iterator API. The first element (key) is always raw binary data. The second element (value) is binary by default but can be changed to a custom type. This allows contracts to reuse the type when deserializing database records.
  • The return type for init, execute and query. Since the error type cannot be serialized to JSON, this is only available within the contract and its unit tests.

Attribute Macros

  • This attribute macro generates the boilerplate required to call into the contract-specific logic from the entry-points to the Wasm module.