2020-04-17 13:01:05 +01:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"encoding/json"
|
|
|
|
"log"
|
|
|
|
"net/http"
|
|
|
|
"os"
|
|
|
|
"strconv"
|
|
|
|
|
2020-04-18 12:58:53 +01:00
|
|
|
"github.com/ray1729/gpx-utils/pkg/placenames"
|
2020-04-20 12:43:41 +01:00
|
|
|
"github.com/ray1729/gpx-utils/pkg/rwgps"
|
2020-04-17 13:01:05 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
listenAddr := os.Getenv("LISTEN_ADDR")
|
|
|
|
if listenAddr == "" {
|
|
|
|
listenAddr = ":8000"
|
|
|
|
}
|
2020-04-18 12:58:53 +01:00
|
|
|
gs, err := placenames.NewGPXSummarizer()
|
2020-04-17 13:01:05 +01:00
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
gpxSummarizer = gs
|
|
|
|
http.HandleFunc("/rwgps", rwgpsHandler)
|
|
|
|
log.Fatal(http.ListenAndServe(listenAddr, nil))
|
|
|
|
}
|
|
|
|
|
2020-04-18 12:58:53 +01:00
|
|
|
var gpxSummarizer *placenames.GPXSummarizer
|
2020-04-17 13:01:05 +01:00
|
|
|
|
|
|
|
func rwgpsHandler(w http.ResponseWriter, r *http.Request) {
|
|
|
|
q := r.URL.Query()
|
|
|
|
x := q.Get("routeId")
|
2020-04-20 12:43:41 +01:00
|
|
|
log.Printf("Handilng request for routeId=%s", x)
|
2020-04-17 13:01:05 +01:00
|
|
|
if x == "" {
|
|
|
|
http.Error(w, "routeId is required", http.StatusBadRequest)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
routeId, err := strconv.Atoi(x)
|
|
|
|
if err != nil {
|
2020-04-20 12:43:41 +01:00
|
|
|
log.Printf("Invalid route id: %s", x)
|
|
|
|
http.Error(w, "Invalid route id", http.StatusBadRequest)
|
2020-04-17 13:01:05 +01:00
|
|
|
return
|
|
|
|
}
|
2020-04-20 12:43:41 +01:00
|
|
|
track, err := rwgps.FetchTrack(routeId)
|
2020-04-17 13:01:05 +01:00
|
|
|
if err != nil {
|
2020-04-20 12:43:41 +01:00
|
|
|
log.Println(err.Error())
|
|
|
|
switch err.(type) {
|
|
|
|
case *rwgps.ErrNotFound:
|
|
|
|
http.Error(w, err.Error(), http.StatusNotFound)
|
|
|
|
default:
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
}
|
2020-04-17 13:01:05 +01:00
|
|
|
return
|
|
|
|
}
|
|
|
|
summary, err := gpxSummarizer.SummarizeTrack(bytes.NewReader(track))
|
|
|
|
if err != nil {
|
2020-04-20 12:43:41 +01:00
|
|
|
log.Printf("Error analyzing route %d: %v", routeId, err)
|
2020-04-17 13:01:05 +01:00
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
result, err := json.Marshal(summary)
|
|
|
|
if err != nil {
|
2020-04-20 12:43:41 +01:00
|
|
|
log.Printf("Error marshalling JSON for route %d: %v", routeId, err)
|
2020-04-17 13:01:05 +01:00
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
w.Header().Add("Content-Type", "application/json")
|
|
|
|
w.WriteHeader(http.StatusOK)
|
|
|
|
w.Write(result)
|
|
|
|
}
|