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
|
#!/bin/bash
|
||||||
|
|
||||||
version=2.54.0
|
version=2.55.0
|
||||||
date="04/12/2017"
|
date="5/12/2017"
|
||||||
projet="simpledeb"
|
projet="simpledeb"
|
||||||
contact="IRC freenode ##sdeb ou https://framagit.org/kyodev/kyopages/issues/"
|
contact="IRC freenode ##sdeb ou https://framagit.org/kyodev/kyopages/issues/"
|
||||||
script="getInfo"
|
script="getInfo"
|
||||||
|
@ -11,10 +11,10 @@ script="getInfo"
|
||||||
# contributeurs: kyodev, saiqui, naguam, agentcobra, amilcar
|
# 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
|
# return 1 on unknown architecture
|
||||||
# remarque, debian: dpkg --print-architecture affiche i386
|
# remarque, debian: dpkg --print-architecture affiche i386
|
||||||
f__architecture(){ # 2/12/2017 spécifique
|
f__architecture(){ # 2/12/2017
|
||||||
case "$(uname -m)" in
|
case "$(uname -m)" in
|
||||||
amd64 | x86_64 )
|
amd64 | x86_64 )
|
||||||
fu_archi="64bits, 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
|
# $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
|
local reply param
|
||||||
[[ "$1" =~ -t[0-9]{1,2} ]] && param="$(sed -En 's/.*(-t[0-9]{1,2}).*/\1/p' <<< $1)"
|
[[ "$1" =~ -t[0-9]{1,2} ]] && param="$(sed -En 's/.*(-t[0-9]{1,2}).*/\1/p' <<< $1)"
|
||||||
printf "$BLUE$2$STD"
|
echo -en "$BLUE$2$STD"
|
||||||
[[ "$1" =~ oui ]] && printf " [O/n] " || printf " [o/N] "
|
[[ "$1" =~ oui ]] && echo -n " [O/n] " || echo -n " [o/N] "
|
||||||
if [ "$param" ]; then
|
if [ "$param" ]; then
|
||||||
read -t2 reply
|
read -t2 reply
|
||||||
else
|
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
|
# 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"
|
echo -e "\n$RED $script $version, erreur critique: $1 $STD"
|
||||||
for (( i=2 ; i<=$# ; i++ )); do
|
for (( i=2 ; i<=$# ; i++ )); do
|
||||||
echo -e " $BLUE${!i}$STD"
|
echo -e " $BLUE${!i}$STD"
|
||||||
|
@ -74,18 +76,10 @@ f__error(){ # 15/10/2017
|
||||||
exit 1
|
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é
|
# 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
|
f__info(){ # 15/10/2017
|
||||||
local depart=1 i
|
local depart=1 i
|
||||||
|
|
||||||
if [ "$1" == "raw" ] || [ "$1" == "log" ]; then depart=2; fi
|
if [ "$1" == "raw" ] || [ "$1" == "log" ]; then depart=2; fi
|
||||||
[ "$1" == "log" ] && f__log "$(sed -E 's/\\t//;s/\\n// ' <<< $2 | xargs )"
|
[ "$1" == "log" ] && f__log "$(sed -E 's/\\t//;s/\\n// ' <<< $2 | xargs )"
|
||||||
for (( i=$depart ; i<=$# ; i++ )); do
|
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
|
# log spécifique, fichier log limité à 10000 octets, $1 message à loguer
|
||||||
f__log(){ # 27/10/2017
|
f__log(){ # 4/12/2017
|
||||||
if [ -w "$fileLogs" ]; then
|
if [ -w "$scriptLogs" ]; then
|
||||||
if [ "$(stat -c %s $fileLogs)" -ge "10000" ]; then
|
if [ "$(stat -c %s $scriptLogs)" -ge "10000" ]; then
|
||||||
echo "$(date +%Y%m%d\ %H%M%S) $1" &>/dev/null > "$fileLogs"
|
echo "$(date +%Y%m%d\ %H%M%S) $1" &>/dev/null > "$scriptLogs"
|
||||||
else
|
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
|
||||||
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 manquants: return 1 et $debOnlyAbsent ( $1=liste paquets )
|
||||||
# si $2=debOnly et si paquets présent: return 0 et $debOnlyPresent ( $1=liste paquets )
|
# si $2=debOnly et si paquets présent: return 0 et $debOnlyPresent ( $1=liste paquets )
|
||||||
# attention priorité $debOnlyAbsent sur $debOnlyPresent
|
# attention priorité $debOnlyAbsent sur $debOnlyPresent
|
||||||
f__requis(){ # 22/11/2017
|
f__requis(){ # 4/12/2017
|
||||||
local dependsMissing packagesMissing command package ireq compteur pluriel
|
local dependsMissing packagesMissing command package ireq compteur pluriel
|
||||||
|
|
||||||
unset debOnlyAbsent debOnlyPresent
|
unset debOnlyAbsent debOnlyPresent
|
||||||
for ireq in $1; do
|
for ireq in $1; do
|
||||||
command="$(cut -d '>' -f 1 <<< $ireq)"
|
command="$(cut -d '>' -f 1 <<< $ireq)"
|
||||||
package="$(cut -d '>' -f 2 <<< $ireq)"
|
package="$(cut -d '>' -f 2 <<< $ireq)"
|
||||||
if [ "$2" == "debOnly" ]; then
|
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" \
|
LC_ALL=C dpkg --get-selections | grep -qE "^$package[[:space:]]+install" \
|
||||||
&& debOnlyPresent+="$package " || debOnlyAbsent+="$package "
|
&& debOnlyPresent+="$package " || debOnlyAbsent+="$package "
|
||||||
fi
|
fi
|
||||||
elif [ -z $( f__which $command ) ]; then
|
elif ! type -p "$command" &>/dev/null ; then
|
||||||
dependsMissing+="$command "
|
dependsMissing+="$command "
|
||||||
packagesMissing+="$package "
|
packagesMissing+="$package "
|
||||||
fi
|
fi
|
||||||
|
@ -143,45 +138,16 @@ f__requis(){ # 22/11/2017
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# $1=rep à scanner [$2=profondeur max|4 défaut] [$3=profondeur encours|0 défaut]
|
# $1=cmd si $2: nb de tentatives pour s'identifier, sinon 2 tentatives par défaut, suppose bash existant
|
||||||
# affichage stdout si $fileOutput non définis, /usr/bin/strings (binutils) requis
|
f__sudo(){ # 4/12/2017
|
||||||
f__scandir(){ # 10/11/2017
|
local nb=2 sudo isudo toBash
|
||||||
[ -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
|
[ $( type -p bash 2>/dev/null ) ] && toBash="$( type -p bash )" || return 2
|
||||||
f__sudo(){ # 22/10/2017
|
|
||||||
local nb=2 sudo isudo
|
|
||||||
# sudo --shell bash équivalent su ?
|
# sudo --shell bash équivalent su ?
|
||||||
if sudo -v &>/dev/null && [ $EUID -ne 0 ] ; then
|
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
|
else
|
||||||
sudo="su --shell $(f__which bash) --preserve-environment -c "
|
sudo="su --shell $toBash --preserve-environment -c "
|
||||||
fi
|
fi
|
||||||
[ "$2" ] && nb="$2"
|
[ "$2" ] && nb="$2"
|
||||||
for (( isudo=1 ; isudo<="$nb" ; isudo++ )); do
|
for (( isudo=1 ; isudo<="$nb" ; isudo++ )); do
|
||||||
|
@ -191,11 +157,21 @@ f__sudo(){ # 22/10/2017
|
||||||
done
|
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
|
# user ayant initié la session graphique, assigne $fu_user
|
||||||
# return 1 sur échec identification user, return 2 sur absence home/
|
# return 1 sur échec identification user, return 2 sur absence home/
|
||||||
# gestion variable environnement user avec: USER_INSTALL=<user> script
|
# gestion variable environnement user avec: USER_INSTALL=<user> script
|
||||||
f__user(){ # 3/12/2017
|
f__user(){ # 3/12/2017
|
||||||
local user userid test root_login
|
local user userid test root_login
|
||||||
|
|
||||||
root_login="$(grep ':0:' /etc/passwd | cut -d':' -f1)" || root_login="root"
|
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
|
if [ "$USER_INSTALL" ]; then # user via variable environnement, moyen d'injecter root si pb
|
||||||
fu_user="$USER_INSTALL";
|
fu_user="$USER_INSTALL";
|
||||||
|
@ -245,33 +221,34 @@ f__wcv(){ # 09/11/2017
|
||||||
[ "$1" == "-wv" ] && echo "$2" | grep -o "$3" | grep -c .
|
[ "$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)
|
# 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 (si présente) et sortie normale fonction
|
# si $2=print affiche url testée & entêtes http & location, return 0
|
||||||
# si $2=loc affiche seulement location et sortie normale fonction
|
# si $2=loc affiche seulement location, return 0
|
||||||
# si $2=test return 0 si ok, return 1 si ko
|
# si $2=test return 0 si ok, return 1 si KO
|
||||||
f__wget_test(){ # 28/11/2017
|
f__wget_test(){ # 5/12/2017
|
||||||
local file_test_wget retourWget retourHttp location
|
local file_test_wget retourWget retourHttp location
|
||||||
|
|
||||||
file_test_wget="/tmp/testWget-$$-$RANDOM"
|
file_test_wget="/tmp/testWget-$$-$RANDOM"
|
||||||
wget -Sq --timeout=10 --user-agent="$user_agent" --spider --save-headers "$1" &>"$file_test_wget"
|
wget -Sq --timeout=10 --user-agent="$user_agent" --spider --save-headers "$1" &>"$file_test_wget"
|
||||||
retourWget="$?"
|
retourWget="$?"
|
||||||
[ "$retourWget" == 1 ] && retourWget="code erreur générique"
|
[ "$retourWget" == 1 ] && retourWget="1: code erreur générique"
|
||||||
[ "$retourWget" == 2 ] && retourWget="parse erreur (ligne de commande?)"
|
[ "$retourWget" == 2 ] && retourWget="2: parse erreur (ligne de commande?)"
|
||||||
[ "$retourWget" == 3 ] && retourWget="erreur Entrée/sortie fichier"
|
[ "$retourWget" == 3 ] && retourWget="3: erreur Entrée/sortie fichier"
|
||||||
[ "$retourWget" == 4 ] && retourWget="défaut réseau"
|
[ "$retourWget" == 4 ] && retourWget="4: défaut réseau"
|
||||||
[ "$retourWget" == 5 ] && retourWget="défaut vérification SSL"
|
[ "$retourWget" == 5 ] && retourWget="5: défaut vérification SSL"
|
||||||
[ "$retourWget" == 6 ] && retourWget="défaut authentification"
|
[ "$retourWget" == 6 ] && retourWget="6: défaut authentification"
|
||||||
[ "$retourWget" == 7 ] && retourWget="erreur de protocole"
|
[ "$retourWget" == 7 ] && retourWget="7: erreur de protocole"
|
||||||
[ "$retourWget" == 8 ] && retourWget="réponse serveur en erreur"
|
[ "$retourWget" == 8 ] && retourWget="8: réponse serveur en erreur"
|
||||||
retourHttp="$(grep -i 'HTTP/' "$file_test_wget" | tr -d '\n' | xargs)"
|
retourHttp="$( grep -i 'HTTP/' "$file_test_wget" | tr -d '\n' | xargs )"
|
||||||
|
location="$( grep -i 'location' $file_test_wget | xargs )"
|
||||||
if [ "$2" == "test" ]; then
|
if [ "$2" == "test" ]; then
|
||||||
rm "$file_test_wget" 2>/dev/null
|
rm "$file_test_wget" 2>/dev/null
|
||||||
# spécial maintenance frama.link
|
# spécial maintenance frama.link, pas de redirection sur page status framalink
|
||||||
[ "$(grep -c '303' <<< $retourHttp)" -ne 0 ] && return 1 # 303 See Other
|
[ "$( grep -c '303' <<< $retourHttp )" -ne 0 ] && return 1 # 303 See Other
|
||||||
[ "$retourWget" == "0" ] && return 0 || return 1
|
[ "$retourWget" == "0" ] && return 0 || return 1
|
||||||
fi
|
fi
|
||||||
location="$(grep -i 'location' $file_test_wget | xargs)"
|
|
||||||
if [ "$2" == "print" ]; then
|
if [ "$2" == "print" ]; then
|
||||||
if [ "$retourWget" ]; then
|
if [ "$retourWget" != "0" ]; then
|
||||||
echo "erreur wget: $RED$retourWget"
|
echo "erreur wget: $RED$retourWget"
|
||||||
echo -e "$BLUE $1$STD\t$RED $retourHttp"
|
echo -e "$BLUE $1$STD\t$RED $retourHttp"
|
||||||
else
|
else
|
||||||
|
@ -279,14 +256,15 @@ f__wget_test(){ # 28/11/2017
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
if [ "$2" == "print" ] || [ "$2" == "loc" ]; then
|
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"
|
echo "$STD"
|
||||||
|
rm "$file_test_wget" 2>/dev/null
|
||||||
return 0
|
return 0
|
||||||
fi
|
fi
|
||||||
if [ "$retourWget" ]; then
|
if [ "$retourWget" != "0" ]; then
|
||||||
rm "$file_test_wget"
|
rm "$file_test_wget" 2>/dev/null
|
||||||
f__error "wget, $retourWget" "$1" "$YELLOW$retourHttp" "$location"
|
# f__error "wget, $retourWget" "$1" "$YELLOW$retourHttp" "$location"
|
||||||
# echo -e "$RED errur wget, $retourWget \n $1 \n $YELLOW$retourHttp \n $location"
|
echo -e "$RED erreur wget, $retourWget \n $1 \n $YELLOW$retourHttp \n $location"
|
||||||
fi
|
fi
|
||||||
if [ "$(grep -c '200' <<< $retourHttp)" -ne 0 ]; then
|
if [ "$(grep -c '200' <<< $retourHttp)" -ne 0 ]; then
|
||||||
echo -e "$GREEN\ntout est ok, réessayer\n$STD"
|
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_affichage(){ # 2/12/2017
|
||||||
f__color
|
f__color
|
||||||
affichage_text=" _ ___ __
|
local affichage_text=" _ ___ __
|
||||||
__ _ ___| |_|_ _|_ __ / _| ___
|
__ _ ___| |_|_ _|_ __ / _| ___
|
||||||
/ _' |/ _ \ __|| || '_ \| |_ / _ \
|
/ _' |/ _ \ __|| || '_ \| |_ / _ \
|
||||||
| (_| | __/ |_ | || | | | _| (_) |
|
| (_| | __/ |_ | || | | | _| (_) |
|
||||||
|
@ -433,24 +411,6 @@ f_dspl_md(){ # 3/12/2017
|
||||||
echo -e "$display2"
|
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
|
# $1=liste fichier(s) à grepper, [$2]: N &| nofile &| novide &| ligneVide &| date &| commentXY
|
||||||
# si aucun fichier dans la liste retour: 'nofile|vide|inexistant'
|
# si aucun fichier dans la liste retour: 'nofile|vide|inexistant'
|
||||||
# /!\ protéger les chemins avec " (surtout si plusieurs chemins ou joker)
|
# /!\ 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
|
# [$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 bluez cmd_bluez cmt_bluez mod cmd_mod cmt_mod srch_mod pluriel text
|
||||||
local alert_na
|
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_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_cards_bluez=$( grep -Eo '^hci[0-9]+' <<< $fe_nb_bluez )
|
||||||
fe_nb_bluez=$( grep -c '^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
|
||||||
}
|
}
|
||||||
|
|
||||||
fi_pkg_apt(){ #v3 3/12/2017
|
fi_pkg_apt(){ #v3 5/12/2017
|
||||||
local dateMaj nb_packages ifile info_update text pluriel
|
local dateMaj nb_packages ifile info_update text pluriel
|
||||||
local sources cmt_sources cmd_sources
|
local sources cmt_sources cmd_sources
|
||||||
local apt_v apt_version apt_prefs cmt_apt_prefs cmd_apt_prefs
|
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="ces urls sont obsolètes, préférer http://deb.debian.org/ ou un miroir local: \n\n"
|
||||||
alert_httpredir+="$(grep 'httpredir' <<< "$sources")"
|
alert_httpredir+="$(grep 'httpredir' <<< "$sources")"
|
||||||
fi
|
fi
|
||||||
printf "◇"
|
echo -n "◇"
|
||||||
# extraction qte ugrade, full-upgrade
|
# extraction qte ugrade, full-upgrade
|
||||||
stck_upgd=$( LC_ALL=C apt-get upgrade --simulate 2>/dev/null )
|
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
|
# $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)"
|
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**"
|
alert_full_upgrade="ces paquets peuvent être mis à jour avec avec: **apt full-upgrade**"
|
||||||
fi
|
fi
|
||||||
printf "◇"
|
echo -n "◇"
|
||||||
# autoremove
|
# autoremove
|
||||||
toRemove=$( LC_ALL=C apt-get autoremove --simulate | grep -E 'Remv | newly installed' )
|
toRemove=$( LC_ALL=C apt-get autoremove --simulate | grep -E 'Remv | newly installed' )
|
||||||
toRemove=$( sort <<< $toRemove )
|
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
|
toRemove=$( sed '/newly/d' <<< "$toRemove" ) # suppression ligne état
|
||||||
[ "$qte_toRemove" -gt 1 ] && pluriel="s" || unset pluriel
|
[ "$qte_toRemove" -gt 1 ] && pluriel="s" || unset pluriel
|
||||||
cmt_toRemove="$qte_toRemove paquet"$pluriel" inutile"$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>"
|
alert_remove+="ou les installer manuellement avec apt install <paquet>"
|
||||||
fi
|
fi
|
||||||
# autoclean
|
# autoclean
|
||||||
printf "◇"
|
echo -n "◇"
|
||||||
autoclean=$( grep '^Del' <<< $( LC_ALL=C apt-get autoclean --simulate 2>/dev/null ) )
|
autoclean=$( grep '^Del' <<< $( LC_ALL=C apt-get autoclean --simulate 2>/dev/null ) )
|
||||||
qte_autoclean=$( f__wcv -l "$autoclean" )
|
qte_autoclean=$( f__wcv -l "$autoclean" )
|
||||||
[ "$qte_autoclean" -gt 1 ] && pluriel="s" || unset pluriel
|
[ "$qte_autoclean" -gt 1 ] && pluriel="s" || unset pluriel
|
||||||
|
@ -1637,7 +1597,7 @@ fi_pkg_apt(){ #v3 3/12/2017
|
||||||
fi
|
fi
|
||||||
# paquet non ^ii
|
# paquet non ^ii
|
||||||
non_ii=$( LC_ALL=C dpkg -l | gawk 'FNR>5 && ! /^i/ {
|
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=$( f__wcv -l "$non_ii" )
|
||||||
[ "$qte_non_ii" -gt 1 ] && pluriel="s" || unset pluriel
|
[ "$qte_non_ii" -gt 1 ] && pluriel="s" || unset pluriel
|
||||||
cmt_non_ii="$qte_non_ii paquet"$pluriel" dans un état non standard (^ii)"
|
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
|
# 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
|
local dirAnacron dirSpool fileAnacron
|
||||||
|
|
||||||
[ "$(type -t fscript_cronAnacron_special)" ] && fscript_cronAnacron_special # test, si fonction spécifique, appel
|
[ "$(type -t fscript_cronAnacron_special)" ] && fscript_cronAnacron_special # test, si fonction spécifique, appel
|
||||||
dirAnacron="/home/$fu_user/.config/anacron"
|
dirAnacron="/home/$fu_user/.config/anacron"
|
||||||
dirSpool="$dirAnacron/spool"
|
dirSpool="$dirAnacron/spool"
|
||||||
|
@ -3579,10 +3540,10 @@ fscript_cronAnacron(){ # 2/12/2017
|
||||||
install | upgrade )
|
install | upgrade )
|
||||||
mkdir -p "$dirAnacron"
|
mkdir -p "$dirAnacron"
|
||||||
# table anacron
|
# 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
|
## anacron journalier pour dev logname
|
||||||
if [ -e "$fileDev" ]; then
|
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
|
fi
|
||||||
# création spool anacron utilisateur
|
# création spool anacron utilisateur
|
||||||
mkdir -p "$dirSpool"
|
mkdir -p "$dirSpool"
|
||||||
|
@ -3603,26 +3564,26 @@ fscript_cronAnacron(){ # 2/12/2017
|
||||||
}
|
}
|
||||||
|
|
||||||
# version script en ligne, [$1=update], assigne $versionScript, $script_aJour=ok|ko
|
# 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
|
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)
|
versionScript=$(wget -q --timeout=15 -O - "$urlScript" | grep -m1 '^version=' | cut -d'=' -f2)
|
||||||
if [ "$versionScript" ]; then
|
if [ "$versionScript" ]; then
|
||||||
if [ "$version" != "$versionScript" ]; then
|
if [ "$version" != "$versionScript" ]; then
|
||||||
[ "$1" = "update" ] && var_temp=", mise à jour en cours"
|
[ "$1" == "update" ] && var_temp=", mise à jour en cours" || var_temp=", mise à jour possible"
|
||||||
[ "$1" = "update" ] || var_temp=", mise à jour possible"
|
|
||||||
script_aJour="ko"
|
script_aJour="ko"
|
||||||
else
|
else
|
||||||
script_aJour="ok"
|
script_aJour="ok"
|
||||||
fi
|
fi
|
||||||
f__info "version script en ligne: $versionScript$var_temp"
|
f__info "version script en ligne: $YELLOW$versionScript$BLUE$var_temp"
|
||||||
else
|
else
|
||||||
f__info "version script en ligne$RED non accessible"
|
f__info "version script en ligne$RED non accessible"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# installation du script dans le système
|
# installation du script dans le système
|
||||||
fscript_install(){ # 2/12/2017
|
fscript_install(){ # 4/12/2017
|
||||||
if grep -q 'bin' <<< "$(dirname $0)" ; then
|
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 )"
|
f__info "$RED""l'installation dans le système doit se faire depuis un script local $GREEN(./$script -i )"
|
||||||
return 1
|
return 1
|
||||||
|
@ -3636,26 +3597,26 @@ fscript_install(){ # 2/12/2017
|
||||||
f__requis "wget anacron cron" || exit 1
|
f__requis "wget anacron cron" || exit 1
|
||||||
# install /opt
|
# install /opt
|
||||||
mkdir -p /opt/bin/
|
mkdir -p /opt/bin/
|
||||||
cp -d "$(basename $0)" "$fileInstall"
|
cp -d "$(basename $0)" "$scriptInstall"
|
||||||
ln -s "$fileInstall" "/usr/bin/$script" &>/dev/null
|
ln -s "$scriptInstall" "/usr/bin/$script" &>/dev/null
|
||||||
chmod 775 "$fileInstall" # rwx rwx r-x, proprio fu_user
|
chmod 775 "$scriptInstall" # rwx rwx r-x, proprio fu_user
|
||||||
# cron/anacron install
|
# cron/anacron install
|
||||||
fscript_cronAnacron "install"
|
fscript_cronAnacron "install"
|
||||||
# création fichier log
|
# création fichier log
|
||||||
touch "$fileLogs"
|
touch "$scriptLogs"
|
||||||
chmod 664 "$fileLogs" # rw- rw- r--, proprio fu_user
|
chmod 664 "$scriptLogs" # rw- rw- r--, proprio fu_user
|
||||||
chown "$fu_user:" "$fileLogs" "$fileInstall"
|
chown "$fu_user:" "$scriptLogs" "$scriptInstall"
|
||||||
[ -e "$fileDev" ] || rm "$(basename $0)" &>/dev/null ## on efface pas si fileDev (dev)
|
[ -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 ./)"
|
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
|
# suppression du script dans le système
|
||||||
fscript_remove(){ # 06/11/2017
|
fscript_remove(){ # 4/12/2017
|
||||||
if ! grep -q 'bin' <<< "$(dirname $0)" ; then
|
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)"
|
f__info "$RED""cette fonction doit être appelée depuis le script installé dans le système $GREEN($script -r)"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
if [ ! -x "$fileInstall" ];then
|
if [ ! -x "$scriptInstall" ];then
|
||||||
f__info "$RED$script n'est pas installé"
|
f__info "$RED$script n'est pas installé"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
@ -3666,7 +3627,7 @@ fscript_remove(){ # 06/11/2017
|
||||||
fi
|
fi
|
||||||
[ "$(type -t fscript_remove_special)" ] && fscript_remove_special # test, si fonction spécifique, appel
|
[ "$(type -t fscript_remove_special)" ] && fscript_remove_special # test, si fonction spécifique, appel
|
||||||
# suppression de /opt
|
# suppression de /opt
|
||||||
rm "$fileInstall" &>/dev/null
|
rm "$scriptInstall" &>/dev/null
|
||||||
unlink "/usr/bin/$script" &>/dev/null
|
unlink "/usr/bin/$script" &>/dev/null
|
||||||
# cron/anacron remove
|
# cron/anacron remove
|
||||||
fscript_cronAnacron "remove"
|
fscript_cronAnacron "remove"
|
||||||
|
@ -3674,8 +3635,9 @@ fscript_remove(){ # 06/11/2017
|
||||||
}
|
}
|
||||||
|
|
||||||
# mise à jour script si dispo, v2, +update spécifique
|
# mise à jour script si dispo, v2, +update spécifique
|
||||||
fscript_update(){ # 2/11/2017
|
fscript_update(){ # 4/12/2017
|
||||||
local dirTemp="/tmp/$script-$RANDOM"
|
local dirTemp="/tmp/$script-$RANDOM"
|
||||||
|
|
||||||
[ $(type -t fscript_update_special) ] && fscript_update_special # test, si fonction spécifique, appel
|
[ $(type -t fscript_update_special) ] && fscript_update_special # test, si fonction spécifique, appel
|
||||||
if [ -z "$updateSpecial" ] && ! grep -q 'bin' <<< "$(dirname $0)" ; then
|
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)"
|
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"
|
wget -q --tries=2 --timeout=15 -O "$dirTemp/$script" "$urlScript"
|
||||||
if [ "$?" != "0" ]; then f__wget_test "$urlScript"; fi
|
if [ "$?" != "0" ]; then f__wget_test "$urlScript"; fi
|
||||||
if grep -q '#!/bin/bash' "$dirTemp/$script" ; then
|
if grep -q '#!/bin/bash' "$dirTemp/$script" ; then
|
||||||
cp -d "$dirTemp/$script" "$fileInstall"
|
cp -d "$dirTemp/$script" "$scriptInstall"
|
||||||
chmod 775 "$fileInstall" # rwx rwx r-x, proprio fu_user
|
chmod 775 "$scriptInstall" # rwx rwx r-x, proprio fu_user
|
||||||
chown "$fu_user:" "$fileInstall"
|
chown "$fu_user:" "$scriptInstall"
|
||||||
[ -z "$updateSpecial" ] && fscript_cronAnacron "upgrade"
|
[ -z "$updateSpecial" ] && fscript_cronAnacron "upgrade"
|
||||||
f__info "log" "$script mis à jour en version $versionScript $updateSpecial"
|
f__info "log" "$script mis à jour en version $versionScript $updateSpecial"
|
||||||
else
|
else
|
||||||
|
@ -3702,12 +3664,14 @@ fscript_update(){ # 2/11/2017
|
||||||
rm -rf "$dirTemp/"
|
rm -rf "$dirTemp/"
|
||||||
}
|
}
|
||||||
|
|
||||||
prg_init(){ # 2/12/2017
|
prg_init(){ # 4/12/2017
|
||||||
|
|
||||||
PATH='/usr/sbin:/usr/bin:/sbin:/bin'
|
PATH='/usr/sbin:/usr/bin:/sbin:/bin'
|
||||||
TERM=xterm
|
TERM=xterm
|
||||||
IFS_INI="$IFS"
|
IFS_INI="$IFS"
|
||||||
IFS=$' \t\n'
|
IFS=$' \t\n'
|
||||||
export PATH TERM IFS
|
export PATH TERM IFS
|
||||||
|
|
||||||
# whereis script retourne vide si installé
|
# whereis script retourne vide si installé
|
||||||
DIRNAME=$( dirname $0 )
|
DIRNAME=$( dirname $0 )
|
||||||
DIRNAME=${DIRNAME#/usr/bin} # suppression /usr/bin éventuel au début ( lien )
|
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
|
# requis pour fonctionnement programme
|
||||||
f__requis "gawk wget ip>iproute2 lspci>pciutils wc>coreutils" || exit 1
|
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"
|
[ $( f__which dpkg ) ] && ENV_DEBIAN="oui"
|
||||||
}
|
}
|
||||||
prg_1(){ # début 2/12/2017
|
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 pouvez le visualiser ultérieurement avec $GREEN$script -l" \
|
||||||
"vous pourrez l'exporter ultérieurement avec $BLUE$script -p"
|
"vous pourrez l'exporter ultérieurement avec $BLUE$script -p"
|
||||||
}
|
}
|
||||||
prg_menu(){ # 10/10/2017
|
prg_menu(){ # 5/12/2017
|
||||||
|
|
||||||
function display_menu {
|
function display_menu {
|
||||||
local centre=50 left=2 larg=60 reply line
|
local centre=50 left=2 larg=60 reply line
|
||||||
|
@ -3820,17 +3784,15 @@ function display_menu {
|
||||||
printf '%.'$larg's' "$2"
|
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" \
|
display_menu "$GREEN$script -c$RED""s$STD : catégorie système" \
|
||||||
"$GREEN$script -c$RED""c$STD : catégorie configuration"
|
"$GREEN$script -c$RED""c$STD : catégorie configuration"
|
||||||
display_menu "$GREEN$script -c$RED""r$STD : catégorie réseau" \
|
display_menu "$GREEN$script -c$RED""r$STD : catégorie réseau" \
|
||||||
"$GREEN$script -c$RED""a$STD : catégorie analyse"
|
"$GREEN$script -c$RED""a$STD : catégorie analyse"
|
||||||
echo -e "\n\n les catégories peuvent être cumulées: \n" \
|
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"
|
" $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)? "
|
echo -en "\n ( ne pas saisir le préfixe $YELLOW-c$STD, all par défaut)\n"
|
||||||
tput sc
|
echo -en "\n choix des catégories à générer (all pour toutes)? "
|
||||||
printf "\n ( ne pas saisir le préfixe $YELLOW-c$STD, all par défaut)"
|
|
||||||
tput rc
|
|
||||||
read reply
|
read reply
|
||||||
[ "$reply" ] && reply="-c${reply,,}" || reply="all"
|
[ "$reply" ] && reply="-c${reply,,}" || reply="all"
|
||||||
reply="$(sed 's/-call/all/' <<< $reply)"
|
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
|
# paramètres généraux
|
||||||
[ "$pasteDuration" ] || pasteDuration=7 # durée de conservation standard du paste en jours
|
[ "$pasteDuration" ] || pasteDuration=7 # durée de conservation standard du paste en jours
|
||||||
fileOutput="getInfo_rapport.md"
|
fileOutput="getInfo_rapport.md"
|
||||||
fileLogs="/var/log/sdeb_$script.log"
|
scriptInstall="/opt/bin/$script"
|
||||||
|
scriptLogs="/var/log/sdeb_$script.log"
|
||||||
fileDev="/opt/bin/fileDev"
|
fileDev="/opt/bin/fileDev"
|
||||||
fileInstall="/opt/bin/$script"
|
|
||||||
urlScript="https://frama.link/getInfo"
|
urlScript="https://frama.link/getInfo"
|
||||||
urlNotice="https://frama.link/doc-getInfo"
|
urlNotice="https://frama.link/doc-getInfo"
|
||||||
# test sur frama.link ok, sinon fallback sur framagit
|
# test sur frama.link ok, sinon fallback sur framagit
|
||||||
|
@ -3961,7 +3923,7 @@ for j in $options; do
|
||||||
-us )
|
-us )
|
||||||
opType="upgrade" # log si f__error
|
opType="upgrade" # log si f__error
|
||||||
updateSpecial="update spécial actif"
|
updateSpecial="update spécial actif"
|
||||||
fileInstall="$(dirname $0)/$script"
|
scriptInstall="$(dirname $0)/$script"
|
||||||
fscript_update
|
fscript_update
|
||||||
exit ;; # upgrade spécial
|
exit ;; # upgrade spécial
|
||||||
-v | --version )
|
-v | --version )
|
||||||
|
|
|
@ -1,7 +1,15 @@
|
||||||
# changelog getInfo
|
# 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: f-grep_file, révision, nouvelle option
|
||||||
* révision: fi_conf, ajout service systemctl
|
* révision: fi_conf, ajout service systemctl
|
||||||
|
|
Loading…
Reference in New Issue