mirror of
https://github.com/semaphoreui/semaphore.git
synced 2025-01-23 19:31:03 +01:00
63 lines
1.4 KiB
Go
63 lines
1.4 KiB
Go
package projects
|
|
|
|
import (
|
|
"github.com/ansible-semaphore/semaphore/database"
|
|
"github.com/ansible-semaphore/semaphore/models"
|
|
"github.com/ansible-semaphore/semaphore/util"
|
|
"github.com/gin-gonic/gin"
|
|
"github.com/masterminds/squirrel"
|
|
)
|
|
|
|
func RepositoryMiddleware(c *gin.Context) {
|
|
c.Next()
|
|
}
|
|
|
|
func GetRepositories(c *gin.Context) {
|
|
project := c.MustGet("project").(models.Project)
|
|
var repos []models.Repository
|
|
|
|
query, args, _ := squirrel.Select("*").
|
|
From("project__repository").
|
|
Where("project_id=?", project.ID).
|
|
ToSql()
|
|
|
|
if _, err := database.Mysql.Select(&repos, query, args...); err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
c.JSON(200, repos)
|
|
}
|
|
|
|
func AddRepository(c *gin.Context) {
|
|
project := c.MustGet("project").(models.Project)
|
|
var repository models.Repository
|
|
|
|
if err := c.Bind(&repository); err != nil {
|
|
return
|
|
}
|
|
|
|
if _, err := database.Mysql.Exec("insert into project__repository set project_id=?, git_url=?, ssh_key_id=?", project.ID, repository.GitUrl, repository.SshKeyID); err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
c.AbortWithStatus(204)
|
|
}
|
|
|
|
func UpdateRepository(c *gin.Context) {
|
|
c.AbortWithStatus(501)
|
|
}
|
|
|
|
func RemoveRepository(c *gin.Context) {
|
|
project := c.MustGet("project").(models.Project)
|
|
repositoryID, err := util.GetIntParam("repository_id", c)
|
|
if err != nil {
|
|
return
|
|
}
|
|
|
|
if _, err := database.Mysql.Exec("delete from project__repository where project_id=? and id=?", project.ID, repositoryID); err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
c.AbortWithStatus(204)
|
|
}
|