|
@@ -0,0 +1,208 @@
|
|
1
|
+
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+db_host="localhost";
|
|
10
|
+db_name="cdr";
|
|
11
|
+db_login="admindb";
|
|
12
|
+db_pass="passdb";
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+get_tools=( "mysql" "mysqlcheck" "mysqldump" "pigz" "locale" );
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+email="admin@mydomen.ru";
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+type="month";
|
|
22
|
+num="3";
|
|
23
|
+records="/home/calls";
|
|
24
|
+typerec="mp3";
|
|
25
|
+arh_path="/home/backup/arh";
|
|
26
|
+sw_backup="1";
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+set_lang="0";
|
|
30
|
+flock="/tmp/cleardb_asterisk.lock";
|
|
31
|
+log="/var/log/clear_asterisk-db.log";
|
|
32
|
+cdate="$(date +%c)";
|
|
33
|
+msg_dat=(
|
|
34
|
+ '"Cleanup of the database and call records before the specified period was successful!" "Чистка базы данных и записей звонков до указанного периода выполнена успешно!"'
|
|
35
|
+ '"The script stopped working due to:" "Остановлена работа скрипта по причине:"'
|
|
36
|
+ '"create full backup database and calls before a given period" "создана резервная копия всей базы и записей звонков до заданного периода"'
|
|
37
|
+ '"An error occurred while creating a backup, the cleaning process was stopped." "Ошибка при создании резервной копии, процесс чистки остановлен."'
|
|
38
|
+ '"Found lock file:/tmp/cleardb_asterisk.lock!" "Найден файл блокировки:/tmp/cleardb_asterisk.lock!"'
|
|
39
|
+ '"not found:" "файл не найден:"'
|
|
40
|
+ '"found ok:" "файл найден:"'
|
|
41
|
+ '"process mysqldump failed executed!" "процесс mysqldump не выполнен!"'
|
|
42
|
+ '"no call recording files to save in the database were found!" "файлы записей звонков для сохранения в базе данных не найдены!"'
|
|
43
|
+ '"not found for delete:" "файл для удаления не найден:"'
|
|
44
|
+ '"delete ok:" "файл удален успешно:"'
|
|
45
|
+ '"no call recording files to delete in the database were found!" "файлы записей звонков для удаления в базе данных не найдены!"'
|
|
46
|
+);
|
|
47
|
+report=();
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
|
|
51
|
+function getTools() {
|
|
52
|
+for ((itools=0; itools != ${#get_tools[@]}; itools++))
|
|
53
|
+ do
|
|
54
|
+eval get_${get_tools[$itools]}=$(whereis -b ${get_tools[$itools]}|awk '/^'${get_tools[$itools]}':/{print $2}');
|
|
55
|
+list_tools[${#list_tools[@]}]="$(whereis -b ${get_tools[$itools]}|awk '/^'${get_tools[$itools]}':/{print $2}')";
|
|
56
|
+done
|
|
57
|
+}
|
|
58
|
+
|
|
59
|
+
|
|
60
|
+function langMsg() {
|
|
61
|
+if [[ ! $($get_locale|grep 'LANG='|sed 's/\LANG=//g'|grep 'ru_RU.UTF-8'|wc -m) -eq 0 ]];
|
|
62
|
+ then
|
|
63
|
+ set_lang="0";
|
|
64
|
+ else
|
|
65
|
+ set_lang="1";
|
|
66
|
+fi
|
|
67
|
+for ((ilang=0; ilang != ${#msg_dat[@]}; ilang++))
|
|
68
|
+ do
|
|
69
|
+ eval tmsg="(" $(echo -e ${msg_dat[$ilang]}) ")";
|
|
70
|
+ msg[$ilang]=${tmsg[$set_lang]};
|
|
71
|
+done
|
|
72
|
+}
|
|
73
|
+
|
|
74
|
+
|
|
75
|
+function preTest() {
|
|
76
|
+if [ ! -f $log ];
|
|
77
|
+ then
|
|
78
|
+ touch $log
|
|
79
|
+ else
|
|
80
|
+ :>$log;
|
|
81
|
+fi
|
|
82
|
+if [ ! -f $flock ]
|
|
83
|
+ then
|
|
84
|
+ echo "$cdate">$flock;
|
|
85
|
+ else
|
|
86
|
+ report=();
|
|
87
|
+ report[${#report[@]}]="${msg[1]}";
|
|
88
|
+ report[${#report[@]}]="${msg[4]}";
|
|
89
|
+ smsg;
|
|
90
|
+ exit;
|
|
91
|
+fi
|
|
92
|
+sqlt="use $db_name; select filename FROM cdr WHERE cdr.calldate <= DATE_SUB(NOW(),interval $num $type) and cdr.filename !='none';";
|
|
93
|
+eval fdata="(" $(sudo $get_mysql -h$db_host -u$db_login -p$db_pass -e "$(echo -e $sqlt)"|grep -v filename) ")";
|
|
94
|
+
|
|
95
|
+}
|
|
96
|
+
|
|
97
|
+
|
|
98
|
+function bakData() {
|
|
99
|
+if [ $sw_backup = "1" ];
|
|
100
|
+ then
|
|
101
|
+ if [ ! -d $arh_path ];
|
|
102
|
+ then
|
|
103
|
+ sudo mkdir -p $arh_path/db
|
|
104
|
+ sudo mkdir -p $arh_path/calls
|
|
105
|
+ else
|
|
106
|
+ if [ ! -d $arh_path/db ];
|
|
107
|
+ then
|
|
108
|
+ sudo mkdir -p $arh_path/db;
|
|
109
|
+ fi
|
|
110
|
+ if [ ! -d $arh_path/calls ];
|
|
111
|
+ then
|
|
112
|
+ sudo mkdir -p $arh_path/calls;
|
|
113
|
+ fi
|
|
114
|
+ fi
|
|
115
|
+
|
|
116
|
+ sudo find $arh_path/calls -maxdepth 1 -type 'f' -name "*.$typerec" -exec rm {} \;
|
|
117
|
+ sudo find $arh_path/db -maxdepth 1 -type 'f' -name "*.gz" -exec rm {} \;
|
|
118
|
+
|
|
119
|
+ if sudo $get_mysqldump -h$db_host -u$db_login -p$db_pass $db_name | sudo pigz -c9 > $arh_path/db/$db_name"_"$(date +%d-%m-%y).sql.gz;
|
|
120
|
+ then
|
|
121
|
+ report=();
|
|
122
|
+ report[${#report[@]}]="$cdate clear_asterisk-db.sh: backup database - ok!";
|
|
123
|
+ smsg;
|
|
124
|
+ if [ ${#fdata[@]} != "0" ];
|
|
125
|
+ then
|
|
126
|
+ for ((dbinx=0; dbinx != ${#fdata[@]}; dbinx++))
|
|
127
|
+ do
|
|
128
|
+ if [ -f $records/${fdata[$dbinx]} ];
|
|
129
|
+ then
|
|
130
|
+ echo "${msg[6]}:${fdata[$dbinx]}">>$log;
|
|
131
|
+ sudo cp -f $records/${fdata[$dbinx]} $arh_path/calls/${fdata[$dbinx]};
|
|
132
|
+ else
|
|
133
|
+ echo "${msg[5]}:${fdata[$dbinx]}">>$log;
|
|
134
|
+ fi
|
|
135
|
+ done
|
|
136
|
+ else
|
|
137
|
+ report=();
|
|
138
|
+ report[${#report[@]}]="$cdate clear_asterisk-db.sh:${msg[8]}";
|
|
139
|
+ smsg;
|
|
140
|
+ fi
|
|
141
|
+ else
|
|
142
|
+ report=();
|
|
143
|
+ report[${#report[@]}]="$cdate clear_asterisk-db.sh:${msg[1]} - ${msg[7]}";
|
|
144
|
+ smsg;
|
|
145
|
+ exit;
|
|
146
|
+ fi
|
|
147
|
+fi
|
|
148
|
+clrData;
|
|
149
|
+}
|
|
150
|
+
|
|
151
|
+function clrData() {
|
|
152
|
+sqlt="use $db_name; DELETE FROM cdr WHERE cdr.calldate <= DATE_SUB(NOW(),interval $num $type); OPTIMIZE TABLE cdr;";
|
|
153
|
+sudo $get_mysql -h$db_host -u$db_login -p$db_pass -e "$(echo -e $sqlt)";
|
|
154
|
+
|
|
155
|
+if [ ${#fdata[@]} != "0" ];
|
|
156
|
+ then
|
|
157
|
+ for ((dbinx=0; dbinx != ${#fdata[@]}; dbinx++))
|
|
158
|
+ do
|
|
159
|
+ if [ -f $records/${fdata[$dbinx]} ];
|
|
160
|
+ then
|
|
161
|
+ echo "${msg[10]}:${fdata[$dbinx]}">>$log;
|
|
162
|
+ sudo rm -f $records/${fdata[$dbinx]};
|
|
163
|
+ else
|
|
164
|
+ echo "${msg[9]}:${fdata[$dbinx]}">>$log;
|
|
165
|
+ fi
|
|
166
|
+ done
|
|
167
|
+ else
|
|
168
|
+ report=();
|
|
169
|
+ report[${#report[@]}]="$cdate clear_asterisk-db.sh:${msg[11]}";
|
|
170
|
+ smsg;
|
|
171
|
+fi
|
|
172
|
+lockOff;
|
|
173
|
+}
|
|
174
|
+
|
|
175
|
+
|
|
176
|
+function smsg() {
|
|
177
|
+if [ ${#report[@]} != "0" ];
|
|
178
|
+ then
|
|
179
|
+ for ((rpt_index=0; rpt_index != ${#report[@]}; rpt_index++))
|
|
180
|
+ do
|
|
181
|
+ if [[ "${report[$rpt_index]}" != "" ]];
|
|
182
|
+ then
|
|
183
|
+ echo -e "${report[$rpt_index]}">>$log;
|
|
184
|
+ fi
|
|
185
|
+ done
|
|
186
|
+fi
|
|
187
|
+}
|
|
188
|
+
|
|
189
|
+
|
|
190
|
+function lockOff() {
|
|
191
|
+if [ -f $flock ];
|
|
192
|
+ then
|
|
193
|
+ sudo rm -f $flock;
|
|
194
|
+fi
|
|
195
|
+report=();
|
|
196
|
+report[${#report[@]}]="$cdate clear_asterisk-db.sh:${msg[0]}";
|
|
197
|
+smsg;
|
|
198
|
+sudo cat $log |mail -s "asterisk clear database & records" $email
|
|
199
|
+sudo systemctl restart asterisk;
|
|
200
|
+exit;
|
|
201
|
+}
|
|
202
|
+
|
|
203
|
+langMsg;
|
|
204
|
+getTools;
|
|
205
|
+preTest;
|
|
206
|
+bakData;
|
|
207
|
+
|
|
208
|
+exit;
|