Mise à jour de 'sisr1/40-bash/crsamba8.sh'

This commit is contained in:
ayoub.boullouh 2022-04-11 14:34:53 +02:00
parent 370887a83e
commit 4af134abdf

View File

@ -1,33 +1,32 @@
#!/bin/bash
#crsamba2
#set -e
#set -u
fich=$1
if [[ $# -ne 1 ]] ; then
echo "usage : $0 <fichier>"
exit 1
echo "usage : $0 <fichier>" # si différent de 1 alors on sortira
exit 1
fi
if [[ ! -r "${fich}" ]] ; then
echo "$0 : erreur d'ouverture du fichier ${fich}"
exit 2
if [[ ! -r $1 ]] ; then
echo "$0 : erreur ouverture fichier $1" # ce n'est pas le bon fichier donc on sortira du script
exit 2
fi
fich=$1
while read ligne #lecture du fichier de lignes en lignes
do
while read ligne
do
login=$(echo "${ligne}"|cut -f1 -d':' )
long=$(echo "${ligne}"|cut -f2 -d':')
echo "${login} ${long}"
echo "$ligne" | grep "^#" >> /dev/null && continue #ceci va ignorer les lignes commentés
[[ -z "$ligne" ]] && continue #ceci va ignorer les lignes vides
login=$(echo "${ligne}" |cut -d ':' -f 1) # récupèration du login
nom=$(echo "${ligne}" |cut -d ':' -f 2) # récupèration du nom
getent passwd "${login}" >> /dev/null
if [[ $? -ne 0 ]] ; then
useradd -m -d /home/"${login}" -s /bin/bash -c "${nom}" "${login}"
else
echo "$0 : utilisateur ${login} existant"
fi
done < ${fich}
getent passwd "${login}" >> /dev/null #génération du mot de passe
if [[ $? -ne 0 ]] ; the # si aucun compte est trouvé alors on le crée
sudo useradd --create-home --home-dir /home/"${login}" --shell /bin/bash --comment "${nom}" "${login}" #création de l'utilisateur
mdp=$(pwgen 6 1) # création du mot de passe possédant au moins 6 caracteres
echo "${login}:${mdp}" | chpasswd #le mot de passe a été ajouté à un utilisateur
echo "${login}:${mdp}" >> "${fich}.pwd" #les mots de passes sont stockés dans le fichier users.txt.pwd
else
echo "$0 : user ${login} existant"
fi
done < $fich