rove/cmd/rove-server/internal/routes.go

122 lines
3.4 KiB
Go
Raw Normal View History

package internal
2020-06-04 17:23:27 +01:00
import (
"context"
2020-06-04 17:23:27 +01:00
"fmt"
"github.com/mdiluz/rove/pkg/accounts"
"github.com/mdiluz/rove/pkg/game"
"github.com/mdiluz/rove/pkg/rove"
2020-06-04 17:23:27 +01:00
"github.com/mdiluz/rove/pkg/version"
"google.golang.org/grpc"
2020-06-04 17:23:27 +01:00
)
func (s *Server) Status(context.Context, *rove.StatusRequest) (*rove.StatusResponse, error) {
response := &rove.StatusResponse{
2020-06-04 17:23:27 +01:00
Ready: true,
Version: version.Version,
Tick: int32(s.tick),
2020-06-06 16:37:57 +01:00
}
// TODO: Verify the accountant is up and ready too
2020-06-06 16:37:57 +01:00
// If there's a schedule, respond with it
if len(s.schedule.Entries()) > 0 {
response.NextTick = s.schedule.Entries()[0].Next.Format("15:04:05")
}
return response, nil
2020-06-04 17:23:27 +01:00
}
func (s *Server) Register(ctx context.Context, req *rove.RegisterRequest) (*rove.RegisterResponse, error) {
if len(req.Name) == 0 {
return nil, fmt.Errorf("empty account name")
}
2020-06-05 16:43:25 +01:00
if _, err := s.accountant.Register(ctx, &accounts.RegisterInfo{Name: req.Name}, grpc.WaitForReady(true)); err != nil {
return nil, err
} else if _, err := s.SpawnRoverForAccount(req.Name); err != nil {
return nil, fmt.Errorf("failed to spawn rover for account: %s", err)
} else if err := s.SaveWorld(); err != nil {
return nil, fmt.Errorf("internal server error when saving world: %s", err)
2020-06-04 17:23:27 +01:00
}
return &rove.RegisterResponse{}, nil
}
func (s *Server) Rover(ctx context.Context, req *rove.RoverRequest) (*rove.RoverResponse, error) {
response := &rove.RoverResponse{}
if len(req.Account) == 0 {
return nil, fmt.Errorf("empty account name")
2020-06-04 17:23:27 +01:00
} else if resp, err := s.accountant.GetValue(ctx, &accounts.DataKey{Account: req.Account, Key: "rover"}); err != nil {
return nil, fmt.Errorf("gRPC failed to contact accountant: %s", err)
2020-06-04 17:23:27 +01:00
} else if rover, err := s.world.GetRover(resp.Value); err != nil {
return nil, fmt.Errorf("error getting rover: %s", err)
} else {
response = &rove.RoverResponse{
Name: rover.Name,
Position: &rove.Vector{
X: int32(rover.Pos.X),
Y: int32(rover.Pos.Y),
},
Range: int32(rover.Range),
Inventory: rover.Inventory,
}
2020-06-04 17:23:27 +01:00
}
return response, nil
2020-06-04 17:23:27 +01:00
}
func (s *Server) Radar(ctx context.Context, req *rove.RadarRequest) (*rove.RadarResponse, error) {
if len(req.Account) == 0 {
return nil, fmt.Errorf("empty account name")
}
2020-06-04 17:23:27 +01:00
response := &rove.RadarResponse{}
2020-06-04 17:23:27 +01:00
resp, err := s.accountant.GetValue(ctx, &accounts.DataKey{Account: req.Account, Key: "rover"})
if err != nil {
return nil, fmt.Errorf("gRPC failed to contact accountant: %s", err)
} else if rover, err := s.world.GetRover(resp.Value); err != nil {
return nil, fmt.Errorf("error getting rover attributes: %s", err)
} else if radar, err := s.world.RadarFromRover(resp.Value); err != nil {
return nil, fmt.Errorf("error getting radar from rover: %s", err)
2020-06-04 17:23:27 +01:00
} else {
response.Tiles = radar
response.Range = int32(rover.Range)
2020-06-04 17:23:27 +01:00
}
return response, nil
2020-06-04 17:23:27 +01:00
}
2020-06-05 22:23:01 +01:00
func (s *Server) Commands(ctx context.Context, req *rove.CommandsRequest) (*rove.CommandsResponse, error) {
if len(req.Account) == 0 {
return nil, fmt.Errorf("empty account")
}
resp, err := s.accountant.GetValue(ctx, &accounts.DataKey{Account: req.Account, Key: "rover"})
2020-06-05 22:23:01 +01:00
if err != nil {
return nil, err
}
var cmds []game.Command
for _, c := range req.Commands {
cmds = append(cmds, game.Command{
Bearing: c.Bearing,
Command: c.Command})
}
2020-06-05 22:23:01 +01:00
if err := s.world.Enqueue(resp.Value, cmds...); err != nil {
return nil, err
2020-06-05 22:23:01 +01:00
}
return &rove.CommandsResponse{}, nil
2020-06-05 22:23:01 +01:00
}