summaryrefslogtreecommitdiff
path: root/golang/pkg/database/systems.go
diff options
context:
space:
mode:
authorJulien Dessaux2025-02-17 00:40:43 +0100
committerJulien Dessaux2025-02-17 00:40:43 +0100
commitbd2fb50c819c2b180758308ef3751e7ea73e6ab7 (patch)
tree19632f7098691a1147357039a5efedf7c40a8d53 /golang/pkg/database/systems.go
parent[golang] handle paginated requests (diff)
downloadspacetraders-bd2fb50c819c2b180758308ef3751e7ea73e6ab7.tar.gz
spacetraders-bd2fb50c819c2b180758308ef3751e7ea73e6ab7.tar.bz2
spacetraders-bd2fb50c819c2b180758308ef3751e7ea73e6ab7.zip
[golang] implement shipyards visits
Diffstat (limited to 'golang/pkg/database/systems.go')
-rw-r--r--golang/pkg/database/systems.go24
1 files changed, 24 insertions, 0 deletions
diff --git a/golang/pkg/database/systems.go b/golang/pkg/database/systems.go
index 858c3dd..0af6aa7 100644
--- a/golang/pkg/database/systems.go
+++ b/golang/pkg/database/systems.go
@@ -45,6 +45,30 @@ func (db *DB) LoadWaypoint(symbol string) (*model.Waypoint, error) {
return &waypoint, nil
}
+func (db *DB) LoadWaypointsInSystem(system *model.System) ([]model.Waypoint, error) {
+ rows, err := db.Query(`SELECT data FROM waypoints WHERE data->>'systemSymbol' = ?;`, system.Symbol)
+ if err != nil {
+ return nil, fmt.Errorf("failed to query waypoints: %w", err)
+ }
+ defer rows.Close()
+ waypoints := make([]model.Waypoint, 0)
+ for rows.Next() {
+ var buf []byte
+ if err := rows.Scan(&buf); err != nil {
+ return nil, fmt.Errorf("failed to load waypoint from row: %w", err)
+ }
+ var waypoint model.Waypoint
+ if err := json.Unmarshal(buf, &waypoint); err != nil {
+ return nil, fmt.Errorf("failed to unmarshal waypoint: %w", err)
+ }
+ waypoints = append(waypoints, waypoint)
+ }
+ if err := rows.Err(); err != nil {
+ return nil, fmt.Errorf("failed to load waypoints from rows: %w", err)
+ }
+ return waypoints, nil
+}
+
func (db *DB) SaveWaypoint(waypoint *model.Waypoint) error {
data, err := json.Marshal(waypoint)
if err != nil {