08-wasm
module in a chain binary and about the recommended approaches depending on whether the x/wasm
module is already used in the chain. The following document only applies for Cosmos SDK chains.
Importing the 08-wasm
module
08-wasm
has no stable releases yet. To use it, you need to import the git commit that contains the module with the compatible versions of ibc-go
and wasmvm
. To do so, run the following command with the desired git commit in your project:
app.go
setup
The sample code below shows the relevant integration points in app.go
required to setup the 08-wasm
module in a chain binary. Since 08-wasm
is a light client module itself, please check out as well the section Integrating light clients for more information:
Keeper instantiation
When it comes to instantiating08-wasm
’s keeper there are two recommended ways of doing it. Choosing one or the other will depend on whether the chain already integrates x/wasm
or not.
If x/wasm
is present
If the chain where the module is integrated uses x/wasm
then we recommend that both 08-wasm
and x/wasm
share the same Wasm VM instance. Having two separate Wasm VM instances is still possible, but care should be taken to make sure that both instances do not share the directory when the VM stores blobs and various caches, otherwise unexpected behaviour is likely to happen.
In order to share the Wasm VM instance please follow the guideline below. Please note that this requires x/wasm
v0.41 or above.
- Instantiate the Wasm VM in
app.go
with the parameters of your choice. - Create an
Option
with this Wasm VM instance. - Add the option created in the previous step to a slice and pass it to the
x/wasm NewKeeper
constructor function. - Pass the pointer to the Wasm VM instance to
08-wasm
NewKeeperWithVM
constructor function.
If x/wasm
is not present
If the chain does not use x/wasm
, even though it is still possible to use the method above from the previous section
(e.g. instantiating a Wasm VM in app.go an pass it to 08-wasm’s NewKeeperWithVM
constructor function, since there would be no need in this case to share the Wasm VM instance with another module, you can use the NewKeeperWithConfig
constructor function and provide the Wasm VM configuration parameters of your choice instead. A Wasm VM instance will be created in NewKeeperWithConfig
. The parameters that can set are:
DataDir
is the directory for Wasm blobs and various caches. Inwasmd
this is set to thewasm
folder under the home directory.SupportedCapabilities
is a comma separated list of capabilities supported by the chain.wasmd
sets this to all the available capabilities, but 08-wasm only requiresiterator
.MemoryCacheSize
sets the size in MiB of an in-memory cache for e.g. module caching. It is not consensus-critical and should be defined on a per-node basis, often in the range 100 to 1000 MB.wasmd
reads this value of. Default value is 256.ContractDebugMode
is a flag to enable/disable printing debug logs from the contract to STDOUT. This should be false in production environments. Default value is false.
wasmd
. This parameter is not configurable by users of 08-wasm
.
The following sample code shows how the keeper would be constructed using this method:
WasmConfig
type definition for more information on each of the configurable parameters. Some parameters allow node-level configurations. There is additionally the function DefaultWasmConfig
available that returns a configuration with the default values.
Options
The08-wasm
module comes with an options API inspired by the one in x/wasm
.
Currently the only option available is the WithQueryPlugins
option, which allows registration of custom query plugins for the 08-wasm
module. The use of this API is optional and it is only required if the chain wants to register custom query plugins for the 08-wasm
module.
WithQueryPlugins
By default, the 08-wasm
module does not support any queries. However, it is possible to register custom query plugins for QueryRequest::Custom
and QueryRequest::Stargate
.
Assuming that the keeper is not yet instantiated, the following sample code shows how to register query plugins for the 08-wasm
module.
We first construct a QueryPlugins
object with the desired query plugins:
QueryPlugins
object as nil
if you do not want to register a query plugin for that query type.
Then, we pass the QueryPlugins
object to the WithQueryPlugins
option:
NewKeeperWithConfig
or NewKeeperWithVM
constructor function during Keeper instantiation:
Updating AllowedClients
In order to use the 08-wasm
module chains must update the AllowedClients
parameter in the 02-client submodule of core IBC. This can be configured directly in the application upgrade handler with the sample code below:
Creating clients
for an example of how to do this).
Adding the module to the store
As part of the upgrade migration you must also add the module to the upgrades store.Adding snapshot support
In order to use the08-wasm
module chains are required to register the WasmSnapshotter
extension in the snapshot manager. This snapshotter takes care of persisting the external state, in the form of contract code, of the Wasm VM instance to disk when the chain is snapshotted. This code should be placed in NewSimApp
function in app.go
.
Pin byte codes at start
Wasm byte codes should be pinned to the WasmVM cache on every application start, therefore this code should be placed inNewSimApp
function in app.go
.