2017-12-28 11:24:34 -08:00
|
|
|
package middleware
|
|
|
|
|
|
|
|
import (
|
2021-07-15 23:34:01 +03:00
|
|
|
"errors"
|
2020-09-03 00:39:57 -07:00
|
|
|
"regexp"
|
2021-02-08 15:58:55 +01:00
|
|
|
|
2021-07-15 23:34:01 +03:00
|
|
|
"github.com/labstack/echo/v5"
|
2017-12-28 11:24:34 -08:00
|
|
|
)
|
|
|
|
|
2021-07-15 23:34:01 +03:00
|
|
|
// RewriteConfig defines the config for Rewrite middleware.
|
|
|
|
type RewriteConfig struct {
|
|
|
|
// Skipper defines a function to skip middleware.
|
|
|
|
Skipper Skipper
|
2017-12-28 11:24:34 -08:00
|
|
|
|
2021-07-15 23:34:01 +03:00
|
|
|
// Rules defines the URL path rewrite rules. The values captured in asterisk can be
|
|
|
|
// retrieved by index e.g. $1, $2 and so on.
|
|
|
|
// Example:
|
|
|
|
// "/old": "/new",
|
|
|
|
// "/api/*": "/$1",
|
|
|
|
// "/js/*": "/public/javascripts/$1",
|
|
|
|
// "/users/*/orders/*": "/user/$1/order/$2",
|
|
|
|
// Required.
|
|
|
|
Rules map[string]string
|
2017-12-28 11:24:34 -08:00
|
|
|
|
2021-07-15 23:34:01 +03:00
|
|
|
// RegexRules defines the URL path rewrite rules using regexp.Rexexp with captures
|
|
|
|
// Every capture group in the values can be retrieved by index e.g. $1, $2 and so on.
|
|
|
|
// Example:
|
|
|
|
// "^/old/[0.9]+/": "/new",
|
|
|
|
// "^/api/.+?/(.*)": "/v2/$1",
|
|
|
|
RegexRules map[*regexp.Regexp]string
|
|
|
|
}
|
2017-12-28 11:24:34 -08:00
|
|
|
|
|
|
|
// Rewrite returns a Rewrite middleware.
|
|
|
|
//
|
|
|
|
// Rewrite middleware rewrites the URL path based on the provided rules.
|
|
|
|
func Rewrite(rules map[string]string) echo.MiddlewareFunc {
|
2021-07-15 23:34:01 +03:00
|
|
|
c := RewriteConfig{}
|
2017-12-28 11:24:34 -08:00
|
|
|
c.Rules = rules
|
|
|
|
return RewriteWithConfig(c)
|
|
|
|
}
|
|
|
|
|
2021-07-15 23:34:01 +03:00
|
|
|
// RewriteWithConfig returns a Rewrite middleware or panics on invalid configuration.
|
|
|
|
//
|
|
|
|
// Rewrite middleware rewrites the URL path based on the provided rules.
|
2017-12-28 11:24:34 -08:00
|
|
|
func RewriteWithConfig(config RewriteConfig) echo.MiddlewareFunc {
|
2021-07-15 23:34:01 +03:00
|
|
|
return toMiddlewareOrPanic(config)
|
|
|
|
}
|
2021-02-08 15:58:55 +01:00
|
|
|
|
2021-07-15 23:34:01 +03:00
|
|
|
// ToMiddleware converts RewriteConfig to middleware or returns an error for invalid configuration
|
|
|
|
func (config RewriteConfig) ToMiddleware() (echo.MiddlewareFunc, error) {
|
2017-12-28 11:24:34 -08:00
|
|
|
if config.Skipper == nil {
|
2021-07-15 23:34:01 +03:00
|
|
|
config.Skipper = DefaultSkipper
|
|
|
|
}
|
|
|
|
if config.Rules == nil && config.RegexRules == nil {
|
|
|
|
return nil, errors.New("echo rewrite middleware requires url path rewrite rules or regex rules")
|
2017-12-28 11:24:34 -08:00
|
|
|
}
|
|
|
|
|
2021-02-08 15:58:55 +01:00
|
|
|
if config.RegexRules == nil {
|
|
|
|
config.RegexRules = make(map[*regexp.Regexp]string)
|
|
|
|
}
|
|
|
|
for k, v := range rewriteRulesRegex(config.Rules) {
|
|
|
|
config.RegexRules[k] = v
|
|
|
|
}
|
2017-12-28 11:24:34 -08:00
|
|
|
|
|
|
|
return func(next echo.HandlerFunc) echo.HandlerFunc {
|
|
|
|
return func(c echo.Context) (err error) {
|
|
|
|
if config.Skipper(c) {
|
|
|
|
return next(c)
|
|
|
|
}
|
|
|
|
|
2021-03-09 14:22:11 +02:00
|
|
|
if err := rewriteURL(config.RegexRules, c.Request()); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2018-01-30 10:27:57 -08:00
|
|
|
return next(c)
|
2017-12-28 11:24:34 -08:00
|
|
|
}
|
2021-07-15 23:34:01 +03:00
|
|
|
}, nil
|
2017-12-28 11:24:34 -08:00
|
|
|
}
|