armbian-router/http.go

105 lines
2.0 KiB
Go
Raw Normal View History

2022-01-10 04:47:40 +00:00
package main
import (
"encoding/json"
2022-01-10 04:53:23 +00:00
"fmt"
log "github.com/sirupsen/logrus"
"github.com/spf13/viper"
2022-01-10 04:53:23 +00:00
"net"
"net/http"
"net/url"
"path"
"strings"
2022-01-10 04:47:40 +00:00
)
func statusHandler(w http.ResponseWriter, r *http.Request) {
2022-01-10 04:53:23 +00:00
w.WriteHeader(http.StatusOK)
2022-01-10 04:47:40 +00:00
}
func mirrorsHandler(w http.ResponseWriter, r *http.Request) {
w.Header().Set("Content-Type", "application/json")
json.NewEncoder(w).Encode(servers)
}
func redirectHandler(w http.ResponseWriter, r *http.Request) {
2022-01-10 04:53:23 +00:00
ipStr, _, err := net.SplitHostPort(r.RemoteAddr)
2022-01-10 04:47:40 +00:00
2022-01-10 04:53:23 +00:00
if err != nil {
http.Error(w, err.Error(), http.StatusInternalServerError)
return
}
2022-01-10 04:47:40 +00:00
2022-01-10 04:53:23 +00:00
ip := net.ParseIP(ipStr)
2022-01-10 04:47:40 +00:00
2022-01-10 04:53:23 +00:00
// TODO: This is temporary to allow testing on private addresses.
if ip.IsPrivate() {
ip = net.ParseIP("1.1.1.1")
}
2022-01-10 04:47:40 +00:00
2022-01-10 04:53:23 +00:00
server, distance, err := servers.Closest(ip)
2022-01-10 04:47:40 +00:00
2022-01-10 04:53:23 +00:00
if err != nil {
http.Error(w, err.Error(), http.StatusInternalServerError)
return
}
2022-01-10 04:47:40 +00:00
scheme := r.URL.Scheme
if scheme == "" {
scheme = "https"
}
redirectPath := path.Join(server.Path, r.URL.Path)
if dlMap != nil {
if newPath, exists := dlMap[strings.TrimLeft(r.URL.Path, "/")]; exists {
downloadsMapped.Inc()
redirectPath = path.Join(server.Path, newPath)
}
}
2022-01-10 04:53:23 +00:00
u := &url.URL{
Scheme: scheme,
2022-01-10 04:53:23 +00:00
Host: server.Host,
Path: redirectPath,
2022-01-10 04:53:23 +00:00
}
2022-01-10 04:47:40 +00:00
server.Redirects.Inc()
redirectsServed.Inc()
2022-01-10 04:53:23 +00:00
w.Header().Set("X-Geo-Distance", fmt.Sprintf("%f", distance))
w.Header().Set("Location", u.String())
w.WriteHeader(http.StatusFound)
}
func reloadHandler(w http.ResponseWriter, r *http.Request) {
if mapFile := viper.GetString("dl_map"); mapFile != "" {
log.WithField("file", mapFile).Info("Loading download map")
newMap, err := loadMap(mapFile)
if err != nil {
http.Error(w, err.Error(), http.StatusInternalServerError)
return
}
dlMap = newMap
return
}
w.WriteHeader(http.StatusNotFound)
}
2022-01-10 05:15:07 +00:00
func dlMapHandler(w http.ResponseWriter, r *http.Request) {
if dlMap == nil {
w.WriteHeader(http.StatusNotFound)
return
}
w.Header().Set("Content-Type", "application/json")
json.NewEncoder(w).Encode(dlMap)
}