Merge branch 'middleware-update' into 'master'

Allow setting values in middleware context like gin context.

See merge request !99
This commit is contained in:
Travis Reeder
2017-07-12 15:05:13 -07:00
3 changed files with 21 additions and 4 deletions

View File

@@ -43,6 +43,23 @@ type middlewareContextImpl struct {
middlewares []Middleware
}
// Set is used to store a new key/value pair exclusively for this context.
// This is different than WithValue(), as it does not make a copy of the context with the new value, it will be available up the chain as well.
func (c *middlewareContextImpl) Set(key string, value interface{}) {
c.ginContext.Set(key, value)
}
// Get returns the value for the given key, ie: (value, true).
// If the value does not exists it returns (nil, false)
func (c *middlewareContextImpl) Get(key string) (value interface{}, exists bool) {
return c.ginContext.Get(key)
}
// MustGet returns the value for the given key if it exists, otherwise it panics.
func (c *middlewareContextImpl) MustGet(key string) interface{} {
return c.ginContext.MustGet(key)
}
func (c *middlewareContextImpl) Next() {
c.nextCalled = true
c.index++
@@ -91,12 +108,12 @@ func (s *Server) middlewareWrapperFunc(ctx context.Context) gin.HandlerFunc {
}
}
// AddAppEndpoint adds an endpoints to /v1/apps/:app/x
// AddMiddleware add middleware
func (s *Server) AddMiddleware(m Middleware) {
s.middlewares = append(s.middlewares, m)
}
// AddAppEndpoint adds an endpoints to /v1/apps/:app/x
// AddMiddlewareFunc adds middleware function
func (s *Server) AddMiddlewareFunc(m func(ctx MiddlewareContext, w http.ResponseWriter, r *http.Request, app *models.App) error) {
s.AddMiddleware(MiddlewareFunc(m))
}

View File

@@ -18,7 +18,7 @@ import (
)
const (
functionsDockerImage = "treeder/functions"
functionsDockerImage = "funcy/functions"
minRequiredDockerVersion = "17.5.0"
)

View File

@@ -7,7 +7,7 @@ import:
subpackages:
- models
- package: github.com/Sirupsen/logrus
repo: https://github.com/sirupsen/logrus
repo: https://github.com/sirupsen/logrus.git
vcs: git
version: ^v0.11.5
subpackages: