summaryrefslogtreecommitdiff
path: root/golang/pkg/api/ships.go
diff options
context:
space:
mode:
authorJulien Dessaux2025-02-12 23:55:18 +0100
committerJulien Dessaux2025-02-12 23:55:18 +0100
commit01263017fcd03fa9560ddb8a5013fdf786c7d609 (patch)
tree0179ae4f3d013f26f49182aecef65febb1fd56dc /golang/pkg/api/ships.go
parent[golang] refactor ships api (diff)
downloadspacetraders-01263017fcd03fa9560ddb8a5013fdf786c7d609.tar.gz
spacetraders-01263017fcd03fa9560ddb8a5013fdf786c7d609.tar.bz2
spacetraders-01263017fcd03fa9560ddb8a5013fdf786c7d609.zip
[golang] implement ship refueling
Diffstat (limited to 'golang/pkg/api/ships.go')
-rw-r--r--golang/pkg/api/ships.go26
1 files changed, 26 insertions, 0 deletions
diff --git a/golang/pkg/api/ships.go b/golang/pkg/api/ships.go
index 08d41ac..0674b3d 100644
--- a/golang/pkg/api/ships.go
+++ b/golang/pkg/api/ships.go
@@ -6,6 +6,7 @@ import (
"path"
"git.adyxax.org/adyxax/spacetraders/golang/pkg/agent"
+ "git.adyxax.org/adyxax/spacetraders/golang/pkg/database"
"git.adyxax.org/adyxax/spacetraders/golang/pkg/model"
)
@@ -49,3 +50,28 @@ func (c *Client) Orbit(s *model.Ship) error {
s.Nav = response.Nav
return nil
}
+
+func (c *Client) Refuel(s *model.Ship, db *database.DB) error {
+ if s.Fuel.Current == s.Fuel.Capacity {
+ return nil
+ }
+ if err := c.Dock(s); err != nil {
+ return fmt.Errorf("failed to refuel ship %s: %w", s.Symbol, err)
+ }
+ uriRef := url.URL{Path: path.Join("my/ships", s.Symbol, "refuel")}
+ type RefuelResponse struct {
+ Agent *model.Agent `json:"agent"`
+ Fuel *model.Fuel `json:"fuel"`
+ Transaction *model.Transaction `json:"transaction"`
+ }
+ var response RefuelResponse
+ if err := c.Send("POST", &uriRef, nil, &response); err != nil {
+ return fmt.Errorf("failed to refuel ship %s: %w", s.Symbol, err)
+ }
+ agent.SetAgent(response.Agent)
+ s.Fuel = response.Fuel
+ if err := db.AppendTransaction(response.Transaction); err != nil {
+ return fmt.Errorf("failed to refuel ship %s: %w", s.Symbol, err)
+ }
+ return nil
+}