wasm-nats-stream-client/README.md

62 lines
1.6 KiB
Markdown
Raw Normal View History

2024-12-14 00:26:30 +00:00
# HTTP Hello World
This is a simple TinyGo Wasm example that responds with a "Hello World" message for each request.
## Prerequisites
- `go` 1.23
- `tinygo` 0.33
- [`wash`](https://wasmcloud.com/docs/installation) 0.35.0
- `wasmtime` 25.0.0 (if running with wasmtime)
## Building
```bash
wash build
```
## Push OCI Artifact to Gitea
```bash
2025-01-06 15:45:56 +00:00
wash push gitea.rebus.ninja/lore/go-nats-client:1.x.x build/go_nats_stream_client_s.wasm
2024-12-14 00:26:30 +00:00
```
2025-01-06 11:31:10 +00:00
## Build and push to the registry using the dockerfile
### Build the cointainer
```bash
docker build -t wash-image-build .
```
### Build the component and push to the registry
First setup your credentials
```bash
export REG_USER=user && export REG_PASS=pass
```
Build and push
```bash
docker run --rm -e REGISTRY=gitea.rebus.ninja/lore/wasm-nats-stream-client:1.0.x -e WASH_REG_USER=$REG_USER -e WASH_REG_PASSWORD=$REG_PASS -v "$(pwd):/app" wash-image-build
```
2024-12-14 00:26:30 +00:00
## Running with wasmtime
You must have wasmtime 25.0.0 for this to work. Make sure to follow the build step above first.
```bash
wasmtime serve -Scommon ./build/http_hello_world_s.wasm
```
## Running with wasmCloud
Make sure to follow the build steps above, and replace the file path in [the wadm manifest](./wadm.yaml) with the absolute path to your local built component.
```shell
wash up -d
wash app deploy ./wadm.yaml
curl http://localhost:8000
```
## Adding Capabilities
To learn how to extend this example with additional capabilities, see the [Adding Capabilities](https://wasmcloud.com/docs/tour/adding-capabilities?lang=tinygo) section of the wasmCloud documentation.