package main import ( "encoding/json" "errors" "io" "net/http" ) type JobTraceRequest struct { JobId int `json:"job_id"` } type JobTraceResponse struct { SuccessResponse File string `json:"file"` } func JobHandler(w http.ResponseWriter, r *http.Request) { w.Header().Set("Content-Type", "application/json") c := r.Context().Value("client").(Client) if r.Method != http.MethodGet { w.Header().Set("Allow", http.MethodGet) c.handleError(w, errors.New("Invalid request type"), "That request type is not allowed", http.StatusMethodNotAllowed) return } body, err := io.ReadAll(r.Body) if err != nil { c.handleError(w, err, "Could not read request body", http.StatusBadRequest) } defer r.Body.Close() var jobTraceRequest JobTraceRequest err = json.Unmarshal(body, &jobTraceRequest) if err != nil { c.handleError(w, err, "Could not unmarshal data from request body", http.StatusBadRequest) } reader, _, err := c.git.Jobs.GetTraceFile(c.projectId, jobTraceRequest.JobId) if err != nil { c.handleError(w, err, "Could not get trace file for job", http.StatusBadRequest) } file, err := io.ReadAll(reader) if err != nil { c.handleError(w, err, "Could not read job trace file", http.StatusBadRequest) } response := JobTraceResponse{ SuccessResponse: SuccessResponse{ Status: http.StatusOK, Message: "Log file read", }, File: string(file), } err = json.NewEncoder(w).Encode(response) if err != nil { c.handleError(w, err, "Could not encode response", http.StatusInternalServerError) } }