rpc/server/servlet_handlers.go

41 lines
1.1 KiB
Go
Raw Normal View History

2017-11-26 10:15:51 +00:00
package server
import (
"fmt"
"git.loafle.net/commons_go/logging"
"git.loafle.net/commons_go/rpc"
"git.loafle.net/commons_go/rpc/protocol"
)
type ServletHandlers struct {
2017-11-28 16:19:03 +00:00
rpc.RPCServletHandlers
2017-11-26 10:15:51 +00:00
RPCRegistry rpc.Registry
}
2017-11-28 16:19:03 +00:00
func (sh *ServletHandlers) Invoke(servletCTX rpc.RPCServletContext, requestCodec protocol.RegistryCodec) (result interface{}, err error) {
2017-11-26 10:15:51 +00:00
if !sh.RPCRegistry.HasMethod(requestCodec.Method()) {
return nil, fmt.Errorf("RPC Servlet Handler: Method[%s] is not exist", requestCodec.Method())
}
result, err = sh.RPCRegistry.Invoke(requestCodec)
if nil != err {
2017-11-28 02:55:25 +00:00
if params, pErr := requestCodec.Params(); nil != err {
logging.Logger().Error(fmt.Sprintf("RPC Servlet Handler: Read Param of Method[%s] returns error %v", requestCodec.Method(), pErr))
} else {
logging.Logger().Error(fmt.Sprintf("RPC Servlet Handler: Method[%s] params[%v] returns error %v", requestCodec.Method(), params, err))
}
2017-11-26 10:15:51 +00:00
}
return
}
func (sh *ServletHandlers) Validate() {
2017-11-28 16:19:03 +00:00
sh.RPCServletHandlers.Validate()
2017-11-26 10:15:51 +00:00
if nil == sh.RPCRegistry {
logging.Logger().Panic(fmt.Sprintf("RPC Servlet Handler: RPC Registry must be specified"))
}
}