2016-04-02 14:40:07 +02:00
package projects
2016-04-07 14:49:34 +02:00
import (
2016-04-13 18:09:44 +02:00
"database/sql"
2017-02-23 00:21:49 +01:00
"net/http"
2016-04-13 18:09:44 +02:00
2016-05-24 11:55:48 +02:00
database "github.com/ansible-semaphore/semaphore/db"
2016-04-07 14:49:34 +02:00
"github.com/ansible-semaphore/semaphore/models"
2016-04-13 18:09:44 +02:00
"github.com/ansible-semaphore/semaphore/util"
2017-02-23 00:21:49 +01:00
"github.com/castawaylabs/mulekick"
"github.com/gorilla/context"
2016-04-07 14:49:34 +02:00
"github.com/masterminds/squirrel"
)
2016-04-02 14:40:07 +02:00
2017-02-22 23:17:36 +01:00
func EnvironmentMiddleware ( w http . ResponseWriter , r * http . Request ) {
2017-02-22 23:21:52 +01:00
project := context . Get ( r , "project" ) . ( models . Project )
2017-02-23 00:21:49 +01:00
envID , err := util . GetIntParam ( "environment_id" , w , r )
2016-04-13 18:09:44 +02:00
if err != nil {
return
}
query , args , _ := squirrel . Select ( "*" ) .
From ( "project__environment" ) .
Where ( "project_id=?" , project . ID ) .
Where ( "id=?" , envID ) .
ToSql ( )
var env models . Environment
if err := database . Mysql . SelectOne ( & env , query , args ... ) ; err != nil {
if err == sql . ErrNoRows {
2017-02-22 23:17:36 +01:00
w . WriteHeader ( http . StatusNotFound )
2016-04-13 18:09:44 +02:00
return
}
panic ( err )
}
2017-02-23 00:21:49 +01:00
context . Set ( r , "environment" , env )
2016-04-02 14:40:07 +02:00
}
2017-02-22 23:17:36 +01:00
func GetEnvironment ( w http . ResponseWriter , r * http . Request ) {
2017-02-22 23:21:52 +01:00
project := context . Get ( r , "project" ) . ( models . Project )
2016-04-07 14:49:34 +02:00
var env [ ] models . Environment
q := squirrel . Select ( "*" ) .
From ( "project__environment" ) .
Where ( "project_id=?" , project . ID )
query , args , _ := q . ToSql ( )
if _ , err := database . Mysql . Select ( & env , query , args ... ) ; err != nil {
panic ( err )
}
2017-02-23 00:21:49 +01:00
mulekick . WriteJSON ( w , http . StatusOK , env )
2016-04-02 14:40:07 +02:00
}
2017-02-22 23:17:36 +01:00
func UpdateEnvironment ( w http . ResponseWriter , r * http . Request ) {
2017-02-22 23:21:52 +01:00
oldEnv := context . Get ( r , "environment" ) . ( models . Environment )
2016-04-13 18:09:44 +02:00
var env models . Environment
2017-02-22 23:21:52 +01:00
if err := mulekick . Bind ( w , r , & env ) ; err != nil {
2016-04-13 18:09:44 +02:00
return
}
if _ , err := database . Mysql . Exec ( "update project__environment set name=?, json=? where id=?" , env . Name , env . JSON , oldEnv . ID ) ; err != nil {
panic ( err )
}
2017-02-22 23:17:36 +01:00
w . WriteHeader ( http . StatusNoContent )
2016-04-13 18:09:44 +02:00
}
2017-02-22 23:17:36 +01:00
func AddEnvironment ( w http . ResponseWriter , r * http . Request ) {
2017-02-22 23:21:52 +01:00
project := context . Get ( r , "project" ) . ( models . Project )
2016-04-13 18:09:44 +02:00
var env models . Environment
2017-02-22 23:21:52 +01:00
if err := mulekick . Bind ( w , r , & env ) ; err != nil {
2016-04-13 18:09:44 +02:00
return
}
2016-04-17 02:20:23 +02:00
res , err := database . Mysql . Exec ( "insert into project__environment set project_id=?, name=?, json=?, password=?" , project . ID , env . Name , env . JSON , env . Password )
if err != nil {
panic ( err )
}
insertID , _ := res . LastInsertId ( )
insertIDInt := int ( insertID )
objType := "environment"
desc := "Environment " + env . Name + " created"
if err := ( models . Event {
ProjectID : & project . ID ,
ObjectType : & objType ,
ObjectID : & insertIDInt ,
Description : & desc ,
} . Insert ( ) ) ; err != nil {
2016-04-13 18:09:44 +02:00
panic ( err )
}
2017-02-22 23:17:36 +01:00
w . WriteHeader ( http . StatusNoContent )
2016-04-04 15:44:34 +02:00
}
2017-02-22 23:17:36 +01:00
func RemoveEnvironment ( w http . ResponseWriter , r * http . Request ) {
2017-02-22 23:21:52 +01:00
env := context . Get ( r , "environment" ) . ( models . Environment )
2016-04-13 18:09:44 +02:00
2016-06-17 22:16:46 +02:00
templatesC , err := database . Mysql . SelectInt ( "select count(1) from project__template where project_id=? and environment_id=?" , env . ProjectID , env . ID )
if err != nil {
panic ( err )
}
if templatesC > 0 {
2017-02-23 00:21:49 +01:00
if len ( r . URL . Query ( ) . Get ( "setRemoved" ) ) == 0 {
mulekick . WriteJSON ( w , http . StatusBadRequest , map [ string ] interface { } {
2016-06-17 22:16:46 +02:00
"error" : "Environment is in use by one or more templates" ,
"inUse" : true ,
} )
return
}
if _ , err := database . Mysql . Exec ( "update project__environment set removed=1 where id=?" , env . ID ) ; err != nil {
panic ( err )
}
2017-02-22 23:17:36 +01:00
w . WriteHeader ( http . StatusNoContent )
2016-06-17 22:16:46 +02:00
return
}
2016-04-13 18:09:44 +02:00
if _ , err := database . Mysql . Exec ( "delete from project__environment where id=?" , env . ID ) ; err != nil {
panic ( err )
}
2016-04-17 02:20:23 +02:00
desc := "Environment " + env . Name + " deleted"
if err := ( models . Event {
ProjectID : & env . ProjectID ,
Description : & desc ,
} . Insert ( ) ) ; err != nil {
panic ( err )
}
2017-02-22 23:17:36 +01:00
w . WriteHeader ( http . StatusNoContent )
2016-04-02 14:40:07 +02:00
}