| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158 | // Copyright 2014 The Gogs Authors. All rights reserved.// Use of this source code is governed by a MIT-style// license that can be found in the LICENSE file.package modelsimport (	"errors"	"strings"	"time"	"github.com/gogits/gogs/modules/base")var (	ErrIssueNotExist = errors.New("Issue does not exist"))// Issue represents an issue or pull request of repository.type Issue struct {	Id          int64	Index       int64 // Index in one repository.	Name        string	RepoId      int64 `xorm:"index"`	PosterId    int64	MilestoneId int64	AssigneeId  int64	IsPull      bool // Indicates whether is a pull request or not.	IsClosed    bool	Labels      string `xorm:"TEXT"`	Mentions    string `xorm:"TEXT"`	Content     string `xorm:"TEXT"`	NumComments int	Created     time.Time `xorm:"created"`	Updated     time.Time `xorm:"updated"`}// CreateIssue creates new issue for repository.func CreateIssue(userId, repoId, milestoneId, assigneeId int64, name, labels, content string, isPull bool) (*Issue, error) {	count, err := GetIssueCount(repoId)	if err != nil {		return nil, err	}	// TODO: find out mentions	mentions := ""	issue := &Issue{		Index:       count + 1,		Name:        name,		RepoId:      repoId,		PosterId:    userId,		MilestoneId: milestoneId,		AssigneeId:  assigneeId,		IsPull:      isPull,		Labels:      labels,		Mentions:    mentions,		Content:     content,	}	_, err = orm.Insert(issue)	return issue, err}// GetIssueCount returns count of issues in the repository.func GetIssueCount(repoId int64) (int64, error) {	return orm.Count(&Issue{RepoId: repoId})}// GetIssueById returns issue object by given id.func GetIssueById(id int64) (*Issue, error) {	issue := new(Issue)	has, err := orm.Id(id).Get(issue)	if err != nil {		return nil, err	} else if !has {		return nil, ErrIssueNotExist	}	return issue, nil}// GetIssues returns a list of issues by given conditions.func GetIssues(userId, repoId, posterId, milestoneId int64, page int, isClosed, isMention bool, labels, sortType string) ([]Issue, error) {	sess := orm.Limit(20, (page-1)*20)	if repoId > 0 {		sess.Where("repo_id=?", repoId).And("is_closed=?", isClosed)	} else {		sess.Where("is_closed=?", isClosed)	}	if userId > 0 {		sess.And("assignee_id=?", userId)	} else if posterId > 0 {		sess.And("poster_id=?", posterId)	} else if isMention {		sess.And("mentions like '%$" + base.ToStr(userId) + "|%'")	}	if milestoneId > 0 {		sess.And("milestone_id=?", milestoneId)	}	if len(labels) > 0 {		for _, label := range strings.Split(labels, ",") {			sess.And("mentions like '%$" + label + "|%'")		}	}	switch sortType {	case "oldest":		sess.Asc("created")	case "recentupdate":		sess.Desc("updated")	case "leastupdate":		sess.Asc("updated")	case "mostcomment":		sess.Desc("num_comments")	case "leastcomment":		sess.Asc("num_comments")	default:		sess.Desc("created")	}	var issues []Issue	err := sess.Find(&issues)	return issues, err}// Label represents a list of labels of repository for issues.type Label struct {	Id     int64	RepoId int64 `xorm:"index"`	Names  string	Colors string}// Milestone represents a milestone of repository.type Milestone struct {	Id        int64	Name      string	RepoId    int64 `xorm:"index"`	IsClosed  bool	Content   string	NumIssues int	DueDate   time.Time	Created   time.Time `xorm:"created"`}// Comment represents a comment in commit and issue page.type Comment struct {	Id       int64	PosterId int64	IssueId  int64	CommitId int64	Line     int	Content  string	Created  time.Time `xorm:"created"`}
 |