-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathcredentials.generate.sh
executable file
·131 lines (108 loc) · 5.44 KB
/
credentials.generate.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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
# Recursive function to check strength of user password
function checkPassword {
# Check to disallow usage of the word password
if [[ "$1" = *"Password"* ]] || [[ "$1" = *"password"* ]]; then
echo "You are not allowed to use a password containing the word password! Please enter another password: "
read -s INITIAL_ADMIN_PASSWORD_PLAIN
checkPassword $INITIAL_ADMIN_PASSWORD_PLAIN
fi
# Check to ensure username is not part of password
if [[ "$1" = *$INITIAL_ADMIN_USER* ]]; then
echo "You are not allowed to include your username in your password! Please enter another password: "
read -s INITIAL_ADMIN_PASSWORD_PLAIN
checkPassword $INITIAL_ADMIN_PASSWORD_PLAIN
fi
# Check to ensure password is a minimum of 8 characters
LEN=${#1}
if [ $LEN -lt 8 ]; then
echo "Your password length is $LEN. It must be at least 8. Try again: "
read -s INITIAL_ADMIN_PASSWORD_PLAIN
checkPassword $INITIAL_ADMIN_PASSWORD_PLAIN
fi
# Check to ensure password contains numerical characters
if [[ $1 =~ [0-9] ]]; then
echo
else
echo "Your password must contain a number. Try again: "
read -s INITIAL_ADMIN_PASSWORD_PLAIN
checkPassword $INITIAL_ADMIN_PASSWORD_PLAIN
fi
echo "Your provided password satisfies the strength criteria."
}
# Function to randomly generate a 16-character password with letters and numbers
function createPassword {
sleep 1
echo "$(date +%s%N | openssl sha256 | awk '{print $2}' | head -c 12)$[ 1000 + $[ RANDOM % 9999 ]]"
}
###############################
if [ -f ./platform.secrets.sh ]; then
echo "Your secrets file already exists, will not re-create..."
else
echo "Creating a new secrets file..."
cp ./platform.secrets.sh.example ./platform.secrets.sh
# Adding commit ID to track version of example secrets file
VERSION_ID=$(git log -1 --format="%H" HEAD platform.secrets.sh.example)
sed -i'' -e "s/###VERSION_ID###/$VERSION_ID/g" platform.secrets.sh
# Check for username, prompt one if not entered and write it to secrets file
if [[ -z $INITIAL_ADMIN_USER ]] || [[ ${INITIAL_ADMIN_USER} = "admin" ]]; then
echo "You have entered an invalid username. Username can not be blank or 'admin'. Please enter a valid username: "
read INITIAL_ADMIN_USER
while [[ -z $INITIAL_ADMIN_USER ]] || [[ ${INITIAL_ADMIN_USER} = "admin" ]]; do
echo "You have entered an invalid username. Username can not be blank or 'admin'. Try again..."
read INITIAL_ADMIN_USER
done
export INITIAL_ADMIN_USER
else
echo "Your user name is $INITIAL_ADMIN_USER"
fi
sed -i'' -e "s/###INITIAL_ADMIN_USER###/$INITIAL_ADMIN_USER/g" platform.secrets.sh
# Generate a random password if user leaves password flag blank
# Else continue checking the input password
if [ -z $INITIAL_ADMIN_PASSWORD_PLAIN ]; then
echo "You have not provided a password. Generating random..."
export INITIAL_ADMIN_PASSWORD_PLAIN=$(createPassword)
echo "Your password is $INITIAL_ADMIN_PASSWORD_PLAIN"
echo "**Please make note of this as you will use this password to log into all the tools**"
else
checkPassword $INITIAL_ADMIN_PASSWORD_PLAIN
fi
sed -i'' -e "s/###INITIAL_ADMIN_PASSWORD_PLAIN###/$INITIAL_ADMIN_PASSWORD_PLAIN/g" platform.secrets.sh
# Generate random passwords for Jenkins, Gitlab, SQL, LDAP Admin and place them in secrets file
echo "Generating random passwords for Jenkins, Gitlab, SQL and LDAP admin..."
PASSWORD_JENKINS=$(createPassword)
sed -i'' -e "s/###PASSWORD_JENKINS_PLAIN###/$PASSWORD_JENKINS/g" platform.secrets.sh
PASSWORD_GITLAB=$(createPassword)
sed -i'' -e "s/###PASSWORD_GITLAB_PLAIN###/$PASSWORD_GITLAB/g" platform.secrets.sh
PASSWORD_POSTGRESQL=$(createPassword)
sed -i'' -e "s/###PASSWORD_POSTGRESQL_PLAIN###/$PASSWORD_POSTGRESQL/g" platform.secrets.sh
PASSWORD_SQL=$(createPassword)
sed -i'' -e "s/###PASSWORD_SQL_PLAIN###/$PASSWORD_SQL/g" platform.secrets.sh
PASSWORD_LDAP=$(createPassword)
sed -i'' -e "s/###LDAP_PWD###/$PASSWORD_LDAP/g" platform.secrets.sh
fi
# Source all the variables that were written to the secrets file
echo "Sourcing variables from platform.secrets.sh file..."
source platform.secrets.sh
# Check the version of the secrets file template
if [[ -z $VERSION_ID ]] || [[ $VERSION_ID != $(git log -1 --format="%H" HEAD platform.secrets.sh.example) ]]; then
echo "ERROR: The version of the secrets file you currently have is not up to date."
echo "Version '$VERSION_ID' does not match '$(git log -1 --format='%H' HEAD platform.secrets.sh.example)'"
echo "Please delete or update the secrets file and then, re-run this credentials generation script."
exit
else
echo "The version of your secrets file is up to date, moving on..."
fi
# Check to make sure the default tokens are not being used
if [ $INITIAL_ADMIN_PASSWORD_PLAIN == "###INITIAL_ADMIN_PASSWORD_PLAIN###" ] || \
[ $PASSWORD_JENKINS == "###PASSWORD_JENKINS_PLAIN###" ] || \
[ $PASSWORD_SQL == "###PASSWORD_SQL_PLAIN###" ] || \
[ $PASSWORD_GITLAB == "###PASSWORD_GITLAB_PLAIN###" ] || \
[ $LDAP_PWD == "###LDAP_PWD###" ]; then
echo "Your passwords are set to the default tokens provided in the example secrets file, this is not allowed."
echo "Delete the platform.secrets.sh file or edit it and then, re-run the credentials.generate.sh script"
exit
fi
# Export the passwords in base64 to be passed in as environment variables for LDAP container
export INITIAL_ADMIN_PASSWORD=$(echo -n $INITIAL_ADMIN_PASSWORD_PLAIN | base64)
export JENKINS_PWD=$(echo -n $PASSWORD_JENKINS | base64)
export GITLAB_PWD=$(echo -n $PASSWORD_GITLAB | base64)