2015-06-03 01:25:37 +01:00
|
|
|
package server
|
|
|
|
|
|
|
|
import (
|
|
|
|
"reflect"
|
|
|
|
|
2021-10-12 12:55:53 +01:00
|
|
|
"go-micro.dev/v4/registry"
|
2015-06-03 01:25:37 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
type rpcHandler struct {
|
|
|
|
name string
|
|
|
|
handler interface{}
|
|
|
|
endpoints []*registry.Endpoint
|
2016-01-08 14:02:32 +00:00
|
|
|
opts HandlerOptions
|
2015-06-03 01:25:37 +01:00
|
|
|
}
|
|
|
|
|
2016-01-08 14:02:32 +00:00
|
|
|
func newRpcHandler(handler interface{}, opts ...HandlerOption) Handler {
|
2016-05-26 18:01:02 +01:00
|
|
|
options := HandlerOptions{
|
|
|
|
Metadata: make(map[string]map[string]string),
|
|
|
|
}
|
|
|
|
|
2016-01-08 14:02:32 +00:00
|
|
|
for _, o := range opts {
|
|
|
|
o(&options)
|
|
|
|
}
|
|
|
|
|
2015-06-03 01:25:37 +01:00
|
|
|
typ := reflect.TypeOf(handler)
|
|
|
|
hdlr := reflect.ValueOf(handler)
|
|
|
|
name := reflect.Indirect(hdlr).Type().Name()
|
|
|
|
|
|
|
|
var endpoints []*registry.Endpoint
|
|
|
|
|
|
|
|
for m := 0; m < typ.NumMethod(); m++ {
|
|
|
|
if e := extractEndpoint(typ.Method(m)); e != nil {
|
2015-10-11 12:05:20 +01:00
|
|
|
e.Name = name + "." + e.Name
|
2016-05-26 18:01:02 +01:00
|
|
|
|
|
|
|
for k, v := range options.Metadata[e.Name] {
|
|
|
|
e.Metadata[k] = v
|
|
|
|
}
|
|
|
|
|
2015-06-03 01:25:37 +01:00
|
|
|
endpoints = append(endpoints, e)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return &rpcHandler{
|
|
|
|
name: name,
|
|
|
|
handler: handler,
|
|
|
|
endpoints: endpoints,
|
2016-01-08 14:02:32 +00:00
|
|
|
opts: options,
|
2015-06-03 01:25:37 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *rpcHandler) Name() string {
|
|
|
|
return r.name
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *rpcHandler) Handler() interface{} {
|
|
|
|
return r.handler
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *rpcHandler) Endpoints() []*registry.Endpoint {
|
|
|
|
return r.endpoints
|
|
|
|
}
|
2016-01-08 14:02:32 +00:00
|
|
|
|
|
|
|
func (r *rpcHandler) Options() HandlerOptions {
|
|
|
|
return r.opts
|
|
|
|
}
|