54 lines
1.2 KiB
Go
54 lines
1.2 KiB
Go
|
package datastore
|
||
|
|
||
|
import (
|
||
|
"github.com/drone/drone/model"
|
||
|
"github.com/russross/meddler"
|
||
|
)
|
||
|
|
||
|
func (db *datastore) GetSecretList(repo *model.Repo) ([]*model.RepoSecret, error) {
|
||
|
var secrets = []*model.RepoSecret{}
|
||
|
var err = meddler.QueryAll(db, &secrets, rebind(secretListQuery), repo.ID)
|
||
|
return secrets, err
|
||
|
}
|
||
|
|
||
|
func (db *datastore) GetSecret(repo *model.Repo, name string) (*model.RepoSecret, error) {
|
||
|
var secret = new(model.RepoSecret)
|
||
|
var err = meddler.QueryRow(db, secret, rebind(secretNameQuery), repo.ID, name)
|
||
|
return secret, err
|
||
|
}
|
||
|
|
||
|
func (db *datastore) SetSecret(sec *model.RepoSecret) error {
|
||
|
var got = new(model.RepoSecret)
|
||
|
var err = meddler.QueryRow(db, got, rebind(secretNameQuery), sec.RepoID, sec.Name)
|
||
|
if err == nil && got.ID != 0 {
|
||
|
sec.ID = got.ID // update existing id
|
||
|
}
|
||
|
return meddler.Save(db, secretTable, sec)
|
||
|
}
|
||
|
|
||
|
func (db *datastore) DeleteSecret(sec *model.RepoSecret) error {
|
||
|
_, err := db.Exec(rebind(secretDeleteStmt), sec.ID)
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
const secretTable = "secrets"
|
||
|
|
||
|
const secretListQuery = `
|
||
|
SELECT *
|
||
|
FROM secrets
|
||
|
WHERE secret_repo_id = ?
|
||
|
`
|
||
|
|
||
|
const secretNameQuery = `
|
||
|
SELECT *
|
||
|
FROM secrets
|
||
|
WHERE secret_repo_id = ?
|
||
|
AND secret_name = ?
|
||
|
LIMIT 1;
|
||
|
`
|
||
|
|
||
|
const secretDeleteStmt = `
|
||
|
DELETE FROM secrets
|
||
|
WHERE secret_id = ?
|
||
|
`
|