package handlers import ( "context" "errors" "net/http" "code.tjo.space/mentos1386/zdravko/internal/models" "code.tjo.space/mentos1386/zdravko/internal/services" "code.tjo.space/mentos1386/zdravko/pkg/api" "github.com/labstack/echo/v4" "gorm.io/gorm" ) type ApiV1WorkersConnectGETResponse struct { Endpoint string `json:"endpoint"` Group string `json:"group"` Slug string `json:"slug"` } func (h *BaseHandler) ApiV1WorkersConnectGET(c echo.Context) error { ctx := context.Background() cc := c.(AuthenticatedContext) worker, err := services.GetWorker(ctx, h.query, cc.Principal.Worker.Slug) if err != nil { if errors.Is(err, gorm.ErrRecordNotFound) { return echo.NewHTTPError(http.StatusUnauthorized, "Token invalid") } return err } response := ApiV1WorkersConnectGETResponse{ Endpoint: h.config.Temporal.ServerHost, Group: worker.Group, Slug: worker.Slug, } return c.JSON(http.StatusOK, response) } // TODO: Can we instead get this from the Workflow outcome? // // To somehow listen for the outcomes and then store them automatically. func (h *BaseHandler) ApiV1MonitorsHistoryPOST(c echo.Context) error { ctx := context.Background() slug := c.Param("slug") var body api.ApiV1MonitorsHistoryPOSTBody err := (&echo.DefaultBinder{}).BindBody(c, &body) if err != nil { return err } monitor, err := services.GetMonitor(ctx, h.query, slug) if err != nil { return err } err = h.query.Monitor.History.Model(monitor).Append( &models.MonitorHistory{ Status: body.Status, Note: body.Note, }) if err != nil { return err } return c.JSON(http.StatusCreated, map[string]string{"status": "ok"}) }