7 Group
Lunny Xiao edited this page 2015-03-20 22:19:54 +08:00

Group let's you simple your routers.

There are two ways to use Group:

g := tango.NewGroup()
g.Get("/1", func() string {
    return "/1"
})
g.Post("/2", func() string {
    return "/2"
})

o := tango.Classic()
o.Group("/api", g)

Then /api/1 will match function 1 and /api/2 will match function 2.

The second way:

o := tango.Classic()
o.Group("/api", func(g *tango.Group) {
    g.Get("/1", func() string {
	return "/1"
    })
    g.Post("/2", func() string {
	return "/2"
    })
})

Then /api/1 will match function 1 and /api/2 will match function 2.

Of course, Group can has children Group:

o := tango.Classic()
o.Group("/api", func(g *tango.Group) {
    g.Group("/v1", func(cg *tango.Group) {
        cg.Get("/1", func() string {
	    return "/1"
        })
        cg.Post("/2", func() string {
	    return "/2"
        })
    })
})

Then /api/v1/1 will match function 1 and /api/v2/2 will match function 2.

Sometimes, we only split routers logically, but they has same parent router. Then we can only put blank string to make virtual Groups:

o := tango.Classic()
o.Group("", func(g *tango.Group) {
    g.Get("/1", func() string {
	return "/1"
    })
})

o.Group("", func(g *tango.Group) {
    g.Post("/2", func() string {
	return "/2"
    })
})

Then /1 will match function 1 and /2 will match function 2.

Last, you can add middlewares to a group.

o := tango.Classic()
o.Group("/api/v1", func(g *tango.Group) {
    g.Use(handlers...)
    g.Get("/1", func() string {
    return "/1"
    })
})