package models import ( "github.com/astaxie/beego/orm" "github.com/lifei6671/mindoc/conf" "time" ) type MemberRelationshipResult struct { MemberId int `json:"member_id"` Account string `json:"account"` Description string `json:"description"` Email string `json:"email"` Phone string `json:"phone"` Avatar string `json:"avatar"` Role int `json:"role"` //用户角色:0 管理员/ 1 普通用户 Status int `json:"status"` //用户状态:0 正常/1 禁用 CreateTime time.Time `json:"create_time"` CreateAt int `json:"create_at"` RelationshipId int `json:"relationship_id"` BookId int `json:"book_id"` // RoleId 角色:0 创始人(创始人不能被移除) / 1 管理员/2 编辑者/3 观察者 RoleId int `json:"role_id"` RoleName string `json:"role_name"` } type SelectMemberResult struct { Result []KeyValueItem `json:"results"` } type KeyValueItem struct { Id int `json:"id"` Text string `json:"text"` } func NewMemberRelationshipResult() *MemberRelationshipResult { return &MemberRelationshipResult{} } func (m *MemberRelationshipResult) FromMember(member *Member) *MemberRelationshipResult { m.MemberId = member.MemberId m.Account = member.Account m.Description = member.Description m.Email = member.Email m.Phone = member.Phone m.Avatar = member.Avatar m.Role = member.Role m.Status = member.Status m.CreateTime = member.CreateTime m.CreateAt = member.CreateAt return m } func (m *MemberRelationshipResult) ResolveRoleName() *MemberRelationshipResult { if m.RoleId == conf.BookAdmin { m.RoleName = "管理者" } else if m.RoleId == conf.BookEditor { m.RoleName = "编辑者" } else if m.RoleId == conf.BookObserver { m.RoleName = "观察者" } return m } // 根据项目ID查询用户 func (m *MemberRelationshipResult) FindForUsersByBookId(bookId, pageIndex, pageSize int) ([]*MemberRelationshipResult, int, error) { o := orm.NewOrm() var members []*MemberRelationshipResult sql1 := "SELECT * FROM md_relationship AS rel LEFT JOIN md_members as member ON rel.member_id = member.member_id WHERE rel.book_id = ? ORDER BY rel.relationship_id DESC LIMIT ?,?" sql2 := "SELECT count(*) AS total_count FROM md_relationship AS rel LEFT JOIN md_members as member ON rel.member_id = member.member_id WHERE rel.book_id = ?" var total_count int err := o.Raw(sql2, bookId).QueryRow(&total_count) if err != nil { return members, 0, err } offset := (pageIndex - 1) * pageSize _, err = o.Raw(sql1, bookId, offset, pageSize).QueryRows(&members) if err != nil { return members, 0, err } for _, item := range members { item.ResolveRoleName() } return members, total_count, nil } // 查询指定文档中不存在的用户列表 func (m *MemberRelationshipResult) FindNotJoinUsersByAccount(bookId, limit int,account string) ([]*Member,error){ o := orm.NewOrm() sql := "SELECT m.* FROM md_members as m LEFT JOIN md_relationship as rel ON m.member_id=rel.member_id AND rel.book_id = ? WHERE rel.relationship_id IS NULL AND m.account LIKE ? LIMIT 0,?;" var members []*Member _,err := o.Raw(sql,bookId,account,limit).QueryRows(&members) return members,err }