repo feed for latest build only
This commit is contained in:
parent
769551cb44
commit
67ac073164
5 changed files with 76 additions and 29 deletions
|
@ -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"`
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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)
|
||||||
|
`
|
||||||
|
|
|
@ -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)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue