-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsql-dump-symfony.sh
executable file
·49 lines (41 loc) · 2.05 KB
/
sql-dump-symfony.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
#!/usr/bin/env bash
source "$(dirname "$BASH_SOURCE")/../vendor/Flower7C3/bash-helpers/_base.sh"
## CONFIG
backup_dir_path=${HOME}/backup/
## WELCOME
program_title "SQL dump on Symfony app"
## VARIABLES
_directory="master"
prompt_variable directory "Remote symfony directory (relative to "'${HOME}'" directory)" "$_directory" 1 "$@"
config_file_path=${HOME}/${directory}/app/config/parameters.yml
sql_host=$(sed -n "s/\([ ]\{1,\}\)database_host:\(.*\)/\2/p" $config_file_path | xargs)
if [[ "$sql_host" == "~" || "$sql_host" == "" || "$sql_host" == "null" ]]; then
sql_host='localhost'
fi
sql_port=$(sed -n "s/\([ ]\{1,\}\)database_port:\(.*\)/\2/p" $config_file_path | xargs)
if [[ "$sql_port" == "~" || "$sql_port" == "" || "$sql_port" == "null" ]]; then
sql_port=3306
fi
sql_user=$(sed -n "s/\([ ]\{1,\}\)database_user:\(.*\)/\2/p" $config_file_path | xargs)
if [[ "$sql_user" == "~" || "$sql_user" == "" || "$sql_user" == "null" ]]; then
sql_user='root'
fi
sql_pass=$(sed -n "s/\([ ]\{1,\}\)database_password:\(.*\)/\2/p" $config_file_path | xargs)
if [[ "$sql_pass" == "~" || "$sql_pass" == "" || "$sql_pass" == "null" ]]; then
sql_pass=''
fi
sql_base=$(sed -n "s/\([ ]\{1,\}\)database_name:\(.*\)/\2/p" $config_file_path | xargs)
_export_file_name=${sql_base}-$(date "+%Y%m%d-%H%M%S").sql
prompt_variable export_file_name "Export filename" "$_export_file_name" 2 "$@"
_backup_time=0
prompt_variable backup_time "Backup time (days)" "$_backup_time" 3 "$@"
## PROGRAM
confirm_or_exit "Dump SQL from ${COLOR_QUESTION_H}${sql_user}@${sql_host}/${sql_base}${COLOR_QUESTION_B} base to ${COLOR_QUESTION_H}${export_file_name}${COLOR_QUESTION_B} file?"
printf "${COLOR_INFO_B}Dumping database ${COLOR_INFO} \n"
mkdir -p ${backup_dir_path}
mysqldump --host=${sql_host} --port=${sql_port} --user=${sql_user} --password=${sql_pass} --skip-lock-tables ${sql_base} >${backup_dir_path}${export_file_name}
if [[ $backup_time > 0 ]]; then
printf "${COLOR_NOTICE_B}Clean old backups ${COLOR_NOTICE} \n"
find ${backup_dir_path} -mtime +${backup_time} -exec rm {} \;
fi
print_new_line