cmd/pkgserver: satisfy handler signature in method

This is somewhat cleaner.

Signed-off-by: Ophestra <cat@gensokyo.uk>
This commit is contained in:
2026-03-11 02:18:21 +09:00
parent 112c32fee2
commit e130443cf4
2 changed files with 69 additions and 73 deletions

View File

@@ -27,8 +27,8 @@ var (
infoPayloadOnce sync.Once infoPayloadOnce sync.Once
) )
// serveInfo returns constant system information. // handleInfo writes constant system information.
func serveInfo(w http.ResponseWriter, _ *http.Request) { func handleInfo(w http.ResponseWriter, _ *http.Request) {
infoPayloadOnce.Do(func() { infoPayloadOnce.Do(func() {
infoPayload.Count = int(rosa.PresetUnexportedStart) infoPayload.Count = int(rosa.PresetUnexportedStart)
infoPayload.HakureiVersion = info.Version() infoPayload.HakureiVersion = info.Version()
@@ -37,8 +37,7 @@ func serveInfo(w http.ResponseWriter, _ *http.Request) {
writeAPIPayload(w, infoPayload) writeAPIPayload(w, infoPayload)
} }
func (index *packageIndex) serveStatus() http.HandlerFunc { func (index *packageIndex) handleStatus(w http.ResponseWriter, r *http.Request) {
return func(w http.ResponseWriter, r *http.Request) {
download := path.Dir(r.URL.Path) == "/status" download := path.Dir(r.URL.Path) == "/status"
if index == nil { if index == nil {
http.Error(w, "index is nil", http.StatusInternalServerError) http.Error(w, "index is nil", http.StatusInternalServerError)
@@ -80,11 +79,9 @@ func (index *packageIndex) serveStatus() http.HandlerFunc {
} else { } else {
http.NotFound(w, r) http.NotFound(w, r)
} }
}
} }
func (index *packageIndex) serveGet() http.HandlerFunc { func (index *packageIndex) handleGet(w http.ResponseWriter, r *http.Request) {
return func(w http.ResponseWriter, r *http.Request) {
q := r.URL.Query() q := r.URL.Query()
limit, err := strconv.Atoi(q.Get("limit")) limit, err := strconv.Atoi(q.Get("limit"))
if err != nil || limit > 100 || limit < 1 { if err != nil || limit > 100 || limit < 1 {
@@ -107,16 +104,15 @@ func (index *packageIndex) serveGet() http.HandlerFunc {
Count int `json:"count"` Count int `json:"count"`
Values []*metadata `json:"values"` Values []*metadata `json:"values"`
}{len(values), values}) }{len(values), values})
}
} }
const ApiVersion = "v1" const ApiVersion = "v1"
func apiRoutes(mux *http.ServeMux, index *packageIndex) { func apiRoutes(mux *http.ServeMux, index *packageIndex) {
mux.HandleFunc(fmt.Sprintf("GET /api/%s/info", ApiVersion), serveInfo) mux.HandleFunc(fmt.Sprintf("GET /api/%s/info", ApiVersion), handleInfo)
mux.HandleFunc(fmt.Sprintf("GET /api/%s/get", ApiVersion), index.serveGet()) mux.HandleFunc(fmt.Sprintf("GET /api/%s/get", ApiVersion), index.handleGet)
mux.HandleFunc(fmt.Sprintf("GET /api/%s/status/", ApiVersion), index.serveStatus()) mux.HandleFunc(fmt.Sprintf("GET /api/%s/status/", ApiVersion), index.handleStatus)
mux.HandleFunc("GET /status/", index.serveStatus()) mux.HandleFunc("GET /status/", index.handleStatus)
} }
// writeAPIPayload sets headers common to API responses and encodes payload as // writeAPIPayload sets headers common to API responses and encodes payload as

View File

@@ -18,7 +18,7 @@ func TestAPIInfo(t *testing.T) {
t.Parallel() t.Parallel()
w := httptest.NewRecorder() w := httptest.NewRecorder()
serveInfo(w, httptest.NewRequestWithContext( handleInfo(w, httptest.NewRequestWithContext(
t.Context(), t.Context(),
http.MethodGet, http.MethodGet,
prefix+"info", prefix+"info",
@@ -42,7 +42,7 @@ func TestAPIGet(t *testing.T) {
index := newIndex(t) index := newIndex(t)
newRequest := func(suffix string) *httptest.ResponseRecorder { newRequest := func(suffix string) *httptest.ResponseRecorder {
w := httptest.NewRecorder() w := httptest.NewRecorder()
index.serveGet()(w, httptest.NewRequestWithContext( index.handleGet(w, httptest.NewRequestWithContext(
t.Context(), t.Context(),
http.MethodGet, http.MethodGet,
target+suffix, target+suffix,