configurar do samba e pureftpd

Publicado por Robert Willian 15/10/2005

[ Hits: 7.923 ]

Download scriptconf_v38.sh




configura o samba como PDC ou nao da rede com varias opções de gerenciamento, para pure gerencia usuarios e o serviço...
obs: meu primeiro script publicado ..... :-)

  



Esconder código-fonte

#!/bin/bash
# Script escrito por Robert Willian Gil
#
#   Para uso com PureFtpd compilar o pacotes com a opcao
#   --with-everything , e ao executar pela primeira vez
#   o scritp comecar com a opcao 3 depois a opcao 2 e
#   por ultimo a opcao 1 para iniciar o servico.
#   Para iniciar o servico junto com o sistema na
#   inicializacao, gerar o rc.pureftpd usando a opcao
#   numero 8 no menu do pureftpd e que vai gerar
#   o arquivo /etc/rc.d/rc.pureftpd e inserir uma entrada
#   no rc.local para executar o mesmo.
#   editar o arquivo gerado e fazer algumas configuracoes
#   necessarias.
#   EX:
#   no arquivo rc.local:
#
#      /etc/rc.d/rc.pureftpd      #isso o fara executar no inicializacao
#
#      Padrao:      /etc/rc.d/rc.pureftpd

#         Para configurar as estacoes seguir procedimentos 
#         descritos em tutos espalhados ne net.
menuprogramas () {
clear
echo "                       ### Menu Principal ###"
echo "         Opcoes de programas a configurar usando este script. "
echo
echo "         1. Samba"
echo "         2. PureFTP"
echo "         3. Acertar Horas e Data"
echo "         4. Sair do script"
echo
echo -n "      Escolha a Opcao.  =>  "
read programa
case "$programa" in
    1 ) esambamenu ;;
    2 ) epureftpmenu ;;
    3 ) fdata ;;
    4 ) clear && exit ;;
    * ) clear ; echo ; echo ; echo ; echo ; echo "          [ "$programa" ] opssao invalida! Entre com uma opcao valida!" ; sleep 3 && echo "" ; echo ""  && clear && menuprogramas
esac
}
fdata () {
   read -n 2 -p "      HH:MM  => " hrs
   read -n 2 -p ":" min
   echo
   read -n 2 -p "      DD/MM/AAAA  =>  " dia
   read -n 2 -p "/" mes
   read -n 4 -p "/" ano
   echo
   echo -n "      "
   date $mes$dia$hrs$min$ano
   clock -w
}
#########    Aqui comeca o script do samba   #########

esambamenu () {
esamba () {
echo "                       ### Menu Principal Samba ###"
echo
echo "           1. Gerar smb.conf em /etc/samba/"
echo "           2. Adicionar Compartilhamentos."
echo "           3. Adicionar Maquinas."
echo "           4. Adicionar Usuarios."  
echo "           5. Adicionar Usuario root no samba."
echo "           6. Excluir Maquinas."
echo "           7. Excluir Usuarios."
echo "           8. Reiniciar o servico."
echo "           9. Sair do script"
echo "           10. Voltar ao Menu Programas"
echo 
echo -n "      Escolha a Opcao.  =>  "
read opssao
case "$opssao" in
    1 ) mkdirsamba ;;
    2 ) settingsshare ;;
    3 ) addmaquinas ;;
    4 ) addusers ;;
    5 ) smbpasswd -a root && sleep 1 &&  echo "Usuario root Criado" ;;
    6 ) removemaquinas ;;
    7 ) removeusers ;;
    8 ) killsmb ;;
    9 ) clear && exit ;;
    10 ) clear && menuprogramas ;;
    * ) clear ; echo ; echo ; echo ; echo ; echo "          [ "$opssao" ] opssao invalida! Entre com uma opcao valida!" ; sleep 2 && echo "" ; echo ""  && clear && esamba
esac
}
killsmb () {
   echo "         Finalizando o Samba"
   killall smbd
   killall nmbd
   sleep 1
   echo "         Iniciando o Samba"
   smbd && nmbd
   sleep 1
   echo "         Servico Iniciado!"
}
mkdirsamba (){
   if [ -e /etc/samba ]
   then
   echo "      O arquivo /etc/samba/smb.conf e /etc/samba/smbpasswd"
   echo "      ja existem! Com a nova geracao os arquivos existentes serao "
   echo -n "      APAGADOS ! Deseja continuar ? Yes/No Enter = Yes  = "
   read jaexistecheck
   if [ -z "$jaexistecheck" ] ; then
      jaexiste="Yes"
   else
      jaexiste="$jaexistecheck"
   fi     
   case "$jaexiste" in
    Yes ) settings ;;
    No  ) exit ;;
    * ) clear ; echo ; echo ; echo ; echo ; echo "          [ "$jaexiste" ] opssao invalida! Entre com uma opcao valida!  Yes/No " ; sleep 3 && echo "" ; echo ""  && clear && mkdirsamba
esac
   else
   echo "      A pasta /etc/samba nao exite" && echo "      Criando a pasta /etc/samba" && sleep 2 && mkdir /etc/samba && echo "      Pasta Criada!" && settings
   fi }
gerasamba () {
echo "[global]
        Workgroup   = "$dominio"
        server string = "$nameofserver"
        hosts allow  = "$ips"
        security = "$nivelseg"
        log file = /var/log/samba/log.%m
        max log size = 100
        logon script = %U.bat
        domain logons = "$logonserver"
        os level = 100
        encrypt passwords = Yes
        smb passwd file = /etc/samba/smbpasswd
        preferred master = "$logonserver"
        domain master = "$logonserver"
        local master = "$logonserver"
        netbios name = "$nameofserver"
   printcap name = "$simp1"
   load printers = "$simp2"
   printing = bsd
   
[netlogon]   

        comment = Network Logon Service
        path = /home/netlogon 
        guest ok = Yes
        share modes = No


[profiles]
        comment = Linux PDC
        path = /home/profiles/%U
        read only = No
        create mask = 0700
        profile acls = Yes
        browseable = No
        guest ok = Yes
        locking = No" > /etc/samba/smb.conf && echo "      Gerando smb.conf" && sleep 1 && touch /etc/samba/smbpasswd

   if [ $simp3 = "sim" ] ; then
echo "[printers]
     comment = All Printers
     browseable = no
     guest ok = yes
     public = yes
     printable = yes" >> /etc/samba/smb.conf && echo "      Pronto." && pergunta1
   else
      echo "       Pronto." && pergunta1
   fi      
}
settings (){
echo
echo -n "      Nome do Dominio ou Grupo ?   Enter = Gerencial    =  "
read dominiocheck
if [ -z "$dominiocheck" ] ; then
         dominio="Gerencial"
 else
         dominio="$dominiocheck"
fi
echo -n "      Faixa de IP? Enter = 192.168.200.    =  "
read ipscheck
if [ -z "$ipscheck" ] ;then
   ips="192.168.200."
else
   ips="$ipscheck"
fi
echo -n "      Nome do Servidor?  Enter = SrvLinux     =  "
read nameofservercheck
if [ -z "$nameofservercheck" ] ;then
   nameofserver="SrvLinux"
else
   nameofserver="$nameofservercheck"
fi
echo -n "      Servidor de logon/Dominio ?  Yes / No    Enter = No   =  " 
read logonservercheck
if [ -z "$logonservercheck" ] ; then
   logonserver="No"
else
   logonserver="$logonservercheck"
fi

servimp () {
echo -n "      Path do arquivo printcap.  Enter = /etc/printcap  =  "
read pathprint
if [ -z $pathprint ] ; then
   printcap="/etc/printcap"
else
   printcap="$pathprint"
fi
   simp1="$printcap"
   simp2="Yes"
}   

echo -n "      Servidor de impressao? Yes / No    Enter = Yes  =  "
read checksimp
if [ -z $checksimp ] ; then
   simp3="sim"
   servimp
else
   if [ $checksimp = "Yes" ] ; then
      simp3="sim"
      servimp
   else
      simp1="Not Configured"
      simp2="No"
      simp3="nao"
   fi
fi
echo    "        Nivel de segunç"
echo "         share = Segurança nivel de compartilhamento."
echo "         user = Segurança nivel de servidor, apenas acessarao"
echo "         usuarios autenticados no dominio ou com login e senha."
echo "         Nivel de segurançescolhido?                =  "
echo -n "      user / share?      Enter = share              =  "
read nivelsegcheck
if [ -z "$nivelsegcheck" ] ; then
   nivelseg="share"
else
   nivelseg="$nivelsegcheck"
fi
gerasamba 
}
addshare () {
echo "
["$nameshare"]
        public = yes
        comment = "$comment"
        path = "$patharq"
        create mask = 0777
        writable = "$writable"
        browseable = yes
        guest ok = "$guestok" " >> /etc/samba/smb.conf && echo "         Criando Compartilhamento." && sleep 1 && echo "         Pronto." && pdesliga

}
settingsshare () {
echo -n "         Nome do Compartilhamento?  Enter = Soft   =  "
read namesharecheck
if [ -z "$namesharecheck" ] ; then
   nameshare="Soft"
else
   nameshare="$namesharecheck"
fi
echo  "         Comentario para a pasta. "
echo -n "         Enter = Pasta "$nameshare"   =  "
read commentcheck
if [ -z "$commentcheck" ] ; then
   comment="Pasta $nameshare"
else
   comment="$commentcheck"
fi
echo  "         Path do compartilhamento? "
echo -n "         Enter = /soft             =  "
read patharqcheck
if [ -z "$patharqcheck" ] ; then
   if [ -e /soft ] ; then
      patharq="/soft"
echo "        Nao serao trocadas as permissoes das subpastas, cabendo"
echo "        ao administrador setar permissoes nas devidas pastas."
echo "        Enter para continuar"
read nulo   
      else
      echo "          A pasta /soft nao existe, criando-a"
      mkdir /soft
      chmod 777 /soft -R
      sleep 1 && echo "         Pasta Criada!"
      patharq="/soft"
   fi
else
   if [ -e "$patharqcheck" ] ; then
      patharq="$patharqcheck"
   else
      echo "          A pasta "$patharqcheck" nao existe, criando-a"
      mkdir -p "$patharqcheck"
      chmod 777 $patharqcheck -R
      sleep 1 && echo "          Pasta Criada!"
      patharq="$patharqcheck"
   fi
fi
   
   
echo "         Permitir escrita?  yes/no  "
echo -n "         Enter = yes                =  "
read writablecheck
if [ -z "$writablecheck" ] ; then
   writable="yes"
else
   writable="$writablecheck"
fi
echo "         Permitir guest?  yes/no  "
echo -n "         Enter = yes               =  "
read guestokcheck
if [ -z "$guestokcheck" ] ; then
   guestok="yes"
else
   guestok="$guestokcheck"
fi
addshare
}
pdesliga () {
   echo "         E necessario reiniciar o servico para que as alteracoes"
   echo "         surtam efeito,"
        echo -n "         Deseja reiniciar o samba agora? yes/no    Enter  =  y   =  "
   read pdescheck
   if [ -z "$pdescheck" ] ; then
      pdes="yes"
        else
      pdes="$pdescheck"
        fi
case $pdes in 
   yes ) killsmb ;;
   no ) exit ;;
   * ) echo "       Escolha uma opcao valida" ; sleep 1 && pdesliga
esac
}   
   
pergunta1 () {
echo -n "      Deseja criar compartilhamentos? yes/no   Enter = Yes   =  "
read yesnocheck
if [ -z "$yesnocheck" ] ; then
   yesno="yes"
else
   yesno="$yesnocheck"
fi
case "$yesno" in
 yes ) settingsshare ;;
 no ) pdesliga ;;
 * ) echo "      Digite 'yes' ou 'no'" && sleep 1 && pergunta1
esac
}
addmaquinas () {
echo -n "      Nome da maquina?  =  "
read nomemaquina
useradd -d /dev/null -s /dev/null -m $nomemaquina$
echo -n "      "
smbpasswd -am $nomemaquina$
sleep 1 &&
echo "      Maquina $nomemaquina Criada!"
}
removemaquinas () {
echo -n "      Nome da maquina p/ excluir?  =  "
read nomeexcluir
echo -n "      "
smbpasswd -x $nomeexcluir$
userdel $nomeexcluir$
sleep 1 &&
echo "      Maquina $nomeexcluir excluida!"
}
removeusers () {
echo -n "      Nome do Usuario p/ excluir?  =  "
read nomeexcluiru
echo "             Escolha:                Opcao:"  
echo "      Excluir Apenas do samba.         1"
echo "      Excluir do samba e do linux.     2"
echo -n "      Opcao desejada.  Enter = 2    =  "
read opppcheck
if [ -z $opppcheck ] ; then
   oppp=2
else
   oppp=$opppcheck
fi
if [ $oppp = 1 ] ; then
   echo -n "      "
        smbpasswd -x $nomeexcluiru
else
   echo -n "      "
        smbpasswd -x $nomeexcluiru
   userdel $nomeexcluiru
fi
}


addusers () {
echo -n "      Nome do usuario a adicionar.  =  "
read nomeadd
adduser $nomeadd
smbpasswd -a $nomeadd
}
clear
esamba
}

####### Aqui termina o script do samba   ########

###### Aqui comeca o script do pureftp  ######
epureftpmenu () {
menupure () {
clear
echo "       ###  Menu Principal Pureftp  ### "
echo 
echo "    1. Iniciar o servico."
echo "    2. Adicionar Usuarios."
echo "    3. Adicionar usuarios e grupos padroes."
echo "    4. Deletar Usuario."
echo "    5. Mudar senha de usuarios."
echo "    6. Informacoes sobre usuarios."
echo "    7. Consulta usuarios cadastrados."
echo "    8. Gerar rc.pureftpd"
echo "    9. Sair do Script."
echo "    10. Voltar ao menu programas"
echo
echo -n "      Escolha a opcao  =>  "
read eopssao 
case "$eopssao" in
    1 ) opssoesini ;;
    2 ) checkpdb ;;
    3 ) addpadroes ;;
    4 ) delusuarios ;;
    5 ) changesenha ;;
    6 ) showusuario ;;
    7 ) echo "Usuario: ## Path Home:" ; pure-pw list | more ;;
    8 ) geraini ;;
    9 ) clear && exit ;;
    10 ) clear && menuprogramas ;;
    * ) clear ; echo ; echo ; echo ; echo ; echo "          [ "$eopssao" ] opssao invalida! Entre com uma opcao valida!" ; sleep 3 && echo "" ; echo ""  && clear && menupure
esac
}
addpadroes () {
userdel ftpuser
groupdel ftpgroup
groupadd ftpgroup
useradd -g ftpgroup -d /dev/null -s /etc ftpuser
echo "Digite a Senha do usuario= normal ,senha obrigató."
pure-pw useradd normal -u ftpuser -d /dev/null
echo "Usuario normal adicionado" && sleep 1 && echo "Grupo ftpgroup e Usuario ftpuser ja existentes!" && sleep 3 && menupure
}
opssoesini () {
echo "      Permitir loggin anonimo? "
echo -n "      Y/n  Enter = n             =  "
read logginanonimocheck
if [ -z "$logginanonimocheck" ] ; then
   logginanonimo="n"
else
   logginanonimo="$logginanonimocheck"
fi
if [ "$logginanonimo" = Y ] ; then
   anonimo=
   echo "       Permitindo login anonymous"
   sleep 1
else
   anonimo="--noanonymous"
   echo "      Proibindo login anonymous"
   sleep 1
fi
echo -n "      Limite maximo de usuarios conectados.  Enter = 15   =>  " 
read maxcheck
if [ -z "$maxcheck" ]; then
   maximousuarios=15
   echo "      Permitindo "$maximousuarios" usuario conectados simultaneamente"
        sleep 1
else
   maximousuarios="$maxcheck"
   echo "      Permitindo "$maxcheck" usuarios conectados simultaneamente"
   sleep 1
fi
pure-ftpd --daemonize 
killall pure-ftpd && pure-ftpd --daemonize "$anonimo" -c "$maximousuarios" -lpuredb:/etc/pureftpd.pdb
echo "      ServiçIniciado com sucesso!" && sleep 3 && menupure
}
addusuarios () {
echo -n "      Nome do usuario  =>  "
read nomeuser
echo -n "      Path da pasta base do usuario. Enter = /soft/ftp  =>  "
read pathhomecheck
if [ -z "$pathhomecheck" ] ; then
   pathhome="/soft/ftp"
   if [ ! -e "$pathhome" ] ; then
      mkdir -p "$pathhome"
      echo "      Pasta "$pathhome" nao existe, criando-a"
      sleep 1 && echo "      Home criado!"
      chmod 777 "$pathhome" -R
   else
      chmod 777 "$pathhome" -R
   fi
else
   pathhome="$pathhomecheck"
   if [ ! -e "$pathhomecheck" ] ; then
      mkdir -p "$pathhomecheck"
      echo "      Pasta "$pathhomecheck" nao existe, criando-a"
      sleep 1 && echo "      Home criado!"
      chmod 777 "$pathhomecheck" -R
        else
      chmod 777 "$pathhomecheck" -R
   fi
fi
echo -n "      Quota de espaco no HD? Enter = Ilimitado  =>  "
read quotambcheck
if [ -z "$quotambcheck" ] ; then
   quotamb=
else
   quotamb="-N $quotambcheck"
fi
pure-pw useradd $nomeuser -u ftpuser -d $pathhome $quotamb -m
pure-pw show $nomeuser
}
checkpdb () {
if [ -e /etc/pureftpd.pdb ] ; then
      addusuarios
else
     if [ -e /etc/pureftpd.passwd ] ; then
        echo "      Criando banco de dados de usuarios" && sleep 2 &&  pure-pw mkdb && echo "      Banco Criado!" && sleep 2 &&  addusuarios
     else
        echo "      Ã‰necessario criar usuario e grupos padroes"
        sleep 2
        echo "      No menu principal selecione a opcao 3" 
        sleep 3 && menupure
     fi
fi     
}
delusuarios () {
echo -n "      Nome do usuario a deletar?  =>  "
read morre
pure-pw userdel $morre -m
echo "      Usuario Deletado!"
sleep 2 
menupure
}
changesenha () {
echo -n "      Nome do usuario a mudar a senha.  =>  "
read trocasenha
pure-pw passwd $trocasenha -m
echo "        Senha trocada!"
menupure
}
showusuario () {
echo -n "      Nome do usuario?  =>  "
read nomeshow
pure-pw show $nomeshow
}
clear
menupure
}

function geraini {
echo "#!/bin/bash
#Permitir Login anonimo?  Y / N .  
logginanonimo=Y

#Numero maximo de usuario conectados simultaneamente.
maximousuarios=15

# Nao mexa daqui para baixo !
if [ \"$logginanonimo\" = Y ] ; then
   anonimo=\"\"
else
   anonimo=\"--noanonymous\"
fi
/usr/local/sbin/pure-ftpd --daemonize \"$anonimo\" -c \"$maximousuarios\" -lpuredb:/etc/pureftpd.pdb " > /etc/rc.d/rc.pureftpd
chmod 777 /etc/rc.d/rc.pureftpd
clear
echo "Arquivo gerado com exito em /etc/rc.d/rc.pureftpd" && sleep 2 && menupure
}

### Aqui termina o script do pureftp ###
menuprogramas   # chama o menu principal

Scripts recomendados

Desligando infraestrutura de ITM6

Compilar OpenSSL

Localizar e Matar Processo

Cronometro em shell

Simples inventário de máquinas em Shell Script


  

Comentários

Nenhum comentário foi encontrado.


Contribuir com comentário




Patrocínio

Site hospedado pelo provedor RedeHost.
Linux banner

Destaques

Artigos

Dicas

Tópicos

Top 10 do mês

Scripts