Finish watch backend

This commit is contained in:
Unknown 2014-03-19 23:39:00 -04:00
parent a922c3ff6a
commit 59ea3c0413
2 changed files with 29 additions and 10 deletions

View File

@ -55,16 +55,27 @@ func CommitRepoAction(userId int64, userName string,
if err != nil { if err != nil {
return err return err
} }
_, err = orm.InsertOne(&Action{
UserId: userId, // Add feeds for user self and all watchers.
ActUserId: userId, watches, err := GetWatches(repoId)
ActUserName: userName, if err != nil {
OpType: OP_COMMIT_REPO, return err
Content: string(bs), }
RepoId: repoId, watches = append(watches, Watch{UserId: userId})
RepoName: repoName,
}) for i := range watches {
return err _, 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
}
return nil
} }
// NewRepoAction records action for create repository. // NewRepoAction records action for create repository.

View File

@ -50,6 +50,7 @@ type Watch struct {
UserId int64 `xorm:"UNIQUE(watch)"` UserId int64 `xorm:"UNIQUE(watch)"`
} }
// Watch or unwatch repository.
func WatchRepo(userId, repoId int64, watch bool) (err error) { func WatchRepo(userId, repoId int64, watch bool) (err error) {
if watch { if watch {
_, err = orm.Insert(&Watch{RepoId: repoId, UserId: userId}) _, err = orm.Insert(&Watch{RepoId: repoId, UserId: userId})
@ -59,6 +60,13 @@ func WatchRepo(userId, repoId int64, watch bool) (err error) {
return err return err
} }
// GetWatches returns all watches of given repository.
func GetWatches(repoId int64) ([]Watch, error) {
watches := make([]Watch, 0, 10)
err := orm.Find(&watches, &Watch{RepoId: repoId})
return watches, err
}
var ( var (
gitInitLocker = sync.Mutex{} gitInitLocker = sync.Mutex{}
LanguageIgns, Licenses []string LanguageIgns, Licenses []string