Add support for Function and Trigger domain objects (#1060)

Vast commit, includes:

 * Introduces the Trigger domain entity.
 * Introduces the Fns domain entity.
 * V2 of the API for interacting with the new entities in swaggerv2.yml
 * Adds v2 end points for Apps to support PUT updates.
 * Rewrites the datastore level tests into a new pattern.
 * V2 routes use entity ID over name as the path parameter.
This commit is contained in:
Tom Coupland
2018-06-25 15:37:06 +01:00
committed by GitHub
parent a5abecaafb
commit 3ebff051a4
76 changed files with 5820 additions and 892 deletions

View File

@@ -11,9 +11,9 @@ import (
func (s *Server) handleAppUpdate(c *gin.Context) {
ctx := c.Request.Context()
wapp := models.AppWrapper{}
app := &models.App{}
err := c.BindJSON(&wapp)
err := c.BindJSON(app)
if err != nil {
if models.IsAPIError(err) {
handleErrorResponse(c, err)
@@ -23,24 +23,20 @@ func (s *Server) handleAppUpdate(c *gin.Context) {
return
}
if wapp.App == nil {
handleErrorResponse(c, models.ErrAppsMissingNew)
id := c.Param(api.ParamAppID)
if app.ID == "" {
app.ID = id
}
if app.ID != id {
handleErrorResponse(c, models.ErrAppsIDMismatch)
return
}
if wapp.App.Name != "" {
handleErrorResponse(c, models.ErrAppsNameImmutable)
return
}
wapp.App.Name = c.MustGet(api.App).(string)
wapp.App.ID = c.MustGet(api.AppID).(string)
app, err := s.datastore.UpdateApp(ctx, wapp.App)
app, err = s.datastore.UpdateApp(ctx, app)
if err != nil {
handleErrorResponse(c, err)
return
}
c.JSON(http.StatusOK, appResponse{"App successfully updated", app})
c.JSON(http.StatusOK, app)
}