From cdd4a7438e63c55448c2b8a102d22a92cb839915 Mon Sep 17 00:00:00 2001 From: LTLA Date: Wed, 10 Apr 2024 09:31:25 -0700 Subject: [PATCH] Fixed handling of absolute and relative paths. --- main.go | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/main.go b/main.go index 64bb552..7ad843f 100644 --- a/main.go +++ b/main.go @@ -71,23 +71,23 @@ func main() { path := filepath.Base(r.PathValue("path")) log.Println("processing " + path) - reqpath := filepath.Join(staging, path) + if !strings.HasPrefix(path, "request-") { + dumpErrorResponse(w, http.StatusBadRequest, "file name should start with \"request-\"", path) + return + } + reqtype := strings.TrimPrefix(path, "request-") + + reqpath := filepath.Join(staging, path) info, err := os.Stat(reqpath) if err != nil { - dumpErrorResponse(w, http.StatusBadRequest, fmt.Sprintf("failed to stat; %v", err), reqpath) + dumpErrorResponse(w, http.StatusBadRequest, fmt.Sprintf("failed to stat; %v", err), path) return } if info.IsDir() { - dumpErrorResponse(w, http.StatusBadRequest, "path is a directory", reqpath) - return - } - - if !strings.HasPrefix(reqpath, "request-") { - dumpErrorResponse(w, http.StatusBadRequest, "file name should start with \"request-\"", reqpath) + dumpErrorResponse(w, http.StatusBadRequest, "path is a directory", path) return } - reqtype := strings.TrimPrefix(reqpath, "request-") var reportable_err error payload := map[string]interface{}{} @@ -136,14 +136,14 @@ func main() { if reportable_err == nil { payload["status"] = "SUCCESS" - dumpJsonResponse(w, http.StatusOK, &payload, reqpath) + dumpJsonResponse(w, http.StatusOK, &payload, path) } else { status_code := http.StatusInternalServerError var http_err *httpError if errors.As(reportable_err, &http_err) { status_code = http_err.Status } - dumpErrorResponse(w, status_code, reportable_err.Error(), reqpath) + dumpErrorResponse(w, status_code, reportable_err.Error(), path) } })