Skip to content

imjasonh/wasimg

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

wasimg

wasimg bundles a Wasm module into an OCI manifest, and pushes it to an OCI registry.

For example:

$ wasimg my-module.wasm example.com/my-project/my-module
example.com/my-project/my-module@sha256:a7bb950a6cf95fd1dfc55907ec997e37840c71f6840d0c32481e7b8392490022

It doesn't require Docker or Dockerfiles, and it reuses your pre-configured registry credentials by default.

Installation

go install github.com/imjasonh/wasimg@latest

Usage

Build a wasm module, for example, build wasimg itself:

GOOS=wasip1 GOARCH=wasm go build -o wasimg.wasm .

If you already have a wasm module, you can skip this step.

Then use wasimg to bundle that wasm module and push it to a registry:

$ wasimg wasimg.wasm ttl.sh/wasimg
ttl.sh/wasimg@sha256:caea81fc44d4d92280a4bc7ceaccf15b3466792c312c9fa38446f73ce358ee3c

This prints the image reference of the pushed image, which you can run:

$ docker run \
  --runtime=io.containerd.wasmedge.v1 \
  --platform=wasip1/wasm \
  ttl.sh/wasimg@sha256:caea81fc44d4d92280a4bc7ceaccf15b3466792c312c9fa38446f73ce358ee3c

Try it out to see what happens!

About

Bundle wasm modules into OCI images

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages