package app import ( "context" "database/sql" "errors" "gim/internal/logic/domain/group/model" "gim/internal/logic/domain/group/repo" "gim/pkg/db" "gim/pkg/pb" ) type groupApp struct{} var GroupApp = new(groupApp) // CreateGroup 创建群组 func (*groupApp) CreateGroup(ctx context.Context, userId int64, in *pb.CreateGroupReq) (int64, error) { group := model.CreateGroup(userId, in) err := repo.GroupRepo.Save(group) if err != nil { return 0, err } return group.Id, nil } // GetGroup 获取群组信息 func (*groupApp) GetGroup(ctx context.Context, groupId int64) (*pb.Group, error) { group, err := repo.GroupRepo.Get(groupId) if err != nil { return nil, err } return group.ToProto(), nil } // GetUserGroups 获取用户加入的群组列表 func (*groupApp) GetUserGroups(ctx context.Context, userId int64) ([]*pb.Group, error) { groups, err := repo.GroupUserRepo.ListByUserId(userId) if err != nil { return nil, err } pbGroups := make([]*pb.Group, len(groups)) for i := range groups { pbGroups[i] = groups[i].ToProto() } return pbGroups, nil } // Update 更新群组 func (*groupApp) Update(ctx context.Context, userId int64, update *pb.UpdateGroupReq) error { group, err := repo.GroupRepo.Get(update.GroupId) if err != nil { return err } var isUpdateIntroduction = false if group.Introduction != update.Introduction { isUpdateIntroduction = true } err = group.Update(ctx, update) if err != nil { return err } err = repo.GroupRepo.Save(group) if err != nil { return err } err = group.PushUpdate(ctx, userId, isUpdateIntroduction) if err != nil { return err } return nil } // AddMembers 添加群组成员 func (*groupApp) AddMembers(ctx context.Context, userId, groupId int64, userIds []int64) ([]int64, error) { group, err := repo.GroupRepo.Get(groupId) if err != nil { return nil, err } existIds, addedIds, err := group.AddMembers(ctx, userIds) if err != nil { return nil, err } err = repo.GroupRepo.Save(group) if err != nil { return nil, err } err = group.PushAddMember(ctx, userId, addedIds) if err != nil { return nil, err } return existIds, nil } // UpdateMember 更新群组用户 func (*groupApp) UpdateMember(ctx context.Context, in *pb.UpdateGroupMemberReq, optId int64) error { group, err := repo.GroupRepo.Get(in.GroupId) if err != nil { return err } err = group.UpdateMember(ctx, in) if err != nil { return err } err = repo.GroupRepo.Save(group) if err != nil { return err } err = group.PushUpdateMember(ctx, optId, in.UserId, int32(in.MemberType)) if err != nil { return err } return nil } // DeleteMember 删除群组成员 func (*groupApp) DeleteMember(ctx context.Context, groupId int64, userId int64, optId int64) error { group, err := repo.GroupRepo.Get(groupId) if err != nil { return err } err = group.DeleteMember(ctx, userId) if err != nil { return err } err = repo.GroupRepo.Save(group) if err != nil { return err } err = group.PushDeleteMember(ctx, optId, userId) if err != nil { return err } return nil } // GetMembers 获取群组成员 func (*groupApp) GetMembers(ctx context.Context, groupId int64) ([]*pb.GroupMember, error) { group, err := repo.GroupRepo.Get(groupId) if err != nil { return nil, err } return group.GetMembers(ctx) } // SendMessage 发送群组消息 func (*groupApp) SendMessage(ctx context.Context, sender *pb.Sender, req *pb.SendMessageReq) (int64, error) { group, err := repo.GroupRepo.Get(req.ReceiverId) if err != nil { return 0, err } return group.SendMessage(ctx, sender, req) } // GetBannedMembers 获取群组禁言成员 func (*groupApp) GetBannedMembers(ctx context.Context, groupId int64) ([]*pb.GroupMember, error) { // 查询被禁言的成员列表 group, err := repo.GroupRepo.GetForBanned(groupId) if err != nil { return nil, err } return group.GetMembers(ctx) } // SetGroupMemberBanned 设置禁言 func (*groupApp) SetGroupMemberBanned(ctx context.Context, optId, groupId int64, userIds []int64, isAllMemberBanned bool) ([]*pb.GroupMember, error) { groupUser, err := repo.GroupUserRepo.Get(groupId, optId) if err != nil { return nil, err } if groupUser == nil { return nil, errors.New("未查询到群组用户信息") } if groupUser.MemberType != int(pb.MemberType_GMT_ADMIN) && groupUser.MemberType != int(pb.MemberType_GMT_MANAGE) { return nil, errors.New("非管理员操作") } group, err := repo.GroupRepo.Get(groupId) if err != nil { return nil, err } if isAllMemberBanned { //设置全员禁言 //1、更新 `group` 的 is_all_member_banned 状态 group.IsAllMemberBanned = int32(pb.AllMemberBannedType_YES_All_Member_Banned) err := repo.GroupRepo.Save(group) if err != nil { return nil, err } //2、发送推送消息 err = group.PushGroupMemberBanned(ctx, optId, 0, isAllMemberBanned) if err != nil { return nil, err } } else { //设置成员禁言 //1、更新 `group` 的 is_all_member_banned 状态 if group.IsAllMemberBanned != int32(pb.AllMemberBannedType_NOT_All_Member_Banned) { group.IsAllMemberBanned = int32(pb.AllMemberBannedType_NOT_All_Member_Banned) err := repo.GroupRepo.Save(group) if err != nil { return nil, err } //TODO::推送消息 err = group.PushGroupMemberBanned(ctx, optId, -1, isAllMemberBanned) if err != nil { return nil, err } } //2、更新 `group_user` 的 status 状态 if len(userIds) == 0 { db.DB.Model(model.GroupUser{}).Where("group_id = ?", groupId).Updates(model.GroupUserV2{Status: sql.NullInt32{Int32: int32(pb.GroupUserStatusType_GROUP_USER_STATUS_NORMAL), Valid: true}}) } else { db.DB.Model(model.GroupUser{}).Where("user_id in (?) and group_id = ?", userIds, groupId).Updates(model.GroupUserV2{Status: sql.NullInt32{Int32: int32(pb.GroupUserStatusType_GROUP_USER_STATUS_Banned), Valid: true}}) db.DB.Model(model.GroupUser{}).Where("(user_id) not in (?) and group_id = ?", userIds, groupId).Updates(model.GroupUserV2{Status: sql.NullInt32{Int32: int32(pb.GroupUserStatusType_GROUP_USER_STATUS_NORMAL), Valid: true}}) } //3、发送推送消息 for _, u := range userIds { err = group.PushGroupMemberBanned(ctx, optId, u, isAllMemberBanned) if err != nil { return nil, err } } } // 查询被禁言的成员列表 group, err = repo.GroupRepo.GetForBanned(groupId) if err != nil { return nil, err } return group.GetMembers(ctx) } // SetGroupMemberRemoveBanned 设置取消禁言 func (*groupApp) SetGroupMemberRemoveBanned(ctx context.Context, optId, groupId int64, removeUserIds []int64) error { groupUser, err := repo.GroupUserRepo.Get(groupId, optId) if err != nil { return err } if groupUser == nil { return errors.New("未查询到群组用户信息") } if groupUser.MemberType != int(pb.MemberType_GMT_ADMIN) && groupUser.MemberType != int(pb.MemberType_GMT_MANAGE) { return errors.New("非管理员操作") } group, err := repo.GroupRepo.Get(groupId) if err != nil { return err } if len(removeUserIds) > 0 { //1、更新 `group_user` 的 status 状态 db.DB.Model(model.GroupUser{}).Where("user_id in (?) and group_id = ?", removeUserIds, groupId).Updates(model.GroupUserV2{Status: sql.NullInt32{Int32: int32(pb.GroupUserStatusType_GROUP_USER_STATUS_NORMAL), Valid: true}}) //2、给取消禁言用户推送消息 for _, u := range removeUserIds { err = group.PushGroupMemberRemoveBanned(ctx, optId, u) if err != nil { return err } } } return nil } // RecallSendMessage 撤回发送消息 func (*groupApp) RecallSendMessage(ctx context.Context, sender *pb.Sender, req *pb.RecallMessageReq) (int64, error) { group, err := repo.GroupRepo.Get(req.ReceiverId) if err != nil { return 0, err } return group.RecallSendMessage(ctx, sender, req) } // SendRedPackage 发送红包消息 func (*groupApp) SendRedPackage(ctx context.Context, sender *pb.Sender, req *pb.SendRedPacketReq) (int64, error) { group, err := repo.GroupRepo.Get(req.ReceiverId) if err != nil { return 0, err } return group.SendRedPackage(ctx, sender, req) }