cli

package module
v1.6.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 15, 2025 License: BSD-3-Clause Imports: 27 Imported by: 2

README

extism CLI

The Extism CLI can be used to generate or execute Extism plugins and manage libextism installations.

Installation

Using curl/sh:
curl https://get.extism.org/cli | sh

See the help output for more options:

curl https://get.extism.org/cli | sh -s -- -h
From source:
go install github.com/extism/cli/extism@latest
Using Nix:
nix-shell -p extism-cli
Manual

You can also download and extract the latest release from https://github.com/extism/cli/releases

Generate a Plugin

To quickly start writing an Extism plugin in any of the supported PDK languages, using extism CLI to generate minimal boilerplate may be helpful:

mkdir js-plugin && cd js-plugin
extism generate plugin 

  Select a PDK language to use for your plugin:  
                                                 
    1. Rust                                      
  > 2. JavaScript                                
    3. Go                                        
    4. Zig                                       
    5. C#                                        
    6. F#                                        
    7. C                                         
    8. Haskell                                   
    9. AssemblyScript                            
# or pass a path to the output via `-o`, see more options running `extism generate -h`

This will output a quickstart plugin project with the necessary configuration and dependencies ready. If no output directory was specified, the current directory will be used.

NOTE:: You may still need to install language tools such as compilers or other system dependencies to compile the plugin to WebAssembly.

To further improve this, we will eventually include a Dockerfile in each generated project, so a build environment can be easily created with all tools necessary. If you're interested in contributing to this effort, please join us on Discord, and check out the PDK template repository of interest, listed in pdk-templates.json

Call a plugin

The following will call the count_vowels function in the count_vowels.wasm module with the input "qwertyuiop":

PLUGIN_URL="https://github.com/extism/plugins/releases/latest/download/count_vowels.wasm"
extism call $PLUGIN_URL count_vowels --input qwertyuiop

Note: The first parameter to call can also be a path to a Wasm file on disk.

See extism call --help for a list of all the flags

Listing libextism versions

To list the available libextism versions:

extism lib versions

To list the available triples for a version:

extism lib versions v0.0.1-alpha
Install libextism

To install the latest version of libextism to /usr/local on macOS and Linux and . on Windows, this will overwrite any existing installation at the same path:

sudo PATH=$PATH env extism lib install

To install to $HOME/.local:

extism lib install --prefix ~/.local

To install the latest build from github:

sudo PATH=$PATH env extism lib install --version git
Uninstall libextism

To uninstall the shared object and header installed in /usr/local:

sudo PATH=$PATH env extism lib uninstall

Or from another prefix:

extism lib uninstall --prefix ~/.local
Check a libextism installation

The lib check command will print the version of the installed libextism library:

extism lib check

Documentation

Index

Constants

This section is empty.

Variables

View Source
var GithubToken = ""
View Source
var LoggingEnabled = false
View Source
var PrintingDisabled = false

Functions

func CallCmd

func CallCmd() *cobra.Command

func GenerateCmd added in v1.3.0

func GenerateCmd() *cobra.Command

func LibCmd

func LibCmd() *cobra.Command

func Log

func Log(s ...any)

func Print

func Print(s ...any)

func RunArgs added in v0.3.1

func RunArgs[T Args](f func(cmd *cobra.Command, args T) error, call T) func(cmd *cobra.Command, args []string) error

Types

type Args

type Args interface {
	SetArgs(args []string)
}

Directories

Path Synopsis
Package gitignore can be used to parse .gitignore-style files into lists of globs that can be used to test against paths or selectively walk a file tree.
Package gitignore can be used to parse .gitignore-style files into lists of globs that can be used to test against paths or selectively walk a file tree.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL