|  | #!/bin/bash -x | 
|  | exec > >(tee -i /tmp/"$(basename "$0" .sh)"_"$(date '+%Y-%m-%d_%H-%M-%S')".log) 2>&1 | 
|  |  | 
|  | install_infra () { | 
|  | # DOP config and rundeck files should be created before container start | 
|  | salt -C 'I@devops_portal:config' state.sls devops_portal.config | 
|  | salt -C 'I@rundeck:server' state.sls rundeck.server | 
|  | } | 
|  |  | 
|  | install_services () { | 
|  | # Up containers | 
|  | salt -C 'I@docker:swarm:role:master' state.sls docker.client | 
|  |  | 
|  | # XXX: first run may fails | 
|  | salt -C 'I@postgresql:client' cmd.run 'while true; do if docker service logs postgresql_db | grep "ready to accept"; then break; else sleep 5; fi; done' | 
|  | for i in $(seq 2); do | 
|  | salt -C 'I@postgresql:client' state.sls postgresql.client | 
|  | sleep 10 | 
|  | done | 
|  |  | 
|  | # Rundeck client, jobs, and etc | 
|  | salt -C 'I@rundeck:client' cmd.run 'while true; do curl -sf 172.16.10.254:4440 >/dev/null && break; done' | 
|  | salt -C 'I@rundeck:client' state.sls rundeck.client | 
|  |  | 
|  | # ElasticSearch indicies | 
|  | salt -C 'I@elasticsearch:client' cmd.run 'while true; do curl -sf 172.16.10.254:9200 >/dev/null && break; done' | 
|  | for i in $(seq 3); do | 
|  | salt -C 'I@elasticsearch:client' state.sls elasticsearch.client | 
|  | sleep 10 | 
|  | done | 
|  | } | 
|  |  | 
|  | case "$1" in | 
|  | "infra") | 
|  | install_infra | 
|  | ;; | 
|  | "services") | 
|  | install_services | 
|  | ;; | 
|  | esac |