Semaphore/db/sql/project.go
2020-12-20 23:00:59 +05:00

96 lines
1.9 KiB
Go

package sql
import (
"github.com/ansible-semaphore/semaphore/db"
"github.com/masterminds/squirrel"
"time"
)
func (d *SqlDb) CreateProject(project db.Project) (newProject db.Project, err error) {
project.Created = time.Now()
res, err := d.sql.Exec("insert into project(name, created) values (?, ?)", project.Name, project.Created)
if err != nil {
return
}
insertId, err := res.LastInsertId()
if err != nil {
return
}
newProject = project
newProject.ID = int(insertId)
return
}
func (d *SqlDb) GetProjects(userID int) (projects []db.Project, err error) {
query, args, err := squirrel.Select("p.*").
From("project as p").
Join("project__user as pu on pu.project_id=p.id").
Where("pu.user_id=?", userID).
OrderBy("p.name").
ToSql()
if err != nil {
return
}
_, err = d.sql.Select(&projects, query, args...)
return
}
func (d *SqlDb) GetProject(projectID int) (project db.Project, err error) {
query, args, err := squirrel.Select("p.*").
From("project as p").
Where("p.id=?", projectID).
ToSql()
if err != nil {
return
}
err = d.sql.SelectOne(&project, query, args...)
return
}
func (d *SqlDb) DeleteProject(projectID int) error {
tx, err := d.sql.Begin()
if err != nil {
return err
}
statements := []string{
"delete from project__template where project_id=?",
"delete from project__user where project_id=?",
"delete from project__repository where project_id=?",
"delete from project__inventory where project_id=?",
"delete from access_key where project_id=?",
"delete from project where id=?",
}
for _, statement := range statements {
_, err = tx.Exec(statement, projectID)
if err != nil {
err = tx.Rollback()
return err
}
}
return tx.Commit()
}
func (d *SqlDb) UpdateProject(project db.Project) error {
_, err := d.sql.Exec(
"update project set name=?, alert=?, alert_chat=? where id=?",
project.Name,
project.Alert,
project.AlertChat,
project.ID)
return err
}