Merge pull request #693 from scottferg/master

Add activity feed endpoint
This commit is contained in:
Brad Rydzewski 2014-11-11 09:07:10 -08:00
commit b33db29400
5 changed files with 77 additions and 1 deletions

View file

@ -27,6 +27,10 @@ type Commitstore interface {
// from the datastore accessible to the specified user. // from the datastore accessible to the specified user.
GetCommitListUser(user *model.User) ([]*model.CommitRepo, error) GetCommitListUser(user *model.User) ([]*model.CommitRepo, error)
// GetCommitListActivity retrieves an ungrouped list of latest commits
// from the datastore accessible to the specified user.
GetCommitListActivity(user *model.User) ([]*model.CommitRepo, error)
// PostCommit saves a commit in the datastore. // PostCommit saves a commit in the datastore.
PostCommit(commit *model.Commit) error PostCommit(commit *model.Commit) error
@ -72,6 +76,12 @@ func GetCommitListUser(c context.Context, user *model.User) ([]*model.CommitRepo
return FromContext(c).GetCommitListUser(user) return FromContext(c).GetCommitListUser(user)
} }
// GetCommitListActivity retrieves an ungrouped list of latest commits
// from the datastore accessible to the specified user.
func GetCommitListActivity(c context.Context, user *model.User) ([]*model.CommitRepo, error) {
return FromContext(c).GetCommitListActivity(user)
}
// PostCommit saves a commit in the datastore. // PostCommit saves a commit in the datastore.
func PostCommit(c context.Context, commit *model.Commit) error { func PostCommit(c context.Context, commit *model.Commit) error {
return FromContext(c).PostCommit(commit) return FromContext(c).PostCommit(commit)

View file

@ -56,6 +56,14 @@ func (db *Commitstore) GetCommitListUser(user *model.User) ([]*model.CommitRepo,
return commits, err return commits, err
} }
// GetCommitListActivity retrieves an ungrouped list of latest commits
// from the datastore accessible to the specified user.
func (db *Commitstore) GetCommitListActivity(user *model.User) ([]*model.CommitRepo, error) {
var commits []*model.CommitRepo
var err = meddler.QueryAll(db, &commits, rebind(commitListActivityQuery), user.ID)
return commits, err
}
// PostCommit saves a commit in the datastore. // PostCommit saves a commit in the datastore.
func (db *Commitstore) PostCommit(commit *model.Commit) error { func (db *Commitstore) PostCommit(commit *model.Commit) error {
if commit.Created == 0 { if commit.Created == 0 {
@ -97,7 +105,7 @@ WHERE commit_id = ?
` `
// SQL query to retrieve the latest Commits accessible // SQL query to retrieve the latest Commits accessible
// to ta specific user account // to a specific user account
const commitListUserQuery = ` const commitListUserQuery = `
SELECT r.repo_remote, r.repo_host, r.repo_owner, r.repo_name, c.* SELECT r.repo_remote, r.repo_host, r.repo_owner, r.repo_name, c.*
FROM FROM
@ -117,6 +125,21 @@ WHERE c.repo_id = r.repo_id
) ORDER BY c.commit_created DESC LIMIT 5; ) ORDER BY c.commit_created DESC LIMIT 5;
` `
// SQL query to retrieve the ungrouped, latest Commits
// accessible to a specific user account
const commitListActivityQuery = `
SELECT r.repo_remote, r.repo_host, r.repo_owner, r.repo_name, c.*
FROM
commits c
,repos r
,perms p
WHERE c.repo_id = r.repo_id
AND r.repo_id = p.repo_id
AND p.user_id = ?
ORDER BY c.commit_created DESC
LIMIT 20
`
// SQL query to retrieve the latest Commits across all branches. // SQL query to retrieve the latest Commits across all branches.
const commitListQuery = ` const commitListQuery = `
SELECT * SELECT *

View file

@ -1,6 +1,7 @@
package database package database
import ( import (
"fmt"
"testing" "testing"
"github.com/drone/drone/shared/model" "github.com/drone/drone/shared/model"
@ -183,6 +184,13 @@ func TestCommitstore(t *testing.T) {
Owner: "drone", Owner: "drone",
Name: "drone", Name: "drone",
} }
repo3 := model.Repo{
UserID: 2,
Remote: "enterprise.github.com",
Host: "github.drone.io",
Owner: "droneio",
Name: "drone",
}
rs.PostRepo(&repo1) rs.PostRepo(&repo1)
rs.PostRepo(&repo2) rs.PostRepo(&repo2)
commit1 := model.Commit{ commit1 := model.Commit{
@ -209,10 +217,17 @@ func TestCommitstore(t *testing.T) {
Sha: "d923a61d8ad3d8d02db4fef0bf40a726bad0fc03", Sha: "d923a61d8ad3d8d02db4fef0bf40a726bad0fc03",
Status: model.StatusStarted, Status: model.StatusStarted,
} }
commit5 := model.Commit{
RepoID: repo3.ID,
Branch: "bar",
Sha: "d923a61d8ad3d8d02db4fef0bf40a726bad0fc03",
Status: model.StatusStarted,
}
cs.PostCommit(&commit1) cs.PostCommit(&commit1)
cs.PostCommit(&commit2) cs.PostCommit(&commit2)
cs.PostCommit(&commit3) cs.PostCommit(&commit3)
cs.PostCommit(&commit4) cs.PostCommit(&commit4)
cs.PostCommit(&commit5)
perm1 := model.Perm{ perm1 := model.Perm{
RepoID: repo1.ID, RepoID: repo1.ID,
UserID: 1, UserID: 1,
@ -237,6 +252,12 @@ func TestCommitstore(t *testing.T) {
g.Assert(commits[0].Sha).Equal(commit1.Sha) g.Assert(commits[0].Sha).Equal(commit1.Sha)
g.Assert(commits[1].Sha).Equal(commit4.Sha) g.Assert(commits[1].Sha).Equal(commit4.Sha)
g.Assert(commits[1].Status).Equal(commit4.Status) g.Assert(commits[1].Status).Equal(commit4.Status)
commits, err = cs.GetCommitListActivity(&model.User{ID: 1})
fmt.Println(commits)
fmt.Println(err)
g.Assert(err == nil).IsTrue()
g.Assert(len(commits)).Equal(3)
}) })
g.It("Should enforce unique Sha + Branch", func() { g.It("Should enforce unique Sha + Branch", func() {

View file

@ -114,6 +114,27 @@ func GetUserFeed(c web.C, w http.ResponseWriter, r *http.Request) {
json.NewEncoder(w).Encode(&repos) json.NewEncoder(w).Encode(&repos)
} }
// GetUserActivity accepts a request to get the user's latest
// build activity, across all repositories, from the datastore.
// The results are encoded and returned in JSON format.
//
// GET /api/user/activity
//
func GetUserActivity(c web.C, w http.ResponseWriter, r *http.Request) {
var ctx = context.FromC(c)
var user = ToUser(c)
if user == nil {
w.WriteHeader(http.StatusUnauthorized)
return
}
repos, err := datastore.GetCommitListActivity(ctx, user)
if err != nil {
w.WriteHeader(http.StatusNotFound)
return
}
json.NewEncoder(w).Encode(&repos)
}
// PostUserSync accepts a request to post user sync // PostUserSync accepts a request to post user sync
// //
// POST /api/user/sync // POST /api/user/sync

View file

@ -61,6 +61,7 @@ func New() *web.Mux {
user := web.New() user := web.New()
user.Use(middleware.RequireUser) user.Use(middleware.RequireUser)
user.Get("/api/user/feed", handler.GetUserFeed) user.Get("/api/user/feed", handler.GetUserFeed)
user.Get("/api/user/activity", handler.GetUserActivity)
user.Get("/api/user/repos", handler.GetUserRepos) user.Get("/api/user/repos", handler.GetUserRepos)
user.Post("/api/user/sync", handler.PostUserSync) user.Post("/api/user/sync", handler.PostUserSync)
user.Get("/api/user", handler.GetUserCurrent) user.Get("/api/user", handler.GetUserCurrent)