Add proxied autocomplete for Stadia
This allows me to make the format consistent and to cache the intermediate results, which is useful for speed and testing
This commit is contained in:
parent
b6cfbee102
commit
2d5dca3fb5
11 changed files with 275 additions and 11 deletions
99
stadia/cmd/geocode-autocomplete/main.go
Normal file
99
stadia/cmd/geocode-autocomplete/main.go
Normal file
|
|
@ -0,0 +1,99 @@
|
|||
package main
|
||||
|
||||
import (
|
||||
"context"
|
||||
"flag"
|
||||
"log"
|
||||
"os"
|
||||
|
||||
"github.com/Gleipnir-Technology/nidus-sync/stadia"
|
||||
)
|
||||
|
||||
func main() {
|
||||
// Define command-line flags
|
||||
query := flag.String("query", "", "Street address query to autocomplete")
|
||||
boundaryRectMaxLat := flag.Float64("boundary-rect-max-lat", 0, "The max lat of the boundary")
|
||||
boundaryRectMinLat := flag.Float64("boundary-rect-min-lat", 0, "The min lat of the boundary")
|
||||
boundaryRectMaxLon := flag.Float64("boundary-rect-max-lng", 0, "The max lon of the boundary")
|
||||
boundaryRectMinLon := flag.Float64("boundary-rect-min-lng", 0, "The min lon of the boundary")
|
||||
focusLat := flag.Float64("focus-lat", 0, "The latitude of the focus point")
|
||||
focusLng := flag.Float64("focus-lng", 0, "The longitude of the focus point")
|
||||
|
||||
// Parse the flags
|
||||
flag.Parse()
|
||||
|
||||
// Validate required arguments
|
||||
if *query == "" {
|
||||
log.Println("Error: -query is required")
|
||||
flag.Usage()
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
if *focusLat != 0 && *focusLng == 0 {
|
||||
log.Println("Error: you must specify both focus-lat and focus-lng together, not just focus-lat")
|
||||
flag.Usage()
|
||||
os.Exit(1)
|
||||
}
|
||||
if *focusLat == 0 && *focusLng != 0 {
|
||||
log.Println("Error: you must specify both focus-lat and focus-lng together, not just focus-lng")
|
||||
flag.Usage()
|
||||
os.Exit(1)
|
||||
}
|
||||
if (*boundaryRectMaxLat != 0 ||
|
||||
*boundaryRectMinLat != 0 ||
|
||||
*boundaryRectMaxLon != 0 ||
|
||||
*boundaryRectMinLon != 0) && (*boundaryRectMaxLat == 0 ||
|
||||
*boundaryRectMinLat == 0 ||
|
||||
*boundaryRectMaxLon == 0 ||
|
||||
*boundaryRectMinLon == 0) {
|
||||
log.Println("If you specify one of boundary-rect you need to specify them all")
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
key := os.Getenv("STADIA_MAPS_API_KEY")
|
||||
if key == "" {
|
||||
log.Println("STADIA_MAPS_API_KEY is empty")
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
client := stadia.NewStadiaMaps(key)
|
||||
ctx := context.Background()
|
||||
req := stadia.RequestGeocodeAutocomplete{
|
||||
Text: *query,
|
||||
}
|
||||
if *focusLat != 0 && *focusLng != 0 {
|
||||
req.FocusPointLat = focusLat
|
||||
req.FocusPointLng = focusLng
|
||||
}
|
||||
if *boundaryRectMaxLat != 0 {
|
||||
req.BoundaryRectMaxLat = boundaryRectMaxLat
|
||||
req.BoundaryRectMinLat = boundaryRectMinLat
|
||||
req.BoundaryRectMaxLon = boundaryRectMaxLon
|
||||
req.BoundaryRectMinLon = boundaryRectMinLon
|
||||
}
|
||||
resp, err := client.GeocodeAutocomplete(ctx, req)
|
||||
if err != nil {
|
||||
log.Printf("err: %v\n", err)
|
||||
os.Exit(2)
|
||||
}
|
||||
log.Printf("type: %s, features: %d\n", resp.Type, len(resp.Features))
|
||||
for i, feature := range resp.Features {
|
||||
log.Printf("feature %d: type %s\n", i, feature.Type)
|
||||
if feature.Geometry == nil {
|
||||
log.Printf("\tno geometry")
|
||||
} else {
|
||||
log.Printf("\tgeometry %s\n", feature.Geometry.Type) //, feature.Geometry.Coordinates[0], feature.Geometry.Coordinates[1])
|
||||
}
|
||||
log.Printf("\tproperties %s\n", feature.Properties.Layer)
|
||||
switch feature.Properties.Layer {
|
||||
case "address":
|
||||
log.Printf("\t\t%s", feature.Properties.Name)
|
||||
if feature.Properties.CoarseLocation != nil {
|
||||
log.Printf("\t\t%s", *feature.Properties.CoarseLocation)
|
||||
}
|
||||
log.Printf("\t\t%s", feature.Properties.Precision)
|
||||
log.Printf("\t\t%s", feature.Properties.Layer)
|
||||
log.Printf("\t\t%s", feature.Properties.GID)
|
||||
}
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue