Skip to main content

Mounted binaries

The mounted binaries section is for using external services inside a Wasm module. Each record of the form cli_tool_name = cli-tool-path within this section allows you to call a CLI tool located in the cli-tool-path directory.

Consider the following example:

toml
[[module]]
name = "curl_adapter"
logger_enabled = true
[module.mounted_binaries]
curl = "/usr/bin/curl"
toml
[[module]]
name = "curl_adapter"
logger_enabled = true
[module.mounted_binaries]
curl = "/usr/bin/curl"

Using this config with adding the following lines in your source code:

rust
#[marine]
#[host_import]
extern "C" {
fn curl(cmd: Vec<String>) -> String;
}
rust
#[marine]
#[host_import]
extern "C" {
fn curl(cmd: Vec<String>) -> String;
}

allows you to pass an argument as a string to the CLI tool and receive its output as a string.

This import function is a host import function, meaning that wasm_import_module must be equal to "host". Note that the signature of such functions must follow the pattern shown above: cli_tool_name(Vec<String>) -> MountedBinaryResult. This pattern reflects the Rust process API.

Then this function can be used as an ordinary Rust FFI function, but without unsafe block:

rust
#[marine]
pub fn download(url: String) -> String {
let result = curl(vec![url]);
String::from_utf8(result.stdout).unwrap()
}
rust
#[marine]
pub fn download(url: String) -> String {
let result = curl(vec![url]);
String::from_utf8(result.stdout).unwrap()
}