-
Notifications
You must be signed in to change notification settings - Fork 126
/
task_manifest.go
48 lines (41 loc) · 1.38 KB
/
task_manifest.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
package route
import (
"context"
"net/http"
"github.com/evergreen-ci/evergreen/rest/data"
"github.com/evergreen-ci/gimlet"
"github.com/pkg/errors"
)
// getManifestHandler implements the route GET /tasks/{task_id}/manifest.
// It fetches the associated manifest and returns it to the user.
type getManifestHandler struct {
taskID string
}
func makeGetManifestHandler() gimlet.RouteHandler {
return &getManifestHandler{}
}
// Factory creates an instance of the handler.
//
// @Summary Get manifest for task
// @Description Fetch the manifest for a task using the task ID.
// @Tags manifests
// @Router /tasks/{task_id}/manifest [get]
// @Security Api-User || Api-Key
// @Param task_id path string true "task ID"
// @Success 200 {object} manifest.Manifest
func (h *getManifestHandler) Factory() gimlet.RouteHandler {
return &getManifestHandler{}
}
// ParseAndValidate fetches the taskId from the http request.
func (h *getManifestHandler) Parse(ctx context.Context, r *http.Request) error {
h.taskID = gimlet.GetVars(r)["task_id"]
return nil
}
// Execute returns the manifest for the given task.
func (h *getManifestHandler) Run(ctx context.Context) gimlet.Responder {
manifest, err := data.GetManifestByTask(h.taskID)
if err != nil {
return gimlet.NewJSONInternalErrorResponse(errors.Wrapf(err, "getting manifest using task '%s'", h.taskID))
}
return gimlet.NewJSONResponse(manifest)
}