Relationship.go 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. package models
  2. import (
  3. "errors"
  4. "github.com/beego/beego/v2/adapter/logs"
  5. "github.com/beego/beego/v2/client/orm"
  6. "github.com/mindoc-org/mindoc/conf"
  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 conf.BookRole `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 (m *Relationship) TableUnique() [][]string {
  28. return [][]string{
  29. {"member_id", "book_id"},
  30. }
  31. }
  32. func (m *Relationship) QueryTable() orm.QuerySeter {
  33. return orm.NewOrm().QueryTable(m.TableNameWithPrefix())
  34. }
  35. func NewRelationship() *Relationship {
  36. return &Relationship{}
  37. }
  38. func (m *Relationship) Find(id int) (*Relationship, error) {
  39. o := orm.NewOrm()
  40. err := o.QueryTable(m.TableNameWithPrefix()).Filter("relationship_id", id).One(m)
  41. return m, err
  42. }
  43. //查询指定项目的创始人.
  44. func (m *Relationship) FindFounder(book_id int) (*Relationship, error) {
  45. o := orm.NewOrm()
  46. err := o.QueryTable(m.TableNameWithPrefix()).Filter("book_id", book_id).Filter("role_id", 0).One(m)
  47. return m, err
  48. }
  49. func (m *Relationship) UpdateRoleId(bookId, memberId int, roleId conf.BookRole) (*Relationship, error) {
  50. o := orm.NewOrm()
  51. book := NewBook()
  52. book.BookId = bookId
  53. if err := o.Read(book); err != nil {
  54. logs.Error("UpdateRoleId => ", err)
  55. return m, errors.New("项目不存在")
  56. }
  57. err := o.QueryTable(m.TableNameWithPrefix()).Filter("member_id", memberId).Filter("book_id", bookId).One(m)
  58. if err == orm.ErrNoRows {
  59. m = NewRelationship()
  60. m.BookId = bookId
  61. m.MemberId = memberId
  62. m.RoleId = roleId
  63. } else if err != nil {
  64. return m, err
  65. } else if m.RoleId == conf.BookFounder {
  66. return m, errors.New("不能变更创始人的权限")
  67. }
  68. m.RoleId = roleId
  69. if m.RelationshipId > 0 {
  70. _, err = o.Update(m)
  71. } else {
  72. _, err = o.Insert(m)
  73. }
  74. return m, err
  75. }
  76. func (m *Relationship) FindForRoleId(bookId, memberId int) (conf.BookRole, error) {
  77. o := orm.NewOrm()
  78. relationship := NewRelationship()
  79. err := o.QueryTable(m.TableNameWithPrefix()).Filter("book_id", bookId).Filter("member_id", memberId).One(relationship)
  80. if err != nil {
  81. return 0, err
  82. }
  83. return relationship.RoleId, nil
  84. }
  85. func (m *Relationship) FindByBookIdAndMemberId(book_id, member_id int) (*Relationship, error) {
  86. o := orm.NewOrm()
  87. err := o.QueryTable(m.TableNameWithPrefix()).Filter("book_id", book_id).Filter("member_id", member_id).One(m)
  88. return m, err
  89. }
  90. func (m *Relationship) Insert() error {
  91. o := orm.NewOrm()
  92. _, err := o.Insert(m)
  93. return err
  94. }
  95. func (m *Relationship) Update(txOrm orm.TxOrmer) error {
  96. _, err := txOrm.Update(m)
  97. if err != nil {
  98. txOrm.Rollback()
  99. }
  100. return err
  101. }
  102. func (m *Relationship) DeleteByBookIdAndMemberId(book_id, member_id int) error {
  103. o := orm.NewOrm()
  104. err := o.QueryTable(m.TableNameWithPrefix()).Filter("book_id", book_id).Filter("member_id", member_id).One(m)
  105. if err == orm.ErrNoRows {
  106. return errors.New("用户未参与该项目")
  107. }
  108. if m.RoleId == conf.BookFounder {
  109. return errors.New("不能删除创始人")
  110. }
  111. _, err = o.Delete(m)
  112. if err != nil {
  113. logs.Error("删除项目参与者 => ", err)
  114. return errors.New("删除失败")
  115. }
  116. return nil
  117. }
  118. func (m *Relationship) Transfer(book_id, founder_id, receive_id int) error {
  119. ormer := orm.NewOrm()
  120. founder := NewRelationship()
  121. err := ormer.QueryTable(m.TableNameWithPrefix()).Filter("book_id", book_id).Filter("member_id", founder_id).One(founder)
  122. if err != nil {
  123. return err
  124. }
  125. if founder.RoleId != conf.BookFounder {
  126. return errors.New("转让者不是创始人")
  127. }
  128. receive := NewRelationship()
  129. err = ormer.QueryTable(m.TableNameWithPrefix()).Filter("book_id", book_id).Filter("member_id", receive_id).One(receive)
  130. if err != orm.ErrNoRows && err != nil {
  131. return err
  132. }
  133. o, _ := ormer.Begin()
  134. founder.RoleId = conf.BookAdmin
  135. receive.MemberId = receive_id
  136. receive.RoleId = conf.BookFounder
  137. receive.BookId = book_id
  138. if err := founder.Update(o); err != nil {
  139. return err
  140. }
  141. if receive.RelationshipId > 0 {
  142. if _, err := o.Update(receive); err != nil {
  143. o.Rollback()
  144. return err
  145. }
  146. } else {
  147. if _, err := o.Insert(receive); err != nil {
  148. o.Rollback()
  149. return err
  150. }
  151. }
  152. return o.Commit()
  153. }