| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 | 
							- package models
 
- import (
 
- 	"time"
 
- 	"github.com/astaxie/beego/orm"
 
- 	"github.com/astaxie/beego/logs"
 
- 	"github.com/lifei6671/godoc/conf"
 
- )
 
- type BookResult struct {
 
- 	BookId int              `json:"book_id"`
 
- 	BookName string         `json:"book_name"`
 
- 	Identify string         `json:"identify"`
 
- 	OrderIndex int          `json:"order_index"`
 
- 	Description string      `json:"description"`
 
- 	PrivatelyOwned int      `json:"privately_owned"`
 
- 	PrivateToken string     `json:"private_token"`
 
- 	DocCount int            `json:"doc_count"`
 
- 	CommentStatus string    `json:"comment_status"`
 
- 	CommentCount int        `json:"comment_count"`
 
- 	CreateTime time.Time    `json:"create_time"`
 
- 	CreateName string 	`json:"create_name"`
 
- 	ModifyTime time.Time	`json:"modify_time"`
 
- 	Cover string            `json:"cover"`
 
- 	Theme string		`json:"theme"`
 
- 	Label string		`json:"label"`
 
- 	MemberId int            `json:"member_id"`
 
- 	Editor string           `json:"editor"`
 
- 	RelationshipId int	`json:"relationship_id"`
 
- 	RoleId int        	`json:"role_id"`
 
- 	RoleName string 	`json:"role_name"`
 
- 	Status int
 
- 	LastModifyText string 	`json:"last_modify_text"`
 
- 	IsDisplayComment bool	`json:"is_display_comment"`
 
- }
 
- func NewBookResult() *BookResult {
 
- 	return &BookResult{}
 
- }
 
- // 根据项目标识查询项目以及指定用户权限的信息.
 
- func (m *BookResult) FindByIdentify(identify string,member_id int) (*BookResult,error) {
 
- 	if identify == "" || member_id <= 0 {
 
- 		return m,ErrInvalidParameter
 
- 	}
 
- 	o := orm.NewOrm()
 
- 	book := NewBook()
 
- 	err := o.QueryTable(book.TableNameWithPrefix()).Filter("identify", identify).One(book)
 
- 	if err != nil {
 
- 		return m, err
 
- 	}
 
- 	relationship := NewRelationship()
 
- 	err = o.QueryTable(relationship.TableNameWithPrefix()).Filter("book_id", book.BookId).Filter("member_id", member_id).One(relationship)
 
- 	if err != nil {
 
- 		return m, err
 
- 	}
 
- 	var relationship2 Relationship
 
- 	err = o.QueryTable(relationship.TableNameWithPrefix()).Filter("book_id", book.BookId).Filter("role_id", 0).One(&relationship2)
 
- 	if err != nil {
 
- 		logs.Error("根据项目标识查询项目以及指定用户权限的信息 => ", err)
 
- 		return m, ErrPermissionDenied
 
- 	}
 
- 	member, err := NewMember().Find(relationship2.MemberId)
 
- 	if err != nil {
 
- 		return m, err
 
- 	}
 
- 	m = book.ToBookResult()
 
- 	m.CreateName 		= member.Account
 
- 	m.MemberId 		= relationship.MemberId
 
- 	m.RoleId		= relationship.RoleId
 
- 	m.RelationshipId	= relationship.RelationshipId
 
- 	if m.RoleId == conf.BookFounder {
 
- 		m.RoleName = "创始人"
 
- 	} else if m.RoleId == conf.BookAdmin {
 
- 		m.RoleName = "管理员"
 
- 	} else if m.RoleId == conf.BookEditor {
 
- 		m.RoleName = "编辑者"
 
- 	} else if m.RoleId == conf.BookObserver {
 
- 		m.RoleName = "观察者"
 
- 	}
 
- 	doc := NewDocument()
 
- 	err = o.QueryTable(doc.TableNameWithPrefix()).Filter("book_id", book.BookId).OrderBy("modify_time").One(doc)
 
- 	if err == nil {
 
- 		member2 := NewMember()
 
- 		member2.Find(doc.ModifyAt)
 
- 		m.LastModifyText = member2.Account + " 于 " + doc.ModifyTime.Format("2006-01-02 15:04:05")
 
- 	}
 
- 	return m, nil
 
- }
 
- func (m *BookResult) FindToPager(pageIndex, pageSize int) (books []*BookResult,totalCount int,err error)  {
 
- 	o := orm.NewOrm()
 
- 	count,err := o.QueryTable(NewBook().TableNameWithPrefix()).Count()
 
- 	if err != nil {
 
- 		return
 
- 	}
 
- 	totalCount = int(count)
 
- 	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 ?,?"
 
- 	offset := (pageIndex -1 )* pageSize
 
- 	_,err = o.Raw(sql,offset,pageSize).QueryRows(&books)
 
- 	return
 
- }
 
 
  |