Clean paths in Group

This commit is contained in:
Nise Void 2018-08-26 11:17:05 +02:00
parent ae68248d25
commit 5a44e82541
Signed by: NiseVoid
GPG Key ID: FBA14AC83EA602F3

View File

@ -2,48 +2,52 @@ package router
import urlpath "path" import urlpath "path"
func join(prefix, path string) string {
return urlpath.Join(prefix, urlpath.Clean(path))
}
type Group struct { type Group struct {
router *Router router *Router
prefix string prefix string
} }
func (g *Group) Group(prefix string) *Group { func (g *Group) Group(prefix string) *Group {
return &Group{prefix: urlpath.Join(g.prefix, prefix), router: g.router} return &Group{prefix: join(g.prefix, prefix), router: g.router}
} }
// GET adds a GET route // GET adds a GET route
func (g *Group) GET(path string, handle GetHandle) { func (g *Group) GET(path string, handle GetHandle) {
g.router.GET(urlpath.Join(g.prefix, path), handle) g.router.GET(join(g.prefix, path), handle)
} }
// POST adds a POST route // POST adds a POST route
func (g *Group) POST(path string, handle interface{}) { func (g *Group) POST(path string, handle interface{}) {
g.router.POST(urlpath.Join(g.prefix, path), handle) g.router.POST(join(g.prefix, path), handle)
} }
// DELETE adds a DELETE route // DELETE adds a DELETE route
func (g *Group) DELETE(path string, handle GetHandle) { func (g *Group) DELETE(path string, handle GetHandle) {
g.router.DELETE(urlpath.Join(g.prefix, path), handle) g.router.DELETE(join(g.prefix, path), handle)
} }
// PUT adds a PUT route // PUT adds a PUT route
func (g *Group) PUT(path string, handle interface{}) { func (g *Group) PUT(path string, handle interface{}) {
checkInterfaceHandle(handle) checkInterfaceHandle(handle)
g.router.PUT(urlpath.Join(g.prefix, path), handle) g.router.PUT(join(g.prefix, path), handle)
} }
// PATCH adds a PATCH route // PATCH adds a PATCH route
func (g *Group) PATCH(path string, handle interface{}) { func (g *Group) PATCH(path string, handle interface{}) {
checkInterfaceHandle(handle) checkInterfaceHandle(handle)
g.router.PATCH(urlpath.Join(g.prefix, path), handle) g.router.PATCH(join(g.prefix, path), handle)
} }
// HEAD adds a HEAD route // HEAD adds a HEAD route
func (g *Group) HEAD(path string, handle GetHandle) { func (g *Group) HEAD(path string, handle GetHandle) {
g.router.HEAD(urlpath.Join(g.prefix, path), handle) g.router.HEAD(join(g.prefix, path), handle)
} }
// OPTIONS adds a OPTIONS route // OPTIONS adds a OPTIONS route
func (g *Group) OPTIONS(path string, handle GetHandle) { func (g *Group) OPTIONS(path string, handle GetHandle) {
g.router.OPTIONS(urlpath.Join(g.prefix, path), handle) g.router.OPTIONS(join(g.prefix, path), handle)
} }