-
Notifications
You must be signed in to change notification settings - Fork 50
/
router.go
51 lines (43 loc) · 1.15 KB
/
router.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
/*
Router module.
A set of functions to access the routing properties of the request.
*/
package router
import (
"github.com/Kong/go-pdk/bridge"
"github.com/Kong/go-pdk/entities"
)
// Holds this module's functions. Accessible as `kong.Router`
type Router struct {
bridge.PdkBridge
}
// Called by the plugin server at initialization.
func New(ch chan interface{}) Router {
return Router{bridge.New(ch)}
}
// kong.Router.GetRoute() returns the current route entity.
// The request was matched against this route.
func (c Router) GetRoute() (route entities.Route, err error) {
reply, err := c.Ask(`kong.router.get_route`)
if err != nil {
return
}
var ok bool
if route, ok = reply.(entities.Route); !ok {
err = bridge.ReturnTypeError("entities.Route")
}
return
}
// kong.Router.GetService() returns the current service entity.
// The request will be targetted to this upstream service.
func (c Router) GetService() (service entities.Service, err error) {
val, err := c.Ask(`kong.router.get_service`)
if err != nil {
return
}
var ok bool
if service, ok = val.(entities.Service); !ok {
err = bridge.ReturnTypeError("entities.Service")
}
return
}