forked from AliceO2Group/InfoLogger
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnewMysql.sh
executable file
·283 lines (236 loc) · 8.12 KB
/
newMysql.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
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
#! /bin/sh
# This script configures infoLogger MySQL DB from scratch
# sylvain.chapeland@cern.ch
# definition of default variables
# they can be overridden when running in automated non-interactive mode
# option i: disable interactive mode
# option a: source a bash script (e.g. to override multiple variables at once)
# option s: evaluate associated argument (e.g. to override a value)
# option f: force re-do all actions
# option q: enable SQL debugging
# defaults assume this script is executed on infoLoggerServer host
# and that DB runs on same node (local connection to db)
IS_INTERACTIVE=1
SQL_ROOT_USER=root
SQL_ROOT_PWD=""
SQL_ROOT_HOST=localhost
# if set, force all actions even if they seem not necessary
FORCE_REDO=0
# if set, SQL queries & output printed
SQL_DEBUG=0
# if set, recreate user accounts unless access to db already ok (existing ones will be deleted, including their privileges)
SQL_RECREATE_USER=1
# where are we running now
HERE=`hostname -f`
# runtime location of infologger DB
INFOLOGGER_DB_HOST=$HERE
# definition of parameters to be configured for various infologger tasks
declare -a EXTRA_CONFIG=(server browser admin);
# section headers in output config file
declare -A EXTRA_CONFIGSECTION
EXTRA_CONFIGSECTION[server]="infoLoggerServer"
EXTRA_CONFIGSECTION[browser]="infoBrowser"
EXTRA_CONFIGSECTION[admin]="admin"
# mysql user name
declare -A EXTRA_USER
EXTRA_USER[server]="infoLoggerServer"
EXTRA_USER[browser]="infoBrowser"
EXTRA_USER[admin]="infoLoggerAdmin"
# mysql user pwd
declare -A EXTRA_PWD
EXTRA_PWD[server]=""
EXTRA_PWD[browser]=""
EXTRA_PWD[admin]=""
# mysql host
declare -A EXTRA_HOST
EXTRA_HOST[server]="localhost"
EXTRA_HOST[browser]="$INFOLOGGER_DB_HOST"
EXTRA_HOST[admin]="$INFOLOGGER_DB_HOST"
# mysql user privileges
declare -A EXTRA_PRIVILEGE
EXTRA_PRIVILEGE[server]="insert"
EXTRA_PRIVILEGE[browser]="select"
EXTRA_PRIVILEGE[admin]="all privileges"
# name of database
INFOLOGGER_DB_NAME=INFOLOGGER
# file where to put (if value is stdout, just print on screen)
INFOLOGGER_CONFIG=stdout
# random password generator
function createPwd {
echo `< /dev/urandom tr -dc A-Za-z0-9 | head -c8`
}
# generate random passwords for all infologger users
for CONFIG in "${EXTRA_CONFIG[@]}"; do
EXTRA_PWD[$CONFIG]=$(createPwd)
done
# an alias for mysql exe, easy to replace for dry run
MYSQL_EXE=mysql
#MYSQL_EXE=echo
# parse command line arguments
while getopts "ia:s:fq" option
do
case $option in
i)
echo "Running non-interactive, automated mode selected"
IS_INTERACTIVE=0
;;
a)
FN=$OPTARG
if [ "$FN" != "" ]; then
echo "Sourcing file '$FN'"
if [ ! -f $FN ]; then
echo "File not found"
exit 1
fi
# load source file to set parameters requested interactively otherwise
# see name of default variables above, for those needing to be changed
source $FN
fi
;;
s)
eval $OPTARG
;;
f)
echo "Force redo all actions"
FORCE_REDO=1
;;
q)
echo "SQL debugging enabled"
SQL_DEBUG=1
;;
esac
done
if [ "$IS_INTERACTIVE" -eq "1" ]; then
# begin interactive part
echo "Configuration of Mysql database for infoLogger"
echo "Please follow instructions. Values in [] are defaults if nothing answered"
echo ""
# Ask which MySQL server to use
read -p "Enter MySQL server host name [$SQL_ROOT_HOST] : " P_SQL_ROOT_HOST
if [ "$P_SQL_ROOT_HOST" != "" ]; then SQL_ROOT_HOST=$P_SQL_ROOT_HOST; fi
# Test if a SQL_ROOT_USER password is defined
mysql -h $SQL_ROOT_HOST -u $SQL_ROOT_USER -e "exit" > /dev/null 2>&1
if [ "$?" = "0" ]; then
echo "No password is defined yet to access MySQL server with mysql user '$SQL_ROOT_USER' on $SQL_ROOT_HOST"
stty -echo
read -p "Enter new password for mysql user '$SQL_ROOT_USER' [leave blank]: " SQL_ROOT_PWD
stty echo
echo
if [ "$SQL_ROOT_PWD" != "" ]; then
stty -echo
read -p "Enter again: " SQL_ROOT_PWD2
stty echo
echo
if [ "$SQL_ROOT_PWD" != "$SQL_ROOT_PWD2" ]; then
echo "Mismatch!"
exit 1
fi
/usr/bin/mysqladmin -h $SQL_ROOT_HOST -u $SQL_ROOT_USER password "$SQL_ROOT_PWD"
echo "Password updated"
# remove empty entries as well
mysql -h $SQL_ROOT_HOST -u $SQL_ROOT_USER -p$SQL_ROOT_PWD -e "DELETE FROM mysql.user WHERE User = ''; \
FLUSH PRIVILEGES;" 2>/dev/null
else
echo "mysql user '$SQL_ROOT_USER' password left blank"
fi
else
stty -echo
read -p "Enter password for mysql user '$SQL_ROOT_USER' : " SQL_ROOT_PWD
stty echo
echo
fi
read -p "Enter a database name for infoLogger logs [$INFOLOGGER_DB_NAME] : " P_INFOLOGGER_DB_NAME
if [ "$P_INFOLOGGER_DB_NAME" != "" ]; then INFOLOGGER_DB_NAME=$P_INFOLOGGER_DB_NAME; fi
read -p "Enter a file name where to save infoLogger configuration [just print on screen] : " P_INFOLOGGER_CONFIG
if [ "$P_INFOLOGGER_CONFIG" != "" ]; then INFOLOGGER_CONFIG=$P_INFOLOGGER_CONFIG; fi
# end interactive part
fi
# define command line password argument
if [ "$SQL_ROOT_PWD" != "" ]; then
SQL_PWD_ARG="-p$SQL_ROOT_PWD"
fi
# try connection
mysql -h $SQL_ROOT_HOST -u $SQL_ROOT_USER $SQL_PWD_ARG -e "exit" 2>/dev/null
if [ "$?" != "0" ]; then
echo "MySQL connection failed"
exit 1
fi
# function to execute SQL command
# arg1: SQL command
# arg2: database name, if any
function mysqlExecute {
if [ "$SQL_DEBUG" -eq "1" ]; then
echo "SQL : $1"
fi
SQLRES=`$MYSQL_EXE -h $SQL_ROOT_HOST -u $SQL_ROOT_USER $SQL_PWD_ARG -B -N -e "$1" $2 2>&1`
RET=$?
if [ "$SQL_DEBUG" -eq "1" ]; then
if [ "$SQLRES" != "" ]; then
echo "$SQLRES"
fi
fi
return $RET
}
echo "Setting up mysql for infoLogger"
CHANGES=0
# Create database
mysqlExecute "quit" $INFOLOGGER_DB_NAME
if [ "$?" != "0" ] || [ "$FORCE_REDO" -eq 1 ]; then
echo "Create database $INFOLOGGER_DB_NAME"
mysqlExecute "create database $INFOLOGGER_DB_NAME"
if [ "$?" != "0" ] && [ "$FORCE_REDO" -eq 0 ]; then
exit
fi
CHANGES=1
else
echo "Database $INFOLOGGER_DB_NAME already exists, skipping database create"
fi
# for mysql8
#PWDOPT="with mysql_native_password"
# Create accounts SQL command
MYSQL_COMMANDS=""
for CONFIG in "${EXTRA_CONFIG[@]}"; do
# check if we can already connect
mysql -u "${EXTRA_USER[$CONFIG]}" -p"${EXTRA_PWD[$CONFIG]}" -B -N -e "quit" $INFOLOGGER_DB_NAME > /dev/null 2>&1
# mysqlExecute "select current_user()"
if [ "$?" == "0" ] && [ "$FORCE_REDO" -eq 0 ]; then
echo "Can already connect as ${EXTRA_USER[$CONFIG]}, skipping user create"
continue
else
CHANGES=1
fi
for QHOST in "%" "localhost" "${HERE}"; do
if [ "$SQL_RECREATE_USER" == "1" ]; then
mysqlExecute "drop user \"${EXTRA_USER[$CONFIG]}\"@\"${QHOST}\";"
mysqlExecute "create user \"${EXTRA_USER[$CONFIG]}\"@\"${QHOST}\";"
mysqlExecute "set password for \"${EXTRA_USER[$CONFIG]}\"@\"${QHOST}\" = PASSWORD(\"${EXTRA_PWD[$CONFIG]}\");"
fi
mysqlExecute "grant ${EXTRA_PRIVILEGE[$CONFIG]} on $INFOLOGGER_DB_NAME.* to \"${EXTRA_USER[$CONFIG]}\"@\"${QHOST}\";"
done
done
echo "MySQL infoLogger accounts created"
if [ "$CHANGES" == "0" ]; then
echo "No changes"
fi
# generate a sample configuration
INFOLOGGER_SAMPLE_CONFIG="# infoLogger configuration file"$'\n'$'\n'
for CONFIG in "${EXTRA_CONFIG[@]}"; do
INFOLOGGER_SAMPLE_CONFIG+="[${EXTRA_CONFIGSECTION[$CONFIG]}]"$'\n'
INFOLOGGER_SAMPLE_CONFIG+="dbUser=${EXTRA_USER[$CONFIG]}"$'\n'
INFOLOGGER_SAMPLE_CONFIG+="dbPassword=${EXTRA_PWD[$CONFIG]}"$'\n'
INFOLOGGER_SAMPLE_CONFIG+="dbHost=${EXTRA_HOST[$CONFIG]}"$'\n'
INFOLOGGER_SAMPLE_CONFIG+="dbName=$INFOLOGGER_DB_NAME"$'\n'
INFOLOGGER_SAMPLE_CONFIG+="serverHost=${HERE}"$'\n'
INFOLOGGER_SAMPLE_CONFIG+=""$'\n'
done
INFOLOGGER_SAMPLE_CONFIG+="[infoLoggerD]"$'\n'
INFOLOGGER_SAMPLE_CONFIG+="serverHost=${HERE}"$'\n'
if [ "$INFOLOGGER_CONFIG" != "" ]; then
if [ "$INFOLOGGER_CONFIG" != "stdout" ]; then
echo "Sample configuration saved to $INFOLOGGER_CONFIG"
echo "$INFOLOGGER_SAMPLE_CONFIG" > $INFOLOGGER_CONFIG
else
echo -e "You may use the following in the infoLogger config files:\n\n"
echo "$INFOLOGGER_SAMPLE_CONFIG"
fi
fi