repo feed for latest build only

This commit is contained in:
Brad Rydzewski 2016-06-14 17:34:47 -07:00
parent 769551cb44
commit 67ac073164
5 changed files with 76 additions and 29 deletions

View file

@ -8,20 +8,20 @@ type Feed struct {
Name string `json:"name" meddler:"repo_name"` Name string `json:"name" meddler:"repo_name"`
FullName string `json:"full_name" meddler:"repo_full_name"` FullName string `json:"full_name" meddler:"repo_full_name"`
Number int `json:"number" meddler:"build_number"` Number int `json:"number,omitempty" meddler:"build_number,zeroisnull"`
Event string `json:"event" meddler:"build_event"` Event string `json:"event,omitempty" meddler:"build_event,zeroisnull"`
Status string `json:"status" meddler:"build_status"` Status string `json:"status,omitempty" meddler:"build_status,zeroisnull"`
Created int64 `json:"created_at" meddler:"build_created"` Created int64 `json:"created_at,omitempty" meddler:"build_created,zeroisnull"`
Started int64 `json:"started_at" meddler:"build_started"` Started int64 `json:"started_at,omitempty" meddler:"build_started,zeroisnull"`
Finished int64 `json:"finished_at" meddler:"build_finished"` Finished int64 `json:"finished_at,omitempty" meddler:"build_finished,zeroisnull"`
Commit string `json:"commit" meddler:"build_commit"` Commit string `json:"commit,omitempty" meddler:"build_commit,zeroisnull"`
Branch string `json:"branch" meddler:"build_branch"` Branch string `json:"branch,omitempty" meddler:"build_branch,zeroisnull"`
Ref string `json:"ref" meddler:"build_ref"` Ref string `json:"ref,omitempty" meddler:"build_ref,zeroisnull"`
Refspec string `json:"refspec" meddler:"build_refspec"` Refspec string `json:"refspec,omitempty" meddler:"build_refspec,zeroisnull"`
Remote string `json:"remote" meddler:"build_remote"` Remote string `json:"remote,omitempty" meddler:"build_remote,zeroisnull"`
Title string `json:"title" meddler:"build_title"` Title string `json:"title,omitempty" meddler:"build_title,zeroisnull"`
Message string `json:"message" meddler:"build_message"` Message string `json:"message,omitempty" meddler:"build_message,zeroisnull"`
Author string `json:"author" meddler:"build_author"` Author string `json:"author,omitempty" meddler:"build_author,zeroisnull"`
Avatar string `json:"author_avatar" meddler:"build_avatar"` Avatar string `json:"author_avatar,omitempty" meddler:"build_avatar,zeroisnull"`
Email string `json:"author_email" meddler:"build_email"` Email string `json:"author_email,omitempty" meddler:"build_email,zeroisnull"`
} }

View file

@ -21,13 +21,15 @@ func GetSelf(c *gin.Context) {
} }
func GetFeed(c *gin.Context) { func GetFeed(c *gin.Context) {
latest, _ := strconv.ParseBool(c.Query("latest"))
repos, err := cache.GetRepos(c, session.User(c)) repos, err := cache.GetRepos(c, session.User(c))
if err != nil { if err != nil {
c.String(500, "Error fetching repository list. %s", err) c.String(500, "Error fetching repository list. %s", err)
return return
} }
feed, err := store.GetUserFeed(c, repos) feed, err := store.GetUserFeed(c, repos, latest)
if err != nil { if err != nil {
c.String(500, "Error fetching feed. %s", err) c.String(500, "Error fetching feed. %s", err)
return return

View file

@ -63,17 +63,6 @@ WHERE repo_full_name = ?
LIMIT 1; LIMIT 1;
` `
const repoListQuery = `
SELECT *
FROM repos
WHERE repo_id IN (
SELECT DISTINCT build_repo_id
FROM builds
WHERE build_author = ?
)
ORDER BY repo_full_name
`
const repoListOfQuery = ` const repoListOfQuery = `
SELECT * SELECT *
FROM repos FROM repos

View file

@ -41,6 +41,22 @@ func (db *datastore) GetUserFeed(listof []*model.RepoLite) ([]*model.Feed, error
return feed, err return feed, err
} }
func (db *datastore) GetUserFeedLatest(listof []*model.RepoLite) ([]*model.Feed, error) {
var (
feed []*model.Feed
args []interface{}
stmt string
)
switch meddler.Default {
case meddler.PostgreSQL:
stmt, args = toListPosgres(listof)
default:
stmt, args = toList(listof)
}
err := meddler.QueryAll(db, &feed, fmt.Sprintf(userFeedLatest, stmt), args...)
return feed, err
}
func (db *datastore) GetUserCount() (int, error) { func (db *datastore) GetUserCount() (int, error) {
var count int var count int
var err = db.QueryRow(rebind(userCountQuery)).Scan(&count) var err = db.QueryRow(rebind(userCountQuery)).Scan(&count)
@ -114,3 +130,36 @@ WHERE b.build_repo_id = r.repo_id
ORDER BY b.build_id DESC ORDER BY b.build_id DESC
LIMIT 50 LIMIT 50
` `
// thanks to this article for helping me find a sane sql query
// https://www.periscopedata.com/blog/4-ways-to-join-only-the-first-row-in-sql.html
const userFeedLatest = `
SELECT
repo_owner
,repo_name
,repo_full_name
,build_number
,build_event
,build_status
,build_created
,build_started
,build_finished
,build_commit
,build_branch
,build_ref
,build_refspec
,build_remote
,build_title
,build_message
,build_author
,build_email
,build_avatar
FROM repos LEFT OUTER JOIN builds ON build_id = (
SELECT build_id FROM builds
WHERE builds.build_repo_id = repos.repo_id
ORDER BY build_id DESC
LIMIT 1
)
WHERE repo_full_name IN (%s)
`

View file

@ -21,6 +21,10 @@ type Store interface {
// GetUserFeed gets a user activity feed. // GetUserFeed gets a user activity feed.
GetUserFeed([]*model.RepoLite) ([]*model.Feed, error) GetUserFeed([]*model.RepoLite) ([]*model.Feed, error)
// GetUserFeedLatest gets a user activity feed for all repositories including
// only the latest build for each repository.
GetUserFeedLatest(listof []*model.RepoLite) ([]*model.Feed, error)
// GetUserCount gets a count of all users in the system. // GetUserCount gets a count of all users in the system.
GetUserCount() (int, error) GetUserCount() (int, error)
@ -146,7 +150,10 @@ func GetUserList(c context.Context) ([]*model.User, error) {
} }
// GetUserFeed gets a user activity feed. // GetUserFeed gets a user activity feed.
func GetUserFeed(c context.Context, listof []*model.RepoLite) ([]*model.Feed, error) { func GetUserFeed(c context.Context, listof []*model.RepoLite, latest bool) ([]*model.Feed, error) {
if latest {
return FromContext(c).GetUserFeedLatest(listof)
}
return FromContext(c).GetUserFeed(listof) return FromContext(c).GetUserFeed(listof)
} }