provision files
This commit is contained in:
@@ -0,0 +1,68 @@
|
|||||||
|
# 1. Login
|
||||||
|
curl -c /tmp/semaphore-cookie -XPOST \
|
||||||
|
-H 'Content-Type: application/json' -H 'Accept: application/json' \
|
||||||
|
-d '{"auth": "admin", "password": "may12002"}' \
|
||||||
|
"http://172.16.4.90:3000/api/auth/login"
|
||||||
|
|
||||||
|
# 2. Get token
|
||||||
|
curl -b /tmp/semaphore-cookie \
|
||||||
|
-H 'Content-Type: application/json' -H 'Accept: application/json' \
|
||||||
|
"http://172.16.4.90:3000/api/user/tokens" > tokens.txt
|
||||||
|
|
||||||
|
# 2.1. Generate a new token & get it
|
||||||
|
curl -v -b /tmp/semaphore-cookie -XPOST \
|
||||||
|
-H 'Content-Type: application/json' -H 'Accept: application/json' \
|
||||||
|
"http://172.16.4.90:3000/api/user/tokens"
|
||||||
|
|
||||||
|
# 2.2. Get a new token
|
||||||
|
curl -v -b /tmp/semaphore-cookie \
|
||||||
|
-H 'Content-Type: application/json' -H 'Accept: application/json' \
|
||||||
|
"http://172.16.4.90:3000/api/user/tokens" > tokens.txt
|
||||||
|
|
||||||
|
# get the last one from array:
|
||||||
|
export TOKEN=`cat tokens.txt | jq .[-1].id | xargs echo`
|
||||||
|
echo "Obtained token: $TOKEN"
|
||||||
|
|
||||||
|
# DEBUG
|
||||||
|
# curl \
|
||||||
|
# -H 'Content-Type: application/json' -H 'Accept: application/json' -H "Authorization: Bearer $TOKEN" \
|
||||||
|
# "http://172.16.4.90:3000/api/projects" -v
|
||||||
|
#curl -b /tmp/semaphore-cookie "http://172.16.4.90:3000/api/projects"
|
||||||
|
|
||||||
|
# 3. Pre-created project (playbooks are stored in git repository and configured through templates 7 variables)
|
||||||
|
# Sample is here https://gitlab.chiefsoft.net/MERMS/AnsibleTest
|
||||||
|
export PROJECT_ID=8
|
||||||
|
|
||||||
|
# 4. Lauch task
|
||||||
|
curl -XPOST \
|
||||||
|
-H 'Content-Type: application/json' -H 'Accept: application/json' -H 'Authorization: Bearer '$TOKEN \
|
||||||
|
-d '{"template_id": 1, "debug": false, "dry_run": false, "playbook": "23607_devprov_mermsemr_com.yml", "environment": "{}"}' \
|
||||||
|
"http://172.16.4.90:3000/api/project/$PROJECT_ID/tasks" > task.txt
|
||||||
|
|
||||||
|
export TASK_ID=`cat task.txt | jq .id | xargs echo`
|
||||||
|
echo "Task queued ID: $TASK_ID"
|
||||||
|
|
||||||
|
# 5. Check task status
|
||||||
|
# need to loop here until it is finished while it is "waiting" and it turns either to "success" or "error"
|
||||||
|
curl \
|
||||||
|
-H 'Content-Type: application/json' -H 'Accept: application/json' -H "Authorization: Bearer $TOKEN" \
|
||||||
|
"http://172.16.4.90:3000/api/project/$PROJECT_ID/tasks/$TASK_ID" > status.txt
|
||||||
|
|
||||||
|
export STATUS=`cat status.txt | jq .status | xargs echo`
|
||||||
|
echo "Task status is: $STATUS"
|
||||||
|
|
||||||
|
# 6. Get output
|
||||||
|
curl \
|
||||||
|
-H 'Content-Type: application/json' -H 'Accept: application/json' -H "Authorization: Bearer $TOKEN" \
|
||||||
|
"http://172.16.4.90:3000/api/project/$PROJECT_ID/tasks/$TASK_ID/output"
|
||||||
|
|
||||||
|
# 7. Expire token
|
||||||
|
curl -XDELETE \
|
||||||
|
-H 'Content-Type: application/json' -H 'Accept: application/json' -H "Authorization: Bearer $TOKEN" \
|
||||||
|
"http://172.16.4.90:3000/api/user/tokens/$TOKEN"
|
||||||
|
|
||||||
|
|
||||||
|
# 8. Logout
|
||||||
|
curl -c /tmp/semaphore-cookie -XPOST \
|
||||||
|
-H 'Content-Type: application/json' -H 'Accept: application/json' \
|
||||||
|
"http://172.16.4.90:3000/api/auth/logout"
|
||||||
@@ -9,3 +9,4 @@ $routes->get('/', 'Home::index');
|
|||||||
|
|
||||||
$routes->get('/provision/prepare', 'Provision::prepareProvision');
|
$routes->get('/provision/prepare', 'Provision::prepareProvision');
|
||||||
$routes->get('/provision/update', 'Provision::updateProvision');
|
$routes->get('/provision/update', 'Provision::updateProvision');
|
||||||
|
$routes->get('/provision/release', 'Provision::releaseProvision');
|
||||||
|
|||||||
@@ -33,9 +33,9 @@ class Provision extends BaseController
|
|||||||
];
|
];
|
||||||
foreach ($provArrv as $svv){
|
foreach ($provArrv as $svv){
|
||||||
$tgt = $ansible_folder = str_replace(".", "_", $svv).".yml";
|
$tgt = $ansible_folder = str_replace(".", "_", $svv).".yml";
|
||||||
// $this->runAnsibleShell($tgt);
|
$this->runAnsibleShell("/var/www/html/ANSIBLE/".$tgt);
|
||||||
}
|
}
|
||||||
// $this->runAnsibleShell('94099_devprov_mermsemr_com.yml');
|
// $this->runAnsibleShell('/var/www/html/ANSIBLE/94099_devprov_mermsemr_com.yml');
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@@ -239,6 +239,19 @@ class Provision extends BaseController
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function releaseProvision(){
|
||||||
|
// Use ls command with shell_exec function
|
||||||
|
$output = shell_exec('ls -alt /var/www/html/ANSIBLE/');
|
||||||
|
|
||||||
|
// Display the list of all files and directories
|
||||||
|
echo "<pre>$output</pre>";
|
||||||
|
|
||||||
|
$shellCommand ="/var/www/html/ANSIBLE/auto_play.sh ";
|
||||||
|
log_message('critical', $shellCommand);
|
||||||
|
$output = shell_exec($shellCommand );
|
||||||
|
var_dump($output);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
public function runAnsibleShell($provisionFile){
|
public function runAnsibleShell($provisionFile){
|
||||||
try{
|
try{
|
||||||
log_message('critical', "***** ***** Provision :: runAnsibleShell($provisionFile) ");
|
log_message('critical', "***** ***** Provision :: runAnsibleShell($provisionFile) ");
|
||||||
|
|||||||
Reference in New Issue
Block a user