Files
go-cart-actor/rpc-server.go
matst80 c70c5cd930
All checks were successful
Build and Publish / BuildAndDeploy (push) Successful in 1m58s
maybe
2024-11-10 21:43:40 +01:00

57 lines
1.3 KiB
Go

package main
import (
"bytes"
"fmt"
)
type GrainHandler struct {
*CartServer
pool *GrainLocalPool
}
func (h *GrainHandler) GetState(id CartId, reply *Grain) error {
grain, err := h.pool.GetGrain(id)
if err != nil {
return err
}
*reply = grain
return nil
}
func NewGrainHandler(pool *GrainLocalPool, listen string) (*GrainHandler, error) {
server, err := CartListen(listen)
handler := &GrainHandler{
CartServer: server,
pool: pool,
}
server.HandleCall(RemoteHandleMutation, handler.RemoteHandleMessageHandler)
server.HandleCall(RemoteGetState, handler.RemoteGetStateHandler)
return handler, err
}
func (h *GrainHandler) RemoteHandleMessageHandler(id CartId, data []byte) (uint32, []byte, error) {
var msg Message
err := ReadMessage(bytes.NewReader(data), &msg)
if err != nil {
fmt.Println("Error reading message:", err)
return RemoteHandleMutationReply, nil, err
}
replyData, err := h.pool.Process(id, msg)
if err != nil {
fmt.Println("Error handling message:", err)
}
if err != nil {
return RemoteHandleMutationReply, nil, err
}
return RemoteHandleMutationReply, replyData, nil
}
func (h *GrainHandler) RemoteGetStateHandler(id CartId, data []byte) (uint32, []byte, error) {
reply, err := h.pool.Get(id)
if err != nil {
return RemoteGetStateReply, nil, err
}
return RemoteGetStateReply, reply, nil
}