代码拉取完成,页面将自动刷新
package node
import (
"context"
"gitee.com/monobytes/gcore/gcluster"
"gitee.com/monobytes/gcore/internal/transporter/internal/client"
"gitee.com/monobytes/gcore/internal/transporter/internal/codes"
"gitee.com/monobytes/gcore/internal/transporter/internal/protocol"
"sync/atomic"
)
type Client struct {
seq uint64
cli *client.Client
}
func NewClient(cli *client.Client) *Client {
return &Client{
cli: cli,
}
}
// Trigger 触发事件
func (c *Client) Trigger(ctx context.Context, event gcluster.Event, cid, uid int64) error {
return c.cli.Send(ctx, protocol.EncodeTriggerReq(0, event, cid, uid))
}
// Deliver 投递消息
func (c *Client) Deliver(ctx context.Context, cid, uid int64, message []byte) error {
return c.cli.Send(ctx, protocol.EncodeDeliverReq(0, cid, uid, message), cid)
}
// GetState 获取状态
func (c *Client) GetState(ctx context.Context) (gcluster.State, error) {
seq := c.doGenSequence()
buf := protocol.EncodeGetStateReq(seq)
res, err := c.cli.Call(ctx, seq, buf)
if err != nil {
return 0, err
}
code, state, err := protocol.DecodeGetStateRes(res)
if err != nil {
return 0, err
}
return state, codes.CodeToError(code)
}
// SetState 设置状态
func (c *Client) SetState(ctx context.Context, state gcluster.State) error {
seq := c.doGenSequence()
buf := protocol.EncodeSetStateReq(seq, state)
res, err := c.cli.Call(ctx, seq, buf)
if err != nil {
return err
}
code, err := protocol.DecodeSetStateRes(res)
if err != nil {
return err
}
return codes.CodeToError(code)
}
// 生成序列号,规避生成序列号为0的编号
func (c *Client) doGenSequence() (seq uint64) {
for {
if seq = atomic.AddUint64(&c.seq, 1); seq != 0 {
return
}
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。