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/wasmv0.41 or above.
- Instantiate the Wasm VM in
app.gowith the parameters of your choice. - Create an
Optionwith this Wasm VM instance. - Add the option created in the previous step to a slice and pass it to the
x/wasm NewKeeperconstructor function. - Pass the pointer to the Wasm VM instance to
08-wasmNewKeeperWithVMconstructor 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:
DataDiris the directory for Wasm blobs and various caches. Inwasmdthis is set to thewasmfolder under the home directory.SupportedCapabilitiesis a comma separated list of capabilities supported by the chain.wasmdsets this to all the available capabilities, but 08-wasm only requiresiterator.MemoryCacheSizesets 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.wasmdreads this value of. Default value is 256.ContractDebugModeis 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.