Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 7 additions & 1 deletion geocoding.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,17 @@ type FeatureCollection struct {
Features []Feature `json:"features"`
}

// PointGeometry is a GeoJSON Point geometry. Coordinates holds [longitude, latitude].
type PointGeometry struct {
Type string `json:"type"`
Coordinates []float64 `json:"coordinates"`
}

// Feature is a GeoJSON Feature with Mapbox v6 geocoding properties.
type Feature struct {
Type string `json:"type"`
ID string `json:"id"`
Geometry GeoJSONGeometry `json:"geometry"`
Geometry PointGeometry `json:"geometry"`
Properties FeatureProperties `json:"properties"`
}

Expand Down
5 changes: 5 additions & 0 deletions geocoding_batch_reverse.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,9 @@ import (
type BatchReverseGeocodeRequest struct {
// Queries are the coordinates to reverse geocode. Must contain 1–1000 items.
Queries []ReverseGeocodeQuery
// Permanent requests Permanent tier geocoding, which permits storing results.
// Defaults to Temporary tier when false.
Permanent bool
}

// ReverseGeocodeQuery is a single query in a batch reverse geocode request.
Expand All @@ -28,6 +31,7 @@ type batchGeocodeQuery struct {
Types string `json:"types"`
Longitude float64 `json:"longitude"`
Latitude float64 `json:"latitude"`
Permanent bool `json:"permanent"`
}

// BatchReverseGeocode performs a batch reverse geocode lookup using Geocoding v6 Batch.
Expand All @@ -53,6 +57,7 @@ func (c *Client) BatchReverseGeocode(ctx context.Context, req *BatchReverseGeoco
Types: "address",
Longitude: q.Longitude,
Latitude: q.Latitude,
Permanent: req.Permanent,
}
}

Expand Down
6 changes: 6 additions & 0 deletions geocoding_reverse.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,9 @@ type ReverseGeocodeRequest struct {
Longitude float64
// Latitude is the coordinate to reverse geocode.
Latitude float64
// Permanent requests Permanent tier geocoding, which permits storing results.
// Defaults to Temporary tier when false.
Permanent bool
}

// ReverseGeocode performs a single reverse geocode lookup using Geocoding v6.
Expand All @@ -29,6 +32,9 @@ func (c *Client) ReverseGeocode(ctx context.Context, req *ReverseGeocodeRequest)
params := url.Values{}
params.Set("longitude", strconv.FormatFloat(req.Longitude, 'f', -1, 64))
params.Set("latitude", strconv.FormatFloat(req.Latitude, 'f', -1, 64))
if req.Permanent {
params.Set("permanent", "true")
}

endpoint := c.baseURL + "/search/geocode/v6/reverse?" + params.Encode()
httpReq, err := http.NewRequestWithContext(ctx, http.MethodGet, endpoint, nil)
Expand Down
43 changes: 43 additions & 0 deletions geocoding_reverse_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,49 @@ func TestReverseGeocode_ContextParsing(t *testing.T) {
}
}

func TestReverseGeocode_PointGeometry(t *testing.T) {
// Mapbox returns Point geometry with flat [lon, lat] coordinates.
// Regression: GeoJSONGeometry used [][]float64 (LineString), causing decode to fail.
const body = `{
"type": "FeatureCollection",
"features": [{
"type": "Feature",
"geometry": {"type": "Point", "coordinates": [24.9384, 60.1699]},
"properties": {
"mapbox_id": "addr.1",
"feature_type": "address",
"full_address": "Mannerheimintie 1, 00100 Helsinki, Finland"
}
}]
}`
srv := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
w.Header().Set("Content-Type", "application/json")
if _, err := w.Write([]byte(body)); err != nil {
t.Errorf("write response: %v", err)
}
}))
defer srv.Close()

client := mapbox.NewClient(mapbox.WithAccessToken("t"), mapbox.WithBaseURL(srv.URL))
result, err := client.ReverseGeocode(context.Background(), &mapbox.ReverseGeocodeRequest{
Longitude: 24.9384,
Latitude: 60.1699,
})
if err != nil {
t.Fatalf("ReverseGeocode error: %v", err)
}
if len(result.Features) != 1 {
t.Fatalf("len(Features) = %d, want 1", len(result.Features))
}
f := result.Features[0]
if f.Geometry.Type != "Point" {
t.Errorf("Geometry.Type = %q, want Point", f.Geometry.Type)
}
if len(f.Geometry.Coordinates) != 2 {
t.Errorf("Geometry.Coordinates len = %d, want 2", len(f.Geometry.Coordinates))
}
}

func TestReverseGeocode_HTTPError(t *testing.T) {
srv := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
http.Error(w, `{"message":"Not Authorized - Invalid Token"}`, http.StatusUnauthorized)
Expand Down
2 changes: 1 addition & 1 deletion searchbox.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ type Suggestion struct {
// RetrieveFeature is a GeoJSON Feature returned by /retrieve.
type RetrieveFeature struct {
Type string `json:"type"`
Geometry GeoJSONGeometry `json:"geometry"`
Geometry PointGeometry `json:"geometry"`
Properties RetrieveFeatureProperties `json:"properties"`
}

Expand Down
Loading