Continued scaffolding and interface definitions

This commit is contained in:
2025-10-12 02:20:20 +08:00
parent 2e5fd96014
commit c3e0eba4b1
18 changed files with 164 additions and 15 deletions

3
go.mod
View File

@@ -3,7 +3,6 @@ module gitlab.michelsen.id/phillmichelsen/tessera
go 1.25.1
require (
github.com/coder/websocket v1.8.14
github.com/google/uuid v1.6.0
github.com/lmittmann/tint v1.1.2
google.golang.org/grpc v1.75.0
@@ -11,8 +10,10 @@ require (
)
require (
github.com/klauspost/cpuid/v2 v2.0.9 // indirect
golang.org/x/net v0.43.0 // indirect
golang.org/x/sys v0.35.0 // indirect
golang.org/x/text v0.28.0 // indirect
google.golang.org/genproto/googleapis/rpc v0.0.0-20250826171959-ef028d996bc1 // indirect
lukechampine.com/blake3 v1.4.1 // indirect
)

6
go.sum
View File

@@ -1,5 +1,3 @@
github.com/coder/websocket v1.8.14 h1:9L0p0iKiNOibykf283eHkKUHHrpG7f65OE3BhhO7v9g=
github.com/coder/websocket v1.8.14/go.mod h1:NX3SzP+inril6yawo5CQXx8+fk145lPDC6pumgx0mVg=
github.com/go-logr/logr v1.4.3 h1:CjnDlHq8ikf6E492q6eKboGOC0T8CDaOvkHCIg8idEI=
github.com/go-logr/logr v1.4.3/go.mod h1:9T104GzyrTigFIr8wt5mBrctHMim0Nb2HLGrmQ40KvY=
github.com/go-logr/stdr v1.2.2 h1:hSWxHoqTgW2S2qGc0LTAI563KZ5YKYRhT3MFKZMbjag=
@@ -10,6 +8,8 @@ github.com/google/go-cmp v0.7.0 h1:wk8382ETsv4JYUZwIsn6YpYiWiBsYLSJiTsyBybVuN8=
github.com/google/go-cmp v0.7.0/go.mod h1:pXiqmnSA92OHEEa9HXL2W4E7lf9JzCmGVUdgjX3N/iU=
github.com/google/uuid v1.6.0 h1:NIvaJDMOsjHA8n1jAhLSgzrAzy1Hgr+hNrb57e+94F0=
github.com/google/uuid v1.6.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
github.com/klauspost/cpuid/v2 v2.0.9 h1:lgaqFMSdTdQYdZ04uHyN2d/eKdOMyi2YLSvlQIBFYa4=
github.com/klauspost/cpuid/v2 v2.0.9/go.mod h1:FInQzS24/EEf25PyTYn52gqo7WaD8xa0213Md/qVLRg=
github.com/lmittmann/tint v1.1.2 h1:2CQzrL6rslrsyjqLDwD11bZ5OpLBPU+g3G/r5LSfS8w=
github.com/lmittmann/tint v1.1.2/go.mod h1:HIS3gSy7qNwGCj+5oRjAutErFBl4BzdQP6cJZ0NfMwE=
go.opentelemetry.io/auto/sdk v1.1.0 h1:cH53jehLUN6UFLY71z+NDOiNJqDdPRaXzTel0sJySYA=
@@ -38,3 +38,5 @@ google.golang.org/grpc v1.75.0 h1:+TW+dqTd2Biwe6KKfhE5JpiYIBWq865PhKGSXiivqt4=
google.golang.org/grpc v1.75.0/go.mod h1:JtPAzKiq4v1xcAB2hydNlWI2RnF85XXcV0mhKXr2ecQ=
google.golang.org/protobuf v1.36.8 h1:xHScyCOEuuwZEc6UtSOvPbAT4zRh0xcNRYekJwfqyMc=
google.golang.org/protobuf v1.36.8/go.mod h1:fuxRtAxBytpl4zzqUh6/eyUujkJdNiuEkXntxiD/uRU=
lukechampine.com/blake3 v1.4.1 h1:I3Smz7gso8w4/TunLKec6K2fn+kyKtDxr/xcQEN84Wg=
lukechampine.com/blake3 v1.4.1/go.mod h1:QFosUxmjB8mnrWFSNwKmvxHpfY72bmD2tQ0kBMM3kwo=

View File

@@ -6,9 +6,6 @@ import (
"time"
"github.com/lmittmann/tint"
"gitlab.michelsen.id/phillmichelsen/tessera/services/data_service/internal/manager"
"gitlab.michelsen.id/phillmichelsen/tessera/services/data_service/internal/router"
"gitlab.michelsen.id/phillmichelsen/tessera/services/data_service/internal/worker"
)
func initLogger() *slog.Logger {
@@ -49,10 +46,5 @@ func main() {
slog.SetDefault(initLogger())
slog.Info("starting", "svc", "data-service")
// Setup
wr := worker.NewRegistry()
r, _ := router.NewRouter("actor", 2048, 512)
_ = manager.NewManager(r, wr)
select {}
}

View File

@@ -1,2 +1,25 @@
// Package control
package control
import (
"github.com/google/uuid"
"gitlab.michelsen.id/phillmichelsen/tessera/services/data_service/internal/node"
"gitlab.michelsen.id/phillmichelsen/tessera/services/data_service/internal/node/processor"
"gitlab.michelsen.id/phillmichelsen/tessera/services/data_service/internal/router"
)
type nodeEntry struct {
Template node.Template
TemplateFingerprint string
}
type Controller struct {
router router.Router
sourceRegistry any // source.Registry
processorRegistry processor.Registry
sinkRegistry any // sink.Registry
sourceNodes map[uuid.UUID]any
processorNodes map[uuid.UUID]processor.Processor
sinkNodes map[uuid.UUID]any
}

View File

@@ -0,0 +1,43 @@
package control
import (
"encoding/binary"
"encoding/hex"
"sort"
"lukechampine.com/blake3"
)
func StreamFingerprint(templateFP, outPort string, inMap map[string]string) string {
// Sort input keys for determinism.
keys := make([]string, 0, len(inMap))
for k := range inMap {
keys = append(keys, k)
}
sort.Strings(keys)
h := blake3.New(32, nil)
write := func(s string) {
var lenbuf [4]byte
binary.LittleEndian.PutUint32(lenbuf[:], uint32(len(s)))
_, _ = h.Write(lenbuf[:])
_, _ = h.Write([]byte(s))
}
// templateFP, outPort, input count, then pairs.
write(templateFP)
write(outPort)
var nbuf [4]byte
binary.LittleEndian.PutUint32(nbuf[:], uint32(len(keys)))
_, _ = h.Write(nbuf[:])
for _, k := range keys {
write(k)
write(inMap[k])
}
sum := h.Sum(nil)
return hex.EncodeToString(sum)
}

View File

@@ -1,2 +0,0 @@
// Package exit
package exit

View File

@@ -5,10 +5,10 @@ import (
"gitlab.michelsen.id/phillmichelsen/tessera/services/data_service/internal/domain"
)
type In interface {
type Receiver interface {
Receive() (port string, message domain.Message, ok bool)
}
type Out interface {
type Sender interface {
Send(port string, message domain.Message) error
}

View File

@@ -0,0 +1,16 @@
package node
type Type string
const (
Source Type = "source"
Processor Type = "processor"
Sink Type = "sink"
)
type Template struct {
Kind Type
Type string
Version string
Config string
}

View File

@@ -1,2 +1,18 @@
// Package processor
package processor
import (
"context"
"gitlab.michelsen.id/phillmichelsen/tessera/services/data_service/internal/node"
)
type Processor interface {
Start(ctx context.Context, cfg string, io IO) error
Stop()
}
type IO interface {
node.Receiver
node.Sender
}

View File

@@ -0,0 +1,11 @@
package processor
type Registry struct{}
type Factory interface {
New() Processor
Type() string
Version() string
TemplateFingerprint(cfg string) (string, error)
}

View File

@@ -0,0 +1,17 @@
// Package sink
package sink
import (
"context"
"gitlab.michelsen.id/phillmichelsen/tessera/services/data_service/internal/node"
)
type Sink interface {
Start(ctx context.Context, io IO) error
Stop()
}
type IO interface {
node.Sender
}

View File

@@ -0,0 +1 @@
package source

View File

@@ -1,2 +1,20 @@
// Package source
package source
import (
"context"
"gitlab.michelsen.id/phillmichelsen/tessera/services/data_service/internal/node"
)
type Source interface {
Start(ctx context.Context, cfg string, io IO) error
Stop()
Serve(key string) error
Unserve(key string) error
}
type IO interface {
node.Sender
}

View File

@@ -0,0 +1,9 @@
// Package router
package router
import "github.com/google/uuid"
type Router interface {
Route(fromNode uuid.UUID, fromOutPort string, toNode uuid.UUID, toInPort string)
Unroute(fromNode uuid.UUID, fromOutPort string, toNode uuid.UUID, toInPort string)
}

View File

@@ -0,0 +1,2 @@
// Package single
package single