2018-09-01 17:18:38 +02:00
|
|
|
package echoswagger
|
|
|
|
|
2019-05-11 16:27:52 +02:00
|
|
|
import (
|
|
|
|
"reflect"
|
|
|
|
"strings"
|
|
|
|
)
|
2018-09-01 17:18:38 +02:00
|
|
|
|
|
|
|
func contains(list []string, s string) bool {
|
|
|
|
for _, t := range list {
|
|
|
|
if t == s {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
func containsMap(list []map[string][]string, m map[string][]string) bool {
|
|
|
|
LoopMaps:
|
|
|
|
for _, t := range list {
|
|
|
|
if len(t) != len(m) {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
for k, v := range t {
|
|
|
|
if mv, ok := m[k]; !ok || !equals(mv, v) {
|
|
|
|
continue LoopMaps
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
func equals(a []string, b []string) bool {
|
|
|
|
if len(a) != len(b) {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
for _, t := range a {
|
|
|
|
if !contains(b, t) {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
func indirect(v reflect.Value) reflect.Value {
|
|
|
|
if v.Kind() == reflect.Ptr {
|
2018-09-04 14:09:11 +02:00
|
|
|
ev := v.Elem()
|
|
|
|
if !ev.IsValid() {
|
|
|
|
ev = reflect.New(v.Type().Elem())
|
|
|
|
}
|
|
|
|
return indirect(ev)
|
2018-09-01 17:18:38 +02:00
|
|
|
}
|
|
|
|
return v
|
|
|
|
}
|
|
|
|
|
|
|
|
func indirectValue(p interface{}) reflect.Value {
|
|
|
|
v := reflect.ValueOf(p)
|
2018-09-04 14:09:11 +02:00
|
|
|
return indirect(v)
|
2018-09-01 17:18:38 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func indirectType(p interface{}) reflect.Type {
|
|
|
|
t := reflect.TypeOf(p)
|
|
|
|
LoopType:
|
|
|
|
if t.Kind() == reflect.Ptr {
|
|
|
|
t = t.Elem()
|
|
|
|
goto LoopType
|
|
|
|
}
|
|
|
|
return t
|
|
|
|
}
|
2018-09-16 10:35:29 +02:00
|
|
|
|
|
|
|
// "" → "/"
|
|
|
|
// "/" → "/"
|
|
|
|
// "a" → "/a"
|
|
|
|
// "/a" → "/a"
|
|
|
|
// "/a/" → "/a/"
|
|
|
|
func connectPath(paths ...string) string {
|
|
|
|
var result string
|
|
|
|
for i, path := range paths {
|
|
|
|
// add prefix slash
|
|
|
|
if len(path) == 0 || path[0] != '/' {
|
|
|
|
path = "/" + path
|
|
|
|
}
|
|
|
|
// remove suffix slash, ignore last path
|
|
|
|
if i != len(paths)-1 && len(path) != 0 && path[len(path)-1] == '/' {
|
|
|
|
path = path[:len(path)-1]
|
|
|
|
}
|
|
|
|
result += path
|
|
|
|
}
|
|
|
|
return result
|
|
|
|
}
|
2019-05-11 16:27:52 +02:00
|
|
|
|
|
|
|
func removeTrailingSlash(path string) string {
|
|
|
|
l := len(path) - 1
|
|
|
|
if l > 0 && strings.HasSuffix(path, "/") {
|
|
|
|
path = path[:l]
|
|
|
|
}
|
|
|
|
return path
|
|
|
|
}
|
|
|
|
|
|
|
|
func trimSuffixSlash(s, suffix string) string {
|
|
|
|
s = connectPath(s)
|
|
|
|
suffix = connectPath(suffix)
|
|
|
|
s = removeTrailingSlash(s)
|
|
|
|
suffix = removeTrailingSlash(suffix)
|
|
|
|
return strings.TrimSuffix(s, suffix)
|
|
|
|
}
|