package gitinstallation import ( "fmt" "net/http" "strings" "github.com/porter-dev/porter/api/server/handlers" "github.com/porter-dev/porter/api/server/shared" "github.com/porter-dev/porter/api/server/shared/apierrors" "github.com/porter-dev/porter/api/server/shared/commonutils" "github.com/porter-dev/porter/api/server/shared/config" ) type GetWorkflowLogsHandler struct { handlers.PorterHandlerReadWriter } func NewGetWorkflowLogsHandler( config *config.Config, decoderValidator shared.RequestDecoderValidator, writer shared.ResultWriter, ) *GetWorkflowLogsHandler { return &GetWorkflowLogsHandler{ PorterHandlerReadWriter: handlers.NewDefaultPorterHandler(config, decoderValidator, writer), } } func (c *GetWorkflowLogsHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) { owner, name, ok := commonutils.GetOwnerAndNameParams(c, w, r) fmt.Printf("HSIEOFDSJPGfSDLKGaslkf") if !ok { return } releaseName := r.URL.Query().Get("release_name") filename := r.URL.Query().Get("filename") if filename == "" && releaseName == "" { c.HandleAPIError(w, r, apierrors.NewErrInternal(fmt.Errorf("filename and release name are both empty"))) return } if filename == "" { if c.Config().ServerConf.InstanceName != "" { filename = fmt.Sprintf("porter_%s_%s.yml", strings.Replace( strings.ToLower(releaseName), "-", "_", -1), strings.ToLower(c.Config().ServerConf.InstanceName), ) } else { filename = fmt.Sprintf("porter_%s.yml", strings.Replace( strings.ToLower(releaseName), "-", "_", -1), ) } } client, err := GetGithubAppClientFromRequest(c.Config(), r) if err != nil { c.HandleAPIError(w, r, apierrors.NewErrInternal(err)) return } latestWorkflowRun, err := commonutils.GetLatestWorkflowRun(client, owner, name, filename, "") if err != nil { c.HandleAPIError(w, r, apierrors.NewErrInternal(err)) return } logsURL, _, err := client.Actions.GetWorkflowRunLogs(r.Context(), owner, name, latestWorkflowRun.GetID(), false) if err != nil { c.HandleAPIError(w, r, apierrors.NewErrInternal(err)) return } fmt.Printf("Fetched workflow logs URL: %v\n", logsURL.String()) c.WriteResult(w, r, logsURL.String()) }