-
Notifications
You must be signed in to change notification settings - Fork 49
/
Copy pathconfigure_chef.sh
executable file
·70 lines (57 loc) · 2.29 KB
/
configure_chef.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
#!/bin/bash
# Create chef-server.rb with variables
echo "nginx['enable_non_ssl']=false" > /etc/opscode/chef-server.rb
if [[ -z $SSL_PORT ]]; then
echo "nginx['ssl_port']=443" >> /etc/opscode/chef-server.rb
else
echo "nginx['ssl_port']=$SSL_PORT" >> /etc/opscode/chef-server.rb
fi
if [[ -z $CONTAINER_NAME ]]; then
echo "nginx['server_name']=\"chef-server\"" >> /etc/opscode/chef-server.rb
else
echo "nginx['server_name']=\"$CONTAINER_NAME\"" >> /etc/opscode/chef-server.rb
fi
echo -e "\nRunning: 'chef-server-ctl reconfigure'. This step will take a few minutes..."
chef-server-ctl reconfigure
URL="http://127.0.0.1:8000/_status"
CODE=1
SECONDS=0
TIMEOUT=60
return=$(curl -sf ${URL})
if [[ -z "$return" ]]; then
echo -e "\nINFO: Chef-Server isn't ready yet!"
echo -e "Blocking until <${URL}> responds...\n"
while [ $CODE -ne 0 ]; do
curl -sf \
--connect-timeout 3 \
--max-time 5 \
--fail \
--silent \
${URL}
CODE=$?
sleep 2
echo -n "."
if [ $SECONDS -ge $TIMEOUT ]; then
echo "$URL is not available after $SECONDS seconds...stopping the script!"
exit 1
fi
done;
fi
echo -e "\n\n$URL is available!\n"
echo -e "\nSetting up admin user and default organization"
chef-server-ctl user-create admin Admin User [email protected] "passwd" --filename /etc/chef/admin.pem
chef-server-ctl org-create my_org "Default organization" --association_user admin --filename /etc/chef/my_org-validator.pem
echo -e "\nRunning: 'chef-server-ctl install chef-manage'"...
chef-server-ctl install chef-manage
echo -e "\nRunning: 'chef-server-ctl reconfigure'"...
chef-server-ctl reconfigure
echo "{ \"error\": \"Please use https:// instead of http:// !\" }" > /var/opt/opscode/nginx/html/500.json
sed -i "s,/503.json;,/503.json;\n error_page 497 =503 /500.json;,g" /var/opt/opscode/nginx/etc/chef_https_lb.conf
sed -i '$i\ location /knife_admin_key.tar.gz {\n default_type application/zip;\n alias /etc/chef/knife_admin_key.tar.gz;\n }' /var/opt/opscode/nginx/etc/chef_https_lb.conf
echo -e "\nCreating tar file with the Knife keys"
cd /etc/chef/ && tar -cvzf knife_admin_key.tar.gz admin.pem my_org-validator.pem
echo -e "\nRestart Nginx..."
chef-server-ctl restart nginx
chef-server-ctl status
touch /root/chef_configured
echo -e "\n\nDone!\n"