| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221 | 
							- package models
 
- import (
 
- 	"github.com/lifei6671/mindoc/conf"
 
- 	"errors"
 
- 	"github.com/astaxie/beego/orm"
 
- 	"github.com/astaxie/beego"
 
- )
 
- type TeamMember struct {
 
- 	TeamMemberId int `orm:"column(team_member_id);pk;auto;unique;" json:"team_member_id"`
 
- 	TeamId       int `orm:"column(team_id);type(int)" json:"team_id"`
 
- 	MemberId     int `orm:"column(member_id);type(int)" json:"member_id"`
 
- 	// RoleId 角色:0 创始人(创始人不能被移除) / 1 管理员/2 编辑者/3 观察者
 
- 	RoleId   conf.BookRole `orm:"column(role_id);type(int)" json:"role_id"`
 
- 	RoleName string        `orm:"-" json:"role_name"`
 
- 	Account  string        `orm:"-" json:"account"`
 
- 	RealName string        `orm:"-" json:"real_name"`
 
- 	Avatar   string        `orm:"-" json:"avatar"`
 
- }
 
- // TableName 获取对应数据库表名.
 
- func (m *TeamMember) TableName() string {
 
- 	return "team_member"
 
- }
 
- func (m *TeamMember) TableNameWithPrefix() string {
 
- 	return conf.GetDatabasePrefix() + m.TableName()
 
- }
 
- // TableEngine 获取数据使用的引擎.
 
- func (m *TeamMember) TableEngine() string {
 
- 	return "INNODB"
 
- }
 
- // 联合唯一键
 
- func (m *TeamMember) TableUnique() [][]string {
 
- 	return [][]string{{"team_id", "member_id"}}
 
- }
 
- func NewTeamMember() *TeamMember {
 
- 	return &TeamMember{}
 
- }
 
- func (m *TeamMember) First(id int, cols ...string) (*TeamMember, error) {
 
- 	if id <= 0 {
 
- 		return nil, errors.New("参数错误")
 
- 	}
 
- 	o := orm.NewOrm()
 
- 	err := o.QueryTable(m.TableNameWithPrefix()).Filter("team_member_id", id).One(m, cols...)
 
- 	if err != nil && err != orm.ErrNoRows {
 
- 		beego.Error("查询团队成员错误 ->", err)
 
- 	}
 
- 	return m.Include(), err
 
- }
 
- func (m *TeamMember) ChangeRoleId(teamId int, memberId int, roleId conf.BookRole) (member *TeamMember, err error) {
 
- 	if teamId <= 0 || memberId <= 0 || roleId <= 0 || roleId > conf.BookObserver {
 
- 		return nil, ErrInvalidParameter
 
- 	}
 
- 	o := orm.NewOrm()
 
- 	err = o.QueryTable(m.TableNameWithPrefix()).Filter("team_id", teamId).Filter("member_id", memberId).One(m)
 
- 	if err != nil {
 
- 		beego.Error("查询团队用户时失败 ->", err)
 
- 		return m, err
 
- 	}
 
- 	m.RoleId = roleId
 
- 	err = m.Save("role_id")
 
- 	if err == nil {
 
- 		m.Include()
 
- 	}
 
- 	return m, err
 
- }
 
- func (m *TeamMember) FindFirst(teamId, memberId int) (*TeamMember, error) {
 
- 	if teamId <= 0 || memberId <= 0 {
 
- 		return nil, ErrInvalidParameter
 
- 	}
 
- 	o := orm.NewOrm()
 
- 	err := o.QueryTable(m.TableNameWithPrefix()).Filter("team_id",teamId).Filter("member_id",memberId).One(m)
 
- 	if err != nil {
 
- 		beego.Error("查询团队用户失败 ->",err)
 
- 		return nil,err
 
- 	}
 
- 	return m.Include(),nil
 
- }
 
- func (m *TeamMember) Save(cols ...string) (err error) {
 
- 	if m.TeamId <= 0 {
 
- 		return errors.New("团队不能为空")
 
- 	}
 
- 	if m.MemberId <= 0 {
 
- 		return errors.New("用户不能为空")
 
- 	}
 
- 	o := orm.NewOrm()
 
- 	if !o.QueryTable(NewTeam().TableNameWithPrefix()).Filter("team_id", m.TeamId).Exist() {
 
- 		return errors.New("团队不存在")
 
- 	}
 
- 	if !o.QueryTable(NewMember()).Filter("member_id", m.MemberId).Filter("status", 0).Exist() {
 
- 		return errors.New("用户不存在或已禁用")
 
- 	}
 
- 	if m.TeamMemberId <= 0 {
 
- 		_, err = o.Insert(m)
 
- 	} else {
 
- 		_, err = o.Update(m, cols...)
 
- 	}
 
- 	if err != nil {
 
- 		beego.Error("在保存团队时出错 ->", err)
 
- 	}
 
- 	return
 
- }
 
- func (m *TeamMember) Delete(id int) (err error) {
 
- 	if id <= 0 {
 
- 		return ErrInvalidParameter
 
- 	}
 
- 	_, err = orm.NewOrm().QueryTable(m.TableNameWithPrefix()).Filter("team_member_id", id).Delete()
 
- 	if err != nil {
 
- 		beego.Error("删除团队用户时出错 ->", err)
 
- 	}
 
- 	return
 
- }
 
- func (m *TeamMember) FindToPager(teamId, pageIndex, pageSize int) (list []*TeamMember, totalCount int, err error) {
 
- 	if teamId <= 0 {
 
- 		err = ErrInvalidParameter
 
- 		return
 
- 	}
 
- 	offset := (pageIndex - 1) * pageSize
 
- 	o := orm.NewOrm()
 
- 	_, err = o.QueryTable(m.TableNameWithPrefix()).Filter("team_id", teamId).Offset(offset).Limit(pageSize).All(&list)
 
- 	if err != nil {
 
- 		if err != orm.ErrNoRows {
 
- 			beego.Error("查询团队成员失败 ->", err)
 
- 		}
 
- 		return
 
- 	}
 
- 	c, err := o.QueryTable(m.TableNameWithPrefix()).Filter("team_id", teamId).Count()
 
- 	if err != nil {
 
- 		return
 
- 	}
 
- 	totalCount = int(c)
 
- 	//将来优化
 
- 	for _, item := range list {
 
- 		item.Include()
 
- 	}
 
- 	return
 
- }
 
- func (m *TeamMember) Include() *TeamMember {
 
- 	if member, err := NewMember().Find(m.MemberId, "account", "real_name", "avatar"); err == nil {
 
- 		m.Account = member.Account
 
- 		m.RealName = member.RealName
 
- 		m.Avatar = member.Avatar
 
- 	}
 
- 	if m.RoleId == 0 {
 
- 		m.RoleName = "创始人"
 
- 	} else if m.RoleId == 1 {
 
- 		m.RoleName = "管理员"
 
- 	} else if m.RoleId == 2 {
 
- 		m.RoleName = "编辑者"
 
- 	} else if m.RoleId == 3 {
 
- 		m.RoleName = "观察者"
 
- 	}
 
- 	return m
 
- }
 
- func (m *TeamMember) FindNotJoinMemberByAccount(teamId int, account string, limit int) (*SelectMemberResult, error) {
 
- 	if teamId <= 0 {
 
- 		return nil, ErrInvalidParameter
 
- 	}
 
- 	o := orm.NewOrm()
 
- 	sql := `select member.member_id,member.account
 
- from md_members as member 
 
-   left join md_team_member as team on team.team_id = ? and member.member_id != team.member_id
 
-   where member.account like ?
 
-   order by member.member_id desc 
 
- limit ?;`
 
- 	members := make([]*Member, 0)
 
- 	_, err := o.Raw(sql, teamId, "%"+account+"%", limit).QueryRows(&members)
 
- 	if err != nil {
 
- 		beego.Error("查询团队用户时出错 ->", err)
 
- 		return nil, err
 
- 	}
 
- 	result := SelectMemberResult{}
 
- 	items := make([]KeyValueItem, 0)
 
- 	for _, member := range members {
 
- 		item := KeyValueItem{}
 
- 		item.Id = member.MemberId
 
- 		item.Text = member.Account
 
- 		items = append(items, item)
 
- 	}
 
- 	result.Result = items
 
- 	return &result, err
 
- }
 
 
  |