2016-04-24 21:07:55 +08:00
|
|
|
package middleware
|
|
|
|
|
2018-10-14 17:16:58 +02:00
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
|
2019-01-30 12:56:56 +02:00
|
|
|
"github.com/labstack/echo/v4"
|
2018-10-14 17:16:58 +02:00
|
|
|
)
|
2016-04-24 21:07:55 +08:00
|
|
|
|
2016-04-27 21:08:06 -07:00
|
|
|
type (
|
2016-07-27 09:34:44 -07:00
|
|
|
// MethodOverrideConfig defines the config for MethodOverride middleware.
|
2016-04-27 21:08:06 -07:00
|
|
|
MethodOverrideConfig struct {
|
2016-07-27 09:34:44 -07:00
|
|
|
// Skipper defines a function to skip middleware.
|
|
|
|
Skipper Skipper
|
|
|
|
|
2016-04-27 22:03:54 -07:00
|
|
|
// Getter is a function that gets overridden method from the request.
|
2016-05-10 11:52:04 -07:00
|
|
|
// Optional. Default values MethodFromHeader(echo.HeaderXHTTPMethodOverride).
|
2016-04-27 21:08:06 -07:00
|
|
|
Getter MethodOverrideGetter
|
|
|
|
}
|
|
|
|
|
|
|
|
// MethodOverrideGetter is a function that gets overridden method from the request
|
|
|
|
MethodOverrideGetter func(echo.Context) string
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
2016-07-27 09:34:44 -07:00
|
|
|
// DefaultMethodOverrideConfig is the default MethodOverride middleware config.
|
2016-04-27 21:08:06 -07:00
|
|
|
DefaultMethodOverrideConfig = MethodOverrideConfig{
|
2017-01-28 11:43:56 -08:00
|
|
|
Skipper: DefaultSkipper,
|
2016-07-27 09:34:44 -07:00
|
|
|
Getter: MethodFromHeader(echo.HeaderXHTTPMethodOverride),
|
2016-04-27 21:08:06 -07:00
|
|
|
}
|
2016-04-24 21:07:55 +08:00
|
|
|
)
|
|
|
|
|
2016-07-27 09:34:44 -07:00
|
|
|
// MethodOverride returns a MethodOverride middleware.
|
2016-05-04 23:33:05 -07:00
|
|
|
// MethodOverride middleware checks for the overridden method from the request and
|
2016-04-27 21:08:06 -07:00
|
|
|
// uses it instead of the original method.
|
|
|
|
//
|
2016-04-27 22:03:54 -07:00
|
|
|
// For security reasons, only `POST` method can be overridden.
|
2016-04-27 21:08:06 -07:00
|
|
|
func MethodOverride() echo.MiddlewareFunc {
|
|
|
|
return MethodOverrideWithConfig(DefaultMethodOverrideConfig)
|
2016-04-24 21:07:55 +08:00
|
|
|
}
|
|
|
|
|
2016-08-31 20:10:14 -07:00
|
|
|
// MethodOverrideWithConfig returns a MethodOverride middleware with config.
|
2016-05-12 17:45:00 -07:00
|
|
|
// See: `MethodOverride()`.
|
2016-04-27 21:08:06 -07:00
|
|
|
func MethodOverrideWithConfig(config MethodOverrideConfig) echo.MiddlewareFunc {
|
2016-05-03 08:32:28 -07:00
|
|
|
// Defaults
|
2016-07-27 09:34:44 -07:00
|
|
|
if config.Skipper == nil {
|
|
|
|
config.Skipper = DefaultMethodOverrideConfig.Skipper
|
|
|
|
}
|
2016-05-03 08:32:28 -07:00
|
|
|
if config.Getter == nil {
|
|
|
|
config.Getter = DefaultMethodOverrideConfig.Getter
|
|
|
|
}
|
|
|
|
|
2016-04-24 21:07:55 +08:00
|
|
|
return func(next echo.HandlerFunc) echo.HandlerFunc {
|
|
|
|
return func(c echo.Context) error {
|
2016-07-27 09:34:44 -07:00
|
|
|
if config.Skipper(c) {
|
|
|
|
return next(c)
|
|
|
|
}
|
|
|
|
|
2016-04-27 21:08:06 -07:00
|
|
|
req := c.Request()
|
2018-10-14 17:16:58 +02:00
|
|
|
if req.Method == http.MethodPost {
|
2016-04-27 21:08:06 -07:00
|
|
|
m := config.Getter(c)
|
2016-04-24 21:07:55 +08:00
|
|
|
if m != "" {
|
2016-09-22 22:53:44 -07:00
|
|
|
req.Method = m
|
2016-04-24 21:07:55 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return next(c)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-04-27 21:08:06 -07:00
|
|
|
|
|
|
|
// MethodFromHeader is a `MethodOverrideGetter` that gets overridden method from
|
|
|
|
// the request header.
|
|
|
|
func MethodFromHeader(header string) MethodOverrideGetter {
|
|
|
|
return func(c echo.Context) string {
|
2016-09-22 22:53:44 -07:00
|
|
|
return c.Request().Header.Get(header)
|
2016-04-27 21:08:06 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// MethodFromForm is a `MethodOverrideGetter` that gets overridden method from the
|
|
|
|
// form parameter.
|
|
|
|
func MethodFromForm(param string) MethodOverrideGetter {
|
|
|
|
return func(c echo.Context) string {
|
|
|
|
return c.FormValue(param)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// MethodFromQuery is a `MethodOverrideGetter` that gets overridden method from
|
|
|
|
// the query parameter.
|
|
|
|
func MethodFromQuery(param string) MethodOverrideGetter {
|
|
|
|
return func(c echo.Context) string {
|
|
|
|
return c.QueryParam(param)
|
|
|
|
}
|
|
|
|
}
|