123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125 |
- package models
- import (
- "encoding/json"
- "time"
- "github.com/gogits/gogs/modules/log"
- )
- const (
- OP_CREATE_REPO = iota + 1
- OP_DELETE_REPO
- OP_STAR_REPO
- OP_FOLLOW_REPO
- OP_COMMIT_REPO
- OP_PULL_REQUEST
- )
- type Action struct {
- Id int64
- UserId int64
- OpType int
- ActUserId int64
- ActUserName string
- RepoId int64
- RepoName string
- Content string `xorm:"TEXT"`
- Created time.Time `xorm:"created"`
- }
- func (a Action) GetOpType() int {
- return a.OpType
- }
- func (a Action) GetActUserName() string {
- return a.ActUserName
- }
- func (a Action) GetRepoName() string {
- return a.RepoName
- }
- func (a Action) GetContent() string {
- return a.Content
- }
- func CommitRepoAction(userId int64, userName string,
- repoId int64, repoName string, commits [][]string) error {
- bs, err := json.Marshal(commits)
- if err != nil {
- return err
- }
-
- watches, err := GetWatches(repoId)
- if err != nil {
- return err
- }
- watches = append(watches, Watch{UserId: userId})
- for i := range watches {
- if userId == watches[i].UserId && i > 0 {
- continue
- }
- _, err = orm.InsertOne(&Action{
- UserId: watches[i].UserId,
- ActUserId: userId,
- ActUserName: userName,
- OpType: OP_COMMIT_REPO,
- Content: string(bs),
- RepoId: repoId,
- RepoName: repoName,
- })
- return err
- }
-
- repo, err := GetRepositoryByName(userId, repoName)
- if err != nil {
- return err
- }
- repo.IsBare = false
- if err = UpdateRepository(repo); err != nil {
- return err
- }
- log.Trace("action.CommitRepoAction: %d/%s", userId, repo.LowerName)
- return nil
- }
- func NewRepoAction(user *User, repo *Repository) error {
- _, err := orm.InsertOne(&Action{
- UserId: user.Id,
- ActUserId: user.Id,
- ActUserName: user.Name,
- OpType: OP_CREATE_REPO,
- RepoId: repo.Id,
- RepoName: repo.Name,
- })
- log.Trace("action.NewRepoAction: %s/%s", user.LowerName, repo.LowerName)
- return err
- }
- func GetFeeds(userid, offset int64, isProfile bool) ([]Action, error) {
- actions := make([]Action, 0, 20)
- sess := orm.Limit(20, int(offset)).Desc("id").Where("user_id=?", userid)
- if isProfile {
- sess.And("act_user_id=?", userid)
- } else {
- sess.And("act_user_id!=?", userid)
- }
- err := sess.Find(&actions)
- return actions, err
- }
|