1
0
mirror of https://github.com/woodpecker-ci/woodpecker.git synced 2024-12-30 10:11:23 +02:00
woodpecker/store/datastore/repos.go

86 lines
1.7 KiB
Go
Raw Normal View History

package datastore
import (
2015-10-22 01:39:43 +02:00
"fmt"
"github.com/drone/drone/model"
2017-05-03 23:25:33 +02:00
"github.com/drone/drone/store/datastore/sql"
"github.com/russross/meddler"
)
func (db *datastore) GetRepo(id int64) (*model.Repo, error) {
var repo = new(model.Repo)
var err = meddler.Load(db, repoTable, repo, id)
return repo, err
}
func (db *datastore) GetRepoName(name string) (*model.Repo, error) {
var repo = new(model.Repo)
var err = meddler.QueryRow(db, repo, rebind(repoNameQuery), name)
return repo, err
}
func (db *datastore) GetRepoListOf(listof []*model.RepoLite) ([]*model.Repo, error) {
2015-10-22 01:39:43 +02:00
var (
repos []*model.Repo
args []interface{}
stmt string
err error
2015-10-22 01:39:43 +02:00
)
switch meddler.Default {
case meddler.PostgreSQL:
2016-09-02 13:32:17 +02:00
stmt, args = toListPostgres(listof)
2015-10-22 01:39:43 +02:00
default:
stmt, args = toList(listof)
}
if len(args) > 0 {
err = meddler.QueryAll(db, &repos, fmt.Sprintf(repoListOfQuery, stmt), args...)
}
return repos, err
}
2017-05-03 23:25:33 +02:00
func (db *datastore) GetRepoCount() (count int, err error) {
2017-05-04 02:02:08 +02:00
err = db.QueryRow(
sql.Lookup(db.driver, "count-repos"),
).Scan(&count)
2017-05-03 23:25:33 +02:00
return
}
func (db *datastore) CreateRepo(repo *model.Repo) error {
return meddler.Insert(db, repoTable, repo)
}
func (db *datastore) UpdateRepo(repo *model.Repo) error {
return meddler.Update(db, repoTable, repo)
}
func (db *datastore) DeleteRepo(repo *model.Repo) error {
var _, err = db.Exec(rebind(repoDeleteStmt), repo.ID)
return err
}
const repoTable = "repos"
const repoNameQuery = `
SELECT *
FROM repos
WHERE repo_full_name = ?
LIMIT 1;
`
2015-10-22 01:39:43 +02:00
const repoListOfQuery = `
SELECT *
FROM repos
WHERE repo_full_name IN (%s)
2015-10-22 01:39:43 +02:00
ORDER BY repo_name
`
const repoCountQuery = `
SELECT COUNT(*) FROM repos
`
const repoDeleteStmt = `
DELETE FROM repos
WHERE repo_id = ?
`