im2
This commit is contained in:
18
business/jxutils/cache/cache.go
vendored
18
business/jxutils/cache/cache.go
vendored
@@ -12,13 +12,13 @@ type ICacher interface {
|
|||||||
GetAs(key string, ptr interface{}) error
|
GetAs(key string, ptr interface{}) error
|
||||||
Keys(prefix string) ([]string, error)
|
Keys(prefix string) ([]string, error)
|
||||||
|
|
||||||
//FlushDB() error
|
FlushDB() error
|
||||||
//Incr(key string) error
|
Incr(key string) error
|
||||||
//LRange(key string) (retVal []string)
|
LRange(key string) (retVal []string)
|
||||||
//Exists(keys ...string) (int64, error)
|
Exists(keys ...string) (int64, error)
|
||||||
//RPush(key string, value interface{}) error
|
RPush(key string, value interface{}) error
|
||||||
//Expire(key string, expiration time.Duration) error
|
Expire(key string, expiration time.Duration) error
|
||||||
//LRem(key string, count int, value interface{}) error
|
LRem(key string, count int, value interface{}) error
|
||||||
//LSet(key string, index int, value interface{}) error
|
LSet(key string, index int, value interface{}) error
|
||||||
//ExpireResult(key string, expiration time.Duration) (bool, error)
|
ExpireResult(key string, expiration time.Duration) (bool, error)
|
||||||
}
|
}
|
||||||
|
|||||||
86
business/jxutils/cache/redis/redis.go
vendored
86
business/jxutils/cache/redis/redis.go
vendored
@@ -74,46 +74,46 @@ func (c *Cacher) Keys(prefix string) ([]string, error) {
|
|||||||
return c.client.Keys(prefix + "*").Result()
|
return c.client.Keys(prefix + "*").Result()
|
||||||
}
|
}
|
||||||
|
|
||||||
//func (c *Cacher) RPush(key string, value interface{}) error {
|
func (c *Cacher) RPush(key string, value interface{}) error {
|
||||||
// return c.client.RPush(key, value).Err()
|
return c.client.RPush(key, value).Err()
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//func (c *Cacher) FlushDB() error {
|
func (c *Cacher) FlushDB() error {
|
||||||
// return c.client.FlushDB().Err()
|
return c.client.FlushDB().Err()
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//func (c *Cacher) Expire(key string, expiration time.Duration) error {
|
func (c *Cacher) Expire(key string, expiration time.Duration) error {
|
||||||
// return c.client.Expire(key, expiration).Err()
|
return c.client.Expire(key, expiration).Err()
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//func (c *Cacher) ExpireResult(key string, expiration time.Duration) (bool, error) {
|
func (c *Cacher) ExpireResult(key string, expiration time.Duration) (bool, error) {
|
||||||
// ok, err := c.client.Expire(key, expiration).Result()
|
ok, err := c.client.Expire(key, expiration).Result()
|
||||||
// if err != nil {
|
if err != nil {
|
||||||
// return false, err
|
return false, err
|
||||||
// }
|
}
|
||||||
// return ok, nil
|
return ok, nil
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//func (c *Cacher) Exists(keys ...string) (int64, error) {
|
func (c *Cacher) Exists(keys ...string) (int64, error) {
|
||||||
// ret := c.client.Exists(keys...)
|
ret := c.client.Exists(keys...)
|
||||||
// return ret.Val(), ret.Err()
|
return ret.Val(), ret.Err()
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//func (c *Cacher) Incr(key string) error {
|
func (c *Cacher) Incr(key string) error {
|
||||||
// return c.client.Incr(key).Err()
|
return c.client.Incr(key).Err()
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//func (c *Cacher) LRange(key string) (retVal []string) {
|
func (c *Cacher) LRange(key string) (retVal []string) {
|
||||||
// if c.client.LLen(key).Val() > 0 {
|
if c.client.LLen(key).Val() > 0 {
|
||||||
// retVal = c.client.LRange(key, 0, -1).Val()
|
retVal = c.client.LRange(key, 0, -1).Val()
|
||||||
// }
|
}
|
||||||
// return retVal
|
return retVal
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//func (c *Cacher) LSet(key string, index int, value interface{}) error {
|
func (c *Cacher) LSet(key string, index int, value interface{}) error {
|
||||||
// return c.client.LSet(key, int64(index), value).Err()
|
return c.client.LSet(key, int64(index), value).Err()
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//func (c *Cacher) LRem(key string, count int, value interface{}) error {
|
func (c *Cacher) LRem(key string, count int, value interface{}) error {
|
||||||
// return c.client.LRem(key, int64(count), value).Err()
|
return c.client.LRem(key, int64(count), value).Err()
|
||||||
//}
|
}
|
||||||
|
|||||||
@@ -1,7 +1,11 @@
|
|||||||
package ebai
|
package ebai
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
|
||||||
"git.rosy.net.cn/baseapi/platformapi/ebaiapi"
|
"git.rosy.net.cn/baseapi/platformapi/ebaiapi"
|
||||||
|
"git.rosy.net.cn/jx-callback/business/partner/purchase/im"
|
||||||
|
"git.rosy.net.cn/jx-callback/globals/api"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
@@ -10,9 +14,9 @@ const (
|
|||||||
|
|
||||||
// OnImMessage 用户/骑手 发送/已读消息 回调
|
// OnImMessage 用户/骑手 发送/已读消息 回调
|
||||||
func (p *PurchaseHandler) OnImMessage(msg *ebaiapi.CallbackMsg) (response *ebaiapi.CallbackResponse) {
|
func (p *PurchaseHandler) OnImMessage(msg *ebaiapi.CallbackMsg) (response *ebaiapi.CallbackResponse) {
|
||||||
//str, err := json.Marshal(msg.Data)
|
str, err := json.Marshal(msg.Data)
|
||||||
|
|
||||||
//im.ReadMsgFromVendor(IMVendorIDELM, msg.Source, str)
|
im.ReadMsgFromVendor(IMVendorIDELM, msg.Source, str)
|
||||||
return nil
|
//return nil
|
||||||
//return api.EbaiAPI.Err2CallbackResponse(msg.Cmd, err, nil)
|
return api.EbaiAPI.Err2CallbackResponse(msg.Cmd, err, nil)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,356 +1,355 @@
|
|||||||
package im
|
package im
|
||||||
|
|
||||||
//
|
import (
|
||||||
//import (
|
"encoding/json"
|
||||||
// "encoding/json"
|
"errors"
|
||||||
// "errors"
|
"fmt"
|
||||||
// "fmt"
|
"net/http"
|
||||||
// "net/http"
|
|
||||||
//
|
"git.rosy.net.cn/jx-callback/globals"
|
||||||
// "git.rosy.net.cn/jx-callback/globals"
|
|
||||||
//
|
"git.rosy.net.cn/baseapi/platformapi/ebaiapi"
|
||||||
// "git.rosy.net.cn/baseapi/platformapi/ebaiapi"
|
|
||||||
//
|
"git.rosy.net.cn/baseapi/platformapi/mtwmapi"
|
||||||
// "git.rosy.net.cn/baseapi/platformapi/mtwmapi"
|
"git.rosy.net.cn/baseapi/utils"
|
||||||
// "git.rosy.net.cn/baseapi/utils"
|
push "git.rosy.net.cn/jx-callback/business/jxutils/unipush"
|
||||||
// push "git.rosy.net.cn/jx-callback/business/jxutils/unipush"
|
"git.rosy.net.cn/jx-callback/globals/api"
|
||||||
// "git.rosy.net.cn/jx-callback/globals/api"
|
"github.com/gorilla/websocket"
|
||||||
// "github.com/gorilla/websocket"
|
)
|
||||||
//)
|
|
||||||
//
|
// SendToVendor 向平台发消息
|
||||||
//// SendToVendor 向平台发消息
|
func SendToVendor(msg []byte) {
|
||||||
//func SendToVendor(msg []byte) {
|
var (
|
||||||
// var (
|
w http.ResponseWriter
|
||||||
// w http.ResponseWriter
|
sendData SendData
|
||||||
// sendData SendData
|
err error
|
||||||
// err error
|
elmAppID = api.EbaiAPI.GetSource()
|
||||||
// elmAppID = api.EbaiAPI.GetSource()
|
)
|
||||||
// )
|
|
||||||
//
|
//解析数据
|
||||||
// //解析数据
|
if err = json.Unmarshal(msg, &sendData); err != nil {
|
||||||
// if err = json.Unmarshal(msg, &sendData); err != nil {
|
return
|
||||||
// return
|
}
|
||||||
// }
|
|
||||||
//
|
//存储数据
|
||||||
// //存储数据
|
ReadMsgFromClient(sendData.VendorID, elmAppID, sendData.Data)
|
||||||
// ReadMsgFromClient(sendData.VendorID, elmAppID, sendData.Data)
|
|
||||||
//
|
//发送信息
|
||||||
// //发送信息
|
if sendData.VendorID == VendorIDMT {
|
||||||
// if sendData.VendorID == VendorIDMT {
|
temp, _ := json.Marshal(sendData.Data)
|
||||||
// temp, _ := json.Marshal(sendData.Data)
|
Send(temp)
|
||||||
// Send(temp)
|
}
|
||||||
// }
|
if sendData.VendorID == VendorIDELM {
|
||||||
// if sendData.VendorID == VendorIDELM {
|
param := sendData.Data.(ebaiapi.BusinessSendMsgReq)
|
||||||
// param := sendData.Data.(ebaiapi.BusinessSendMsgReq)
|
if err := api.EbaiAPI.BusinessSendMsg(¶m); err != nil {
|
||||||
// if err := api.EbaiAPI.BusinessSendMsg(¶m); err != nil {
|
globals.SugarLogger.Debugf("elm发送信息错误:%v", err)
|
||||||
// globals.SugarLogger.Debugf("elm发送信息错误:%v", err)
|
return
|
||||||
// return
|
}
|
||||||
// }
|
}
|
||||||
// }
|
|
||||||
//
|
if err != nil {
|
||||||
// if err != nil {
|
ClientRender(w, Fail, FailMsg, map[string]string{
|
||||||
// ClientRender(w, Fail, FailMsg, map[string]string{
|
"errMsg": fmt.Sprintf("%v", err),
|
||||||
// "errMsg": fmt.Sprintf("%v", err),
|
})
|
||||||
// })
|
} else {
|
||||||
// } else {
|
ClientRender(w, SuccessCode, SuccessMsg, map[string]interface{}{
|
||||||
// ClientRender(w, SuccessCode, SuccessMsg, map[string]interface{}{
|
"vendorID": sendData.VendorID,
|
||||||
// "vendorID": sendData.VendorID,
|
"msg": "ok",
|
||||||
// "msg": "ok",
|
})
|
||||||
// })
|
}
|
||||||
// }
|
return
|
||||||
// return
|
}
|
||||||
//}
|
|
||||||
//
|
func Send(data []byte) {
|
||||||
//func Send(data []byte) {
|
//生成完整url
|
||||||
// //生成完整url
|
fullUrl := GenFullUrl() //clientID暂时不用
|
||||||
// fullUrl := GenFullUrl() //clientID暂时不用
|
|
||||||
//
|
conn, resp, err := websocket.DefaultDialer.Dial(fullUrl, nil)
|
||||||
// conn, resp, err := websocket.DefaultDialer.Dial(fullUrl, nil)
|
if err != nil || resp.StatusCode != 101 {
|
||||||
// if err != nil || resp.StatusCode != 101 {
|
fmt.Printf("连接失败:%v http响应不成功", err)
|
||||||
// fmt.Printf("连接失败:%v http响应不成功", err)
|
}
|
||||||
// }
|
//关闭
|
||||||
// //关闭
|
defer func(conn *websocket.Conn) {
|
||||||
// defer func(conn *websocket.Conn) {
|
err := conn.Close()
|
||||||
// err := conn.Close()
|
if err != nil {
|
||||||
// if err != nil {
|
return
|
||||||
// return
|
}
|
||||||
// }
|
}(conn)
|
||||||
// }(conn)
|
|
||||||
//
|
err = conn.WriteMessage(websocket.TextMessage, data)
|
||||||
// err = conn.WriteMessage(websocket.TextMessage, data)
|
if err != nil {
|
||||||
// if err != nil {
|
fmt.Println(err)
|
||||||
// fmt.Println(err)
|
}
|
||||||
// }
|
|
||||||
//
|
for {
|
||||||
// for {
|
_, msg, err := conn.ReadMessage()
|
||||||
// _, msg, err := conn.ReadMessage()
|
if err != nil {
|
||||||
// if err != nil {
|
break
|
||||||
// break
|
} else {
|
||||||
// } else {
|
temp := string(msg)
|
||||||
// temp := string(msg)
|
if temp != HeartCheckSuccess {
|
||||||
// if temp != HeartCheckSuccess {
|
ReadMsgFromVendor(VendorIDMT, "", msg)
|
||||||
// ReadMsgFromVendor(VendorIDMT, "", msg)
|
}
|
||||||
// }
|
}
|
||||||
// }
|
fmt.Printf("%s receive: %s\n", conn.RemoteAddr(), string(msg))
|
||||||
// fmt.Printf("%s receive: %s\n", conn.RemoteAddr(), string(msg))
|
}
|
||||||
// }
|
}
|
||||||
//}
|
|
||||||
//
|
// ReadMsgFromClient 存储客户端发送的消息
|
||||||
//// ReadMsgFromClient 存储客户端发送的消息
|
func ReadMsgFromClient(vendorID int, elmAppID string, msg interface{}) {
|
||||||
//func ReadMsgFromClient(vendorID int, elmAppID string, msg interface{}) {
|
var (
|
||||||
// var (
|
err error
|
||||||
// err error
|
jxMsg = &JXMsg{}
|
||||||
// jxMsg = &JXMsg{}
|
userList = &UserMessageList{}
|
||||||
// userList = &UserMessageList{}
|
)
|
||||||
// )
|
|
||||||
//
|
data, err := json.Marshal(msg)
|
||||||
// data, err := json.Marshal(msg)
|
if err != nil {
|
||||||
// if err != nil {
|
return
|
||||||
// return
|
}
|
||||||
// }
|
|
||||||
//
|
if vendorID == VendorIDMT {
|
||||||
// if vendorID == VendorIDMT {
|
var MtSingleChat = mtwmapi.SingleChat{}
|
||||||
// var MtSingleChat = mtwmapi.SingleChat{}
|
err = json.Unmarshal(data, &MtSingleChat)
|
||||||
// err = json.Unmarshal(data, &MtSingleChat)
|
jxMsg = &JXMsg{
|
||||||
// jxMsg = &JXMsg{
|
SendType: SendTypeJx,
|
||||||
// SendType: SendTypeJx,
|
Data: MtSingleChat,
|
||||||
// Data: MtSingleChat,
|
}
|
||||||
// }
|
userList = &UserMessageList{
|
||||||
// userList = &UserMessageList{
|
VendorID: VendorIDMT,
|
||||||
// VendorID: VendorIDMT,
|
UserID: utils.Int2Str(MtSingleChat.OpenUserID),
|
||||||
// UserID: utils.Int2Str(MtSingleChat.OpenUserID),
|
LatestMsg: MtSingleChat.MsgContent,
|
||||||
// LatestMsg: MtSingleChat.MsgContent,
|
LatestTime: MtSingleChat.Cts,
|
||||||
// LatestTime: MtSingleChat.Cts,
|
}
|
||||||
// }
|
}
|
||||||
// }
|
if vendorID == VendorIDELM {
|
||||||
// if vendorID == VendorIDELM {
|
var ElmData = ebaiapi.ImMessageSend{}
|
||||||
// var ElmData = ebaiapi.ImMessageSend{}
|
err = json.Unmarshal(data, &ElmData)
|
||||||
// err = json.Unmarshal(data, &ElmData)
|
jxMsg = &JXMsg{
|
||||||
// jxMsg = &JXMsg{
|
SendType: SendTypeJx,
|
||||||
// SendType: SendTypeJx,
|
Data: ElmData,
|
||||||
// Data: ElmData,
|
}
|
||||||
// }
|
userList = &UserMessageList{
|
||||||
// userList = &UserMessageList{
|
VendorID: VendorIDMT,
|
||||||
// VendorID: VendorIDMT,
|
UserID: ElmData.PayLoad.GroupID,
|
||||||
// UserID: ElmData.PayLoad.GroupID,
|
LatestMsg: ElmData.PayLoad.Content,
|
||||||
// LatestMsg: ElmData.PayLoad.Content,
|
LatestTime: int(ElmData.PayLoad.CreateTime),
|
||||||
// LatestTime: int(ElmData.PayLoad.CreateTime),
|
}
|
||||||
// }
|
}
|
||||||
// }
|
|
||||||
//
|
//1 存储详细聊天记录list
|
||||||
// //1 存储详细聊天记录list
|
if err = SetMessageDetail(jxMsg, vendorID, elmAppID); err != nil {
|
||||||
// if err = SetMessageDetail(jxMsg, vendorID, elmAppID); err != nil {
|
return
|
||||||
// return
|
}
|
||||||
// }
|
//2 存储展示列表时单条数据
|
||||||
// //2 存储展示列表时单条数据
|
if err = SetUserList(jxMsg, userList, vendorID, elmAppID); err != nil {
|
||||||
// if err = SetUserList(jxMsg, userList, vendorID, elmAppID); err != nil {
|
return
|
||||||
// return
|
}
|
||||||
// }
|
}
|
||||||
//}
|
|
||||||
//
|
// ReadMsgFromVendor 读取数据并存储到redis
|
||||||
//// ReadMsgFromVendor 读取数据并存储到redis
|
func ReadMsgFromVendor(vendorID int, elmAppID string, msg []byte) {
|
||||||
//func ReadMsgFromVendor(vendorID int, elmAppID string, msg []byte) {
|
if string(msg) == "" {
|
||||||
// if string(msg) == "" {
|
return
|
||||||
// return
|
}
|
||||||
// }
|
var (
|
||||||
// var (
|
err error
|
||||||
// err error
|
vendorStoreID string
|
||||||
// vendorStoreID string
|
jxMsg = &JXMsg{}
|
||||||
// jxMsg = &JXMsg{}
|
userList = &UserMessageList{}
|
||||||
// userList = &UserMessageList{}
|
)
|
||||||
// )
|
if vendorID == VendorIDMT {
|
||||||
// if vendorID == VendorIDMT {
|
var MtSingleChat = mtwmapi.SingleChat{}
|
||||||
// var MtSingleChat = mtwmapi.SingleChat{}
|
err = json.Unmarshal(msg, &MtSingleChat)
|
||||||
// err = json.Unmarshal(msg, &MtSingleChat)
|
jxMsg = &JXMsg{
|
||||||
// jxMsg = &JXMsg{
|
SendType: SendTypeMt,
|
||||||
// SendType: SendTypeMt,
|
Data: MtSingleChat,
|
||||||
// Data: MtSingleChat,
|
}
|
||||||
// }
|
userList = &UserMessageList{
|
||||||
// userList = &UserMessageList{
|
VendorID: VendorIDMT,
|
||||||
// VendorID: VendorIDMT,
|
UserID: utils.Int2Str(MtSingleChat.OpenUserID),
|
||||||
// UserID: utils.Int2Str(MtSingleChat.OpenUserID),
|
LatestMsg: MtSingleChat.MsgContent,
|
||||||
// LatestMsg: MtSingleChat.MsgContent,
|
LatestTime: MtSingleChat.Cts,
|
||||||
// LatestTime: MtSingleChat.Cts,
|
}
|
||||||
// }
|
vendorStoreID = MtSingleChat.AppPoiCode
|
||||||
// vendorStoreID = MtSingleChat.AppPoiCode
|
}
|
||||||
// }
|
if vendorID == VendorIDELM {
|
||||||
// if vendorID == VendorIDELM {
|
var ElmData = ebaiapi.ImMessageSend{}
|
||||||
// var ElmData = ebaiapi.ImMessageSend{}
|
err = json.Unmarshal(msg, &ElmData)
|
||||||
// err = json.Unmarshal(msg, &ElmData)
|
jxMsg = &JXMsg{
|
||||||
// jxMsg = &JXMsg{
|
SendType: SendTypeElm,
|
||||||
// SendType: SendTypeElm,
|
Data: ElmData,
|
||||||
// Data: ElmData,
|
}
|
||||||
// }
|
userList = &UserMessageList{
|
||||||
// userList = &UserMessageList{
|
VendorID: VendorIDMT,
|
||||||
// VendorID: VendorIDMT,
|
UserID: ElmData.PayLoad.GroupID,
|
||||||
// UserID: ElmData.PayLoad.GroupID,
|
LatestMsg: ElmData.PayLoad.Content,
|
||||||
// LatestMsg: ElmData.PayLoad.Content,
|
LatestTime: int(ElmData.PayLoad.CreateTime),
|
||||||
// LatestTime: int(ElmData.PayLoad.CreateTime),
|
}
|
||||||
// }
|
}
|
||||||
// }
|
|
||||||
//
|
//1 存储详细聊天记录list
|
||||||
// //1 存储详细聊天记录list
|
if err = SetMessageDetail(jxMsg, vendorID, elmAppID); err != nil {
|
||||||
// if err = SetMessageDetail(jxMsg, vendorID, elmAppID); err != nil {
|
return
|
||||||
// return
|
}
|
||||||
// }
|
//2 存储展示列表时单条数据
|
||||||
// //2 存储展示列表时单条数据
|
if err = SetUserList(jxMsg, userList, vendorID, elmAppID); err != nil {
|
||||||
// if err = SetUserList(jxMsg, userList, vendorID, elmAppID); err != nil {
|
return
|
||||||
// return
|
}
|
||||||
// }
|
//3 cid推送新消息
|
||||||
// //3 cid推送新消息
|
err = PushMsgByCid(vendorStoreID, vendorID)
|
||||||
// err = PushMsgByCid(vendorStoreID, vendorID)
|
//4 长链接通知给客户端
|
||||||
// //4 长链接通知给客户端
|
ToClientChan <- clientInfo{Code: SuccessCode, Msg: fmt.Sprintf("%v", err), Data: jxMsg}
|
||||||
// ToClientChan <- clientInfo{Code: SuccessCode, Msg: fmt.Sprintf("%v", err), Data: jxMsg}
|
}
|
||||||
//}
|
|
||||||
//
|
// PushMsgByCid 通过cid push用户
|
||||||
//// PushMsgByCid 通过cid push用户
|
func PushMsgByCid(vendorStoreID string, vendorID int) error {
|
||||||
//func PushMsgByCid(vendorStoreID string, vendorID int) error {
|
if err := push.NotifyImNewMessage(vendorStoreID, vendorID); err != nil {
|
||||||
// if err := push.NotifyImNewMessage(vendorStoreID, vendorID); err != nil {
|
return err
|
||||||
// return err
|
}
|
||||||
// }
|
return nil
|
||||||
// return nil
|
}
|
||||||
//}
|
|
||||||
//
|
// SetMessageDetail 赋值
|
||||||
//// SetMessageDetail 赋值
|
//格式 AppID:AppPoiCode:10:OpenUserID
|
||||||
////格式 AppID:AppPoiCode:10:OpenUserID
|
func SetMessageDetail(req *JXMsg, vendorID int, elmAppID string) error {
|
||||||
//func SetMessageDetail(req *JXMsg, vendorID int, elmAppID string) error {
|
//生成京西消息ID detail
|
||||||
// //生成京西消息ID detail
|
msgID := GenMsgDetailID(req, vendorID, elmAppID)
|
||||||
// msgID := GenMsgDetailID(req, vendorID, elmAppID)
|
|
||||||
//
|
data, _ := json.Marshal(req)
|
||||||
// data, _ := json.Marshal(req)
|
err := rdb.RPush(msgID, string(data))
|
||||||
// err := rdb.RPush(msgID, string(data))
|
ok, err := rdb.ExpireResult(msgID, ExpireTimeDay)
|
||||||
// ok, err := rdb.ExpireResult(msgID, ExpireTimeDay)
|
if err != nil || !ok {
|
||||||
// if err != nil || !ok {
|
return err
|
||||||
// return err
|
}
|
||||||
// }
|
return nil
|
||||||
// return nil
|
}
|
||||||
//}
|
|
||||||
//
|
// SetUserList 赋值
|
||||||
//// SetUserList 赋值
|
//AppPoiCode:10 [userid1:{SingleChat},userid2:{}]
|
||||||
////AppPoiCode:10 [userid1:{SingleChat},userid2:{}]
|
func SetUserList(jxMsg *JXMsg, userList *UserMessageList, vendorID int, elmAppID string) error {
|
||||||
//func SetUserList(jxMsg *JXMsg, userList *UserMessageList, vendorID int, elmAppID string) error {
|
//生成msgID
|
||||||
// //生成msgID
|
msgID := GenMsgListID(jxMsg, vendorID, elmAppID)
|
||||||
// msgID := GenMsgListID(jxMsg, vendorID, elmAppID)
|
|
||||||
//
|
//获取未读消息条数并删除旧数据
|
||||||
// //获取未读消息条数并删除旧数据
|
cnt, err := GetNewAndTrim(msgID, userList.UserID)
|
||||||
// cnt, err := GetNewAndTrim(msgID, userList.UserID)
|
if cnt > 0 {
|
||||||
// if cnt > 0 {
|
userList.NewMessageNum = cnt
|
||||||
// userList.NewMessageNum = cnt
|
} else {
|
||||||
// } else {
|
userList.NewMessageNum = 1
|
||||||
// userList.NewMessageNum = 1
|
}
|
||||||
// }
|
//存储当前数据
|
||||||
// //存储当前数据
|
data, _ := json.Marshal(userList)
|
||||||
// data, _ := json.Marshal(userList)
|
err = rdb.RPush(msgID, string(data))
|
||||||
// err = rdb.RPush(msgID, string(data))
|
|
||||||
//
|
ok, err := rdb.ExpireResult(msgID, ExpireTimeDay)
|
||||||
// ok, err := rdb.ExpireResult(msgID, ExpireTimeDay)
|
if err != nil || !ok {
|
||||||
// if err != nil || !ok {
|
return err
|
||||||
// return err
|
}
|
||||||
// }
|
return nil
|
||||||
// return nil
|
}
|
||||||
//}
|
|
||||||
//
|
// GetNewAndTrim 获取未读条数并清除旧数据
|
||||||
//// GetNewAndTrim 获取未读条数并清除旧数据
|
func GetNewAndTrim(key string, flag string) (cnt int, err error) {
|
||||||
//func GetNewAndTrim(key string, flag string) (cnt int, err error) {
|
cnt = 0
|
||||||
// cnt = 0
|
if n, err := rdb.Exists(key); n > 0 && err == nil {
|
||||||
// if n, err := rdb.Exists(key); n > 0 && err == nil {
|
s2 := rdb.LRange(key)
|
||||||
// s2 := rdb.LRange(key)
|
for i := 0; i < len(s2); i++ {
|
||||||
// for i := 0; i < len(s2); i++ {
|
v := UserMessageList{}
|
||||||
// v := UserMessageList{}
|
_ = json.Unmarshal([]byte(s2[i]), &v)
|
||||||
// _ = json.Unmarshal([]byte(s2[i]), &v)
|
if v.UserID == flag {
|
||||||
// if v.UserID == flag {
|
err = rdb.LSet(key, i, "del")
|
||||||
// err = rdb.LSet(key, i, "del")
|
err = rdb.LRem(key, 0, "del")
|
||||||
// err = rdb.LRem(key, 0, "del")
|
s2 = append(s2[:i], s2[i+1:]...)
|
||||||
// s2 = append(s2[:i], s2[i+1:]...)
|
i--
|
||||||
// i--
|
if v.NewMessageNum == 0 { //目前为首条
|
||||||
// if v.NewMessageNum == 0 { //目前为首条
|
cnt++ //赋值1
|
||||||
// cnt++ //赋值1
|
} else {
|
||||||
// } else {
|
cnt = v.NewMessageNum
|
||||||
// cnt = v.NewMessageNum
|
}
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
// }
|
} else {
|
||||||
// } else {
|
return 0, nil
|
||||||
// return 0, nil
|
}
|
||||||
// }
|
return cnt, err
|
||||||
// return cnt, err
|
}
|
||||||
//}
|
|
||||||
//
|
// GenMsgDetailID 生成查询详细聊天记录ID
|
||||||
//// GenMsgDetailID 生成查询详细聊天记录ID
|
func GenMsgDetailID(jxMsg *JXMsg, vendorID int, elmAppID string) (msgID string) {
|
||||||
//func GenMsgDetailID(jxMsg *JXMsg, vendorID int, elmAppID string) (msgID string) {
|
if vendorID == VendorIDMT {
|
||||||
// if vendorID == VendorIDMT {
|
var d1 = jxMsg.Data.(mtwmapi.SingleChat)
|
||||||
// var d1 = jxMsg.Data.(mtwmapi.SingleChat)
|
msgID = utils.Int2Str(d1.AppID) + ":" + d1.AppPoiCode + ":10:" + utils.Int2Str(d1.OpenUserID)
|
||||||
// msgID = utils.Int2Str(d1.AppID) + ":" + d1.AppPoiCode + ":10:" + utils.Int2Str(d1.OpenUserID)
|
}
|
||||||
// }
|
if vendorID == VendorIDELM {
|
||||||
// if vendorID == VendorIDELM {
|
var d2 = jxMsg.Data.(ebaiapi.ImMessageSend)
|
||||||
// var d2 = jxMsg.Data.(ebaiapi.ImMessageSend)
|
msgID = elmAppID + ":" + d2.PlatformShopID + ":11:" + d2.PayLoad.GroupID
|
||||||
// msgID = elmAppID + ":" + d2.PlatformShopID + ":11:" + d2.PayLoad.GroupID
|
}
|
||||||
// }
|
return msgID
|
||||||
// return msgID
|
}
|
||||||
//}
|
|
||||||
//
|
// GenMsgListID 生成展示列表时单条数据ID(部分)
|
||||||
//// GenMsgListID 生成展示列表时单条数据ID(部分)
|
func GenMsgListID(jxMsg *JXMsg, vendorID int, elmAppID string) (msgID string) {
|
||||||
//func GenMsgListID(jxMsg *JXMsg, vendorID int, elmAppID string) (msgID string) {
|
if vendorID == VendorIDMT {
|
||||||
// if vendorID == VendorIDMT {
|
var d1 = jxMsg.Data.(mtwmapi.SingleChat)
|
||||||
// var d1 = jxMsg.Data.(mtwmapi.SingleChat)
|
msgID = utils.Int2Str(d1.AppID) + ":" + d1.AppPoiCode + ":10"
|
||||||
// msgID = utils.Int2Str(d1.AppID) + ":" + d1.AppPoiCode + ":10"
|
}
|
||||||
// }
|
if vendorID == VendorIDELM {
|
||||||
// if vendorID == VendorIDELM {
|
var d2 = jxMsg.Data.(ebaiapi.ImMessageSend)
|
||||||
// var d2 = jxMsg.Data.(ebaiapi.ImMessageSend)
|
msgID = elmAppID + ":" + d2.PlatformShopID + ":11"
|
||||||
// msgID = elmAppID + ":" + d2.PlatformShopID + ":11"
|
}
|
||||||
// }
|
return msgID
|
||||||
// return msgID
|
}
|
||||||
//}
|
|
||||||
//
|
// GetImUserList 获取门店用户聊天列表
|
||||||
//// GetImUserList 获取门店用户聊天列表
|
func GetImUserList(req []RelInfo) (retVal []interface{}, err error) {
|
||||||
//func GetImUserList(req []RelInfo) (retVal []interface{}, err error) {
|
if len(req) == 0 {
|
||||||
// if len(req) == 0 {
|
return nil, errors.New("msgID不允许为空")
|
||||||
// return nil, errors.New("msgID不允许为空")
|
}
|
||||||
// }
|
var keys []string
|
||||||
// var keys []string
|
for _, i := range req {
|
||||||
// for _, i := range req {
|
key := i.AppID + ":" + i.VendorStoreID + ":" + i.VendorID
|
||||||
// key := i.AppID + ":" + i.VendorStoreID + ":" + i.VendorID
|
keys = append(keys, key)
|
||||||
// keys = append(keys, key)
|
}
|
||||||
// }
|
for _, j := range keys {
|
||||||
// for _, j := range keys {
|
temp := rdb.Get(j)
|
||||||
// temp := rdb.Get(j)
|
retVal = append(retVal, temp)
|
||||||
// retVal = append(retVal, temp)
|
}
|
||||||
// }
|
return retVal, err
|
||||||
// return retVal, err
|
}
|
||||||
//}
|
|
||||||
//
|
// GetImChatDetail 获取门店用户聊天详情
|
||||||
//// GetImChatDetail 获取门店用户聊天详情
|
func GetImChatDetail(req []UserRelInfo) (retVal []interface{}, err error) {
|
||||||
//func GetImChatDetail(req []UserRelInfo) (retVal []interface{}, err error) {
|
if len(req) == 0 {
|
||||||
// if len(req) == 0 {
|
return nil, errors.New("msgID不允许为空")
|
||||||
// return nil, errors.New("msgID不允许为空")
|
}
|
||||||
// }
|
var keys []string
|
||||||
// var keys []string
|
for _, i := range req {
|
||||||
// for _, i := range req {
|
key := i.AppID + ":" + i.VendorStoreID + ":" + i.VendorID + ":" + i.UserID
|
||||||
// key := i.AppID + ":" + i.VendorStoreID + ":" + i.VendorID + ":" + i.UserID
|
keys = append(keys, key)
|
||||||
// keys = append(keys, key)
|
}
|
||||||
// }
|
for _, j := range keys {
|
||||||
// for _, j := range keys {
|
temp := rdb.Get(j)
|
||||||
// temp := rdb.Get(j)
|
retVal = append(retVal, temp)
|
||||||
// retVal = append(retVal, temp)
|
}
|
||||||
// }
|
return retVal, err
|
||||||
// return retVal, err
|
}
|
||||||
//}
|
|
||||||
//
|
// SetJxMsgRead 设置jx消息已读 userID(美团:openUserID;饿了么:groupID)
|
||||||
//// SetJxMsgRead 设置jx消息已读 userID(美团:openUserID;饿了么:groupID)
|
func SetJxMsgRead(appID, vendorStoreID, vendorID, userID string) error {
|
||||||
//func SetJxMsgRead(appID, vendorStoreID, vendorID, userID string) error {
|
key := appID + ":" + vendorStoreID + ":" + vendorID
|
||||||
// key := appID + ":" + vendorStoreID + ":" + vendorID
|
if n, err := rdb.Exists(key); n > 0 && err == nil {
|
||||||
// if n, err := rdb.Exists(key); n > 0 && err == nil {
|
s2 := rdb.LRange(key)
|
||||||
// s2 := rdb.LRange(key)
|
for i := 0; i < len(s2); i++ {
|
||||||
// for i := 0; i < len(s2); i++ {
|
v := UserMessageList{}
|
||||||
// v := UserMessageList{}
|
_ = json.Unmarshal([]byte(s2[i]), &v)
|
||||||
// _ = json.Unmarshal([]byte(s2[i]), &v)
|
if v.UserID == userID {
|
||||||
// if v.UserID == userID {
|
err = rdb.LSet(key, i, "del")
|
||||||
// err = rdb.LSet(key, i, "del")
|
err = rdb.LRem(key, 0, "del")
|
||||||
// err = rdb.LRem(key, 0, "del")
|
s2 = append(s2[:i], s2[i+1:]...)
|
||||||
// s2 = append(s2[:i], s2[i+1:]...)
|
i--
|
||||||
// i--
|
}
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
// }
|
return nil
|
||||||
// return nil
|
}
|
||||||
//}
|
|
||||||
|
|||||||
@@ -1,276 +1,276 @@
|
|||||||
package im
|
package im
|
||||||
|
|
||||||
//
|
import (
|
||||||
//import (
|
"encoding/json"
|
||||||
// "encoding/json"
|
"flag"
|
||||||
// "flag"
|
"fmt"
|
||||||
// "fmt"
|
"io"
|
||||||
// "git.rosy.net.cn/baseapi/utils"
|
"log"
|
||||||
// "io"
|
"net"
|
||||||
// "log"
|
"net/http"
|
||||||
// "net"
|
"sync"
|
||||||
// "net/http"
|
"time"
|
||||||
// "sync"
|
|
||||||
// "time"
|
"git.rosy.net.cn/baseapi/utils"
|
||||||
//
|
|
||||||
// "git.rosy.net.cn/baseapi/platformapi/mtwmapi"
|
"git.rosy.net.cn/baseapi/platformapi/mtwmapi"
|
||||||
// "git.rosy.net.cn/jx-callback/globals/api"
|
"git.rosy.net.cn/jx-callback/globals/api"
|
||||||
// "github.com/gazeboxu/mapstructure"
|
"github.com/gazeboxu/mapstructure"
|
||||||
// "github.com/gorilla/websocket"
|
"github.com/gorilla/websocket"
|
||||||
// "gopkg.in/ini.v1"
|
"gopkg.in/ini.v1"
|
||||||
//)
|
)
|
||||||
//
|
|
||||||
//// ClientManager 连接管理
|
// ClientManager 连接管理
|
||||||
//type ClientManager struct {
|
type ClientManager struct {
|
||||||
// ClientIdMap map[string]*Client // 全部的连接
|
ClientIdMap map[string]*Client // 全部的连接
|
||||||
// ClientIdMapLock sync.RWMutex // 读写锁
|
ClientIdMapLock sync.RWMutex // 读写锁
|
||||||
//
|
|
||||||
// Connect chan *Client // 连接处理
|
Connect chan *Client // 连接处理
|
||||||
// DisConnect chan *Client // 断开连接处理
|
DisConnect chan *Client // 断开连接处理
|
||||||
//
|
|
||||||
// GroupLock sync.RWMutex
|
GroupLock sync.RWMutex
|
||||||
// Groups map[string][]string
|
Groups map[string][]string
|
||||||
//
|
|
||||||
// SystemClientsLock sync.RWMutex
|
SystemClientsLock sync.RWMutex
|
||||||
// SystemClients map[string][]string
|
SystemClients map[string][]string
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//// Client 客户端连接信息
|
// Client 客户端连接信息
|
||||||
//type Client struct {
|
type Client struct {
|
||||||
// ClientId string // 标识ID
|
ClientId string // 标识ID
|
||||||
// Socket *websocket.Conn // 用户连接
|
Socket *websocket.Conn // 用户连接
|
||||||
// ConnectTime uint64 // 首次连接时间
|
ConnectTime uint64 // 首次连接时间
|
||||||
// IsDeleted bool // 是否删除或下线
|
IsDeleted bool // 是否删除或下线
|
||||||
// UserId string // 业务端标识用户ID
|
UserId string // 业务端标识用户ID
|
||||||
// //Extend string // 扩展字段,用户可以自定义
|
//Extend string // 扩展字段,用户可以自定义
|
||||||
// //GroupList []string
|
//GroupList []string
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
////channel通道结构体
|
//channel通道结构体
|
||||||
//type clientInfo struct {
|
type clientInfo struct {
|
||||||
// ClientId string `json:"clientId" validate:"required"` //链接ID
|
ClientId string `json:"clientId" validate:"required"` //链接ID
|
||||||
// Data interface{}
|
Data interface{}
|
||||||
// SendUserId string
|
SendUserId string
|
||||||
// MessageId string
|
MessageId string
|
||||||
// Code int
|
Code int
|
||||||
// Msg string
|
Msg string
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//// RetData 统一返回值结构体
|
// RetData 统一返回值结构体
|
||||||
//type RetData struct {
|
type RetData struct {
|
||||||
// Code int `json:"code"` //响应code
|
Code int `json:"code"` //响应code
|
||||||
// Msg string `json:"msg"` //响应msg success/fail
|
Msg string `json:"msg"` //响应msg success/fail
|
||||||
// Data interface{} `json:"data"` //信息
|
Data interface{} `json:"data"` //信息
|
||||||
//
|
|
||||||
// //MessageType string `json:"messageType"` //消息类型 heart-心跳检测;send-发送消息;receive-接收消息
|
//MessageType string `json:"messageType"` //消息类型 heart-心跳检测;send-发送消息;receive-接收消息
|
||||||
// //MessageId string `json:"messageId"` //发送/接收信息 id
|
//MessageId string `json:"messageId"` //发送/接收信息 id
|
||||||
// //UserId string `json:"userId"` //必须是平台方userID
|
//UserId string `json:"userId"` //必须是平台方userID
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//type global struct {
|
type global struct {
|
||||||
// LocalHost string //本机内网IP
|
LocalHost string //本机内网IP
|
||||||
// ServerList map[string]string
|
ServerList map[string]string
|
||||||
// ServerListLock sync.RWMutex
|
ServerListLock sync.RWMutex
|
||||||
//}
|
}
|
||||||
//type commonConf struct {
|
type commonConf struct {
|
||||||
// HttpPort string
|
HttpPort string
|
||||||
// RPCPort string
|
RPCPort string
|
||||||
// Cluster bool
|
Cluster bool
|
||||||
// CryptoKey string
|
CryptoKey string
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//// SendData 客户端写入参数
|
// SendData 客户端写入参数
|
||||||
//type SendData struct {
|
type SendData struct {
|
||||||
// //ClientId string `json:"clientId" validate:"required"` //链接ID
|
//ClientId string `json:"clientId" validate:"required"` //链接ID
|
||||||
// VendorID int `json:"vendorID"` //消息来源平台ID
|
VendorID int `json:"vendorID"` //消息来源平台ID
|
||||||
// Data interface{} `json:"data"` //发送给平台 美团/饿了么消息结构体
|
Data interface{} `json:"data"` //发送给平台 美团/饿了么消息结构体
|
||||||
// //返回值
|
//返回值
|
||||||
// //Code int `json:"code"`
|
//Code int `json:"code"`
|
||||||
// //Msg string `json:"msg"`
|
//Msg string `json:"msg"`
|
||||||
// //SendUserId string `json:"sendUserId"`
|
//SendUserId string `json:"sendUserId"`
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//// JXMsg 京西消息结构体
|
// JXMsg 京西消息结构体
|
||||||
//type JXMsg struct {
|
type JXMsg struct {
|
||||||
// SendType string `json:"sendType"` //消息发送方 jx-商家;mt-美团;elm-饿了么
|
SendType string `json:"sendType"` //消息发送方 jx-商家;mt-美团;elm-饿了么
|
||||||
// Data interface{} `json:"data"` //美团/饿了么 单聊消息
|
Data interface{} `json:"data"` //美团/饿了么 单聊消息
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//// GetUserListReq 获取门店用户聊天列表
|
// GetUserListReq 获取门店用户聊天列表
|
||||||
//type GetUserListReq struct {
|
type GetUserListReq struct {
|
||||||
// VendorStoreID string `json:"vendorStoreID"` //平台门店id
|
VendorStoreID string `json:"vendorStoreID"` //平台门店id
|
||||||
// VendorID string `json:"vendorID"` //平台标识id
|
VendorID string `json:"vendorID"` //平台标识id
|
||||||
// AppID string `json:"appID"` //应用ID
|
AppID string `json:"appID"` //应用ID
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//type GetChatDetailReq struct {
|
type GetChatDetailReq struct {
|
||||||
// VendorStoreID string `json:"vendorStoreID"` //平台门店id
|
VendorStoreID string `json:"vendorStoreID"` //平台门店id
|
||||||
// VendorID string `json:"vendorID"` //平台标识id
|
VendorID string `json:"vendorID"` //平台标识id
|
||||||
// AppID string `json:"appID"` //应用ID
|
AppID string `json:"appID"` //应用ID
|
||||||
// UserID string `json:"userID"` //userID/groupID
|
UserID string `json:"userID"` //userID/groupID
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//// UserMessageList 用户消息列表
|
// UserMessageList 用户消息列表
|
||||||
//type UserMessageList struct {
|
type UserMessageList struct {
|
||||||
// VendorID int `json:"vendorID"` //平台品牌 10-美团 11-饿了么
|
VendorID int `json:"vendorID"` //平台品牌 10-美团 11-饿了么
|
||||||
// UserID string `json:"userID"` //用户ID
|
UserID string `json:"userID"` //用户ID
|
||||||
// NewMessageNum int `json:"NewMessageNum"` //新消息数量
|
NewMessageNum int `json:"NewMessageNum"` //新消息数量
|
||||||
// LatestMsg string `json:"latestMsg"` //最新一条消息
|
LatestMsg string `json:"latestMsg"` //最新一条消息
|
||||||
// LatestTime int `json:"latestTime"` //最新一条消息发送时间
|
LatestTime int `json:"latestTime"` //最新一条消息发送时间
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//type RelInfo struct {
|
type RelInfo struct {
|
||||||
// VendorStoreID string `json:"vendorStoreID"` //平台门店id
|
VendorStoreID string `json:"vendorStoreID"` //平台门店id
|
||||||
// VendorID string `json:"vendorID"` //平台标识id
|
VendorID string `json:"vendorID"` //平台标识id
|
||||||
// AppID string `json:"appID"` //应用ID
|
AppID string `json:"appID"` //应用ID
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//type UserRelInfo struct {
|
type UserRelInfo struct {
|
||||||
// VendorStoreID string `json:"vendorStoreID"` //平台门店id
|
VendorStoreID string `json:"vendorStoreID"` //平台门店id
|
||||||
// VendorID string `json:"vendorID"` //平台标识id
|
VendorID string `json:"vendorID"` //平台标识id
|
||||||
// AppID string `json:"appID"` //应用ID
|
AppID string `json:"appID"` //应用ID
|
||||||
// UserID string `json:"userID"` //用户id/groupID
|
UserID string `json:"userID"` //用户id/groupID
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//var (
|
var (
|
||||||
// cfg *ini.File
|
cfg *ini.File
|
||||||
// rdb = api.Cacher
|
rdb = api.Cacher
|
||||||
// Manager = NewClientManager() // 管理者
|
Manager = NewClientManager() // 管理者
|
||||||
// CommonSetting = &commonConf{}
|
CommonSetting = &commonConf{}
|
||||||
// GlobalSetting = &global{}
|
GlobalSetting = &global{}
|
||||||
// ToClientChan chan clientInfo
|
ToClientChan chan clientInfo
|
||||||
// heartbeatInterval = 60 * time.Second // 心跳间隔
|
heartbeatInterval = 60 * time.Second // 心跳间隔
|
||||||
// HeartCheckMsg = "~#HHHBBB#~" //心跳检测消息
|
HeartCheckMsg = "~#HHHBBB#~" //心跳检测消息
|
||||||
// HeartCheckSuccess = "HB" //成功发送返回心跳消息
|
HeartCheckSuccess = "HB" //成功发送返回心跳消息
|
||||||
// VendorIDMT = 10 //im美团
|
VendorIDMT = 10 //im美团
|
||||||
// VendorIDELM = 11 //im饿了么
|
VendorIDELM = 11 //im饿了么
|
||||||
// SendTypeJx = "jx" //京西客户端发送方标识
|
SendTypeJx = "jx" //京西客户端发送方标识
|
||||||
// SendTypeMt = "mt" //美团用户发送方标识符
|
SendTypeMt = "mt" //美团用户发送方标识符
|
||||||
// SendTypeElm = "elm" //饿了么用户发送方标识符
|
SendTypeElm = "elm" //饿了么用户发送方标识符
|
||||||
// MTIMPushUrl = "wss://wpush.meituan.com/websocket" //buildPushConnect建立长连接
|
MTIMPushUrl = "wss://wpush.meituan.com/websocket" //buildPushConnect建立长连接
|
||||||
//)
|
)
|
||||||
//
|
|
||||||
//const (
|
const (
|
||||||
// ExpireTimeDay = 24 * time.Hour //redis一天过期时间
|
ExpireTimeDay = 24 * time.Hour //redis一天过期时间
|
||||||
// maxMessageSize = 8192 // 最大的消息大小
|
maxMessageSize = 8192 // 最大的消息大小
|
||||||
//)
|
)
|
||||||
//
|
|
||||||
//type renderData struct {
|
type renderData struct {
|
||||||
// ClientId string `json:"clientId"`
|
ClientId string `json:"clientId"`
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//const (
|
const (
|
||||||
// SuccessCode = 0
|
SuccessCode = 0
|
||||||
// SuccessMsg = "success"
|
SuccessMsg = "success"
|
||||||
// Fail = -1
|
Fail = -1
|
||||||
// FailMsg = "fail"
|
FailMsg = "fail"
|
||||||
//
|
|
||||||
// SYSTEM_ID_ERROR = -1001
|
SYSTEM_ID_ERROR = -1001
|
||||||
// ONLINE_MESSAGE_CODE = 1001
|
ONLINE_MESSAGE_CODE = 1001
|
||||||
// OFFLINE_MESSAGE_CODE = 1002
|
OFFLINE_MESSAGE_CODE = 1002
|
||||||
//)
|
)
|
||||||
//
|
|
||||||
//// Render 统一返回值
|
// Render 统一返回值
|
||||||
//func Render(conn *websocket.Conn, messageId string, code int, message string, data interface{}) error {
|
func Render(conn *websocket.Conn, messageId string, code int, message string, data interface{}) error {
|
||||||
// return conn.WriteJSON(RetData{
|
return conn.WriteJSON(RetData{
|
||||||
// Code: code,
|
Code: code,
|
||||||
// Msg: message,
|
Msg: message,
|
||||||
// Data: data,
|
Data: data,
|
||||||
// })
|
})
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//func ClientRender(w http.ResponseWriter, code int, msg string, data interface{}) (str string) {
|
func ClientRender(w http.ResponseWriter, code int, msg string, data interface{}) (str string) {
|
||||||
// var retData RetData
|
var retData RetData
|
||||||
//
|
|
||||||
// retData.Code = code
|
retData.Code = code
|
||||||
// retData.Msg = msg
|
retData.Msg = msg
|
||||||
// retData.Data = data
|
retData.Data = data
|
||||||
//
|
|
||||||
// retJson, _ := json.Marshal(retData)
|
retJson, _ := json.Marshal(retData)
|
||||||
// str = string(retJson)
|
str = string(retJson)
|
||||||
//
|
|
||||||
// w.Header().Set("Content-Type", "application/json; charset=utf-8")
|
w.Header().Set("Content-Type", "application/json; charset=utf-8")
|
||||||
// _, _ = io.WriteString(w, str)
|
_, _ = io.WriteString(w, str)
|
||||||
// return
|
return
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//func ConnRender(conn *websocket.Conn, data interface{}) (err error) {
|
func ConnRender(conn *websocket.Conn, data interface{}) (err error) {
|
||||||
// err = conn.WriteJSON(RetData{
|
err = conn.WriteJSON(RetData{
|
||||||
// Code: SuccessCode,
|
Code: SuccessCode,
|
||||||
// Msg: "success",
|
Msg: "success",
|
||||||
// Data: data,
|
Data: data,
|
||||||
// })
|
})
|
||||||
// return
|
return
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//// Default 给默认值
|
// Default 给默认值
|
||||||
//func Default() {
|
func Default() {
|
||||||
// CommonSetting = &commonConf{
|
CommonSetting = &commonConf{
|
||||||
// HttpPort: "6000",
|
HttpPort: "6000",
|
||||||
// RPCPort: "7000",
|
RPCPort: "7000",
|
||||||
// Cluster: false,
|
Cluster: false,
|
||||||
// CryptoKey: "Adba723b7fe06819",
|
CryptoKey: "Adba723b7fe06819",
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// GlobalSetting = &global{
|
GlobalSetting = &global{
|
||||||
// LocalHost: getIntranetIp(),
|
LocalHost: getIntranetIp(),
|
||||||
// ServerList: make(map[string]string),
|
ServerList: make(map[string]string),
|
||||||
// }
|
}
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//// Setup 初始化全局设置变量
|
// Setup 初始化全局设置变量
|
||||||
//func Setup() {
|
func Setup() {
|
||||||
// configFile := flag.String("c", "conf/app.ini", "-c conf/app.ini")
|
configFile := flag.String("c", "conf/app.ini", "-c conf/app.ini")
|
||||||
//
|
|
||||||
// var err error
|
var err error
|
||||||
// cfg, err = ini.Load(*configFile)
|
cfg, err = ini.Load(*configFile)
|
||||||
// if err != nil {
|
if err != nil {
|
||||||
// log.Fatalf("setting.Setup, fail to parse 'conf/app.ini': %v", err)
|
log.Fatalf("setting.Setup, fail to parse 'conf/app.ini': %v", err)
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// mapTo("common", CommonSetting)
|
mapTo("common", CommonSetting)
|
||||||
//
|
|
||||||
// GlobalSetting = &global{
|
GlobalSetting = &global{
|
||||||
// LocalHost: getIntranetIp(),
|
LocalHost: getIntranetIp(),
|
||||||
// ServerList: make(map[string]string),
|
ServerList: make(map[string]string),
|
||||||
// }
|
}
|
||||||
// fmt.Printf("LocalHost=%s\n ServerList=%s\n", GlobalSetting.LocalHost, utils.Format4Output(GlobalSetting.ServerList, false))
|
fmt.Printf("LocalHost=%s\n ServerList=%s\n", GlobalSetting.LocalHost, utils.Format4Output(GlobalSetting.ServerList, false))
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//// mapTo map section
|
// mapTo map section
|
||||||
//func mapTo(section string, v interface{}) {
|
func mapTo(section string, v interface{}) {
|
||||||
// err := cfg.Section(section).MapTo(v)
|
err := cfg.Section(section).MapTo(v)
|
||||||
// if err != nil {
|
if err != nil {
|
||||||
// log.Fatalf("Cfg.MapTo %s err: %v", section, err)
|
log.Fatalf("Cfg.MapTo %s err: %v", section, err)
|
||||||
// }
|
}
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
////获取本机IP
|
//获取本机IP
|
||||||
//func getIntranetIp() string {
|
func getIntranetIp() string {
|
||||||
// addrs, _ := net.InterfaceAddrs()
|
addrs, _ := net.InterfaceAddrs()
|
||||||
// for _, addr := range addrs {
|
for _, addr := range addrs {
|
||||||
// // 检查ip地址判断是否回环地址
|
// 检查ip地址判断是否回环地址
|
||||||
// if ipnet, ok := addr.(*net.IPNet); ok && !ipnet.IP.IsLoopback() {
|
if ipnet, ok := addr.(*net.IPNet); ok && !ipnet.IP.IsLoopback() {
|
||||||
// if ipnet.IP.To4() != nil {
|
if ipnet.IP.To4() != nil {
|
||||||
// return ipnet.IP.String()
|
return ipnet.IP.String()
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
// return ""
|
return ""
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
//// GenFullUrl 组装完整websocket url以及生成clientID
|
// GenFullUrl 组装完整websocket url以及生成clientID
|
||||||
//func GenFullUrl() (fullUrl string) {
|
func GenFullUrl() (fullUrl string) {
|
||||||
// resp, err := api.MtwmAPI.GetConnectionToken()
|
resp, err := api.MtwmAPI.GetConnectionToken()
|
||||||
// if err != nil {
|
if err != nil {
|
||||||
// return ""
|
return ""
|
||||||
// }
|
}
|
||||||
// retVal := mtwmapi.GetConnTokenResp{}
|
retVal := mtwmapi.GetConnTokenResp{}
|
||||||
// err = mapstructure.Decode(resp, &retVal)
|
err = mapstructure.Decode(resp, &retVal)
|
||||||
// fullUrl = MTIMPushUrl + "/" + retVal.AppKey + "/" + retVal.ConnectionToken
|
fullUrl = MTIMPushUrl + "/" + retVal.AppKey + "/" + retVal.ConnectionToken
|
||||||
// //clientID = api.MtwmAPI.GetAppID() + ":" + retVal.ConnectionToken
|
//clientID = api.MtwmAPI.GetAppID() + ":" + retVal.ConnectionToken
|
||||||
// //打印输出
|
//打印输出
|
||||||
// //fmt.Printf("Create websocket connect failCount:%d", retVal.UserCount)
|
//fmt.Printf("Create websocket connect failCount:%d", retVal.UserCount)
|
||||||
// return fullUrl
|
return fullUrl
|
||||||
//}
|
}
|
||||||
|
|||||||
@@ -1,264 +1,263 @@
|
|||||||
package im
|
package im
|
||||||
|
|
||||||
//
|
import (
|
||||||
//import (
|
"errors"
|
||||||
// "errors"
|
"fmt"
|
||||||
// "fmt"
|
"net/http"
|
||||||
// "net/http"
|
"time"
|
||||||
// "time"
|
|
||||||
//
|
"git.rosy.net.cn/baseapi/utils"
|
||||||
// "git.rosy.net.cn/baseapi/utils"
|
|
||||||
//
|
"git.rosy.net.cn/jx-callback/globals"
|
||||||
// "git.rosy.net.cn/jx-callback/globals"
|
"github.com/gorilla/websocket"
|
||||||
// "github.com/gorilla/websocket"
|
)
|
||||||
//)
|
|
||||||
//
|
func Init() {
|
||||||
//func Init() {
|
//初始化
|
||||||
// //初始化
|
ToClientChan = make(chan clientInfo, 1000)
|
||||||
// ToClientChan = make(chan clientInfo, 1000)
|
//写入全局变量
|
||||||
// //写入全局变量
|
//Default()
|
||||||
// //Default()
|
|
||||||
//
|
Setup()
|
||||||
// Setup()
|
//建立长链接
|
||||||
// //建立长链接
|
//StartWebSocket(res, req)
|
||||||
// //StartWebSocket(res, req)
|
Send([]byte(HeartCheckMsg))
|
||||||
// Send([]byte(HeartCheckMsg))
|
|
||||||
//
|
//启动定时器
|
||||||
// //启动定时器
|
PingTimer()
|
||||||
// PingTimer()
|
|
||||||
//
|
go WriteMessage()
|
||||||
// go WriteMessage()
|
|
||||||
//
|
go Manager.Start()
|
||||||
// go Manager.Start()
|
|
||||||
//
|
fmt.Printf("服务器启动成功,端口号:%s\n", CommonSetting.HttpPort)
|
||||||
// fmt.Printf("服务器启动成功,端口号:%s\n", CommonSetting.HttpPort)
|
}
|
||||||
//}
|
|
||||||
//
|
func Run(w http.ResponseWriter, r *http.Request) {
|
||||||
//func Run(w http.ResponseWriter, r *http.Request) {
|
conn, err := (&websocket.Upgrader{
|
||||||
// conn, err := (&websocket.Upgrader{
|
ReadBufferSize: 1024,
|
||||||
// ReadBufferSize: 1024,
|
WriteBufferSize: 1024,
|
||||||
// WriteBufferSize: 1024,
|
// 允许所有CORS跨域请求
|
||||||
// // 允许所有CORS跨域请求
|
CheckOrigin: func(r *http.Request) bool {
|
||||||
// CheckOrigin: func(r *http.Request) bool {
|
return true
|
||||||
// return true
|
},
|
||||||
// },
|
}).Upgrade(w, r, nil)
|
||||||
// }).Upgrade(w, r, nil)
|
if err != nil {
|
||||||
// if err != nil {
|
globals.SugarLogger.Debugf("upgrade error: %v", err)
|
||||||
// globals.SugarLogger.Debugf("upgrade error: %v", err)
|
http.NotFound(w, r)
|
||||||
// http.NotFound(w, r)
|
return
|
||||||
// return
|
}
|
||||||
// }
|
|
||||||
//
|
//设置读取消息大小上线
|
||||||
// //设置读取消息大小上线
|
conn.SetReadLimit(maxMessageSize)
|
||||||
// conn.SetReadLimit(maxMessageSize)
|
|
||||||
//
|
clientID := r.FormValue("clientId")
|
||||||
// clientID := r.FormValue("clientId")
|
clientSocket := NewClient(clientID, conn)
|
||||||
// clientSocket := NewClient(clientID, conn)
|
|
||||||
//
|
//读取客户端消息
|
||||||
// //读取客户端消息
|
clientSocket.Read()
|
||||||
// clientSocket.Read()
|
|
||||||
//
|
if err = ConnRender(conn, renderData{ClientId: clientID}); err != nil {
|
||||||
// if err = ConnRender(conn, renderData{ClientId: clientID}); err != nil {
|
_ = conn.Close()
|
||||||
// _ = conn.Close()
|
return
|
||||||
// return
|
}
|
||||||
// }
|
|
||||||
//
|
// 用户连接事件
|
||||||
// // 用户连接事件
|
Manager.Connect <- clientSocket
|
||||||
// Manager.Connect <- clientSocket
|
}
|
||||||
//}
|
|
||||||
//
|
func StartWebSocket(conn *websocket.Conn, clientID string, err error) {
|
||||||
//func StartWebSocket(conn *websocket.Conn, clientID string, err error) {
|
|
||||||
//
|
//设置读取消息大小上线
|
||||||
// //设置读取消息大小上线
|
conn.SetReadLimit(maxMessageSize)
|
||||||
// conn.SetReadLimit(maxMessageSize)
|
|
||||||
//
|
clientSocket := NewClient(clientID, conn)
|
||||||
// clientSocket := NewClient(clientID, conn)
|
|
||||||
//
|
//读取客户端消息
|
||||||
// //读取客户端消息
|
clientSocket.Read()
|
||||||
// clientSocket.Read()
|
|
||||||
//
|
if err = ConnRender(conn, renderData{ClientId: clientID}); err != nil {
|
||||||
// if err = ConnRender(conn, renderData{ClientId: clientID}); err != nil {
|
_ = conn.Close()
|
||||||
// _ = conn.Close()
|
return
|
||||||
// return
|
}
|
||||||
// }
|
|
||||||
//
|
// 用户连接事件
|
||||||
// // 用户连接事件
|
Manager.Connect <- clientSocket
|
||||||
// Manager.Connect <- clientSocket
|
|
||||||
//
|
}
|
||||||
//}
|
|
||||||
//
|
// PingTimer 定时器发送心跳
|
||||||
//// PingTimer 定时器发送心跳
|
func PingTimer() {
|
||||||
//func PingTimer() {
|
go func() {
|
||||||
// go func() {
|
ticker := time.NewTicker(heartbeatInterval)
|
||||||
// ticker := time.NewTicker(heartbeatInterval)
|
defer ticker.Stop()
|
||||||
// defer ticker.Stop()
|
//测试用
|
||||||
// //测试用
|
i := 0
|
||||||
// i := 0
|
for {
|
||||||
// for {
|
i++
|
||||||
// i++
|
<-ticker.C
|
||||||
// <-ticker.C
|
for clientId, conn := range Manager.AllClient() {
|
||||||
// for clientId, conn := range Manager.AllClient() {
|
if err := conn.Socket.WriteControl(websocket.PingMessage, []byte{}, time.Now().Add(time.Second)); err != nil {
|
||||||
// if err := conn.Socket.WriteControl(websocket.PingMessage, []byte{}, time.Now().Add(time.Second)); err != nil {
|
Manager.DisConnect <- conn
|
||||||
// Manager.DisConnect <- conn
|
globals.SugarLogger.Debugf("发送心跳失败: %s 总连接数:%d", clientId, Manager.Count())
|
||||||
// globals.SugarLogger.Debugf("发送心跳失败: %s 总连接数:%d", clientId, Manager.Count())
|
}
|
||||||
// }
|
if err := ConnRender(conn.Socket, renderData{ClientId: clientId}); err != nil {
|
||||||
// if err := ConnRender(conn.Socket, renderData{ClientId: clientId}); err != nil {
|
return
|
||||||
// return
|
}
|
||||||
// }
|
globals.SugarLogger.Debugf("clientId=%s,i=%d", clientId, i)
|
||||||
// globals.SugarLogger.Debugf("clientId=%s,i=%d", clientId, i)
|
}
|
||||||
// }
|
}
|
||||||
// }
|
}()
|
||||||
// }()
|
}
|
||||||
//}
|
|
||||||
//
|
// WriteMessage 监听并发送给客户端信息
|
||||||
//// WriteMessage 监听并发送给客户端信息
|
func WriteMessage() {
|
||||||
//func WriteMessage() {
|
i := 0
|
||||||
// i := 0
|
for {
|
||||||
// for {
|
clientInfo := <-ToClientChan
|
||||||
// clientInfo := <-ToClientChan
|
//广播发送通知所有客户端
|
||||||
// //广播发送通知所有客户端
|
i++
|
||||||
// i++
|
fmt.Printf("WriteMessage clientInfo=%s i=%d", utils.Format4Output(clientInfo, false), i)
|
||||||
// fmt.Printf("WriteMessage clientInfo=%s i=%d", utils.Format4Output(clientInfo, false), i)
|
if Manager.AllClient() != nil {
|
||||||
// if Manager.AllClient() != nil {
|
for _, conn := range Manager.AllClient() {
|
||||||
// for _, conn := range Manager.AllClient() {
|
if err := Render(conn.Socket, clientInfo.MessageId, clientInfo.Code, clientInfo.Msg, clientInfo.Data); err != nil {
|
||||||
// if err := Render(conn.Socket, clientInfo.MessageId, clientInfo.Code, clientInfo.Msg, clientInfo.Data); err != nil {
|
Manager.DisConnect <- conn
|
||||||
// Manager.DisConnect <- conn
|
}
|
||||||
// }
|
}
|
||||||
// }
|
} else {
|
||||||
// } else {
|
globals.SugarLogger.Debugf("无客户端连接,请检查")
|
||||||
// globals.SugarLogger.Debugf("无客户端连接,请检查")
|
return
|
||||||
// return
|
}
|
||||||
// }
|
//if conn, err := Manager.GetByClientId(clientInfo.ClientId); err == nil && conn != nil {
|
||||||
// //if conn, err := Manager.GetByClientId(clientInfo.ClientId); err == nil && conn != nil {
|
// if err := Render(conn.Socket, clientInfo.MessageId, clientInfo.Code, clientInfo.Msg, clientInfo.Data); err != nil {
|
||||||
// // if err := Render(conn.Socket, clientInfo.MessageId, clientInfo.Code, clientInfo.Msg, clientInfo.Data); err != nil {
|
// Manager.DisConnect <- conn
|
||||||
// // Manager.DisConnect <- conn
|
// }
|
||||||
// // }
|
//}
|
||||||
// //}
|
}
|
||||||
// }
|
}
|
||||||
//}
|
|
||||||
//
|
// Start 管道处理程序
|
||||||
//// Start 管道处理程序
|
func (manager *ClientManager) Start() {
|
||||||
//func (manager *ClientManager) Start() {
|
for {
|
||||||
// for {
|
select {
|
||||||
// select {
|
case client := <-manager.Connect:
|
||||||
// case client := <-manager.Connect:
|
// 建立连接事件
|
||||||
// // 建立连接事件
|
manager.EventConnect(client)
|
||||||
// manager.EventConnect(client)
|
case conn := <-manager.DisConnect:
|
||||||
// case conn := <-manager.DisConnect:
|
// 断开连接事件
|
||||||
// // 断开连接事件
|
manager.EventDisconnect(conn)
|
||||||
// manager.EventDisconnect(conn)
|
}
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
//}
|
|
||||||
//
|
//从客户端读取数据
|
||||||
////从客户端读取数据
|
func (c *Client) Read() {
|
||||||
//func (c *Client) Read() {
|
go func() {
|
||||||
// go func() {
|
for {
|
||||||
// for {
|
messageType, msg, err := c.Socket.ReadMessage()
|
||||||
// messageType, msg, err := c.Socket.ReadMessage()
|
if err != nil {
|
||||||
// if err != nil {
|
if messageType == -1 && websocket.IsCloseError(err, websocket.CloseGoingAway, websocket.CloseNormalClosure, websocket.CloseNoStatusReceived) {
|
||||||
// if messageType == -1 && websocket.IsCloseError(err, websocket.CloseGoingAway, websocket.CloseNormalClosure, websocket.CloseNoStatusReceived) {
|
Manager.DisConnect <- c
|
||||||
// Manager.DisConnect <- c
|
return
|
||||||
// return
|
} else if messageType != websocket.PingMessage {
|
||||||
// } else if messageType != websocket.PingMessage {
|
return
|
||||||
// return
|
}
|
||||||
// }
|
} else {
|
||||||
// } else {
|
SendToVendor(msg)
|
||||||
// SendToVendor(msg)
|
}
|
||||||
// }
|
}
|
||||||
// }
|
}()
|
||||||
// }()
|
}
|
||||||
//}
|
|
||||||
//
|
// 以下为连接事件操作*******************************************
|
||||||
//// 以下为连接事件操作*******************************************
|
|
||||||
//
|
// EventConnect 建立连接事件
|
||||||
//// EventConnect 建立连接事件
|
func (manager *ClientManager) EventConnect(client *Client) {
|
||||||
//func (manager *ClientManager) EventConnect(client *Client) {
|
manager.AddClient(client)
|
||||||
// manager.AddClient(client)
|
}
|
||||||
//}
|
|
||||||
//
|
// EventDisconnect 断开连接事件
|
||||||
//// EventDisconnect 断开连接事件
|
func (manager *ClientManager) EventDisconnect(client *Client) {
|
||||||
//func (manager *ClientManager) EventDisconnect(client *Client) {
|
//关闭连接
|
||||||
// //关闭连接
|
_ = client.Socket.Close()
|
||||||
// _ = client.Socket.Close()
|
manager.DelClient(client)
|
||||||
// manager.DelClient(client)
|
//标记销毁
|
||||||
// //标记销毁
|
client.IsDeleted = true
|
||||||
// client.IsDeleted = true
|
client = nil
|
||||||
// client = nil
|
}
|
||||||
//}
|
|
||||||
//
|
//以下为客户端Client操作*******************************************
|
||||||
////以下为客户端Client操作*******************************************
|
|
||||||
//
|
// NewClient 初始化Client
|
||||||
//// NewClient 初始化Client
|
func NewClient(clientId string, socket *websocket.Conn) *Client {
|
||||||
//func NewClient(clientId string, socket *websocket.Conn) *Client {
|
return &Client{
|
||||||
// return &Client{
|
ClientId: clientId,
|
||||||
// ClientId: clientId,
|
Socket: socket,
|
||||||
// Socket: socket,
|
ConnectTime: uint64(time.Now().Unix()),
|
||||||
// ConnectTime: uint64(time.Now().Unix()),
|
IsDeleted: false,
|
||||||
// IsDeleted: false,
|
}
|
||||||
// }
|
}
|
||||||
//}
|
|
||||||
//
|
// AddClient 添加客户端
|
||||||
//// AddClient 添加客户端
|
func (manager *ClientManager) AddClient(client *Client) {
|
||||||
//func (manager *ClientManager) AddClient(client *Client) {
|
manager.ClientIdMapLock.Lock()
|
||||||
// manager.ClientIdMapLock.Lock()
|
defer manager.ClientIdMapLock.Unlock()
|
||||||
// defer manager.ClientIdMapLock.Unlock()
|
|
||||||
//
|
manager.ClientIdMap[client.ClientId] = client
|
||||||
// manager.ClientIdMap[client.ClientId] = client
|
}
|
||||||
//}
|
|
||||||
//
|
// DelClient 删除客户端
|
||||||
//// DelClient 删除客户端
|
func (manager *ClientManager) DelClient(client *Client) {
|
||||||
//func (manager *ClientManager) DelClient(client *Client) {
|
manager.delClientIdMap(client.ClientId)
|
||||||
// manager.delClientIdMap(client.ClientId)
|
|
||||||
//
|
}
|
||||||
//}
|
|
||||||
//
|
// 删除clientIdMap
|
||||||
//// 删除clientIdMap
|
func (manager *ClientManager) delClientIdMap(clientId string) {
|
||||||
//func (manager *ClientManager) delClientIdMap(clientId string) {
|
manager.ClientIdMapLock.Lock()
|
||||||
// manager.ClientIdMapLock.Lock()
|
defer manager.ClientIdMapLock.Unlock()
|
||||||
// defer manager.ClientIdMapLock.Unlock()
|
|
||||||
//
|
delete(manager.ClientIdMap, clientId)
|
||||||
// delete(manager.ClientIdMap, clientId)
|
}
|
||||||
//}
|
|
||||||
//
|
// GetByClientId 通过clientId获取client
|
||||||
//// GetByClientId 通过clientId获取client
|
func (manager *ClientManager) GetByClientId(clientId string) (*Client, error) {
|
||||||
//func (manager *ClientManager) GetByClientId(clientId string) (*Client, error) {
|
manager.ClientIdMapLock.RLock()
|
||||||
// manager.ClientIdMapLock.RLock()
|
defer manager.ClientIdMapLock.RUnlock()
|
||||||
// defer manager.ClientIdMapLock.RUnlock()
|
|
||||||
//
|
if client, ok := manager.ClientIdMap[clientId]; !ok {
|
||||||
// if client, ok := manager.ClientIdMap[clientId]; !ok {
|
return nil, errors.New("客户端不存在")
|
||||||
// return nil, errors.New("客户端不存在")
|
} else {
|
||||||
// } else {
|
return client, nil
|
||||||
// return client, nil
|
}
|
||||||
// }
|
}
|
||||||
//}
|
|
||||||
//
|
// AllClient 获取所有的客户端
|
||||||
//// AllClient 获取所有的客户端
|
func (manager *ClientManager) AllClient() map[string]*Client {
|
||||||
//func (manager *ClientManager) AllClient() map[string]*Client {
|
manager.ClientIdMapLock.RLock()
|
||||||
// manager.ClientIdMapLock.RLock()
|
defer manager.ClientIdMapLock.RUnlock()
|
||||||
// defer manager.ClientIdMapLock.RUnlock()
|
|
||||||
//
|
return manager.ClientIdMap
|
||||||
// return manager.ClientIdMap
|
}
|
||||||
//}
|
|
||||||
//
|
//与客户端的交互操作*************************
|
||||||
////与客户端的交互操作*************************
|
|
||||||
//
|
// NewClientManager 初始化客户端管理
|
||||||
//// NewClientManager 初始化客户端管理
|
func NewClientManager() (clientManager *ClientManager) {
|
||||||
//func NewClientManager() (clientManager *ClientManager) {
|
clientManager = &ClientManager{
|
||||||
// clientManager = &ClientManager{
|
ClientIdMap: make(map[string]*Client),
|
||||||
// ClientIdMap: make(map[string]*Client),
|
Connect: make(chan *Client, 10000),
|
||||||
// Connect: make(chan *Client, 10000),
|
DisConnect: make(chan *Client, 10000),
|
||||||
// DisConnect: make(chan *Client, 10000),
|
Groups: make(map[string][]string, 100),
|
||||||
// Groups: make(map[string][]string, 100),
|
SystemClients: make(map[string][]string, 100),
|
||||||
// SystemClients: make(map[string][]string, 100),
|
}
|
||||||
// }
|
|
||||||
//
|
return
|
||||||
// return
|
}
|
||||||
//}
|
|
||||||
//
|
// Count 获取客户端数量
|
||||||
//// Count 获取客户端数量
|
func (manager *ClientManager) Count() int {
|
||||||
//func (manager *ClientManager) Count() int {
|
manager.ClientIdMapLock.RLock()
|
||||||
// manager.ClientIdMapLock.RLock()
|
defer manager.ClientIdMapLock.RUnlock()
|
||||||
// defer manager.ClientIdMapLock.RUnlock()
|
return len(manager.ClientIdMap)
|
||||||
// return len(manager.ClientIdMap)
|
}
|
||||||
//}
|
|
||||||
|
|||||||
@@ -1,106 +1,105 @@
|
|||||||
package controllers
|
package controllers
|
||||||
|
|
||||||
//
|
import (
|
||||||
//import (
|
"encoding/json"
|
||||||
// "encoding/json"
|
"net/http"
|
||||||
// "net/http"
|
|
||||||
//
|
"git.rosy.net.cn/jx-callback/globals"
|
||||||
// "git.rosy.net.cn/jx-callback/globals"
|
|
||||||
//
|
"git.rosy.net.cn/jx-callback/business/partner/purchase/im"
|
||||||
// "git.rosy.net.cn/jx-callback/business/partner/purchase/im"
|
"github.com/astaxie/beego/server/web"
|
||||||
// "github.com/astaxie/beego/server/web"
|
)
|
||||||
//)
|
|
||||||
//
|
type IMController struct {
|
||||||
//type IMController struct {
|
web.Controller
|
||||||
// web.Controller
|
}
|
||||||
//}
|
|
||||||
//
|
// @Title IM初始化长链接
|
||||||
//// @Title IM初始化长链接
|
// @Description IM初始化长链接
|
||||||
//// @Description IM初始化长链接
|
// @Success 200 {object} controllers.CallResult
|
||||||
//// @Success 200 {object} controllers.CallResult
|
// @Failure 200 {object} controllers.CallResult
|
||||||
//// @Failure 200 {object} controllers.CallResult
|
// @router /StartWebSocket [get]
|
||||||
//// @router /StartWebSocket [get]
|
func (c *IMController) StartWebSocket() {
|
||||||
//func (c *IMController) StartWebSocket() {
|
upgrader.CheckOrigin = func(r *http.Request) bool {
|
||||||
// upgrader.CheckOrigin = func(r *http.Request) bool {
|
return true
|
||||||
// return true
|
}
|
||||||
// }
|
ws, err := upgrader.Upgrade(c.Ctx.ResponseWriter, c.Ctx.Request, nil)
|
||||||
// ws, err := upgrader.Upgrade(c.Ctx.ResponseWriter, c.Ctx.Request, nil)
|
if err != nil {
|
||||||
// if err != nil {
|
globals.SugarLogger.Errorf("upgrade error: %v", err)
|
||||||
// globals.SugarLogger.Errorf("upgrade error: %v", err)
|
return
|
||||||
// return
|
}
|
||||||
// }
|
defer ws.Close()
|
||||||
// defer ws.Close()
|
|
||||||
//
|
clientID := c.GetString("clientID")
|
||||||
// clientID := c.GetString("clientID")
|
globals.SugarLogger.Debugf("clientID=%s", clientID)
|
||||||
// globals.SugarLogger.Debugf("clientID=%s", clientID)
|
|
||||||
//
|
im.StartWebSocket(ws, clientID, err)
|
||||||
// im.StartWebSocket(ws, clientID, err)
|
}
|
||||||
//}
|
|
||||||
//
|
// @Title IM获取门店用户聊天列表
|
||||||
//// @Title IM获取门店用户聊天列表
|
// @Description IM获取门店用户聊天列表
|
||||||
//// @Description IM获取门店用户聊天列表
|
// @Param token header string true "认证token"
|
||||||
//// @Param token header string true "认证token"
|
// @Param payLoad formData string true "平台应用映射关系"
|
||||||
//// @Param payLoad formData string true "平台应用映射关系"
|
// @Success 200 {object} controllers.CallResult
|
||||||
//// @Success 200 {object} controllers.CallResult
|
// @Failure 200 {object} controllers.CallResult
|
||||||
//// @Failure 200 {object} controllers.CallResult
|
// @router /GetIMUserList [get]
|
||||||
//// @router /GetIMUserList [get]
|
func (c *IMController) GetIMUserList() {
|
||||||
//func (c *IMController) GetIMUserList() {
|
c.callGetIMUserList(func(params *tImGetIMUserListParams) (retVal interface{}, errCode string, err error) {
|
||||||
// c.callGetIMUserList(func(params *tImGetIMUserListParams) (retVal interface{}, errCode string, err error) {
|
var relInfo []im.RelInfo
|
||||||
// var relInfo []im.RelInfo
|
if err = json.Unmarshal([]byte(params.PayLoad), &relInfo); err != nil {
|
||||||
// if err = json.Unmarshal([]byte(params.PayLoad), &relInfo); err != nil {
|
retVal, err = im.GetImUserList(relInfo)
|
||||||
// retVal, err = im.GetImUserList(relInfo)
|
}
|
||||||
|
return retVal, "", err
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// @Title IM获取单个用户聊天详情
|
||||||
|
// @Description IM获取单个用户聊天详情
|
||||||
|
// @Param token header string true "认证token"
|
||||||
|
// @Param payLoad formData string true "平台用户应用映射关系"
|
||||||
|
// @Success 200 {object} controllers.CallResult
|
||||||
|
// @Failure 200 {object} controllers.CallResult
|
||||||
|
// @router /GetImChatDetail [get]
|
||||||
|
func (c *IMController) GetImChatDetail() {
|
||||||
|
c.callGetImChatDetail(func(params *tImGetImChatDetailParams) (retVal interface{}, errCode string, err error) {
|
||||||
|
var temp []im.UserRelInfo
|
||||||
|
if err = json.Unmarshal([]byte(params.PayLoad), &temp); err == nil {
|
||||||
|
retVal, err = im.GetImChatDetail(temp)
|
||||||
|
}
|
||||||
|
return retVal, "", err
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// @Title IM设置门店与单个用户已读
|
||||||
|
// @Description IM设置门店与单个用户已读
|
||||||
|
// @Param token header string true "认证token"
|
||||||
|
// @Param appID formData string true "应用id"
|
||||||
|
// @Param vendorStoreID formData string true "平台门店id"
|
||||||
|
// @Param vendorID formData string true "平台id"
|
||||||
|
// @Param userID formData string true "用户id/会话id"
|
||||||
|
// @Success 200 {object} controllers.CallResult
|
||||||
|
// @Failure 200 {object} controllers.CallResult
|
||||||
|
// @router /SetImMsgRead [post]
|
||||||
|
func (c *IMController) SetImMsgRead() {
|
||||||
|
c.callSetImMsgRead(func(params *tImSetImMsgReadParams) (retVal interface{}, errCode string, err error) {
|
||||||
|
err = im.SetJxMsgRead(params.AppID, params.VendorStoreID, params.VendorID, params.UserID)
|
||||||
|
return nil, "", err
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// @Title 向平台商发送信息
|
||||||
|
// @Description 向平台商发送信息
|
||||||
|
// @Param token header string true "认证token"
|
||||||
|
// @Param sendData formData string true "平台商消息结构体"
|
||||||
|
// @Success 200 {object} controllers.CallResult
|
||||||
|
// @Failure 200 {object} controllers.CallResult
|
||||||
|
// @router /SendToVendor [post]
|
||||||
|
//func (c *IMController) SendToVendor() {
|
||||||
|
// c.callSendToVendor(func(params *tImSendToVendorParams) (retVal interface{}, errCode string, err error) {
|
||||||
|
// var sendData im.SendData
|
||||||
|
// if err = json.Unmarshal([]byte(params.SendData), &sendData); err == nil {
|
||||||
|
// im.SendToVendor(sendData)
|
||||||
// }
|
// }
|
||||||
// return retVal, "", err
|
|
||||||
// })
|
|
||||||
//}
|
|
||||||
//
|
|
||||||
//// @Title IM获取单个用户聊天详情
|
|
||||||
//// @Description IM获取单个用户聊天详情
|
|
||||||
//// @Param token header string true "认证token"
|
|
||||||
//// @Param payLoad formData string true "平台用户应用映射关系"
|
|
||||||
//// @Success 200 {object} controllers.CallResult
|
|
||||||
//// @Failure 200 {object} controllers.CallResult
|
|
||||||
//// @router /GetImChatDetail [get]
|
|
||||||
//func (c *IMController) GetImChatDetail() {
|
|
||||||
// c.callGetImChatDetail(func(params *tImGetImChatDetailParams) (retVal interface{}, errCode string, err error) {
|
|
||||||
// var temp []im.UserRelInfo
|
|
||||||
// if err = json.Unmarshal([]byte(params.PayLoad), &temp); err == nil {
|
|
||||||
// retVal, err = im.GetImChatDetail(temp)
|
|
||||||
// }
|
|
||||||
// return retVal, "", err
|
|
||||||
// })
|
|
||||||
//}
|
|
||||||
//
|
|
||||||
//// @Title IM设置门店与单个用户已读
|
|
||||||
//// @Description IM设置门店与单个用户已读
|
|
||||||
//// @Param token header string true "认证token"
|
|
||||||
//// @Param appID formData string true "应用id"
|
|
||||||
//// @Param vendorStoreID formData string true "平台门店id"
|
|
||||||
//// @Param vendorID formData string true "平台id"
|
|
||||||
//// @Param userID formData string true "用户id/会话id"
|
|
||||||
//// @Success 200 {object} controllers.CallResult
|
|
||||||
//// @Failure 200 {object} controllers.CallResult
|
|
||||||
//// @router /SetImMsgRead [post]
|
|
||||||
//func (c *IMController) SetImMsgRead() {
|
|
||||||
// c.callSetImMsgRead(func(params *tImSetImMsgReadParams) (retVal interface{}, errCode string, err error) {
|
|
||||||
// err = im.SetJxMsgRead(params.AppID, params.VendorStoreID, params.VendorID, params.UserID)
|
|
||||||
// return nil, "", err
|
// return nil, "", err
|
||||||
// })
|
// })
|
||||||
//}
|
//}
|
||||||
//
|
|
||||||
//// @Title 向平台商发送信息
|
|
||||||
//// @Description 向平台商发送信息
|
|
||||||
//// @Param token header string true "认证token"
|
|
||||||
//// @Param sendData formData string true "平台商消息结构体"
|
|
||||||
//// @Success 200 {object} controllers.CallResult
|
|
||||||
//// @Failure 200 {object} controllers.CallResult
|
|
||||||
//// @router /SendToVendor [post]
|
|
||||||
////func (c *IMController) SendToVendor() {
|
|
||||||
//// c.callSendToVendor(func(params *tImSendToVendorParams) (retVal interface{}, errCode string, err error) {
|
|
||||||
//// var sendData im.SendData
|
|
||||||
//// if err = json.Unmarshal([]byte(params.SendData), &sendData); err == nil {
|
|
||||||
//// im.SendToVendor(sendData)
|
|
||||||
//// }
|
|
||||||
//// return nil, "", err
|
|
||||||
//// })
|
|
||||||
////}
|
|
||||||
|
|||||||
@@ -294,7 +294,7 @@ func Init() {
|
|||||||
QiniuAPI = qbox.NewMac(beego.AppConfig.DefaultString("qiniuAK", ""), beego.AppConfig.DefaultString("qiniuSK", ""))
|
QiniuAPI = qbox.NewMac(beego.AppConfig.DefaultString("qiniuAK", ""), beego.AppConfig.DefaultString("qiniuSK", ""))
|
||||||
ShowAPI = showapi.New(beego.AppConfig.DefaultInt("showAppID", 0), beego.AppConfig.DefaultString("showAppSecret", ""))
|
ShowAPI = showapi.New(beego.AppConfig.DefaultInt("showAppID", 0), beego.AppConfig.DefaultString("showAppSecret", ""))
|
||||||
|
|
||||||
Cacher = redis.New(beego.AppConfig.DefaultString("redisHost", ""), beego.AppConfig.DefaultInt("redisPort", 0), beego.AppConfig.DefaultString("redisPassword", ""))
|
Cacher = redis.New(beego.AppConfig.DefaultString("redisHost", "localhost"), beego.AppConfig.DefaultInt("redisPort", 0), beego.AppConfig.DefaultString("redisPassword", ""))
|
||||||
//Todo 本地测试用
|
//Todo 本地测试用
|
||||||
//Cacher = redis.New(beego.AppConfig.DefaultString("redisHost", "127.0.0.1"), beego.AppConfig.DefaultInt("redisPort", 6379), beego.AppConfig.DefaultString("redisPassword", "123456"))
|
//Cacher = redis.New(beego.AppConfig.DefaultString("redisHost", "127.0.0.1"), beego.AppConfig.DefaultInt("redisPort", 6379), beego.AppConfig.DefaultString("redisPassword", "123456"))
|
||||||
|
|
||||||
|
|||||||
3
main.go
3
main.go
@@ -3,6 +3,7 @@ package main
|
|||||||
import (
|
import (
|
||||||
"flag"
|
"flag"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"git.rosy.net.cn/jx-callback/business/partner/purchase/im"
|
||||||
"net/http"
|
"net/http"
|
||||||
_ "net/http/pprof"
|
_ "net/http/pprof"
|
||||||
"os"
|
"os"
|
||||||
@@ -94,7 +95,7 @@ func Init() {
|
|||||||
enterprise.Init() // 初始化enterprise key
|
enterprise.Init() // 初始化enterprise key
|
||||||
auto_delivery.Init() // 初始化骑手列表
|
auto_delivery.Init() // 初始化骑手列表
|
||||||
|
|
||||||
//im.Init() //初始化ws连接
|
im.Init() //初始化ws连接
|
||||||
//go http.HandleFunc("/v2/im/StartWebSocket", im.Run)
|
//go http.HandleFunc("/v2/im/StartWebSocket", im.Run)
|
||||||
|
|
||||||
//test
|
//test
|
||||||
|
|||||||
@@ -165,11 +165,11 @@ func init() {
|
|||||||
&controllers.VersionController{},
|
&controllers.VersionController{},
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
//web.NSNamespace("/im",
|
web.NSNamespace("/im",
|
||||||
// web.NSInclude(
|
web.NSInclude(
|
||||||
// &controllers.IMController{},
|
&controllers.IMController{},
|
||||||
// ),
|
),
|
||||||
//),
|
),
|
||||||
)
|
)
|
||||||
web.AddNamespace(ns)
|
web.AddNamespace(ns)
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user