diff --git a/scripts/getInfo b/scripts/getInfo index dc0edef..1ce039f 100755 --- a/scripts/getInfo +++ b/scripts/getInfo @@ -1,7 +1,7 @@ #!/bin/bash -version=2.54.0 -date="04/12/2017" +version=2.55.0 +date="5/12/2017" projet="simpledeb" contact="IRC freenode ##sdeb ou https://framagit.org/kyodev/kyopages/issues/" script="getInfo" @@ -11,10 +11,10 @@ script="getInfo" # contributeurs: kyodev, saiqui, naguam, agentcobra, amilcar ##### - # détecte system architecture, assign $fu_archi : 32bits, i686 | 64bits, amd64 (x86_64) + # détecte architecture système, assign $fu_archi: 32bits, i686 | 64bits, amd64 (x86_64) # return 1 on unknown architecture # remarque, debian: dpkg --print-architecture affiche i386 -f__architecture(){ # 2/12/2017 spécifique +f__architecture(){ # 2/12/2017 case "$(uname -m)" in amd64 | x86_64 ) fu_archi="64bits, amd64 (x86_64)";; @@ -46,11 +46,11 @@ f__color(){ # 08/10/2017 } # $1=oui|non&[-tx] réponse par défaut & -tx=timeout, $2=message question, return 0 pour oui, 1 pour non -f__dialog_oui_non(){ # 08/10/2017 +f__dialog_oui_non(){ # 5/12/2017 local reply param [[ "$1" =~ -t[0-9]{1,2} ]] && param="$(sed -En 's/.*(-t[0-9]{1,2}).*/\1/p' <<< $1)" - printf "$BLUE$2$STD" - [[ "$1" =~ oui ]] && printf " [O/n] " || printf " [o/N] " + echo -en "$BLUE$2$STD" + [[ "$1" =~ oui ]] && echo -n " [O/n] " || echo -n " [o/N] " if [ "$param" ]; then read -t2 reply else @@ -64,7 +64,9 @@ f__dialog_oui_non(){ # 08/10/2017 } # affichage $1 en rouge, $1++ optionnels en bleu, sortie script sur erreur, log $1 si $opType=upgrade -f__error(){ # 15/10/2017 +f__error(){ # 4/12/2017 + local depart=1 i + echo -e "\n$RED $script $version, erreur critique: $1 $STD" for (( i=2 ; i<=$# ; i++ )); do echo -e " $BLUE${!i}$STD" @@ -74,18 +76,10 @@ f__error(){ # 15/10/2017 exit 1 } - # conversion human, source ko, $1=nombre à convertir, affiche ko ou Mo ou Go, ! dépendance gawk -f__unit_human(){ # 09/10/2017 - printf "$( gawk ' { - if ( $1<1024 ) {unit="ko"; printf "%d%s", $1, unit; exit} - if ( $1<1024*1024 && $1>=1024 ) {unit="Mo"; printf "%d%s", $1/1024, unit} - else {unit="Go"; printf "%.1f%s", $1/1024/1024, unit} - }' <<< $1 )" -} - # affichage des paramètres en bleu, si $1=raw pas de ligne vide à la fin, si $1=log alors uniquement $2 logué f__info(){ # 15/10/2017 local depart=1 i + if [ "$1" == "raw" ] || [ "$1" == "log" ]; then depart=2; fi [ "$1" == "log" ] && f__log "$(sed -E 's/\\t//;s/\\n// ' <<< $2 | xargs )" for (( i=$depart ; i<=$# ; i++ )); do @@ -95,12 +89,12 @@ f__info(){ # 15/10/2017 } # log spécifique, fichier log limité à 10000 octets, $1 message à loguer -f__log(){ # 27/10/2017 - if [ -w "$fileLogs" ]; then - if [ "$(stat -c %s $fileLogs)" -ge "10000" ]; then - echo "$(date +%Y%m%d\ %H%M%S) $1" &>/dev/null > "$fileLogs" +f__log(){ # 4/12/2017 + if [ -w "$scriptLogs" ]; then + if [ "$(stat -c %s $scriptLogs)" -ge "10000" ]; then + echo "$(date +%Y%m%d\ %H%M%S) $1" &>/dev/null > "$scriptLogs" else - echo "$(date +%Y%m%d\ %H%M%S) $1" &>/dev/null >> "$fileLogs" + echo "$(date +%Y%m%d\ %H%M%S) $1" &>/dev/null >> "$scriptLogs" fi fi } @@ -110,18 +104,19 @@ f__log(){ # 27/10/2017 # si $2=debOnly et si paquets manquants: return 1 et $debOnlyAbsent ( $1=liste paquets ) # si $2=debOnly et si paquets présent: return 0 et $debOnlyPresent ( $1=liste paquets ) # attention priorité $debOnlyAbsent sur $debOnlyPresent -f__requis(){ # 22/11/2017 +f__requis(){ # 4/12/2017 local dependsMissing packagesMissing command package ireq compteur pluriel + unset debOnlyAbsent debOnlyPresent for ireq in $1; do command="$(cut -d '>' -f 1 <<< $ireq)" package="$(cut -d '>' -f 2 <<< $ireq)" if [ "$2" == "debOnly" ]; then - if [ $( f__which dpkg ) ]; then # package only et debian + if type -p "dpkg" &>/dev/null ; then # package only et debian LC_ALL=C dpkg --get-selections | grep -qE "^$package[[:space:]]+install" \ && debOnlyPresent+="$package " || debOnlyAbsent+="$package " fi - elif [ -z $( f__which $command ) ]; then + elif ! type -p "$command" &>/dev/null ; then dependsMissing+="$command " packagesMissing+="$package " fi @@ -143,45 +138,16 @@ f__requis(){ # 22/11/2017 fi } - # $1=rep à scanner [$2=profondeur max|4 défaut] [$3=profondeur encours|0 défaut] - # affichage stdout si $fileOutput non définis, /usr/bin/strings (binutils) requis -f__scandir(){ # 10/11/2017 - [ -d "$1" ] || f__error "erreur sur le répertoire à scanner" - f__requis "strings>binutils" || exit 1 - local repToScan irep rc text prof prof_max tempo - [ "${1: -1}" == "/" ] && repToScan="$1" || repToScan="$1/" # ajout / final si besoin - [ "$2" ] && prof_max="$2" || prof_max=4 # profondeur max par défaut si besoin - [ "$3" ] && prof=$3 || prof=0 # initialisation compteur profondeur en cours si nécessaire (début) - text="répertoire: $repToScan \n" - for irep in $(ls $repToScan); do # contenu du répertoire - prof=$(( $prof+1 )) # niveau++ - if [ -d "$repToScan$irep" ]; then # si c'est un répertoire - # si compteur niveau <= max, scandir, sinon suivant dans la boucle - [ "$prof" -le "$prof_max" ] && f__scandir "$repToScan$irep/" "$prof_max" "$prof" || continue - else # si c'est pas un répertoire - if [ ! -r "$repToScan$irep" ]; then # si fichier non lisible (read) - text+="$repToScan$irep : inaccessible en lecture \n" - continue # suivant dans la boucle - fi - # traitements fichier - [[ "$irep" == "uevent" || "$irep" == "modalias" ]] && rc=" \n" || unset rc - tempo="$(strings -aw -n1 $repToScan$irep)" # au moins 1 caractère, inclus white space, all tout le fichier - [ "$tempo" ] && text+="$irep: $rc$tempo \n" || text+="$irep: \n" - fi - prof=$(( prof-1 )) # niveau-- - done - [ "$fileOutput" ] && echo -e "$text" >> "$fileOutput" # sauvegarde dans fichier si $fileOutput défini - [ "$fileOutput" ] || echo -e "$text" # affichage si $fileOutput non défini -} + # $1=cmd si $2: nb de tentatives pour s'identifier, sinon 2 tentatives par défaut, suppose bash existant +f__sudo(){ # 4/12/2017 + local nb=2 sudo isudo toBash - # $1=cmd si $2: nb de tentatives pour s'identifier, sinon 2 tentatives par défaut -f__sudo(){ # 22/10/2017 - local nb=2 sudo isudo + [ $( type -p bash 2>/dev/null ) ] && toBash="$( type -p bash )" || return 2 # sudo --shell bash équivalent su ? if sudo -v &>/dev/null && [ $EUID -ne 0 ] ; then - sudo="sudo su --shell $(f__which bash) --preserve-environment -c " + sudo="sudo su --shell $toBash --preserve-environment -c " else - sudo="su --shell $(f__which bash) --preserve-environment -c " + sudo="su --shell $toBash --preserve-environment -c " fi [ "$2" ] && nb="$2" for (( isudo=1 ; isudo<="$nb" ; isudo++ )); do @@ -191,11 +157,21 @@ f__sudo(){ # 22/10/2017 done } + # conversion human, source ko, $1=nombre à convertir, affiche ko ou Mo ou Go, ! dépendance gawk +f__unit_human(){ # 5/12/2017 + echo -n "$( gawk ' { + if ( $1<1024 ) {unit="ko"; printf "%d%s", $1, unit; exit} + if ( $1<1024*1024 && $1>=1024 ) {unit="Mo"; printf "%d%s", $1/1024, unit} + else {unit="Go"; printf "%.1f%s", $1/1024/1024, unit} + }' <<< $1 )" +} + # user ayant initié la session graphique, assigne $fu_user # return 1 sur échec identification user, return 2 sur absence home/ # gestion variable environnement user avec: USER_INSTALL= script f__user(){ # 3/12/2017 local user userid test root_login + root_login="$(grep ':0:' /etc/passwd | cut -d':' -f1)" || root_login="root" if [ "$USER_INSTALL" ]; then # user via variable environnement, moyen d'injecter root si pb fu_user="$USER_INSTALL"; @@ -245,33 +221,34 @@ f__wcv(){ # 09/11/2017 [ "$1" == "-wv" ] && echo "$2" | grep -o "$3" | grep -c . } - # test wget, $1 url à tester, sortie du script si $1 seul (même si url testée ok) - # si $2=print affiche url testée & entêtes http & location (si présente) et sortie normale fonction - # si $2=loc affiche seulement location et sortie normale fonction - # si $2=test return 0 si ok, return 1 si ko -f__wget_test(){ # 28/11/2017 + # test wget, $1=url à tester, sortie du script (même si url testée ok) avec affichage erreur ou ok + # si $2=print affiche url testée & entêtes http & location, return 0 + # si $2=loc affiche seulement location, return 0 + # si $2=test return 0 si ok, return 1 si KO +f__wget_test(){ # 5/12/2017 local file_test_wget retourWget retourHttp location + file_test_wget="/tmp/testWget-$$-$RANDOM" wget -Sq --timeout=10 --user-agent="$user_agent" --spider --save-headers "$1" &>"$file_test_wget" retourWget="$?" - [ "$retourWget" == 1 ] && retourWget="code erreur générique" - [ "$retourWget" == 2 ] && retourWget="parse erreur (ligne de commande?)" - [ "$retourWget" == 3 ] && retourWget="erreur Entrée/sortie fichier" - [ "$retourWget" == 4 ] && retourWget="défaut réseau" - [ "$retourWget" == 5 ] && retourWget="défaut vérification SSL" - [ "$retourWget" == 6 ] && retourWget="défaut authentification" - [ "$retourWget" == 7 ] && retourWget="erreur de protocole" - [ "$retourWget" == 8 ] && retourWget="réponse serveur en erreur" - retourHttp="$(grep -i 'HTTP/' "$file_test_wget" | tr -d '\n' | xargs)" + [ "$retourWget" == 1 ] && retourWget="1: code erreur générique" + [ "$retourWget" == 2 ] && retourWget="2: parse erreur (ligne de commande?)" + [ "$retourWget" == 3 ] && retourWget="3: erreur Entrée/sortie fichier" + [ "$retourWget" == 4 ] && retourWget="4: défaut réseau" + [ "$retourWget" == 5 ] && retourWget="5: défaut vérification SSL" + [ "$retourWget" == 6 ] && retourWget="6: défaut authentification" + [ "$retourWget" == 7 ] && retourWget="7: erreur de protocole" + [ "$retourWget" == 8 ] && retourWget="8: réponse serveur en erreur" + retourHttp="$( grep -i 'HTTP/' "$file_test_wget" | tr -d '\n' | xargs )" + location="$( grep -i 'location' $file_test_wget | xargs )" if [ "$2" == "test" ]; then rm "$file_test_wget" 2>/dev/null - # spécial maintenance frama.link - [ "$(grep -c '303' <<< $retourHttp)" -ne 0 ] && return 1 # 303 See Other + # spécial maintenance frama.link, pas de redirection sur page status framalink + [ "$( grep -c '303' <<< $retourHttp )" -ne 0 ] && return 1 # 303 See Other [ "$retourWget" == "0" ] && return 0 || return 1 fi - location="$(grep -i 'location' $file_test_wget | xargs)" if [ "$2" == "print" ]; then - if [ "$retourWget" ]; then + if [ "$retourWget" != "0" ]; then echo "erreur wget: $RED$retourWget" echo -e "$BLUE $1$STD\t$RED $retourHttp" else @@ -279,14 +256,15 @@ f__wget_test(){ # 28/11/2017 fi fi if [ "$2" == "print" ] || [ "$2" == "loc" ]; then - [ "$location" ] && echo "$YELLOW $location" || echo "$YELLOW no location" + [ "$location" ] && echo -n "$YELLOW $location" || echo -n "$YELLOW no location" echo "$STD" + rm "$file_test_wget" 2>/dev/null return 0 fi - if [ "$retourWget" ]; then - rm "$file_test_wget" - f__error "wget, $retourWget" "$1" "$YELLOW$retourHttp" "$location" -# echo -e "$RED errur wget, $retourWget \n $1 \n $YELLOW$retourHttp \n $location" + if [ "$retourWget" != "0" ]; then + rm "$file_test_wget" 2>/dev/null +# f__error "wget, $retourWget" "$1" "$YELLOW$retourHttp" "$location" + echo -e "$RED erreur wget, $retourWget \n $1 \n $YELLOW$retourHttp \n $location" fi if [ "$(grep -c '200' <<< $retourHttp)" -ne 0 ]; then echo -e "$GREEN\ntout est ok, réessayer\n$STD" @@ -308,7 +286,7 @@ f__which(){ # 27/11/2017 f_affichage(){ # 2/12/2017 f__color - affichage_text=" _ ___ __ + local affichage_text=" _ ___ __ __ _ ___| |_|_ _|_ __ / _| ___ / _' |/ _ \ __|| || '_ \| |_ / _ \ | (_| | __/ |_ | || | | | _| (_) | @@ -433,24 +411,6 @@ f_dspl_md(){ # 3/12/2017 echo -e "$display2" } - # $1 répertoire à scanner, $2 profondeur -f_dspl_scandir(){ # 21/10/2017 - [ "$text" ] && echo -e "$text" >> "$fileOutput" # flush avant fonction - unset text - local text - text="\`$1 $2\` \n" - text+='``` \n' - echo -e "$text" >> "$fileOutput" # flush avant scandir - unset text - if [ -d "$1" ]; then - f__scandir $1 $2 - else - text="$1 inexistant \n" - fi - text+='``` \n' - echo -e "$text" >> "$fileOutput" # flush fonction -} - # $1=liste fichier(s) à grepper, [$2]: N &| nofile &| novide &| ligneVide &| date &| commentXY # si aucun fichier dans la liste retour: 'nofile|vide|inexistant' # /!\ protéger les chemins avec " (surtout si plusieurs chemins ou joker) @@ -661,11 +621,11 @@ fi_batt(){ # 1/12/2017 } # [$1=silent] (pas d'affichage), assigne $fe_nb_bluez, $fe_cards_bluez -fi_bluez(){ # 1/12/2017 +fi_bluez(){ # 4/12/2017 local bluez cmd_bluez cmt_bluez mod cmd_mod cmt_mod srch_mod pluriel text local alert_na - if [ "$( f__which hciconfig )" ]; then + if [ $( f__which hciconfig ) ]; then fe_nb_bluez=$( hciconfig name 2>/dev/null ) || alert_na="PB" # stck tempo du retour hciconfig fe_cards_bluez=$( grep -Eo '^hci[0-9]+' <<< $fe_nb_bluez ) fe_nb_bluez=$( grep -c '^hci[0-9].*$' <<< $fe_nb_bluez ) @@ -1473,7 +1433,7 @@ fi_packagers(){ #v2 23/11/2017 fi } -fi_pkg_apt(){ #v3 3/12/2017 +fi_pkg_apt(){ #v3 5/12/2017 local dateMaj nb_packages ifile info_update text pluriel local sources cmt_sources cmd_sources local apt_v apt_version apt_prefs cmt_apt_prefs cmd_apt_prefs @@ -1558,7 +1518,7 @@ fi_pkg_apt(){ #v3 3/12/2017 alert_httpredir="ces urls sont obsolètes, préférer http://deb.debian.org/ ou un miroir local: \n\n" alert_httpredir+="$(grep 'httpredir' <<< "$sources")" fi - printf "◇" + echo -n "◇" # extraction qte ugrade, full-upgrade stck_upgd=$( LC_ALL=C apt-get upgrade --simulate 2>/dev/null ) # $1 upgraded, $6 to remove, $10 not upgraded # => qte_upgradable [0]=upgraded, [1]=notUpgraded @@ -1588,11 +1548,11 @@ fi_pkg_apt(){ #v3 3/12/2017 cmt_notUpgraded="${qte_upgradable[1]} paquet"$pluriel" nécessitant une mise à jour profonde)" alert_full_upgrade="ces paquets peuvent être mis à jour avec avec: **apt full-upgrade**" fi - printf "◇" + echo -n "◇" # autoremove toRemove=$( LC_ALL=C apt-get autoremove --simulate | grep -E 'Remv | newly installed' ) toRemove=$( sort <<< $toRemove ) - qte_toRemove=$( gawk '/ newly installed/{printf $6}' <<< $toRemove ) + qte_toRemove=$( gawk '/ newly installed/{ printf $6 }' <<< $toRemove ) toRemove=$( sed '/newly/d' <<< "$toRemove" ) # suppression ligne état [ "$qte_toRemove" -gt 1 ] && pluriel="s" || unset pluriel cmt_toRemove="$qte_toRemove paquet"$pluriel" inutile"$pluriel @@ -1607,7 +1567,7 @@ fi_pkg_apt(){ #v3 3/12/2017 alert_remove+="ou les installer manuellement avec apt install " fi # autoclean - printf "◇" + echo -n "◇" autoclean=$( grep '^Del' <<< $( LC_ALL=C apt-get autoclean --simulate 2>/dev/null ) ) qte_autoclean=$( f__wcv -l "$autoclean" ) [ "$qte_autoclean" -gt 1 ] && pluriel="s" || unset pluriel @@ -1637,7 +1597,7 @@ fi_pkg_apt(){ #v3 3/12/2017 fi # paquet non ^ii non_ii=$( LC_ALL=C dpkg -l | gawk 'FNR>5 && ! /^i/ { - printf "%-3s %-20s %-12s",$1,$2,$3; $1=$2=$3=$4=""; printf "%s \n",$0}' ) + printf "%-3s %-20s %-12s",$1,$2,$3; $1=$2=$3=$4=""; printf "%s \n",$0 }' ) qte_non_ii=$( f__wcv -l "$non_ii" ) [ "$qte_non_ii" -gt 1 ] && pluriel="s" || unset pluriel cmt_non_ii="$qte_non_ii paquet"$pluriel" dans un état non standard (^ii)" @@ -3568,8 +3528,9 @@ fipaste_curl_markdownshare(){ # à tester/finir } # inscription dans tache upgrade en anacron hebdomadaire, via cron horaire, $1=upgrade|install|remove -fscript_cronAnacron(){ # 2/12/2017 +fscript_cronAnacron(){ # 4/12/2017 local dirAnacron dirSpool fileAnacron + [ "$(type -t fscript_cronAnacron_special)" ] && fscript_cronAnacron_special # test, si fonction spécifique, appel dirAnacron="/home/$fu_user/.config/anacron" dirSpool="$dirAnacron/spool" @@ -3579,10 +3540,10 @@ fscript_cronAnacron(){ # 2/12/2017 install | upgrade ) mkdir -p "$dirAnacron" # table anacron - echo "7 10 $script nice $fileInstall --upgrade 1>/dev/null" > "$fileAnacron" # juste erreurs en syslog + echo "7 10 $script nice $scriptInstall --upgrade 1>/dev/null" > "$fileAnacron" # juste erreurs en syslog ## anacron journalier pour dev logname if [ -e "$fileDev" ]; then - echo "1 00 $script""Dev nice $fileInstall --upgrade 1>/dev/null" >> "$fileAnacron" + echo "1 00 $script""Dev nice $scriptInstall --upgrade 1>/dev/null" >> "$fileAnacron" fi # création spool anacron utilisateur mkdir -p "$dirSpool" @@ -3603,26 +3564,26 @@ fscript_cronAnacron(){ # 2/12/2017 } # version script en ligne, [$1=update], assigne $versionScript, $script_aJour=ok|ko -fscript_get_version(){ # 06/11/2017 +fscript_get_version(){ # 5/12/2017 local var_temp - f__info "raw" "$GREEN""version script en cours: $version" + + f__info "raw" "version script en cours: $GREEN$version" versionScript=$(wget -q --timeout=15 -O - "$urlScript" | grep -m1 '^version=' | cut -d'=' -f2) if [ "$versionScript" ]; then if [ "$version" != "$versionScript" ]; then - [ "$1" = "update" ] && var_temp=", mise à jour en cours" - [ "$1" = "update" ] || var_temp=", mise à jour possible" + [ "$1" == "update" ] && var_temp=", mise à jour en cours" || var_temp=", mise à jour possible" script_aJour="ko" else script_aJour="ok" fi - f__info "version script en ligne: $versionScript$var_temp" + f__info "version script en ligne: $YELLOW$versionScript$BLUE$var_temp" else f__info "version script en ligne$RED non accessible" fi } # installation du script dans le système -fscript_install(){ # 2/12/2017 +fscript_install(){ # 4/12/2017 if grep -q 'bin' <<< "$(dirname $0)" ; then f__info "$RED""l'installation dans le système doit se faire depuis un script local $GREEN(./$script -i )" return 1 @@ -3636,26 +3597,26 @@ fscript_install(){ # 2/12/2017 f__requis "wget anacron cron" || exit 1 # install /opt mkdir -p /opt/bin/ - cp -d "$(basename $0)" "$fileInstall" - ln -s "$fileInstall" "/usr/bin/$script" &>/dev/null - chmod 775 "$fileInstall" # rwx rwx r-x, proprio fu_user + cp -d "$(basename $0)" "$scriptInstall" + ln -s "$scriptInstall" "/usr/bin/$script" &>/dev/null + chmod 775 "$scriptInstall" # rwx rwx r-x, proprio fu_user # cron/anacron install fscript_cronAnacron "install" # création fichier log - touch "$fileLogs" - chmod 664 "$fileLogs" # rw- rw- r--, proprio fu_user - chown "$fu_user:" "$fileLogs" "$fileInstall" + touch "$scriptLogs" + chmod 664 "$scriptLogs" # rw- rw- r--, proprio fu_user + chown "$fu_user:" "$scriptLogs" "$scriptInstall" [ -e "$fileDev" ] || rm "$(basename $0)" &>/dev/null ## on efface pas si fileDev (dev) f__info "log" "$script $version installé dans le système." "maintenant, appel du script par: $GREEN$script$BLUE (sans ./)" } # suppression du script dans le système -fscript_remove(){ # 06/11/2017 +fscript_remove(){ # 4/12/2017 if ! grep -q 'bin' <<< "$(dirname $0)" ; then f__info "$RED""cette fonction doit être appelée depuis le script installé dans le système $GREEN($script -r)" return 1 fi - if [ ! -x "$fileInstall" ];then + if [ ! -x "$scriptInstall" ];then f__info "$RED$script n'est pas installé" return 1 fi @@ -3666,7 +3627,7 @@ fscript_remove(){ # 06/11/2017 fi [ "$(type -t fscript_remove_special)" ] && fscript_remove_special # test, si fonction spécifique, appel # suppression de /opt - rm "$fileInstall" &>/dev/null + rm "$scriptInstall" &>/dev/null unlink "/usr/bin/$script" &>/dev/null # cron/anacron remove fscript_cronAnacron "remove" @@ -3674,8 +3635,9 @@ fscript_remove(){ # 06/11/2017 } # mise à jour script si dispo, v2, +update spécifique -fscript_update(){ # 2/11/2017 +fscript_update(){ # 4/12/2017 local dirTemp="/tmp/$script-$RANDOM" + [ $(type -t fscript_update_special) ] && fscript_update_special # test, si fonction spécifique, appel if [ -z "$updateSpecial" ] && ! grep -q 'bin' <<< "$(dirname $0)" ; then f__info "$RED""cette fonction doit être appelée depuis le script installé dans le système $GREEN($script -u)" @@ -3690,9 +3652,9 @@ fscript_update(){ # 2/11/2017 wget -q --tries=2 --timeout=15 -O "$dirTemp/$script" "$urlScript" if [ "$?" != "0" ]; then f__wget_test "$urlScript"; fi if grep -q '#!/bin/bash' "$dirTemp/$script" ; then - cp -d "$dirTemp/$script" "$fileInstall" - chmod 775 "$fileInstall" # rwx rwx r-x, proprio fu_user - chown "$fu_user:" "$fileInstall" + cp -d "$dirTemp/$script" "$scriptInstall" + chmod 775 "$scriptInstall" # rwx rwx r-x, proprio fu_user + chown "$fu_user:" "$scriptInstall" [ -z "$updateSpecial" ] && fscript_cronAnacron "upgrade" f__info "log" "$script mis à jour en version $versionScript $updateSpecial" else @@ -3702,12 +3664,14 @@ fscript_update(){ # 2/11/2017 rm -rf "$dirTemp/" } -prg_init(){ # 2/12/2017 +prg_init(){ # 4/12/2017 + PATH='/usr/sbin:/usr/bin:/sbin:/bin' TERM=xterm IFS_INI="$IFS" IFS=$' \t\n' export PATH TERM IFS + # whereis script retourne vide si installé DIRNAME=$( dirname $0 ) DIRNAME=${DIRNAME#/usr/bin} # suppression /usr/bin éventuel au début ( lien ) @@ -3755,7 +3719,7 @@ prg_init(){ # 2/12/2017 # requis pour fonctionnement programme f__requis "gawk wget ip>iproute2 lspci>pciutils wc>coreutils" || exit 1 - # detect rapide systeme deb pour f_requis debOnly, en attendant mieux + # detect rapide systeme deb [ $( f__which dpkg ) ] && ENV_DEBIAN="oui" } prg_1(){ # début 2/12/2017 @@ -3805,7 +3769,7 @@ prg_3(){ # fin de traitements "vous pouvez le visualiser ultérieurement avec $GREEN$script -l" \ "vous pourrez l'exporter ultérieurement avec $BLUE$script -p" } -prg_menu(){ # 10/10/2017 +prg_menu(){ # 5/12/2017 function display_menu { local centre=50 left=2 larg=60 reply line @@ -3820,17 +3784,15 @@ function display_menu { printf '%.'$larg's' "$2" } - printf " $GREEN$script -h$STD : afficher l'aide \n" + echo -en " $GREEN$script -h$STD : afficher l'aide \n" display_menu "$GREEN$script -c$RED""s$STD : catégorie système" \ "$GREEN$script -c$RED""c$STD : catégorie configuration" display_menu "$GREEN$script -c$RED""r$STD : catégorie réseau" \ "$GREEN$script -c$RED""a$STD : catégorie analyse" echo -e "\n\n les catégories peuvent être cumulées: \n" \ " $GREEN$script -c$RED""sa$STD générera un rapport sur le système & l'analyse" - printf "\n choix des catégories à générer (all pour toutes)? " - tput sc - printf "\n ( ne pas saisir le préfixe $YELLOW-c$STD, all par défaut)" - tput rc + echo -en "\n ( ne pas saisir le préfixe $YELLOW-c$STD, all par défaut)\n" + echo -en "\n choix des catégories à générer (all pour toutes)? " read reply [ "$reply" ] && reply="-c${reply,,}" || reply="all" reply="$(sed 's/-call/all/' <<< $reply)" @@ -3864,9 +3826,9 @@ options="$(sed -E 's/--debug-paste//g; s/-t[0-9]+//g' <<< $options | xargs)" # n # paramètres généraux [ "$pasteDuration" ] || pasteDuration=7 # durée de conservation standard du paste en jours fileOutput="getInfo_rapport.md" -fileLogs="/var/log/sdeb_$script.log" +scriptInstall="/opt/bin/$script" +scriptLogs="/var/log/sdeb_$script.log" fileDev="/opt/bin/fileDev" -fileInstall="/opt/bin/$script" urlScript="https://frama.link/getInfo" urlNotice="https://frama.link/doc-getInfo" # test sur frama.link ok, sinon fallback sur framagit @@ -3961,7 +3923,7 @@ for j in $options; do -us ) opType="upgrade" # log si f__error updateSpecial="update spécial actif" - fileInstall="$(dirname $0)/$script" + scriptInstall="$(dirname $0)/$script" fscript_update exit ;; # upgrade spécial -v | --version ) diff --git a/scripts/getInfo_changelog.md b/scripts/getInfo_changelog.md index 216ee54..55c1a5f 100644 --- a/scripts/getInfo_changelog.md +++ b/scripts/getInfo_changelog.md @@ -1,7 +1,15 @@ # changelog getInfo -## 2.54.0 04/12/2017 +## 2.55.0 5/12/2017 + +* révision: syncro fonctions communes +* révision: f__requis, f__sudo indépendants de f__which +* révision: fscript_cronAnacron, fscript_install, fscript_remove, fscript_update + f__log, renommage $fileInstall $fileLogs +* fix: f__wget_test + +## 2.54.0 03/12/2017 * révision: f-grep_file, révision, nouvelle option * révision: fi_conf, ajout service systemctl