This repository has been archived by the owner on Apr 2, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 79
/
Copy pathscript-16.sh
204 lines (185 loc) · 7.83 KB
/
script-16.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
#!/bin/bash
# Autor: Robson Vaamonde
# Site: www.procedimentosemti.com.br
# Facebook: facebook.com/ProcedimentosEmTI
# Facebook: facebook.com/BoraParaPratica
# YouTube: youtube.com/BoraParaPratica
# Data de criação: 31/05/2016
# Data de atualização: 01/10/2018
# Versão: 0.9
# Testado e homologado para a versão do Ubuntu Server 16.04 LTS x64
# Kernel >= 4.4.x
#
# Criação da estrutura de Grupos Globais e Domínio Local.
# Utilizando do comando samba-tool para a criação
# Utilizando arquivo de referência dos grupos
# samba-tool group add
# samba-tool group addmembers
# samba-tool group list -v
# Scope: Domain ou Global
# Type: Security
#
# Utilizar o comando: sudo -i para executar o script
#
# Caminho para o Log do Script-16.sh
LOG="/var/log/script-16.log"
#
# Variável da Data Inicial para calcular tempo de execução do Script
DATAINICIAL=`date +%s`
#
# Validando o ambiente, verificando se o usuário e "root"
USUARIO=`id -u`
UBUNTU=`lsb_release -rs`
KERNEL=`uname -r | cut -d'.' -f1,2`
if [ "$USUARIO" == "0" ]
then
if [ "$UBUNTU" == "16.04" ]
then
if [ "$KERNEL" == "4.4" ]
then
clear
#
GRUPOGLOBAL="conf/group.global"
GRUPOLOCAL="conf/group.local"
MEMBERS="conf/members.group"
#
echo -e "Usuário é `whoami`, continuando a executar o Script-16.sh"
echo
echo -e "Rodando o Script-16.sh em: `date`" > $LOG
echo -e "================================================================================="
echo -e " Criação da estrutura de Grupos"
echo -e "================================================================================="
echo
echo -e "Criação da estrutura de grupos Globais para o servidor: `hostname`"
echo -e "Pressione <Enter> para editar o arquivo: group.global"
read
#Editando o arquivo de grupos globais
vim $GRUPOGLOBAL
echo -e "Arquivo editado com sucesso!!!, pressione <Enter> para continuar com o script"
read
sleep 2
clear
echo -e "Criação da estrutura de grupos Domínio Local para o servidor: `hostname`"
echo -e "Pressione <Enter> para editar o arquivo: group.local"
read
#Editando o arquivo de grupos domínio local
vim $GRUPOLOCAL
echo -e "Arquivo editado com sucesso!!!, pressione <Enter> para continuar com o script"
read
sleep 2
clear
echo -e "Criação da estrutura de Membros de Grupos: `hostname`"
echo -e "Pressione <Enter> para editar o arquivo: members.group"
read
#Editando o arquivo de membro de grupos globais e domínio local
vim $MEMBERS
echo -e "Arquivo editado com sucesso!!!, pressione <Enter> para continuar com o script"
read
sleep 2
clear
echo -e "Pressione <Enter> para criar os Grupos Globais"
read
echo -e "Criação dos Grupos Globais" >> $LOG
#Utilizando o comando gawk (melhor que o cut) para listar o contéudo do arquivo group.global
#Executando o laço de loop com o comando while para acrescentar todos os grupos a base de dados do SAMBA-4 utilizando o comando samba-tool
gawk -F ":" '{ print $2, $3, $4 }' $GRUPOGLOBAL | while read LISTAGG;
do $(echo "/usr/bin/samba-tool group add $LISTAGG --group-scope=Global --group-type=Security") &>> $LOG;
done;
echo
echo -e "Total de Grupos Globais criados: `wc -l $GRUPOGLOBAL | cut -d ' ' -f1`"
echo
echo -e "Grupos criado com sucesso!!!, pressione <Enter> para continuar com o script"
read
sleep 2
clear
echo -e "Pressione <Enter> para criar os Grupos Locais"
read
echo -e "Criação dos Grupos Locais" >> $LOG
#Utilizando o comando gawk (melhor que o cut) para listar o contéudo do arquivo group.locais
#Executando o laço de loop com o comando while para acrescentar todos os grupos a base de dados do SAMBA-4 utilizando o comando samba-tool
gawk -F ":" '{ print $2, $3, $4 }' $GRUPOLOCAL | while read LISTAGL;
do $(echo "/usr/bin/samba-tool group add $LISTAGL --group-scope=Domain --group-type=Security") &>> $LOG;
done;
echo
echo -e "Total de Grupos Globais criados: `wc -l $GRUPOLOCAL | cut -d ' ' -f1`"
echo
echo -e "Grupos criado com sucesso!!!, pressione <Enter> para continuar com o script"
read
sleep 2
clear
echo -e "Pressione <Enter> para associar os Grupos Globais com Locais"
read
echo -e "Associação dos Grupos Globais com Grupos Locais" >> $LOG
#Utilizando o comando gawk (melhor que o cut) para listar o contéudo do arquivo members.group
#Executando o laço de loop com o comando while para associar todos os grupos a base de dados do SAMBA-4 utilizando o comando samba-tool
gawk -F ":" '{ print $2, $3 }' $MEMBERS | while read LISTAMG;
do $(echo "/usr/bin/samba-tool group addmembers $LISTAMG") &>> $LOG;
done;
echo
echo -e "Total de Grupos Associados: `wc -l $MEMBERS | cut -d ' ' -f1`"
echo
echo -e "Associação de grupos feita com sucesso!!!, pressione <Enter> para continuar com o script"
read
sleep 2
clear
echo -e "Pressione <Enter> para listar os Grupos Globais"
read
#Listando todos dos grupos globais utilizando o comando samba-tool com filtro
samba-tool group list -v | grep GG | sort | cat -n
echo
echo -e "Pressione <Enter> para continuar com o script"
read
sleep 2
clear
echo -e "Pressione <Enter> para listar os Grupos Locais"
read
#Listando todos dos grupos domínio local utilizando o comando samba-tool com filtro
samba-tool group list -v | grep ACL | sort | cat -n
echo
echo -e "Pressione <Enter> para continuar com o script"
read
sleep 2
clear
echo -e "Pressione <Enter> para listar os Membros de Grupos"
read
#Utilizando o comando gawk (melhor que o cut) para listar o contéudo do arquivo members.group e criar um arquivo temporario
gawk -F ":" '{ print $2 }' $MEMBERS &>> /tmp/members.group
echo
#Utilizando o comando gawk (melhor que o cut) para listar o contéudo do arquivo members.group e criar um laço de loop para verificar os membros ds grupos e criar um arquivo temporario
gawk -F ":" '{ print $2 }' $MEMBERS | while read LISTAMG;
do $(echo "/usr/bin/samba-tool group listmembers $LISTAMG") &>> /tmp/listmembers;
done;
echo
#Concatenando os arquivos temporários para mostrar o resultado
paste -d' ' /tmp/members.group /tmp/listmembers
echo -e "Pressione <Enter> para continuar com o script"
read
sleep 2
clear
echo -e "Fim do Script-16.sh em: `date`" >> $LOG
echo -e " Finalização da riação da estrutura de Grupos"
echo -e "================================================================================="
echo
# Script para calcular o tempo gasto para a execução do script-16.sh
DATAFINAL=`date +%s`
SOMA=`expr $DATAFINAL - $DATAINICIAL`
RESULTADO=`expr 10800 + $SOMA`
TEMPO=`date -d @$RESULTADO +%H:%M:%S`
echo -e "Tempo gasto para execução do script-16.sh: $TEMPO"
echo -e "Pressione <Enter> para concluir o processo."
read
else
echo -e "Versão do Kernel: $KERNEL não homologada para esse script, versão: >= 4.4 "
echo -e "Pressione <Enter> para finalizar o script"
read
fi
else
echo -e "Distribuição GNU/Linux: `lsb_release -is` não homologada para esse script, versão: $UBUNTU"
echo -e "Pressione <Enter> para finalizar o script"
read
fi
else
echo -e "Usuário não é ROOT, execute o comando com a opção: sudo -i <Enter> depois digite a senha do usuário `whoami`"
echo -e "Pressione <Enter> para finalizar o script"
read
fi