Documentation ¶
Index ¶
- Constants
- type CurrentPlugin
- func (p *CurrentPlugin) Alloc(n uint64) (uint64, error)
- func (p *CurrentPlugin) Free(offset uint64) error
- func (p *CurrentPlugin) Length(offs uint64) (uint64, error)
- func (p *CurrentPlugin) Log(level LogLevel, message string)
- func (p *CurrentPlugin) Logf(level LogLevel, format string, args ...any)
- func (p *CurrentPlugin) Memory() api.Memory
- func (p *CurrentPlugin) ReadBytes(offset uint64) ([]byte, error)
- func (p *CurrentPlugin) ReadString(offset uint64) (string, error)
- func (p *CurrentPlugin) WriteBytes(b []byte) (uint64, error)
- func (p *CurrentPlugin) WriteString(s string) (uint64, error)
- type HostFunction
- type HostFunctionStackCallback
- type HttpRequest
- type LogLevel
- type Manifest
- type Plugin
- func (plugin *Plugin) Call(name string, data []byte) (uint32, []byte, error)
- func (p *Plugin) Close() error
- func (plugin *Plugin) FunctionExists(name string) bool
- func (plugin *Plugin) GetError() string
- func (plugin *Plugin) GetOutput() ([]byte, error)
- func (p *Plugin) Log(level LogLevel, message string)
- func (p *Plugin) Logf(level LogLevel, format string, args ...any)
- func (plugin *Plugin) Memory() api.Memory
- func (plugin *Plugin) SetInput(data []byte) (uint64, error)
- func (p *Plugin) SetLogLevel(level LogLevel)
- func (p *Plugin) SetLogger(logger func(LogLevel, string))
- type PluginConfig
- type Runtime
- type ValType
- type Wasm
- type WasmData
- type WasmFile
- type WasmUrl
Constants ¶
const ( None runtimeType = iota Haskell Wasi )
const I32 = api.ValueTypeI32
const I64 = api.ValueTypeI64
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type CurrentPlugin ¶
type CurrentPlugin struct {
// contains filtered or unexported fields
}
func (*CurrentPlugin) Alloc ¶
func (p *CurrentPlugin) Alloc(n uint64) (uint64, error)
Alloc a new memory block of the given length, returning its offset
func (*CurrentPlugin) Free ¶
func (p *CurrentPlugin) Free(offset uint64) error
Free the memory block specified by the given offset
func (*CurrentPlugin) Length ¶
func (p *CurrentPlugin) Length(offs uint64) (uint64, error)
Length returns the number of bytes allocated at the specified offset
func (*CurrentPlugin) Log ¶
func (p *CurrentPlugin) Log(level LogLevel, message string)
func (*CurrentPlugin) Logf ¶
func (p *CurrentPlugin) Logf(level LogLevel, format string, args ...any)
func (*CurrentPlugin) Memory ¶
func (p *CurrentPlugin) Memory() api.Memory
Memory returns the plugin's WebAssembly memory interface.
func (*CurrentPlugin) ReadBytes ¶
func (p *CurrentPlugin) ReadBytes(offset uint64) ([]byte, error)
ReadBytes reads a byte array from memory
func (*CurrentPlugin) ReadString ¶
func (p *CurrentPlugin) ReadString(offset uint64) (string, error)
ReadString reads a string from wasm memory
func (*CurrentPlugin) WriteBytes ¶
func (p *CurrentPlugin) WriteBytes(b []byte) (uint64, error)
WriteBytes writes a string to wasm memory and return the offset
func (*CurrentPlugin) WriteString ¶
func (p *CurrentPlugin) WriteString(s string) (uint64, error)
Write a string to wasm memory and return the offset
type HostFunction ¶
type HostFunction struct { Name string Namespace string Params []api.ValueType Returns []api.ValueType // contains filtered or unexported fields }
HostFunction represents a custom function defined by the host.
func NewHostFunctionWithStack ¶
func NewHostFunctionWithStack( name string, namespace string, callback HostFunctionStackCallback, params []api.ValueType, returnTypes []api.ValueType) HostFunction
NewHostFunctionWithStack creates a new instance of a HostFunction, which is designed to provide custom functionality in a given host environment. Here's an example multiplication function that loads operands from memory:
mult := NewHostFunctionWithStack( "mult", "env", func(ctx context.Context, plugin *CurrentPlugin, stack []uint64) { a := api.DecodeI32(stack[0]) b := api.DecodeI32(stack[1]) stack[0] = api.EncodeI32(a * b) }, []api.ValueType{api.ValueTypeI64, api.ValueTypeI64}, api.ValueTypeI64 )
type HostFunctionStackCallback ¶
type HostFunctionStackCallback func(ctx context.Context, p *CurrentPlugin, stack []uint64)
HostFunctionStackCallback is a Function implemented in Go instead of a wasm binary. The plugin parameter is the calling plugin, used to access memory or exported functions and logging.
The stack is includes any parameters encoded according to their ValueType. Its length is the max of parameter or result length. When there are results, write them in order beginning at index zero. Do not use the stack after the function returns.
Here's a typical way to read three parameters and write back one.
// read parameters in index order argv, argvBuf := api.DecodeU32(inputs[0]), api.DecodeU32(inputs[1]) // write results back to the stack in index order stack[0] = api.EncodeU32(ErrnoSuccess)
This function can be non-deterministic or cause side effects. It also has special properties not defined in the WebAssembly Core specification. Notably, this uses the caller's memory (via Module.Memory). See https://www.w3.org/TR/wasm-core-1/#host-functions%E2%91%A0
To safely decode/encode values from/to the uint64 inputs/ouputs, users are encouraged to use Wazero's api.EncodeXXX or api.DecodeXXX functions.
type HttpRequest ¶
HttpRequest represents an HTTP request to be made by the plugin.
type Manifest ¶
type Manifest struct { Wasm []Wasm `json:"wasm"` Memory struct { MaxPages uint32 `json:"max_pages,omitempty"` } `json:"memory,omitempty"` Config map[string]string `json:"config,omitempty"` AllowedHosts []string `json:"allowed_hosts,omitempty"` AllowedPaths map[string]string `json:"allowed_paths,omitempty"` Timeout uint64 `json:"timeout_ms,omitempty"` }
Manifest represents the plugin's manifest, including Wasm modules and configuration. See https://extism.org/docs/concepts/manifest for schema.
type Plugin ¶
type Plugin struct { Runtime *Runtime Modules map[string]api.Module Main api.Module Timeout time.Duration Config map[string]string // NOTE: maybe we can have some nice methods for getting/setting vars Var map[string][]byte AllowedHosts []string AllowedPaths map[string]string LastStatusCode int // contains filtered or unexported fields }
Plugin is used to call WASM functions
func NewPlugin ¶
func NewPlugin( ctx context.Context, manifest Manifest, config PluginConfig, functions []HostFunction) (*Plugin, error)
NewPlugin creates a new Extism plugin with the given manifest, configuration, and host functions. The returned plugin can be used to call WebAssembly functions and interact with the plugin.
func (*Plugin) FunctionExists ¶
FunctionExists returns true when the named function is present in the plugin's main module
func (*Plugin) GetError ¶
GetError retrieves the error message from the last WebAssembly function call, if any.
func (*Plugin) GetOutput ¶
GetOutput retrieves the output data from the last WebAssembly function call.
func (*Plugin) SetInput ¶
SetInput sets the input data for the plugin to be used in the next WebAssembly function call.
func (*Plugin) SetLogLevel ¶
SetLogLevel sets the minim logging level, applies to custom logging callbacks too
type PluginConfig ¶
type PluginConfig struct { ModuleConfig wazero.ModuleConfig RuntimeConfig wazero.RuntimeConfig EnableWasi bool // TODO: couldn't find a better way for this, but I wonder if there is a better and more idomatic way for Option<T> LogLevel *LogLevel }
PluginConfig contains configuration options for the Extism plugin.
type Runtime ¶
type Runtime struct { Wazero wazero.Runtime Extism api.Module Env api.Module // contains filtered or unexported fields }
Runtime represents the Extism plugin's runtime environment, including the underlying Wazero runtime and modules.
type WasmData ¶
type WasmData struct { Data []byte `json:"data"` Hash string `json:"hash,omitempty"` Name string `json:"name,omitempty"` }
WasmData represents in-memory WebAssembly data, including its content, hash, and name.
type WasmFile ¶
type WasmFile struct { Path string `json:"path"` Hash string `json:"hash,omitempty"` Name string `json:"name,omitempty"` }
WasmFile represents WebAssembly data that needs to be loaded from a file.
type WasmUrl ¶
type WasmUrl struct { Url string `json:"url"` Hash string `json:"hash,omitempty"` Headers map[string]string `json:"headers,omitempty"` Name string `json:"name,omitempty"` Method string `json:"method,omitempty"` }
WasmUrl represents WebAssembly data that needs to be fetched from a URL.