a
This commit is contained in:
@@ -130,6 +130,7 @@ func ImMessage(userID string, ws *websocket.Conn) (err error) {
|
|||||||
//接受消息 业务逻辑
|
//接受消息 业务逻辑
|
||||||
broadcast <- s
|
broadcast <- s
|
||||||
if s.GroupID != 0 {
|
if s.GroupID != 0 {
|
||||||
|
if s.GroupID != model.SysGroupID {
|
||||||
//发聊天消息时,这个组所有的成员包括创建者都在userIDs里
|
//发聊天消息时,这个组所有的成员包括创建者都在userIDs里
|
||||||
userIDs := []string{}
|
userIDs := []string{}
|
||||||
if results, err := dao.GetMessageGroups(db, "", s.GroupID, 0, true, ""); err == nil {
|
if results, err := dao.GetMessageGroups(db, "", s.GroupID, 0, true, ""); err == nil {
|
||||||
@@ -150,6 +151,15 @@ func ImMessage(userID string, ws *websocket.Conn) (err error) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
if wsClient.ClientsHeart[s.ToUserID] == nil {
|
||||||
|
messageGroupReads, _ := dao.GetMessageGroupRead(db, s.ToUserID, s.GroupID)
|
||||||
|
for _, vv := range messageGroupReads {
|
||||||
|
vv.UnReadCount++
|
||||||
|
dao.UpdateEntity(db, vv, "UnReadCount")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
utils.CallFuncAsync(func() {
|
utils.CallFuncAsync(func() {
|
||||||
if s.GroupID != 0 {
|
if s.GroupID != 0 {
|
||||||
|
|||||||
@@ -142,7 +142,7 @@ func GetOperateEvents(db *DaoDB, name string, apiFunctions []string, operateType
|
|||||||
return operateEventExt, totalCount, err
|
return operateEventExt, totalCount, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetImMessageRecord(db *DaoDB, groupID int, userID string, storeID, vendorID int, fromTime, toTime time.Time, offset, pageSize int) (pagedInfo *model.PagedInfo, err error) {
|
func GetImMessageRecord(db *DaoDB, groupID int, userID, toUserID string, storeID, vendorID int, fromTime, toTime time.Time, offset, pageSize int) (pagedInfo *model.PagedInfo, err error) {
|
||||||
var msg []*model.ImMessageRecord
|
var msg []*model.ImMessageRecord
|
||||||
sql := `
|
sql := `
|
||||||
SELECT SQL_CALC_FOUND_ROWS *
|
SELECT SQL_CALC_FOUND_ROWS *
|
||||||
@@ -155,6 +155,10 @@ func GetImMessageRecord(db *DaoDB, groupID int, userID string, storeID, vendorID
|
|||||||
if groupID != 0 {
|
if groupID != 0 {
|
||||||
sql += " AND group_id = ?"
|
sql += " AND group_id = ?"
|
||||||
sqlParams = append(sqlParams, groupID)
|
sqlParams = append(sqlParams, groupID)
|
||||||
|
if groupID == model.SysGroupID {
|
||||||
|
sql += " AND to_user_id = ?"
|
||||||
|
sqlParams = append(sqlParams, toUserID)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if userID != "" {
|
if userID != "" {
|
||||||
sql += " AND user_id = ?"
|
sql += " AND user_id = ?"
|
||||||
|
|||||||
@@ -93,7 +93,7 @@ func (c *EventController) TestWebsocket() {
|
|||||||
func (c *EventController) GetImMessageRecord() {
|
func (c *EventController) GetImMessageRecord() {
|
||||||
c.callGetImMessageRecord(func(params *tEventGetImMessageRecordParams) (retVal interface{}, errCode string, err error) {
|
c.callGetImMessageRecord(func(params *tEventGetImMessageRecordParams) (retVal interface{}, errCode string, err error) {
|
||||||
var db = dao.GetDB()
|
var db = dao.GetDB()
|
||||||
retVal, err = dao.GetImMessageRecord(db, params.GroupID, "", 0, -1, utils.Str2Time(params.FromTime), utils.Str2Time(params.ToTime), params.Offset, params.PageSize)
|
retVal, err = dao.GetImMessageRecord(db, params.GroupID, "", params.Ctx.GetUserID(), 0, -1, utils.Str2Time(params.FromTime), utils.Str2Time(params.ToTime), params.Offset, params.PageSize)
|
||||||
//清除此用户组所有的未读标记
|
//清除此用户组所有的未读标记
|
||||||
if messageGroupReads, err := dao.GetMessageGroupRead(db, params.Ctx.GetUserID(), params.GroupID); err == nil {
|
if messageGroupReads, err := dao.GetMessageGroupRead(db, params.Ctx.GetUserID(), params.GroupID); err == nil {
|
||||||
for _, v := range messageGroupReads {
|
for _, v := range messageGroupReads {
|
||||||
|
|||||||
Reference in New Issue
Block a user