-
Notifications
You must be signed in to change notification settings - Fork 0
/
changegroup.sh
executable file
·79 lines (57 loc) · 2.48 KB
/
changegroup.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
#!/usr/bin/env bash
# -------------------------------------------
#путь к папкам
FOLDERS="$(dirname $0)/Folders"
DIR_TRASH="$(dirname $0)/Trash"
DIR_ROOT="$(dirname $0)"
# -------------------------------------------
#доступ к базе MySQL
USER="root"
#PASSWD=""
#HOST="10.80.32.116"
PASSWD=""
HOST="127.0.0.1"
# -------------------------------------------
#проверка соединения с базой данных и отмена вывода ошибок
if ! mysql --user=$USER --password=$PASSWD --host=$HOST -e "USE phones" 2>/dev/null; then
echo "The database does not exist."
exit 0
fi
#очищаем массив
unset deps
#заполняем его строками файла deplist
deps=($(cat "$DIR_ROOT/listdep"))
#обход каждого пункта из массива подразделений
for i in ${deps[@]}; do
echo "$i"
#переменную из списка подразделений переводим в название группы
#GROUP=$(echo $i | awk '{print tolower($0)}')
#echo $GROUP
#Пользователи с личными телефонами. Если личный пустой, то служебный
mysql phones --user=$USER --password=$PASSWD --host=$HOST -t -N -e "SELECT IF(cellular IS NULL OR cellular = '', business, cellular), abbr FROM persons LEFT JOIN depart USING (iddep) WHERE abbr = '$i'" 2>/dev/null | (
while read -r line; do
if [ ! -z $(echo $line | awk -F'|' '{print $2}') ]; then
#echo $line
PHONE=$(echo $line | awk -F'|' '{print $2}')
#echo $PHONE
#переменную из списка подразделений переводим в название группы
GROUP=$(echo $i | awk '{print tolower($0)}')
#echo $GROUP
SYSGROUP=$(id -gn $PHONE)
#echo 'ID -GN' $PHONE $ID
if [ "$GROUP" = "$SYSGROUP" ]; then
echo $PHONE 'OK'
else
echo $PHONE 'NO'
echo 'GROUP' $GROUP
echo 'SYSGROUP' $SYSGROUP
#Добавить юзера в группу
usermod -g $GROUP $PHONE
usermod -G "" $PHONE
fi
fi
done
)
done
#после добавления пользователей сбрасываются права
chmod -R 775 $FOLDERS