Runtime APIs
The Extism runtime is implemented as a Rust crate, from which we generate C headers so that any language with a C-compatible FFI can bind functions to the runtime itself and embed Extism. This is how the official SDKs are created.
If you would like to embed Extism into a language that we currently do not support, you should take a look at the header file linked above.
The general set of functions that is necessary to satisfy the runtime requirements is:
extism_context_new
Create a new context.
struct ExtismContext *extism_context_new(void);
extism_context_free
Free a context.
void extism_context_free(struct ExtismContext *ctx);
extism_plugin_new
Create a new plugin.
wasm
: is a WASM module (wat or wasm) or a JSON encoded manifestwasm_size
: the length of thewasm
parameterwith_wasi
: enables/disables WASI
ExtismPlugin extism_plugin_new(struct ExtismContext *ctx,
const uint8_t *wasm,
ExtismSize wasm_size,
bool with_wasi);
extism_plugin_update
Update a plugin, keeping the existing ID.
Similar to extism_plugin_new
but takes an index
argument to specify which plugin to update.
Memory for this plugin will be reset upon update.
bool extism_plugin_update(struct ExtismContext *ctx,
ExtismPlugin index,
const uint8_t *wasm,
ExtismSize wasm_size,
bool with_wasi);
extism_plugin_free
Remove a plugin from the registry and free associated memory.
void extism_plugin_free(struct ExtismContext *ctx, ExtismPlugin plugin);
extism_context_reset
Remove all plugins from the registry.
void extism_context_reset(struct ExtismContext *ctx);
extism_plugin_config
Update plugin config values, this will merge with the existing values.
bool extism_plugin_config(struct ExtismContext *ctx,
ExtismPlugin plugin,
const uint8_t *json,
ExtismSize json_size);
extism_plugin_function_exists
Returns true if func_name
exists.
bool extism_plugin_function_exists(struct ExtismContext *ctx,
ExtismPlugin plugin,
const char *func_name);
extism_plugin_call
Call a function.
func_name
: is the function to calldata
: is the input datadata_len
: is the length ofdata
int32_t extism_plugin_call(struct ExtismContext *ctx,
ExtismPlugin plugin_id,
const char *func_name,
const uint8_t *data,
ExtismSize data_len);
extism_error
Get the error associated with a Context
or Plugin
, if plugin
is -1
then the context error will be returned.
const char *extism_error(struct ExtismContext *ctx, ExtismPlugin plugin);
extism_plugin_output_length
Get the length of a plugin's output data.
ExtismSize extism_plugin_output_length(struct ExtismContext *ctx, ExtismPlugin plugin);
extism_plugin_output_data
Get the plugin's output data.
const uint8_t *extism_plugin_output_data(struct ExtismContext *ctx, ExtismPlugin plugin);
extism_log_file
Set log file and level.
bool extism_log_file(const char *filename, const char *log_level);
extism_version
Get the Extism version string.
const char *extism_version(void);
Type definitions:
ExtismContext
A Context
is used to store and manage plugins
typedef struct ExtismContext ExtismContext;
ExtismPlugin
typedef int32_t ExtismPlugin;
ExtimsSize
typedef uint64_t ExtismSize;