package server import ( "context" "net/http" "github.com/gin-gonic/gin" "github.com/iron-io/functions/api/models" "github.com/iron-io/runner/common" ) func (s *Server) handleAppCreate(c *gin.Context) { ctx := c.MustGet("ctx").(context.Context) log := common.Logger(ctx) var wapp models.AppWrapper err := c.BindJSON(&wapp) if err != nil { log.WithError(err).Debug(models.ErrInvalidJSON) c.JSON(http.StatusBadRequest, simpleError(models.ErrInvalidJSON)) return } if wapp.App == nil { log.Debug(models.ErrAppsMissingNew) c.JSON(http.StatusBadRequest, simpleError(models.ErrAppsMissingNew)) return } if err := wapp.Validate(); err != nil { log.Error(err) c.JSON(http.StatusInternalServerError, simpleError(err)) return } err = Api.FireBeforeAppCreate(ctx, wapp.App) if err != nil { log.WithError(err).Errorln(models.ErrAppsCreate) c.JSON(http.StatusInternalServerError, simpleError(err)) return } _, err = Api.Datastore.InsertApp(ctx, wapp.App) if err != nil { log.WithError(err).Errorln(models.ErrAppsCreate) c.JSON(http.StatusInternalServerError, simpleError(err)) return } err = Api.FireAfterAppCreate(ctx, wapp.App) if err != nil { log.WithError(err).Errorln(models.ErrAppsCreate) c.JSON(http.StatusInternalServerError, simpleError(err)) return } c.JSON(http.StatusCreated, appResponse{"App successfully created", wapp.App}) }