MemberGroupMemberModel.go 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264
  1. package models
  2. import (
  3. "github.com/lifei6671/mindoc/conf"
  4. "time"
  5. "github.com/astaxie/beego/orm"
  6. "github.com/astaxie/beego"
  7. "errors"
  8. )
  9. type MemberGroupMembers struct {
  10. GroupMemberId int `orm:"column(group_member_id);pk;auto;unique;" json:"group_member_id"`
  11. MemberId int `orm:"column(member_id);index" json:"member_id"`
  12. GroupId int `orm:"column(group_id);index" json:"group_id"`
  13. CreateTime time.Time `orm:"type(datetime);column(create_time);auto_now_add" json:"create_time"`
  14. CreateAt int `orm:"type(int);column(create_at)" json:"create_at"`
  15. }
  16. type MemberGroupMemberResult struct {
  17. GroupMemberId int `json:"group_member_id"`
  18. MemberId int `json:"member_id"`
  19. Account string `json:"account"`
  20. RealName string `json:"real_name"`
  21. RoleName string `json:"role_name"`
  22. Avatar string `json:"avatar"`
  23. GroupId int `json:"group_id"`
  24. CreateTime time.Time `json:"create_time"`
  25. CreateAt int `json:"create_at"`
  26. }
  27. //搜索未加入当前用户组的用户信息
  28. type MemberGroupMemberNoJoinSearchResult struct {
  29. MemberId int `json:"member_id"`
  30. Account string `json:"account"`
  31. }
  32. // TableName 获取对应数据库表名.
  33. func (m *MemberGroupMembers) TableName() string {
  34. return "member_group_members"
  35. }
  36. // TableEngine 获取数据使用的引擎.
  37. func (m *MemberGroupMembers) TableEngine() string {
  38. return "INNODB"
  39. }
  40. func (m *MemberGroupMembers) TableNameWithPrefix() string {
  41. return conf.GetDatabasePrefix() + m.TableName()
  42. }
  43. // 多字段唯一键
  44. func (m *MemberGroupMembers) TableUnique() [][]string {
  45. return [][]string{
  46. {"member_id", "group_id"},
  47. }
  48. }
  49. func NewMemberGroupMembers() *MemberGroupMembers {
  50. return &MemberGroupMembers{}
  51. }
  52. // 查询用户组成员
  53. func (m *MemberGroupMembers) FindResultByGroupId(groupId int) ([]*MemberGroupMemberResult,error) {
  54. o := orm.NewOrm()
  55. var groupMembers []*MemberGroupMemberResult
  56. _,err := o.QueryTable(m.TableNameWithPrefix()).Filter("group_id",groupId).All(&groupMembers);
  57. if err != nil {
  58. beego.Error("获取用户组成员出错 =>",err)
  59. return nil,err
  60. }
  61. ids := make([]int,0)
  62. for _,member := range groupMembers {
  63. ids = append(ids,member.MemberId)
  64. }
  65. var members []*Member
  66. _,err = o.QueryTable(NewMember().TableNameWithPrefix()).Filter("member_id__in",ids).All(&members)
  67. if err != nil {
  68. beego.Error("获取用户组成员出错 =>",err)
  69. return nil,err
  70. }
  71. for _,member := range members {
  72. for _,groupMember := range groupMembers {
  73. if groupMember.MemberId == member.MemberId {
  74. groupMember.Account = member.Account
  75. groupMember.Avatar = member.Avatar
  76. groupMember.RealName = member.RealName
  77. }
  78. }
  79. }
  80. return groupMembers,nil
  81. }
  82. func (m *MemberGroupMembers) FindByGroupId(groupId int) ([]*MemberGroupMembers,error) {
  83. o := orm.NewOrm()
  84. var groupMembers []*MemberGroupMembers
  85. _,err := o.QueryTable(m.TableNameWithPrefix()).Filter("group_id",groupId).All(&groupMembers);
  86. if err != nil {
  87. beego.Error("获取用户组成员出错 =>",err)
  88. return nil,err
  89. }
  90. return groupMembers,nil
  91. }
  92. //判断一个用户是否加入了指定用户组
  93. func (m *MemberGroupMembers) IsJoin(groupId ,memberId int) (bool) {
  94. o := orm.NewOrm()
  95. return o.QueryTable(m.TableNameWithPrefix()).Filter("group_id",groupId).Filter("member_id",memberId).Exist()
  96. }
  97. //添加或更新用户组成员
  98. func (m *MemberGroupMembers) InsertOrUpdate(cols ...string) error {
  99. o := orm.NewOrm()
  100. if m.GroupMemberId > 0 {
  101. _,err := o.Update(m,cols...)
  102. if err != nil {
  103. beego.Error("更新用户组成员失败 =>",err)
  104. }
  105. return err
  106. }else{
  107. if m.GroupId <= 0 {
  108. return errors.New("用户组不能为空")
  109. }
  110. _,err := o.Insert(m)
  111. if err != nil {
  112. beego.Error("添加用户组成员失败 =>",err)
  113. }else{
  114. go NewMemberGroup().ResetMemberGroupNumber(m.GroupId)
  115. }
  116. return err
  117. }
  118. }
  119. //删除用户组成员
  120. func (m *MemberGroupMembers) Delete(id int) error {
  121. o := orm.NewOrm()
  122. if err := o.QueryTable(m.TableNameWithPrefix()).Filter("group_member_id",id).One(m);err != nil {
  123. beego.Error("删除用户组成员失败 =>",err)
  124. return err
  125. }
  126. i,err := o.QueryTable(m.TableNameWithPrefix()).Filter("group_member_id",id).Delete()
  127. if err != nil {
  128. beego.Error("删除用户组成员失败 =>",err)
  129. return err
  130. }
  131. if i <= 0 {
  132. beego.Info("删除用户组成员返回行数 =>",i)
  133. }
  134. go NewMemberGroup().ResetMemberGroupNumber(m.GroupId)
  135. return nil
  136. }
  137. //分页获取用户组成员
  138. func (m *MemberGroupMembers) FindToPager(pageIndex, pageSize, groupId int) ([]*MemberGroupMemberResult,int,error) {
  139. o := orm.NewOrm()
  140. if pageIndex <= 0 {
  141. pageIndex = 1
  142. }
  143. offset := (pageIndex - 1) * pageSize
  144. var memberGroupMembers []*MemberGroupMembers
  145. totalCount := 0
  146. _,err := o.QueryTable(m.TableNameWithPrefix()).Filter("group_id",groupId).Offset(offset).Limit(pageSize).All(&memberGroupMembers)
  147. memberGroupMemberList := make([]*MemberGroupMemberResult,0)
  148. if err != nil {
  149. beego.Error("分页查询用户组成员失败 =>",err)
  150. }else{
  151. i,err := o.QueryTable(m.TableNameWithPrefix()).Filter("group_id",groupId).Count()
  152. if err != nil {
  153. beego.Error("分页查询用户组成员失败 =>",err)
  154. }else {
  155. totalCount = int(i)
  156. }
  157. for _,member := range memberGroupMembers {
  158. memberGroupMemberList = append(memberGroupMemberList,member.ToMemberRelationshipResult())
  159. }
  160. }
  161. return memberGroupMemberList,totalCount,err
  162. }
  163. //将用户组信息转换为完整的用户信息
  164. func (m *MemberGroupMembers) ToMemberRelationshipResult() *MemberGroupMemberResult {
  165. memberGroupMemberResult := &MemberGroupMemberResult{}
  166. memberGroupMemberResult.GroupId = m.GroupId
  167. memberGroupMemberResult.GroupMemberId = m.GroupMemberId
  168. memberGroupMemberResult.MemberId = m.MemberId
  169. memberGroupMemberResult.CreateAt = m.CreateAt
  170. memberGroupMemberResult.CreateTime = m.CreateTime
  171. if m.MemberId > 0 {
  172. member,err := NewMember().Find(memberGroupMemberResult.MemberId)
  173. if err != nil {
  174. beego.Error("查询用户组成员信息时出错 =>",err)
  175. }else{
  176. memberGroupMemberResult.RealName = member.RealName
  177. memberGroupMemberResult.Avatar = member.Avatar
  178. memberGroupMemberResult.Account = member.Account
  179. memberGroupMemberResult.RoleName = member.RoleName
  180. }
  181. }
  182. return memberGroupMemberResult
  183. }
  184. //获取未加入用户组的用户成员
  185. func (m *MemberGroupMembers) FindMemberGroupMemberNoJoinSearchResult(groupId int,q string) ([]*MemberGroupMemberNoJoinSearchResult,error) {
  186. o := orm.NewOrm()
  187. sql := "select member.member_id,member.account from md_members as member left join md_member_group_members as member_group on member_group.member_id = member.member_id and member_group.group_id=? where member_group.member_id isnull and account like ?limit 20;"
  188. var memberGroupMembers []*MemberGroupMemberNoJoinSearchResult
  189. _,err := o.Raw(sql,groupId,"%" + q + "%").QueryRows(&memberGroupMembers)
  190. if err != nil {
  191. beego.Error("获取未加入用户组的用户失败 =>",err)
  192. }
  193. return memberGroupMembers,err
  194. }