mirror of
https://github.com/semaphoreui/semaphore.git
synced 2024-12-04 07:11:05 +01:00
104 lines
2.3 KiB
Go
104 lines
2.3 KiB
Go
package sql
|
|
|
|
import (
|
|
"github.com/Masterminds/squirrel"
|
|
"github.com/ansible-semaphore/semaphore/db"
|
|
)
|
|
|
|
func (d *SqlDb) GetRepository(projectID int, repositoryID int) (db.Repository, error) {
|
|
var repository db.Repository
|
|
err := d.getObject(projectID, db.RepositoryProps, repositoryID, &repository)
|
|
|
|
if err != nil {
|
|
return repository, err
|
|
}
|
|
|
|
repository.SSHKey, err = d.GetAccessKey(projectID, repository.SSHKeyID)
|
|
|
|
return repository, err
|
|
}
|
|
|
|
func (d *SqlDb) GetRepositoryRefs(projectID int, repositoryID int) (db.ObjectReferrers, error) {
|
|
return d.getObjectRefs(projectID, db.RepositoryProps, repositoryID)
|
|
}
|
|
|
|
func (d *SqlDb) GetRepositories(projectID int, params db.RetrieveQueryParams) (repositories []db.Repository, err error) {
|
|
q := squirrel.Select("*").
|
|
From("project__repository pr")
|
|
|
|
order := "ASC"
|
|
if params.SortInverted {
|
|
order = "DESC"
|
|
}
|
|
|
|
switch params.SortBy {
|
|
case "name", "git_url":
|
|
q = q.Where("pr.project_id=?", projectID).
|
|
OrderBy("pr." + params.SortBy + " " + order)
|
|
case "ssh_key":
|
|
q = q.LeftJoin("access_key ak ON (pr.ssh_key_id = ak.id)").
|
|
Where("pr.project_id=?", projectID).
|
|
OrderBy("ak.name " + order)
|
|
default:
|
|
q = q.Where("pr.project_id=?", projectID).
|
|
OrderBy("pr.name " + order)
|
|
}
|
|
|
|
query, args, err := q.ToSql()
|
|
|
|
if err != nil {
|
|
return
|
|
}
|
|
|
|
_, err = d.selectAll(&repositories, query, args...)
|
|
|
|
return
|
|
}
|
|
|
|
func (d *SqlDb) UpdateRepository(repository db.Repository) error {
|
|
err := repository.Validate()
|
|
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
_, err = d.exec(
|
|
"update project__repository set name=?, git_url=?, git_branch=?, ssh_key_id=? where id=?",
|
|
repository.Name,
|
|
repository.GitURL,
|
|
repository.GitBranch,
|
|
repository.SSHKeyID,
|
|
repository.ID)
|
|
|
|
return err
|
|
}
|
|
|
|
func (d *SqlDb) CreateRepository(repository db.Repository) (newRepo db.Repository, err error) {
|
|
err = repository.Validate()
|
|
|
|
if err != nil {
|
|
return
|
|
}
|
|
|
|
insertID, err := d.insert(
|
|
"id",
|
|
"insert into project__repository(project_id, git_url, git_branch, ssh_key_id, name) values (?, ?, ?, ?, ?)",
|
|
repository.ProjectID,
|
|
repository.GitURL,
|
|
repository.GitBranch,
|
|
repository.SSHKeyID,
|
|
repository.Name)
|
|
|
|
if err != nil {
|
|
return
|
|
}
|
|
|
|
newRepo = repository
|
|
newRepo.ID = insertID
|
|
return
|
|
}
|
|
|
|
func (d *SqlDb) DeleteRepository(projectID int, repositoryId int) error {
|
|
return d.deleteObject(projectID, db.RepositoryProps, repositoryId)
|
|
}
|