10 stable releases (3 major)
new 27.0.0 | Nov 20, 2024 |
---|---|
26.0.1 | Nov 5, 2024 |
26.0.0 | Oct 22, 2024 |
25.0.3 | Nov 5, 2024 |
24.0.2 | Nov 5, 2024 |
#978 in WebAssembly
1,125 downloads per month
Used in 5 crates
(3 directly)
3MB
43K
SLoC
Wasmtime's wasi-keyvalue Implementation
This crate provides a Wasmtime host implementation of the wasi-keyvalue API. With this crate, the runtime can run components that call APIs in wasi-keyvalue and provide components with access to key-value storages.
Currently supported storage backends:
- In-Memory (empty identifier)
Examples
The usage of this crate is very similar to other WASI API implementations such as wasi:cli and wasi:http.
A common scenario is accessing KV store in a wasi:cli component. A standalone example of doing all this looks like:
use wasmtime::{
component::{Linker, ResourceTable},
Config, Engine, Result, Store,
};
use wasmtime_wasi::{WasiCtx, WasiCtxBuilder, WasiView};
use wasmtime_wasi_keyvalue::{WasiKeyValue, WasiKeyValueCtx, WasiKeyValueCtxBuilder};
#[tokio::main]
async fn main() -> Result<()> {
let mut config = Config::new();
config.async_support(true);
let engine = Engine::new(&config)?;
let mut store = Store::new(&engine, Ctx {
table: ResourceTable::new(),
wasi_ctx: WasiCtxBuilder::new().build(),
wasi_keyvalue_ctx: WasiKeyValueCtxBuilder::new().build(),
});
let mut linker = Linker::<Ctx>::new(&engine);
wasmtime_wasi::add_to_linker_async(&mut linker)?;
// add `wasi-keyvalue` world's interfaces to the linker
wasmtime_wasi_keyvalue::add_to_linker(&mut linker, |h: &mut Ctx| {
WasiKeyValue::new(&h.wasi_keyvalue_ctx, &mut h.table)
})?;
// ... use `linker` to instantiate within `store` ...
Ok(())
}
struct Ctx {
table: ResourceTable,
wasi_ctx: WasiCtx,
wasi_keyvalue_ctx: WasiKeyValueCtx,
}
impl WasiView for Ctx {
fn table(&mut self) -> &mut ResourceTable { &mut self.table }
fn ctx(&mut self) -> &mut WasiCtx { &mut self.wasi_ctx }
}
Dependencies
~20–31MB
~604K SLoC