-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathroute.go
130 lines (110 loc) · 3.83 KB
/
route.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
// Package makross is a high productive and modular web framework in Golang.
package makross
import (
"fmt"
"net/url"
"strings"
)
// Route represents a URL path pattern that can be used to match requested URLs.
type Route struct {
group *RouteGroup
method, path string
name, template string
tags []interface{}
routes []*Route
}
// Name sets the name of the route.
// This method will update the registration of the route in the makross as well.
func (r *Route) Name(name string) *Route {
r.name = name
r.group.makross.namedRoutes[name] = r
return r
}
// Tag associates some custom data with the route.
func (r *Route) Tag(value interface{}) *Route {
if len(r.routes) > 0 {
// this route is a composite one (a path with multiple methods)
for _, route := range r.routes {
route.Tag(value)
}
return r
}
if r.tags == nil {
r.tags = []interface{}{}
}
r.tags = append(r.tags, value)
return r
}
// Method returns the HTTP method that this route is associated with.
func (r *Route) Method() string {
return r.method
}
// Path returns the request path that this route should match.
func (r *Route) Path() string {
return r.group.prefix + r.path
}
// Tags returns all custom data associated with the route.
func (r *Route) Tags() []interface{} {
return r.tags
}
// Get adds the route to the makross using the GET HTTP method.
func (r *Route) Get(handlers ...Handler) *Route {
return r.group.add("GET", r.path, handlers)
}
// Post adds the route to the makross using the POST HTTP method.
func (r *Route) Post(handlers ...Handler) *Route {
return r.group.add("POST", r.path, handlers)
}
// Put adds the route to the makross using the PUT HTTP method.
func (r *Route) Put(handlers ...Handler) *Route {
return r.group.add("PUT", r.path, handlers)
}
// Patch adds the route to the makross using the PATCH HTTP method.
func (r *Route) Patch(handlers ...Handler) *Route {
return r.group.add("PATCH", r.path, handlers)
}
// Delete adds the route to the makross using the DELETE HTTP method.
func (r *Route) Delete(handlers ...Handler) *Route {
return r.group.add("DELETE", r.path, handlers)
}
// Connect adds the route to the makross using the CONNECT HTTP method.
func (r *Route) Connect(handlers ...Handler) *Route {
return r.group.add("CONNECT", r.path, handlers)
}
// Head adds the route to the makross using the HEAD HTTP method.
func (r *Route) Head(handlers ...Handler) *Route {
return r.group.add("HEAD", r.path, handlers)
}
// Options adds the route to the makross using the OPTIONS HTTP method.
func (r *Route) Options(handlers ...Handler) *Route {
return r.group.add("OPTIONS", r.path, handlers)
}
// Trace adds the route to the makross using the TRACE HTTP method.
func (r *Route) Trace(handlers ...Handler) *Route {
return r.group.add("TRACE", r.path, handlers)
}
// To adds the route to the makross with the given HTTP methods and handlers.
// Multiple HTTP methods should be separated by commas (without any surrounding spaces).
func (r *Route) To(methods string, handlers ...Handler) *Route {
return r.group.To(methods, r.path, handlers...)
}
// URL creates a URL using the current route and the given parameters.
// The parameters should be given in the sequence of name1, value1, name2, value2, and so on.
// If a parameter in the route is not provided a value, the parameter token will remain in the resulting URL.
// The method will perform URL encoding for all given parameter values.
func (r *Route) URL(pairs ...interface{}) (s string) {
s = r.template
for i := 0; i < len(pairs); i++ {
name := fmt.Sprintf("<%v>", pairs[i])
value := ""
if i < len(pairs)-1 {
value = url.QueryEscape(fmt.Sprint(pairs[i+1]))
}
s = strings.Replace(s, name, value, -1)
}
return
}
// String returns the string representation of the route.
func (r *Route) String() string {
return r.method + " " + r.group.prefix + r.path
}