book_result.go 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. package models
  2. import (
  3. "time"
  4. "github.com/astaxie/beego/orm"
  5. "strings"
  6. "github.com/astaxie/beego/logs"
  7. "github.com/lifei6671/godoc/conf"
  8. )
  9. type BookResult struct {
  10. BookId int `json:"book_id"`
  11. BookName string `json:"book_name"`
  12. Identify string `json:"identify"`
  13. OrderIndex int `json:"order_index"`
  14. Description string `json:"description"`
  15. PrivatelyOwned int `json:"privately_owned"`
  16. PrivateToken string `json:"private_token"`
  17. DocCount int `json:"doc_count"`
  18. CommentStatus string `json:"comment_status"`
  19. CommentCount int `json:"comment_count"`
  20. CreateTime time.Time `json:"create_time"`
  21. CreateName string `json:"create_name"`
  22. ModifyTime time.Time `json:"modify_time"`
  23. Cover string `json:"cover"`
  24. Label string `json:"label"`
  25. MemberId int `json:"member_id"`
  26. RelationshipId int `json:"relationship_id"`
  27. RoleId int `json:"role_id"`
  28. RoleName string `json:"role_name"`
  29. Status int
  30. LastModifyText string `json:"last_modify_text"`
  31. }
  32. func NewBookResult() *BookResult {
  33. return &BookResult{}
  34. }
  35. // 根据项目标识查询项目以及指定用户权限的信息.
  36. func (m *BookResult) FindByIdentify(identify string,member_id int) (*BookResult,error) {
  37. o := orm.NewOrm()
  38. book := NewBook()
  39. err := o.QueryTable(book.TableNameWithPrefix()).Filter("identify", identify).One(book)
  40. if err != nil {
  41. return m, err
  42. }
  43. relationship := NewRelationship()
  44. err = o.QueryTable(relationship.TableNameWithPrefix()).Filter("book_id",book.BookId).Filter("member_id",member_id).One(relationship)
  45. if err != nil {
  46. return m,err
  47. }
  48. var relationship2 Relationship
  49. err = o.QueryTable(relationship.TableNameWithPrefix()).Filter("book_id",book.BookId).Filter("role_id",0).One(&relationship2)
  50. if err != nil {
  51. logs.Error("根据项目标识查询项目以及指定用户权限的信息 => ",err)
  52. return m,ErrPermissionDenied
  53. }
  54. member := NewMember()
  55. err = member.Find(relationship2.MemberId)
  56. if err != nil {
  57. return m,err
  58. }
  59. m.BookId = book.BookId
  60. m.BookName = book.BookName
  61. m.Identify = book.Identify
  62. m.OrderIndex = book.OrderIndex
  63. m.Description = strings.Replace(book.Description,"\r\n","<br/>",-1)
  64. m.PrivatelyOwned = book.PrivatelyOwned
  65. m.PrivateToken = book.PrivateToken
  66. m.DocCount = book.DocCount
  67. m.CommentStatus = book.CommentStatus
  68. m.CommentCount = book.CommentCount
  69. m.CreateTime = book.CreateTime
  70. m.CreateName = member.Account
  71. m.ModifyTime = book.ModifyTime
  72. m.Cover = book.Cover
  73. m.Label = book.Label
  74. m.Status = book.Status
  75. m.MemberId = relationship.MemberId
  76. m.RoleId = relationship.RoleId
  77. m.RelationshipId = relationship.RelationshipId
  78. if m.RoleId == conf.BookFounder {
  79. m.RoleName = "创始人"
  80. }else if m.RoleId == conf.BookAdmin {
  81. m.RoleName = "管理员"
  82. }else if m.RoleId == conf.BookEditor {
  83. m.RoleName = "编辑者"
  84. }else if m.RoleId == conf.BookObserver {
  85. m.RoleName = "观察者"
  86. }
  87. doc := NewDocument()
  88. err = o.QueryTable(doc.TableNameWithPrefix()).Filter("book_id",book.BookId).OrderBy("modify_time").One(doc)
  89. if err == nil {
  90. member2 := NewMember()
  91. member2.Find(doc.ModifyAt)
  92. m.LastModifyText = member2.Account + " 于 " + doc.ModifyTime.Format("2006-01-02 15:04:05")
  93. }
  94. return m,nil
  95. }
  96. func (m *BookResult) FindToPager(pageIndex, pageSize int) (books []*BookResult,totalCount int,err error) {
  97. o := orm.NewOrm()
  98. count,err := o.QueryTable(NewBook().TableNameWithPrefix()).Count()
  99. if err != nil {
  100. return
  101. }
  102. totalCount = int(count)
  103. sql := "SELECT book.*,rel.relationship_id,rel.role_id,m.account AS create_name FROM md_books AS book LEFT JOIN md_relationship AS rel ON rel.book_id = book.book_id AND rel.role_id = 0 LEFT JOIN md_members AS m ON rel.member_id = m.member_id ORDER BY book.order_index DESC ,book.book_id DESC LIMIT ?,?"
  104. offset := (pageIndex -1 )* pageSize
  105. _,err = o.Raw(sql,offset,pageSize).QueryRows(&books)
  106. return
  107. }