This MR adds the ability to see log traces associated with Gitlab CI jobs, via the new `perform_linewise_action` keybinding in the pipeline popup.
60 lines
1.3 KiB
Go
60 lines
1.3 KiB
Go
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)
|
|
|
|
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),
|
|
}
|
|
|
|
json.NewEncoder(w).Encode(response)
|
|
}
|