This repository has been archived by the owner on Jul 20, 2019. It is now read-only.
forked from Terry-Mao/goim
-
Notifications
You must be signed in to change notification settings - Fork 16
architecture and Customization
TsingsonQin edited this page Apr 20, 2019
·
1 revision
code in /internal/logic/dao/kafka.go
please note:
below source code in https://github.com/Terry-Mao/goim
not in my repo https://github.com/tsingson/goim
// PushMsg push a message to databus.
func (d *Dao) PushMsg(c context.Context, op int32, server string, keys []string, msg []byte) (err error) {
pushMsg := &pb.PushMsg{
Type: pb.PushMsg_PUSH,
Operation: op,
Server: server,
Keys: keys,
Msg: msg,
}
//
// instance message storage HOOKS:
// add your message storage logic here
// if you want to save offline message only, check current user online or not first
//
b, err := proto.Marshal(pushMsg)
if err != nil {
return
}
m := &sarama.ProducerMessage{
Key: sarama.StringEncoder(keys[0]),
Topic: d.c.Kafka.Topic,
Value: sarama.ByteEncoder(b),
}
if _, _, err = d.kafkaPub.SendMessage(m); err != nil {
log.Errorf("PushMsg.send(push pushMsg:%v) error(%v)", pushMsg, err)
}
return
}
code in /internal/logic/conn.go
please note:
below source code in https://github.com/Terry-Mao/goim
not in my repo https://github.com/tsingson/goim
// Connect connected a conn.
func (l *Logic) Connect(c context.Context, server, cookie string, token []byte) (mid int64, key, roomID string, accepts []int32, hb int64, err error) {
var params struct {
Mid int64 `json:"mid"`
Key string `json:"key"`
RoomID string `json:"room_id"`
Platform string `json:"platform"`
Accepts []int32 `json:"accepts"`
}
if err = json.Unmarshal(token, ¶ms); err != nil {
log.Errorf("json.Unmarshal(%s) error(%v)", token, err)
return
}
mid = params.Mid
roomID = params.RoomID
accepts = params.Accepts
hb = int64(l.c.Node.Heartbeat) * int64(l.c.Node.HeartbeatMax)
//
// User Management HOOKS
// add your user management logic here , somethings like:
// 1. access user management unit to verify mid ( member / user ID )
// 2. check permission to access room or not
//
// Session Management HOOKS
// key just like the session ID, add your session management logic here, like:
// 1. check session ID is valid or not
// 2. if not, generate new session ID
// example like below:
if key = params.Key; key == "" {
keyUuid, _ := uuid.NewV4()
key = keyUuid.String()
}
//
if err = l.dao.AddMapping(c, mid, key, server); err != nil {
log.Errorf("l.dao.AddMapping(%d,%s,%s) error(%v)", mid, key, server, err)
return
}
//
log.Infof("conn connected key:%s server:%s mid:%d token:%s", key, server, mid, token)
return
}
this wiki page create by tsingson at china shenzhen, 2019/04/21