get_job_status.go 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. package release
  2. import (
  3. "net/http"
  4. "github.com/porter-dev/porter/api/server/authz"
  5. "github.com/porter-dev/porter/api/server/handlers"
  6. "github.com/porter-dev/porter/api/server/shared"
  7. "github.com/porter-dev/porter/api/server/shared/apierrors"
  8. "github.com/porter-dev/porter/api/server/shared/config"
  9. "github.com/porter-dev/porter/api/types"
  10. "github.com/porter-dev/porter/internal/models"
  11. "helm.sh/helm/v3/pkg/release"
  12. )
  13. type GetJobsStatusHandler struct {
  14. handlers.PorterHandlerReadWriter
  15. authz.KubernetesAgentGetter
  16. }
  17. func NewGetJobsStatusHandler(
  18. config *config.Config,
  19. writer shared.ResultWriter,
  20. ) *GetJobsStatusHandler {
  21. return &GetJobsStatusHandler{
  22. PorterHandlerReadWriter: handlers.NewDefaultPorterHandler(config, nil, writer),
  23. KubernetesAgentGetter: authz.NewOutOfClusterAgentGetter(config),
  24. }
  25. }
  26. func (c *GetJobsStatusHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  27. helmRelease, _ := r.Context().Value(types.ReleaseScope).(*release.Release)
  28. cluster, _ := r.Context().Value(types.ClusterScope).(*models.Cluster)
  29. agent, err := c.GetAgent(r, cluster, "")
  30. if err != nil {
  31. c.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  32. return
  33. }
  34. jobs, err := agent.ListJobsByLabel(helmRelease.Namespace, getJobLabels(helmRelease)...)
  35. if err != nil {
  36. c.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  37. return
  38. }
  39. res := &types.GetJobsStatusResponse{}
  40. // get the most recent job
  41. if len(jobs) > 0 {
  42. mostRecentJob := jobs[0]
  43. for _, job := range jobs {
  44. createdAt := job.ObjectMeta.CreationTimestamp
  45. if mostRecentJob.CreationTimestamp.Before(&createdAt) {
  46. mostRecentJob = job
  47. }
  48. }
  49. res.StartTime = mostRecentJob.Status.StartTime
  50. // get the status of the most recent job
  51. if mostRecentJob.Status.Succeeded >= 1 {
  52. res.Status = "succeeded"
  53. } else if mostRecentJob.Status.Active >= 1 {
  54. res.Status = "running"
  55. } else if mostRecentJob.Status.Failed >= 1 {
  56. res.Status = "failed"
  57. }
  58. }
  59. c.WriteResult(w, r, res)
  60. }