weiduxiaoxi
This commit is contained in:
@@ -179,7 +179,16 @@ func CreateMessageGroup(ctx *jxcontext.Context, userID, userID2, groupName strin
|
|||||||
messageGroupRead2 := messageGroupRead
|
messageGroupRead2 := messageGroupRead
|
||||||
messageGroupRead2.UserID = userID2
|
messageGroupRead2.UserID = userID2
|
||||||
dao.CreateEntity(db, messageGroupRead)
|
dao.CreateEntity(db, messageGroupRead)
|
||||||
dao.CreateEntity(db, messageGroupRead2)
|
if err = dao.CreateEntity(db, messageGroupRead2); err == nil {
|
||||||
|
if messageGroupReads, err := dao.GetMessageGroupRead(db, userID2, model.SysGroupID); len(messageGroupReads) == 0 && err == nil {
|
||||||
|
messageGroupRead := &model.MessageGroupRead{
|
||||||
|
GroupID: model.SysGroupID,
|
||||||
|
UserID: userID2,
|
||||||
|
}
|
||||||
|
dao.WrapAddIDCULEntity(messageGroupRead, ctx.GetUserName())
|
||||||
|
dao.CreateEntity(db, messageGroupRead)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
userMembers, err := dao.GetUserMember(db, userID, model.MemberTypeNormal)
|
userMembers, err := dao.GetUserMember(db, userID, model.MemberTypeNormal)
|
||||||
@@ -216,6 +225,16 @@ func CreateMessageGroup(ctx *jxcontext.Context, userID, userID2, groupName strin
|
|||||||
dao.CreateEntity(db, messageGroupRead)
|
dao.CreateEntity(db, messageGroupRead)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if err == nil {
|
||||||
|
if messageGroupReads, err := dao.GetMessageGroupRead(db, userID, model.SysGroupID); len(messageGroupReads) == 0 && err == nil {
|
||||||
|
messageGroupRead := &model.MessageGroupRead{
|
||||||
|
GroupID: model.SysGroupID,
|
||||||
|
UserID: userID,
|
||||||
|
}
|
||||||
|
dao.WrapAddIDCULEntity(messageGroupRead, ctx.GetUserName())
|
||||||
|
dao.CreateEntity(db, messageGroupRead)
|
||||||
|
}
|
||||||
|
}
|
||||||
return messageGroupResult, err
|
return messageGroupResult, err
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -263,6 +282,14 @@ func GetMessageGroupByUser(ctx *jxcontext.Context, userID string) (messageGroupR
|
|||||||
err = nil
|
err = nil
|
||||||
return messageGroups, err
|
return messageGroups, err
|
||||||
}
|
}
|
||||||
|
//该用户各组的未读消息数
|
||||||
|
var unReadCount int
|
||||||
|
if messageGroupReads, err := dao.GetMessageGroupRead(db, v.UserID, v.GroupID); err == nil && len(messageGroupReads) > 0 {
|
||||||
|
for _, vv := range messageGroupReads {
|
||||||
|
unReadCount += vv.UnReadCount
|
||||||
|
}
|
||||||
|
}
|
||||||
|
v.UnReadMessageCount = unReadCount
|
||||||
}
|
}
|
||||||
return messageGroups, err
|
return messageGroups, err
|
||||||
}
|
}
|
||||||
@@ -306,7 +333,16 @@ func AddMessageGroup(ctx *jxcontext.Context, groupID int, userID string) (err er
|
|||||||
UserID: userID,
|
UserID: userID,
|
||||||
}
|
}
|
||||||
dao.WrapAddIDCULEntity(messageGroupRead, ctx.GetUserName())
|
dao.WrapAddIDCULEntity(messageGroupRead, ctx.GetUserName())
|
||||||
dao.CreateEntity(db, messageGroupRead)
|
if err = dao.CreateEntity(db, messageGroupRead); err == nil {
|
||||||
|
if messageGroupReads, err := dao.GetMessageGroupRead(db, userID, model.SysGroupID); len(messageGroupReads) == 0 && err == nil {
|
||||||
|
messageGroupRead := &model.MessageGroupRead{
|
||||||
|
GroupID: model.SysGroupID,
|
||||||
|
UserID: userID,
|
||||||
|
}
|
||||||
|
dao.WrapAddIDCULEntity(messageGroupRead, ctx.GetUserName())
|
||||||
|
dao.CreateEntity(db, messageGroupRead)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -21,9 +21,10 @@ type UserDeliveryAddressEx struct {
|
|||||||
type GetSelfInfoResult struct {
|
type GetSelfInfoResult struct {
|
||||||
model.User
|
model.User
|
||||||
model.UserBill
|
model.UserBill
|
||||||
WaitCashPrice int `json:"waitCashPrice"`
|
WaitCashPrice int `json:"waitCashPrice"`
|
||||||
UserMembers []*model.UserMember `json:"userMembers"`
|
UserMembers []*model.UserMember `json:"userMembers"`
|
||||||
PopedUserName string `json:"popedUserName"`
|
PopedUserName string `json:"popedUserName"`
|
||||||
|
UnReadMessageCount int `json:"unReadMessageCount"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetUserByID(db *DaoDB, fieldName, fieldValue string) (user *model.User, err error) {
|
func GetUserByID(db *DaoDB, fieldName, fieldValue string) (user *model.User, err error) {
|
||||||
@@ -58,6 +59,13 @@ func GetUserByIDWithMembers(db *DaoDB, fieldName, fieldValue string) (getSelfInf
|
|||||||
}
|
}
|
||||||
// globals.SugarLogger.Debugf("GetUserByID sql:%s, sqlParams:%s", sql, utils.Format4Output(sqlParams, false))
|
// globals.SugarLogger.Debugf("GetUserByID sql:%s, sqlParams:%s", sql, utils.Format4Output(sqlParams, false))
|
||||||
err = GetRow(db, &getSelfInfoResult, sql, sqlParams...)
|
err = GetRow(db, &getSelfInfoResult, sql, sqlParams...)
|
||||||
|
if messageGroupReads, err := GetMessageGroupRead(db, getSelfInfoResult.User.UserID, 0); err == nil {
|
||||||
|
var unReadCount int
|
||||||
|
for _, v := range messageGroupReads {
|
||||||
|
unReadCount += v.UnReadCount
|
||||||
|
}
|
||||||
|
getSelfInfoResult.UnReadMessageCount = unReadCount
|
||||||
|
}
|
||||||
return getSelfInfoResult, err
|
return getSelfInfoResult, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -206,6 +206,7 @@ type GetMessageGroupsResult struct {
|
|||||||
LastTime time.Time `json:"lastTime"`
|
LastTime time.Time `json:"lastTime"`
|
||||||
LastUserName string `json:"lastUserName"`
|
LastUserName string `json:"lastUserName"`
|
||||||
UserName string `json:"userName"`
|
UserName string `json:"userName"`
|
||||||
|
UnReadMessageCount int `json:"unReadMessageCount"`
|
||||||
MessageGroupMembers []*GetMessageGroupsMemberResult `json:"messageGroupMembers"`
|
MessageGroupMembers []*GetMessageGroupsMemberResult `json:"messageGroupMembers"`
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -303,3 +304,22 @@ func GetUserMessageGroups(db *DaoDB, userID string) (messageGroup []*model.Messa
|
|||||||
err = GetRows(db, &messageGroup, sql, sqlParams)
|
err = GetRows(db, &messageGroup, sql, sqlParams)
|
||||||
return messageGroup, err
|
return messageGroup, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func GetMessageGroupRead(db *DaoDB, userID string, groupID int) (messageGroupReads []*model.MessageGroupRead, err error) {
|
||||||
|
sql := `
|
||||||
|
SELECT *
|
||||||
|
FROM message_group_read a
|
||||||
|
WHERE 1 = 1
|
||||||
|
`
|
||||||
|
sqlParams := []interface{}{}
|
||||||
|
if userID != "" {
|
||||||
|
sql += ` AND a.user_id = ?`
|
||||||
|
sqlParams = append(sqlParams, userID)
|
||||||
|
}
|
||||||
|
if groupID != 0 {
|
||||||
|
sql += ` AND a.group_id = ?`
|
||||||
|
sqlParams = append(sqlParams, groupID)
|
||||||
|
}
|
||||||
|
err = GetRows(db, &messageGroupReads, sql, sqlParams...)
|
||||||
|
return messageGroupReads, err
|
||||||
|
}
|
||||||
|
|||||||
@@ -111,6 +111,26 @@ func (c *EventController) TestWebsocket() {
|
|||||||
//接受消息 业务逻辑
|
//接受消息 业务逻辑
|
||||||
broadcast <- s
|
broadcast <- s
|
||||||
utils.CallFuncAsync(func() {
|
utils.CallFuncAsync(func() {
|
||||||
|
//发聊天消息时,这个组所有的成员包括创建者都在userIDs里
|
||||||
|
userIDs := []string{}
|
||||||
|
if results, err := dao.GetMessageGroups(db, "", s.GroupID, 0, true, ""); err == nil {
|
||||||
|
for _, v := range results {
|
||||||
|
userIDs = append(userIDs, v.UserID)
|
||||||
|
for _, vv := range v.MessageGroupMembers {
|
||||||
|
userIDs = append(userIDs, vv.UserID)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//如果这些人不在这个组的ws池子里就打上未读标记
|
||||||
|
for _, v := range userIDs {
|
||||||
|
if clients[s.GroupID][v] == nil {
|
||||||
|
messageGroupReads, _ := dao.GetMessageGroupRead(db, v, s.GroupID)
|
||||||
|
for _, vv := range messageGroupReads {
|
||||||
|
vv.UnReadCount++
|
||||||
|
dao.UpdateEntity(db, vv, "UnReadCount")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
dao.WrapAddIDCULDEntity(s, "")
|
dao.WrapAddIDCULDEntity(s, "")
|
||||||
dao.CreateEntity(db, s)
|
dao.CreateEntity(db, s)
|
||||||
})
|
})
|
||||||
@@ -161,6 +181,7 @@ func handleMessages() {
|
|||||||
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) {
|
||||||
retVal, err = dao.GetImMessageRecord(dao.GetDB(), params.GroupID, "", 0, -1, utils.Str2Time(params.FromTime), utils.Str2Time(params.ToTime), params.Offset, params.PageSize)
|
retVal, err = dao.GetImMessageRecord(dao.GetDB(), params.GroupID, "", 0, -1, utils.Str2Time(params.FromTime), utils.Str2Time(params.ToTime), params.Offset, params.PageSize)
|
||||||
|
//清除此用户组所有的未读标记
|
||||||
return retVal, "", err
|
return retVal, "", err
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -27,6 +27,7 @@ func Init() {
|
|||||||
orm.RegisterModel(&model.JobTimer{})
|
orm.RegisterModel(&model.JobTimer{})
|
||||||
//聊天
|
//聊天
|
||||||
orm.RegisterModel(&model.ImMessageRecord{}, &model.MessageGroup{}, &model.MessageGroupMember{})
|
orm.RegisterModel(&model.ImMessageRecord{}, &model.MessageGroup{}, &model.MessageGroupMember{})
|
||||||
|
orm.RegisterModel(&model.MessageGroupRead{})
|
||||||
|
|
||||||
orm.RegisterModel(&model.Place{})
|
orm.RegisterModel(&model.Place{})
|
||||||
orm.RegisterModel(&model.OperateEventDetail{})
|
orm.RegisterModel(&model.OperateEventDetail{})
|
||||||
|
|||||||
Reference in New Issue
Block a user