diff options
Diffstat (limited to 'models/action.go')
-rw-r--r-- | models/action.go | 139 |
1 files changed, 139 insertions, 0 deletions
diff --git a/models/action.go b/models/action.go new file mode 100644 index 00000000..44d7aea8 --- /dev/null +++ b/models/action.go @@ -0,0 +1,139 @@ +// 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 models + +import ( + "encoding/json" + "time" + + "github.com/gogits/gogs/modules/base" + "github.com/gogits/gogs/modules/log" +) + +// Operation types of user action. +const ( + OP_CREATE_REPO = iota + 1 + OP_DELETE_REPO + OP_STAR_REPO + OP_FOLLOW_REPO + OP_COMMIT_REPO + OP_PULL_REQUEST +) + +// Action represents user operation type and information to the repository. +type Action struct { + Id int64 + UserId int64 // Receiver user id. + OpType int // Operations: CREATE DELETE STAR ... + ActUserId int64 // Action user id. + ActUserName string // Action user name. + RepoId int64 + RepoName string + RefName 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) GetBranch() string { + return a.RefName +} + +func (a Action) GetContent() string { + return a.Content +} + +// CommitRepoAction records action for commit repository. +func CommitRepoAction(userId int64, userName string, + repoId int64, repoName string, refName string, commits *base.PushCommits) error { + log.Trace("action.CommitRepoAction: %d/%s", userId, repoName) + + bs, err := json.Marshal(commits) + if err != nil { + log.Error("action.CommitRepoAction(json): %d/%s", userId, repoName) + return err + } + + // Add feeds for user self and all watchers. + watches, err := GetWatches(repoId) + if err != nil { + log.Error("action.CommitRepoAction(get watches): %d/%s", userId, repoName) + return err + } + watches = append(watches, Watch{UserId: userId}) + + for i := range watches { + if userId == watches[i].UserId && i > 0 { + continue // Do not add twice in case author watches his/her repository. + } + + _, err = orm.InsertOne(&Action{ + UserId: watches[i].UserId, + ActUserId: userId, + ActUserName: userName, + OpType: OP_COMMIT_REPO, + Content: string(bs), + RepoId: repoId, + RepoName: repoName, + RefName: refName, + }) + if err != nil { + log.Error("action.CommitRepoAction(notify watches): %d/%s", userId, repoName) + } + return err + } + + // Update repository last update time. + repo, err := GetRepositoryByName(userId, repoName) + if err != nil { + log.Error("action.CommitRepoAction(GetRepositoryByName): %d/%s", userId, repoName) + return err + } + repo.IsBare = false + if err = UpdateRepository(repo); err != nil { + log.Error("action.CommitRepoAction(UpdateRepository): %d/%s", userId, repoName) + return err + } + return nil +} + +// NewRepoAction records action for create repository. +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 +} + +// GetFeeds returns action list of given user in given context. +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 +} |