2016-10-25 12:09:54 +02:00
|
|
|
#!/bin/bash
|
|
|
|
set -e
|
|
|
|
|
|
|
|
attrs=(
|
|
|
|
harbor_admin_password
|
|
|
|
ldap_url
|
|
|
|
ldap_searchdn
|
|
|
|
ldap_search_pwd
|
|
|
|
ldap_basedn
|
|
|
|
ldap_uid
|
|
|
|
email_server
|
|
|
|
email_server_port
|
|
|
|
email_username
|
|
|
|
email_password
|
|
|
|
email_from
|
|
|
|
email_ssl
|
|
|
|
db_password
|
|
|
|
verify_remote_cert
|
2016-10-31 06:31:11 +01:00
|
|
|
self_registration
|
2016-10-25 12:09:54 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
base_dir="$( cd "$( dirname "${BASH_SOURCE[0]}" )/../" && pwd )"
|
|
|
|
|
|
|
|
#The location of harbor.cfg
|
|
|
|
cfg=$base_dir/harbor/harbor.cfg
|
|
|
|
|
|
|
|
#Format cert and key files
|
|
|
|
function format {
|
|
|
|
file=$1
|
|
|
|
head=$(sed -rn 's/(-+[A-Za-z ]*-+)([^-]*)(-+[A-Za-z ]*-+)/\1/p' $file)
|
|
|
|
body=$(sed -rn 's/(-+[A-Za-z ]*-+)([^-]*)(-+[A-Za-z ]*-+)/\2/p' $file)
|
|
|
|
tail=$(sed -rn 's/(-+[A-Za-z ]*-+)([^-]*)(-+[A-Za-z ]*-+)/\3/p' $file)
|
|
|
|
echo $head > $file
|
|
|
|
echo $body | sed 's/\s\+/\n/g' >> $file
|
|
|
|
echo $tail >> $file
|
|
|
|
}
|
|
|
|
|
|
|
|
#Modify hostname
|
2016-11-10 09:18:13 +01:00
|
|
|
hostname=$(hostname --fqdn) || true
|
|
|
|
if [ -z "$hostname" ]
|
2016-10-25 12:09:54 +02:00
|
|
|
then
|
2016-11-10 09:18:13 +01:00
|
|
|
hostname=$(ip addr show eth0|grep "inet "|tr -s ' '|cut -d ' ' -f 3|cut -d '/' -f 1)
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -n "$hostname" ]
|
|
|
|
then
|
|
|
|
echo "Read hostname/IP: [ hostname/IP - $hostname ]"
|
|
|
|
sed -i -r s/"hostname\s*=\s*.*"/"hostname = $hostname"/ $cfg
|
2016-10-25 12:09:54 +02:00
|
|
|
else
|
2016-11-10 09:18:13 +01:00
|
|
|
echo "Failed to get the hostname/IP"
|
2016-10-25 12:09:54 +02:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
#Handle http/https
|
2016-11-09 07:56:32 +01:00
|
|
|
protocol=http
|
2016-10-25 12:09:54 +02:00
|
|
|
echo "Read attribute using ovfenv: [ ssl_cert ]"
|
|
|
|
ssl_cert=$(ovfenv -k ssl_cert)
|
|
|
|
echo "Read attribute using ovfenv: [ ssl_cert_key ]"
|
|
|
|
ssl_cert_key=$(ovfenv -k ssl_cert_key)
|
|
|
|
if [ -n "$ssl_cert" ] && [ -n "$ssl_cert_key" ]
|
|
|
|
then
|
2016-11-09 07:56:32 +01:00
|
|
|
echo "ssl_cert and ssl_cert_key are set, using HTTPS protocol"
|
|
|
|
protocol=https
|
2016-11-10 09:18:13 +01:00
|
|
|
sed -i -r s%"#?ui_url_protocol\s*=\s*.*"%"ui_url_protocol = $protocol"% $cfg
|
2016-11-09 07:56:32 +01:00
|
|
|
echo $ssl_cert > /data/server.crt
|
|
|
|
format /data/server.crt
|
|
|
|
echo $ssl_cert_key > /data/server.key
|
|
|
|
format /data/server.key
|
2016-10-25 12:09:54 +02:00
|
|
|
else
|
2016-11-09 07:56:32 +01:00
|
|
|
echo "ssl_cert and ssl_cert_key are not set, using HTTP protocol"
|
2016-10-25 12:09:54 +02:00
|
|
|
fi
|
|
|
|
|
|
|
|
for attr in "${attrs[@]}"
|
|
|
|
do
|
|
|
|
echo "Read attribute using ovfenv: [ $attr ]"
|
|
|
|
value=$(ovfenv -k $attr)
|
|
|
|
|
|
|
|
#ldap search password and email password can be null
|
|
|
|
if [ -n "$value" ] || [ "$attr" = "ldap_search_pwd" ] \
|
|
|
|
|| [ "$attr" = "email_password" ]
|
|
|
|
then
|
|
|
|
if [ "$attr" = ldap_search_pwd ] \
|
|
|
|
|| [ "$attr" = email_password ] \
|
|
|
|
|| [ "$attr" = db_password ] \
|
|
|
|
|| [ "$attr" = harbor_admin_password ]
|
|
|
|
then
|
|
|
|
bs=$(echo $value | base64)
|
|
|
|
#value={base64}$bs
|
|
|
|
fi
|
2016-11-10 09:18:13 +01:00
|
|
|
sed -i -r s%"#?$attr\s*=\s*.*"%"$attr = $value"% $cfg
|
2016-10-25 12:09:54 +02:00
|
|
|
fi
|
|
|
|
done
|