Web dashboard, task release, logs api

This commit is contained in:
simon987
2019-01-21 20:16:30 -05:00
parent 0346dd8b6b
commit cbd32daf02
65 changed files with 13430 additions and 114 deletions

View File

@@ -3,6 +3,7 @@ package storage
import (
"database/sql"
"github.com/Sirupsen/logrus"
"github.com/google/uuid"
"strings"
)
@@ -13,22 +14,34 @@ type Project struct {
CloneUrl string `json:"clone_url"`
GitRepo string `json:"git_repo"`
Version string `json:"version"`
Motd string `json:"motd"`
}
type AssignedTasks struct {
Assignee uuid.UUID `json:"assignee"`
TaskCount int64 `json:"task_count"`
}
type ProjectStats struct {
Project *Project `json:"project"`
NewTaskCount int64 `json:"new_task_count"`
FailedTaskCount int64 `json:"failed_task_count"`
ClosedTaskCount int64 `json:"closed_task_count"`
Assignees []*AssignedTasks `json:"assignees"`
}
func (database *Database) SaveProject(project *Project) (int64, error) {
db := database.getDB()
id, projectErr := saveProject(project, db)
err := db.Close()
handleErr(err)
return id, projectErr
}
func saveProject(project *Project, db *sql.DB) (int64, error) {
row := db.QueryRow(`INSERT INTO project (name, git_repo, clone_url, version, priority)
VALUES ($1,$2,$3,$4,$5) RETURNING id`,
project.Name, project.GitRepo, project.CloneUrl, project.Version, project.Priority)
row := db.QueryRow(`INSERT INTO project (name, git_repo, clone_url, version, priority, motd)
VALUES ($1,$2,$3,$4,$5,$6) RETURNING id`,
project.Name, project.GitRepo, project.CloneUrl, project.Version, project.Priority, project.Motd)
var id int64
err := row.Scan(&id)
@@ -40,6 +53,8 @@ func saveProject(project *Project, db *sql.DB) (int64, error) {
return -1, err
}
project.Id = id
logrus.WithFields(logrus.Fields{
"id": id,
"project": project,
@@ -52,8 +67,6 @@ func (database *Database) GetProject(id int64) *Project {
db := database.getDB()
project := getProject(id, db)
err := db.Close()
handleErr(err)
return project
}
@@ -80,8 +93,8 @@ func getProject(id int64, db *sql.DB) *Project {
func scanProject(row *sql.Row) (*Project, error) {
project := &Project{}
err := row.Scan(&project.Id, &project.Priority, &project.Name, &project.CloneUrl, &project.GitRepo,
&project.Version)
err := row.Scan(&project.Id, &project.Priority, &project.Motd, &project.Name, &project.CloneUrl,
&project.GitRepo, &project.Version)
return project, err
}
@@ -90,20 +103,18 @@ func (database *Database) GetProjectWithRepoName(repoName string) *Project {
db := database.getDB()
project := getProjectWithRepoName(repoName, db)
err := db.Close()
handleErr(err)
return project
}
func getProjectWithRepoName(repoName string, db *sql.DB) *Project {
row := db.QueryRow(`SELECT * FROm project WHERE LOWER(git_repo)=$1`, strings.ToLower(repoName))
row := db.QueryRow(`SELECT * FROM project WHERE LOWER(git_repo)=$1`, strings.ToLower(repoName))
project, err := scanProject(row)
if err != nil {
logrus.WithError(err).WithFields(logrus.Fields{
"repoName": repoName,
}).Error("Database.getProjectWithRepoName SELECT project NOT FOUND")
}).Warn("Database.getProjectWithRepoName SELECT project NOT FOUND")
return nil
}
@@ -114,15 +125,13 @@ func (database *Database) UpdateProject(project *Project) {
db := database.getDB()
updateProject(project, db)
err := db.Close()
handleErr(err)
}
func updateProject(project *Project, db *sql.DB) {
res, err := db.Exec(`UPDATE project
SET (priority, name, clone_url, git_repo, version) = ($1,$2,$3,$4,$5) WHERE id=$6`,
project.Priority, project.Name, project.CloneUrl, project.GitRepo, project.Version, project.Id)
SET (priority, name, clone_url, git_repo, version, motd) = ($1,$2,$3,$4,$5,$6) WHERE id=$7`,
project.Priority, project.Name, project.CloneUrl, project.GitRepo, project.Version, project.Motd, project.Id)
handleErr(err)
rowsAffected, _ := res.RowsAffected()
@@ -134,3 +143,47 @@ func updateProject(project *Project, db *sql.DB) {
return
}
func (database *Database) GetProjectStats(id int64) *ProjectStats {
db := database.getDB()
stats := getProjectStats(id, db)
return stats
}
func getProjectStats(id int64, db *sql.DB) *ProjectStats {
stats := ProjectStats{}
stats.Project = getProject(id, db)
if stats.Project != nil {
row := db.QueryRow(`SELECT
SUM(CASE WHEN status='new' THEN 1 ELSE 0 END) newCount,
SUM(CASE WHEN status='failed' THEN 1 ELSE 0 END) failedCount,
SUM(CASE WHEN status='closed' THEN 1 ELSE 0 END) closedCount
FROM task WHERE project=$1 GROUP BY project`, id)
err := row.Scan(&stats.NewTaskCount, &stats.FailedTaskCount, &stats.ClosedTaskCount)
if err != nil {
logrus.WithError(err).WithFields(logrus.Fields{
"id": id,
}).Warn("???") //todo
return nil
}
rows, err := db.Query(`SELECT assignee, COUNT(*) FROM TASK
LEFT JOIN worker ON TASK.assignee = worker.id WHERE project=$1 GROUP BY assignee`, id)
for rows.Next() {
assignee := AssignedTasks{}
err = rows.Scan(&assignee.Assignee, &assignee.TaskCount)
handleErr(err)
stats.Assignees = append(stats.Assignees, &assignee)
}
}
return &stats
}