relationship.go 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. package models
  2. import (
  3. "github.com/lifei6671/godoc/conf"
  4. "github.com/astaxie/beego/orm"
  5. "errors"
  6. "github.com/astaxie/beego/logs"
  7. )
  8. type Relationship struct {
  9. RelationshipId int `orm:"pk;auto;unique;column(relationship_id)" json:"relationship_id"`
  10. MemberId int `orm:"column(member_id);type(int)" json:"member_id"`
  11. BookId int `orm:"column(book_id);type(int)" json:"book_id"`
  12. // RoleId 角色:0 创始人(创始人不能被移除) / 1 管理员/2 编辑者/3 观察者
  13. RoleId int `orm:"column(role_id);type(int)" json:"role_id"`
  14. }
  15. // TableName 获取对应数据库表名.
  16. func (m *Relationship) TableName() string {
  17. return "relationship"
  18. }
  19. func (m *Relationship) TableNameWithPrefix() string {
  20. return conf.GetDatabasePrefix() + m.TableName()
  21. }
  22. // TableEngine 获取数据使用的引擎.
  23. func (m *Relationship) TableEngine() string {
  24. return "INNODB"
  25. }
  26. // 联合唯一键
  27. func (u *Relationship) TableUnique() [][]string {
  28. return [][]string{
  29. []string{"MemberId", "BookId"},
  30. }
  31. }
  32. func NewRelationship() *Relationship {
  33. return &Relationship{}
  34. }
  35. func (m *Relationship) Find(id int) (*Relationship,error) {
  36. o := orm.NewOrm()
  37. err := o.QueryTable(m.TableNameWithPrefix()).Filter("relationship_id",id).One(m)
  38. return m,err
  39. }
  40. //查询指定项目的创始人.
  41. func (m *Relationship) FindFounder(book_id int) (*Relationship,error) {
  42. o := orm.NewOrm()
  43. err := o.QueryTable(m.TableNameWithPrefix()).Filter("book_id",book_id).Filter("role_id",0).One(m)
  44. return m,err
  45. }
  46. func (m *Relationship) UpdateRoleId(book_id,member_id, role_id int) (*Relationship,error) {
  47. o := orm.NewOrm()
  48. book := NewBook()
  49. book.BookId = book_id
  50. if err := o.Read(book); err != nil {
  51. logs.Error("UpdateRoleId => ", err)
  52. return m,errors.New("项目不存在")
  53. }
  54. err := o.QueryTable(m.TableNameWithPrefix()).Filter("member_id",member_id).Filter("book_id",book_id).One(m)
  55. if err == orm.ErrNoRows {
  56. m = NewRelationship()
  57. m.BookId = book_id
  58. m.MemberId = member_id
  59. m.RoleId = role_id
  60. }else if err != nil {
  61. return m,err
  62. }else if m.RoleId == conf.BookFounder{
  63. return m,errors.New("不能变更创始人的权限")
  64. }
  65. m.RoleId = role_id
  66. _,err = o.InsertOrUpdate(m)
  67. return m,err
  68. }
  69. func (m *Relationship) FindForRoleId(book_id ,member_id int) (int,error) {
  70. o := orm.NewOrm()
  71. relationship := NewRelationship()
  72. err := o.QueryTable(m.TableNameWithPrefix()).Filter("book_id",book_id).Filter("member_id",member_id).One(relationship)
  73. if err != nil {
  74. return 0,err
  75. }
  76. return relationship.RoleId,nil
  77. }
  78. func (m *Relationship) FindByBookIdAndMemberId(book_id ,member_id int) (*Relationship,error) {
  79. o := orm.NewOrm()
  80. err := o.QueryTable(m.TableNameWithPrefix()).Filter("book_id",book_id).Filter("member_id",member_id).One(m)
  81. return m,err
  82. }
  83. func (m *Relationship) Insert() error {
  84. o := orm.NewOrm()
  85. _,err := o.Insert(m)
  86. return err
  87. }
  88. func (m *Relationship) Update() error {
  89. o := orm.NewOrm()
  90. _,err := o.Update(m)
  91. return err
  92. }
  93. func (m *Relationship) DeleteByBookIdAndMemberId(book_id,member_id int) error {
  94. o := orm.NewOrm()
  95. err := o.QueryTable(m.TableNameWithPrefix()).Filter("book_id",book_id).Filter("member_id",member_id).One(m)
  96. if err == orm.ErrNoRows {
  97. return errors.New("用户未参与该项目")
  98. }
  99. if m.RoleId == conf.BookFounder {
  100. return errors.New("不能删除创始人")
  101. }
  102. _,err = o.Delete(m)
  103. if err != nil {
  104. logs.Error("删除项目参与者 => ",err)
  105. return errors.New("删除失败")
  106. }
  107. return nil
  108. }
  109. func (m *Relationship) Transfer(book_id,founder_id,receive_id int) error {
  110. o := orm.NewOrm()
  111. founder := NewRelationship()
  112. err := o.QueryTable(m.TableNameWithPrefix()).Filter("book_id",book_id).Filter("member_id",founder_id).One(founder)
  113. if err != nil {
  114. return err
  115. }
  116. if founder.RoleId != conf.BookFounder {
  117. return errors.New("转让者不是创始人")
  118. }
  119. receive := NewRelationship()
  120. err = o.QueryTable(m.TableNameWithPrefix()).Filter("book_id",book_id).Filter("member_id",receive_id).One(receive)
  121. if err != orm.ErrNoRows && err != nil {
  122. return err
  123. }
  124. o.Begin()
  125. founder.RoleId = conf.BookAdmin
  126. receive.MemberId = receive_id
  127. receive.RoleId = conf.BookFounder
  128. receive.BookId = book_id
  129. if err := founder.Update();err != nil {
  130. o.Rollback()
  131. return err
  132. }
  133. if _,err := o.InsertOrUpdate(receive);err != nil {
  134. o.Rollback()
  135. return err
  136. }
  137. return o.Commit()
  138. }