initial commit
This commit is contained in:
parent
53a068b36c
commit
208424de98
4 changed files with 90 additions and 0 deletions
11
examples/hello_world/go.mod
Normal file
11
examples/hello_world/go.mod
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
module hello_world
|
||||||
|
|
||||||
|
go 1.20
|
||||||
|
|
||||||
|
require (
|
||||||
|
code.icb4dc0.de/buildr/wasi-module-sdk latest
|
||||||
|
)
|
||||||
|
|
||||||
|
replace (
|
||||||
|
code.icb4dc0.de/buildr/wasi-module-sdk => ../../
|
||||||
|
)
|
8
go.mod
Normal file
8
go.mod
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
module code.icb4dc0.de/buildr/wasi-module-sdk
|
||||||
|
|
||||||
|
go 1.20
|
||||||
|
|
||||||
|
require (
|
||||||
|
buf.build/gen/go/buildr/buildr/protocolbuffers/go v1.30.0-20230504155321-a2ad89049f80.1 // indirect
|
||||||
|
github.com/tetratelabs/wazero v1.1.0 // indirect
|
||||||
|
)
|
9
go.sum
Normal file
9
go.sum
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
buf.build/gen/go/buildr/buildr/protocolbuffers/go v1.30.0-20230504155321-a2ad89049f80.1 h1:gDR2MbPrmDLMU4SU83sLG53G1BO2jWLZRSwA7Zx/ORs=
|
||||||
|
buf.build/gen/go/buildr/buildr/protocolbuffers/go v1.30.0-20230504155321-a2ad89049f80.1/go.mod h1:HnJwr6AoSkS1h+Fr8+UR7MDcZMzmv7lJPJWeTjdclPs=
|
||||||
|
github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk=
|
||||||
|
github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
|
||||||
|
github.com/tetratelabs/wazero v1.1.0 h1:EByoAhC+QcYpwSZJSs/aV0uokxPwBgKxfiokSUwAknQ=
|
||||||
|
github.com/tetratelabs/wazero v1.1.0/go.mod h1:wYx2gNRg8/WihJfSDxA1TIL8H+GkfLYm+bIfbblu9VQ=
|
||||||
|
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||||
|
google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw=
|
||||||
|
google.golang.org/protobuf v1.30.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
|
62
test/test_host.go
Normal file
62
test/test_host.go
Normal file
|
@ -0,0 +1,62 @@
|
||||||
|
package test
|
||||||
|
|
||||||
|
import (
|
||||||
|
rpcv1 "buf.build/gen/go/buildr/buildr/protocolbuffers/go/rpc/v1"
|
||||||
|
"context"
|
||||||
|
"errors"
|
||||||
|
"github.com/tetratelabs/wazero"
|
||||||
|
"github.com/tetratelabs/wazero/api"
|
||||||
|
"github.com/tetratelabs/wazero/imports/wasi_snapshot_preview1"
|
||||||
|
"golang.org/x/exp/slog"
|
||||||
|
"google.golang.org/protobuf/proto"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Host struct {
|
||||||
|
Logger *slog.Logger
|
||||||
|
}
|
||||||
|
|
||||||
|
func (h *Host) Run(ctx context.Context) (err error) {
|
||||||
|
r := wazero.NewRuntime(ctx)
|
||||||
|
defer r.Close(context.Background())
|
||||||
|
|
||||||
|
_, err = r.NewHostModuleBuilder("test").
|
||||||
|
NewFunctionBuilder().WithFunc(h.log).Export("log").
|
||||||
|
Instantiate(ctx)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
closer, err := wasi_snapshot_preview1.Instantiate(ctx, r)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
defer func() {
|
||||||
|
err = errors.Join(err, closer.Close(context.Background()))
|
||||||
|
}()
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (h *Host) log(ctx context.Context, m api.Module, offset, byteCount uint32) {
|
||||||
|
buf, ok := m.Memory().Read(offset, byteCount)
|
||||||
|
if !ok {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
var taskLog *rpcv1.TaskLog
|
||||||
|
if err := proto.Unmarshal(buf, taskLog); err != nil {
|
||||||
|
h.Logger.Warn("failed to unmarshal task log", slog.String("err", err.Error()))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
rec := slog.NewRecord(taskLog.Time.AsTime(), slog.Level(taskLog.Level), taskLog.Message, -1)
|
||||||
|
|
||||||
|
for i := range taskLog.Attributes {
|
||||||
|
attr := taskLog.Attributes[i]
|
||||||
|
rec.AddAttrs(slog.String(attr.Key, attr.Value))
|
||||||
|
}
|
||||||
|
|
||||||
|
_ = h.Logger.Handler().Handle(ctx, rec)
|
||||||
|
}
|
Loading…
Reference in a new issue