mirror of https://framagit.org/kyodev/kyopages.git
getInfo 2.55.0
This commit is contained in:
parent
290273cbfc
commit
fc9e7a490f
248
scripts/getInfo
248
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: <vide> \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=<user> 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 <paquet>"
|
||||
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 )
|
||||
|
|
|
@ -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
|
||||
|
|
Loading…
Reference in New Issue