2019-07-12 11:10:03 +02:00
|
|
|
package api
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
2019-09-02 11:38:04 +02:00
|
|
|
"fmt"
|
2019-07-12 11:10:03 +02:00
|
|
|
"net/http"
|
2024-01-25 10:56:05 +02:00
|
|
|
"net/url"
|
2019-07-12 11:10:03 +02:00
|
|
|
"sort"
|
|
|
|
"strconv"
|
|
|
|
|
2019-08-03 03:58:23 +02:00
|
|
|
"github.com/gorilla/mux"
|
2022-11-21 18:36:05 +01:00
|
|
|
"github.com/rs/zerolog/log"
|
2023-02-03 15:24:05 +01:00
|
|
|
"github.com/traefik/traefik/v3/pkg/config/static"
|
2019-07-12 11:10:03 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
type entryPointRepresentation struct {
|
|
|
|
*static.EntryPoint
|
|
|
|
Name string `json:"name,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h Handler) getEntryPoints(rw http.ResponseWriter, request *http.Request) {
|
|
|
|
results := make([]entryPointRepresentation, 0, len(h.staticConfig.EntryPoints))
|
|
|
|
|
|
|
|
for name, ep := range h.staticConfig.EntryPoints {
|
|
|
|
results = append(results, entryPointRepresentation{
|
|
|
|
EntryPoint: ep,
|
|
|
|
Name: name,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
sort.Slice(results, func(i, j int) bool {
|
|
|
|
return results[i].Name < results[j].Name
|
|
|
|
})
|
|
|
|
|
2019-09-02 11:38:04 +02:00
|
|
|
rw.Header().Set("Content-Type", "application/json")
|
|
|
|
|
2019-07-12 11:10:03 +02:00
|
|
|
pageInfo, err := pagination(request, len(results))
|
|
|
|
if err != nil {
|
2019-09-02 11:38:04 +02:00
|
|
|
writeError(rw, err.Error(), http.StatusBadRequest)
|
2019-07-12 11:10:03 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
rw.Header().Set(nextPageHeader, strconv.Itoa(pageInfo.nextPage))
|
|
|
|
|
|
|
|
err = json.NewEncoder(rw).Encode(results[pageInfo.startIndex:pageInfo.endIndex])
|
|
|
|
if err != nil {
|
2022-11-21 18:36:05 +01:00
|
|
|
log.Ctx(request.Context()).Error().Err(err).Send()
|
2019-09-02 11:38:04 +02:00
|
|
|
writeError(rw, err.Error(), http.StatusInternalServerError)
|
2019-07-12 11:10:03 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h Handler) getEntryPoint(rw http.ResponseWriter, request *http.Request) {
|
2024-01-25 10:56:05 +02:00
|
|
|
scapedEntryPointID := mux.Vars(request)["entryPointID"]
|
|
|
|
|
|
|
|
entryPointID, err := url.PathUnescape(scapedEntryPointID)
|
|
|
|
if err != nil {
|
|
|
|
writeError(rw, fmt.Sprintf("unable to decode entryPointID %q: %s", scapedEntryPointID, err), http.StatusBadRequest)
|
|
|
|
return
|
|
|
|
}
|
2019-07-12 11:10:03 +02:00
|
|
|
|
2019-09-02 11:38:04 +02:00
|
|
|
rw.Header().Set("Content-Type", "application/json")
|
|
|
|
|
2019-07-12 11:10:03 +02:00
|
|
|
ep, ok := h.staticConfig.EntryPoints[entryPointID]
|
|
|
|
if !ok {
|
2019-09-02 11:38:04 +02:00
|
|
|
writeError(rw, fmt.Sprintf("entry point not found: %s", entryPointID), http.StatusNotFound)
|
2019-07-12 11:10:03 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
result := entryPointRepresentation{
|
|
|
|
EntryPoint: ep,
|
|
|
|
Name: entryPointID,
|
|
|
|
}
|
|
|
|
|
2024-01-25 10:56:05 +02:00
|
|
|
err = json.NewEncoder(rw).Encode(result)
|
2019-07-12 11:10:03 +02:00
|
|
|
if err != nil {
|
2022-11-21 18:36:05 +01:00
|
|
|
log.Ctx(request.Context()).Error().Err(err).Send()
|
2019-09-02 11:38:04 +02:00
|
|
|
writeError(rw, err.Error(), http.StatusInternalServerError)
|
2019-07-12 11:10:03 +02:00
|
|
|
}
|
|
|
|
}
|