mirror of
https://github.com/fnproject/fn.git
synced 2022-10-28 21:29:17 +03:00
this patch has no behavior changes, changes are: * server.Datastore() -> server.datastore * server.MQ -> server.mq * server.LogDB -> server.logstore * server.Agent -> server.agent these were at a minimum not uniform. further, it's probably better to force configuration through initialization in `server.New` to ensure thread safety of referencing if someone does want to modify these as well as forcing things into our initialization path and reducing the surface area of the Server abstraction.
51 lines
877 B
Go
51 lines
877 B
Go
package server
|
|
|
|
import (
|
|
"net/http"
|
|
|
|
"github.com/fnproject/fn/api/models"
|
|
"github.com/gin-gonic/gin"
|
|
)
|
|
|
|
func (s *Server) handleAppCreate(c *gin.Context) {
|
|
ctx := c.Request.Context()
|
|
|
|
var wapp models.AppWrapper
|
|
|
|
err := c.BindJSON(&wapp)
|
|
if err != nil {
|
|
handleErrorResponse(c, models.ErrInvalidJSON)
|
|
return
|
|
}
|
|
|
|
if wapp.App == nil {
|
|
handleErrorResponse(c, models.ErrAppsMissingNew)
|
|
return
|
|
}
|
|
|
|
if err = wapp.Validate(); err != nil {
|
|
handleErrorResponse(c, err)
|
|
return
|
|
}
|
|
|
|
err = s.FireBeforeAppCreate(ctx, wapp.App)
|
|
if err != nil {
|
|
handleErrorResponse(c, err)
|
|
return
|
|
}
|
|
|
|
app, err := s.datastore.InsertApp(ctx, wapp.App)
|
|
if err != nil {
|
|
handleErrorResponse(c, err)
|
|
return
|
|
}
|
|
|
|
err = s.FireAfterAppCreate(ctx, wapp.App)
|
|
if err != nil {
|
|
handleErrorResponse(c, err)
|
|
return
|
|
}
|
|
|
|
c.JSON(http.StatusOK, appResponse{"App successfully created", app})
|
|
}
|