summaryrefslogtreecommitdiffstats
path: root/tools/dev_update_schema.sh
blob: e1d08d60e267e41e2a25126799952df9f9be664d (plain)
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
#!/bin/bash

set -e
set -o pipefail

cd "$(dirname "$0")"

BASEDIR=".."

test "$1" = '-f' || (
	echo "Run  '$0' -f  to DROP ALL ICINGADB TABLES and re-create them using the current schema"
	false
)

set -x

(
	mysql -uroot -e 'SHOW TABLES\G' icingadb </dev/null |\
	( grep -Ee '^Tables_in_icingadb: ' || true ) |\
	cut -d ' ' -f 2 |\
	perl -pe 's/^(.*?)$/DROP TABLE $1;/'

	mysql -uroot -e 'SHOW PROCEDURE STATUS\G' icingadb </dev/null |\
	( grep -Ee '^ *Name: ' || true ) |\
	cut -d ':' -f 2 |\
	perl -pe 's/^ *(.*?)$/DROP PROCEDURE IF EXISTS $1;/'

	cat $BASEDIR/etc/schema/mysql/{,helper/}*.sql

	echo "GRANT ALL ON icingadb.* TO 'icingadb'@'127.0.0.1' IDENTIFIED BY 'icingadb';"
) |mysql -uroot icingadb