代码拉取完成,页面将自动刷新
package sbox
import (
"gitee.com/dennis-kk/rpc-go-backend/idlrpc"
"gitee.com/dennis-kk/rpc-go-backend/idlrpc/pkg/transport"
)
type (
//ServiceBoxContext service-box context
ServiceBoxContext struct {
*idlrpc.RpcContext
trans *BoxChannel // 消息管道
box *ServiceBox // box实例
}
)
func NewServiceBoxContext(box *ServiceBox) *ServiceBoxContext {
return &ServiceBoxContext{
RpcContext: &idlrpc.RpcContext{},
trans: nil,
box: box,
}
}
func (c *ServiceBoxContext) GetServiceBox() *ServiceBox {
return c.box
}
func (c *ServiceBoxContext) GetTransport() transport.ITransport {
return c.trans
}
func (c *ServiceBoxContext) GetIdentityID() string {
if c.trans == nil {
return ""
}
return c.trans.IdentityID()
}
func (c *ServiceBoxContext) GetIdentityTag() string {
if c.trans == nil {
return ""
}
return c.trans.IdentityTag()
}
func (c *ServiceBoxContext) GetProxyFromPeer(uuid uint64) idlrpc.IProxy {
if c.box == nil {
return nil
}
if peer, err := c.box.GetProxyFromPeer(c, uuid); err != nil {
c.box.logger.Error("Obtaining the peer Proxy failed, error: %s", err.Error())
return nil
} else {
return peer
}
}
func (c *ServiceBoxContext) GetProxy(uuid uint64) idlrpc.IProxy {
if c.box == nil {
return nil
}
if proxy, err := c.box.GetProxy(uuid); err != nil {
c.box.logger.Error("Obtaining the proxy %d failed, error: %s", uuid, err.Error())
return nil
} else {
return proxy
}
}
func (c *ServiceBoxContext) GetProxyWithNickname(uuid uint64, name string) idlrpc.IProxy {
if c.box == nil {
return nil
}
if proxy, err := c.box.GetProxyWithNickName(uuid, name); err != nil {
c.box.logger.Error("Obtaining the proxy %d failed, error: %s", uuid, err.Error())
return nil
} else {
return proxy
}
}
func (c *ServiceBoxContext) Debug(format string, i ...interface{}) {
c.box.logger.Debug(format, i...)
}
func (c *ServiceBoxContext) Info(format string, i ...interface{}) {
c.box.logger.Info(format, i...)
}
func (c *ServiceBoxContext) Warning(format string, i ...interface{}) {
c.box.logger.Warn(format, i...)
}
func (c *ServiceBoxContext) Error(format string, i ...interface{}) {
c.box.logger.Error(format, i...)
}
// Clone clone 一个新的上下文,保留连接,身份信息但是不保留global index 和 用户协议的中间态
func (c *ServiceBoxContext) Clone() idlrpc.IServiceContext {
return &ServiceBoxContext{
RpcContext: c.RpcContext.Clone(),
trans: c.trans,
box: c.box,
}
}
func (c *ServiceBoxContext) setBoxChannel(trans *BoxChannel) {
c.trans = trans
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。