source: client/engine/Inventory.lib @ 0d6e7222

918-git-images-111dconfigfileconfigure-oglivegit-imageslgromero-new-oglivemainmaint-cronmount-efivarfsmultivmmultivm-ogboot-installerogClonningEngineogboot-installer-jenkinsoglive-ipv6test-python-scriptsticket-301ticket-50ticket-50-oldticket-577ticket-585ticket-611ticket-612ticket-693ticket-700ubu24tplunification2use-local-agent-oglivevarios-instalacionwebconsole3
Last change on this file since 0d6e7222 was 1a2fa9d8, checked in by ramon <ramongomez@…>, 10 years ago

#673: Actualizar código incluido en OepnGnSys? 1.0.6 sobre la rama version1.1 para desarrollar la nueva versión.

git-svn-id: https://opengnsys.es/svn/branches/version1.1@4609 a21b9725-9963-47de-94b9-378ad31fedc9

  • Property mode set to 100755
File size: 15.4 KB
Line 
1#!/bin/bash
2#/**
3#@file    Inventory.lib
4#@brief   Librería o clase Inventory
5#@class   Inventory
6#@brief   Funciones para recogida de datos de inventario de hardware y software de los clientes.
7#@version 1.0.6
8#@warning License: GNU GPLv3+
9#*/
10
11
12#/**
13#         ogGetArch
14#@brief   Devuelve el tipo de arquitectura del cliente.
15#@return  str_arch - Arquitectura (i386 para 32 bits, x86_64 para 64 bits).
16#@version 0.9.2 - Primera versión para OpenGnSys.
17#@author  Ramon Gomez, ETSII Universidad de Sevilla
18#@date    2010-07-17
19#*/
20function ogGetArch ()
21{
22if [ "$*" == "help" ]; then
23    ogHelp "$FUNCNAME" "$FUNCNAME" "$FUNCNAME  =>  x86_64"
24    return
25fi
26
27[ -d /lib64 ] && echo "x86_64" || echo "i386"
28}
29
30
31#/**
32#         ogGetOsType int_ndisk int_npartition
33#@brief   Devuelve el tipo del sistema operativo instalado.
34#@param   int_ndisk      nº de orden del disco
35#@param   int_npartition nº de orden de la partición
36#@return  OSType - Tipo de sistema operativo.
37#@see     ogGetOsVersion
38#*/ ##
39function ogGetOsType ()
40{
41# Si se solicita, mostrar ayuda.
42if [ "$*" == "help" ]; then
43    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" \
44           "$FUNCNAME 1 2  =>  Linux"
45    return
46fi
47ogGetOsVersion "$@" | cut -sf1 -d:
48}
49
50
51#/**
52#         ogGetOsVersion int_ndisk int_nfilesys
53#@brief   Devuelve la versión del sistema operativo instalado en un sistema de archivos.
54#@param   int_ndisk      nº de orden del disco
55#@param   int_nfilesys   nº de orden de la partición
56#@return  OSType:OSVersion - tipo y versión del sistema operativo.
57#@note    OSType = { Android, BSD, GrubLoader, Hurd, Linux, MacOS, Solaris, Windows, WinLoader }
58#@note    Requisitos: awk, head, chroot
59#@exception OG_ERR_FORMAT    Formato incorrecto.
60#@exception OG_ERR_NOTFOUND  Disco o partición no corresponden con un dispositiv
61#@exception OG_ERR_PARTITION Fallo al montar el sistema de archivos.
62#@version 0.9 - Primera versión para OpenGnSys
63#@author  Ramon Gomez, ETSII Universidad de Sevilla
64#@date    2009-09-15
65#@version 1.0.4 - Incluir tipos BSD, MacOS y Solaris.
66#@author  Ramon Gomez, ETSII Universidad de Sevilla
67#@date    2012-06-29
68#@version 1.0.5 - Incluir tipos GrubLoader, Hurd y WinLoader, leer por defecto fichero /etc/os-release.
69#@author  Ramon Gomez, ETSII Universidad de Sevilla
70#@date    2013-10-07
71#@version 1.0.6 - Detectar GrubLoader al final y sistemas basados en EFI.
72#@author  Ramon Gomez, ETSII Universidad de Sevilla
73#@date    2014-08-27
74#*/ ##
75function ogGetOsVersion ()
76{
77# Variables locales.
78local MNTDIR TYPE DISTRIB VERSION IS64BIT FILE
79# Si se solicita, mostrar ayuda.
80if [ "$*" == "help" ]; then
81    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_nfilesys" \
82           "$FUNCNAME 1 2  =>  Linux:Ubuntu precise (12.04 LTS) 64 bits"
83    return
84fi
85# Error si no se reciben 2 parametros.
86[ $# = 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
87
88# Montar la particion, si no lo estaba previamente.
89MNTDIR=$(ogMount $1 $2) || return $?
90
91# Buscar tipo de sistema operativo.
92# Para GNU/Linux: leer descripción.
93TYPE="Linux"
94FILE="$MNTDIR/etc/os-release"
95[ -r $FILE ] && VERSION="$(awk -F= '$1~/PRETTY_NAME/ {gsub(/\"/,"",$2); print $2}' $FILE)"
96# Si no se puede obtener, buscar en ficheros del sistema.
97if [ -z "$VERSION" ]; then
98    FILE="$MNTDIR/etc/lsb-release"
99    [ -r $FILE ] && VERSION="$(awk -F= '$1~/DESCRIPTION/ {gsub(/\"/,"",$2); print $2}' $FILE)"
100    for DISTRIB in redhat SuSE mandrake gentoo; do
101        FILE="$MNTDIR/etc/${DISTRIB}-release"
102        [ -r $FILE ] && VERSION="$(head -1 $FILE)"
103    done
104    FILE="$MNTDIR/etc/arch-release"
105    [ -r $FILE ] && VERSION="Arch Linux"
106    FILE="$MNTDIR/etc/slackware-version"
107    [ -r $FILE ] && VERSION="Slackware $(cat $FILE)"
108fi
109# Si no se encuentra, intentar ejecutar "lsb_release".
110[ -z "$VERSION" ] && VERSION=$(chroot $MNTDIR lsb_release -d 2>/dev/null | awk -F":\t" '{print $2}')
111# Comprobar Linux de 64 bits.
112[ -n "$VERSION" ] && [ -e $MNTDIR/lib64 ] && IS64BIT="$MSG_64BIT"
113# Para Android, leer fichero de propiedades.
114if [ -z "$VERSION" ]; then
115    TYPE="Android"
116    FILE="$MNTDIR/android*/system/build.prop"
117    [ -r $FILE ] && VERSION="Android $(awk -F= '$1~/(product.brand|build.version.release)/ {print $2}' $FILE | tr '\n' ' ')"
118    [ -e $MNTDIR/lib64 ] && IS64BIT="$MSG_64BIT"
119fi
120# Para GNU/Hurd, comprobar fichero de inicio (basado en os-prober).
121if [ -z "$VERSION" ]; then
122    TYPE="Hurd"
123    FILE="$MNTDIR/hurd/init"
124    [ -r $FILE ] && VERSION="GNU/Hurd"
125fi
126# Para Windows: leer la version del registro.
127if [ -z "$VERSION" ]; then
128    TYPE="Windows"
129    VERSION=$(ogGetRegistryValue $MNTDIR software '\Microsoft\Windows NT\CurrentVersion\ProductName' 2>/dev/null)
130    [ -n "$(ogGetRegistryValue $MNTDIR software '\Microsoft\Windows\CurrentVersion\ProgramW6432Dir' 2>/dev/null)" ] && IS64BIT="$MSG_64BIT"
131fi
132# Para cargador Windows: buscar versión en fichero BCD (basado en os-prober).
133if [ -z "$VERSION" ]; then
134    TYPE="WinLoader"
135    FILE="$(ogGetPath $MNTDIR/boot/bcd)"
136    [ -z "$FILE" ] && FILE="$(ogGetPath $MNTDIR/EFI/Microsoft/boot/bcd)"
137    if [ -n "$FILE" ]; then
138        for DISTRIB in "Windows Recovery" "Windows Boot"; do
139            if grep -qs "$(echo "$DISTRIB" | sed 's/./&./g')" $FILE; then
140                VERSION="$DISTRIB loader"
141            fi
142        done
143    fi
144fi
145# Para MacOS: detectar kernel y completar con fichero plist de información del sistema.
146if [ -z "$VERSION" ]; then
147    TYPE="MacOS"
148    # Kernel de Mac OS (no debe ser fichero de texto).
149    FILE="$MNTDIR/mach_kernel"
150    if [ -z "$(file -b $FILE | grep 'text')" ]; then
151        # Obtener tipo de kernel.
152        [ -n "$(file -b $FILE | grep 'Mach-O')" ] && VERSION="Mac OS"
153        [ -n "$(file -b $FILE | grep 'Mach-O 64-bit')" ] && IS64BIT="$MSG_64BIT"
154        # Datos de configuración de versión de Mac OS.
155        FILE="$MNTDIR/System/Library/CoreServices/SystemVersion.plist"
156        [ -r $FILE ] && VERSION=$(awk -F"[<>]" '
157                                      /ProductName/ {getline;s=$3}
158                                      /ProductVersion/ {getline;v=$3}
159                                      END {print s,v}' $FILE)
160        # Datos de recuperación de Mac OS.
161        FILE="$MNTDIR/com.apple.recovery.boot"
162        [ -r $FILE -a -n "$VERSION" ] && VERSION="$VERSION recovery"
163    fi
164fi
165# Para FreeBSD: obtener datos del Kernel.
166### TODO Revisar solución.
167if [ -z "$VERSION" ]; then
168    TYPE="BSD"
169    FILE="$MNTDIR/boot/kernel/kernel"
170    if [ -r $FILE ]; then
171        VERSION="$(strings $FILE|awk '/@.*RELEASE/ {print $1,$2}')"
172        [ -n "$(file -b $FILE | grep 'x86-64')" ] && IS64BIT="$MSG_64BIT"
173    fi
174fi
175# Para Solaris: leer el fichero de versión.
176### TODO Revisar solución.
177if [ -z "$VERSION" ]; then
178    TYPE="Solaris"
179    FILE="$MNTDIR/etc/release"
180    [ -r $FILE ] && VERSION="$(head -1 $FILE)"
181fi
182# Para cargador GRUB, comprobar fichero de configuración.
183if [ -z "$VERSION" ]; then
184    TYPE="GrubLoader"
185    for FILE in $MNTDIR/{,boot/}grub/menu.lst; do
186        [ -r $FILE ] && VERSION="GRUB Loader"
187    done
188    for FILE in $MNTDIR/{,boot/}{grub{,2},EFI/*}/grub.cfg; do
189        [ -r $FILE ] && VERSION="GRUB2 Loader"
190    done
191fi
192
193# Mostrar resultado y salir sin errores.
194[ -n "$VERSION" ] && echo "$TYPE:$VERSION $IS64BIT"
195return 0
196}
197
198
199#/**
200#         ogListHardwareInfo
201#@brief   Lista el inventario de hardware de la máquina cliente.
202#@return  TipoDispositivo:Modelo    (por determinar)
203#@warning Se ignoran los parámetros de entrada.
204#@note    TipoDispositivo = { ata, bio, boa, cdr, cpu, dis, fir, mem, mod, mul, net, ser, vga }
205#@note    Requisitos: lshw, awk
206#@version 0.1 - Primeras pruebas con OpenGnSys
207#@author  Ramon Gomez, ETSII Universidad de Sevilla
208#@date    2009-07-28
209#*/ ##
210function ogListHardwareInfo ()
211{
212# Si se solicita, mostrar ayuda.
213if [ "$*" == "help" ]; then
214    ogHelp "$FUNCNAME" "$FUNCNAME"
215    return
216fi
217
218# Recopilación de disposibivos procesando la salida de \c lshw
219ogEcho info "$MSG_HARDWAREINVENTORY}"
220lshw | awk 'BEGIN {type="mod";}
221        /product:/ {sub(/ *product: */,"");  prod=$0;}
222        /vendor:/  {sub(/ *vendor: */,"");   vend=$0;}
223        /version:/ {sub(/ *version: */,"v.");vers=$0;}
224        /size:/    {sub(/ *size: */,"");     size=$0;}
225        /\*-/      {if (type=="mem")
226                    print type"="size;
227                else
228                    if (type!="" && prod!="")
229                        print type"="vend,prod,size,vers;
230                type=prod=vend=vers=size="";}
231        /-core/    {type="boa";}
232        /-firmware/ {type="bio";}
233        /-cpu/     {type="cpu";}
234        /-memory/  {type="mem";}
235        /-ide/     {type="ide";}
236        /-disk/    {type="dis";}
237        /-cdrom/   {type="cdr";}
238        /-display/ {type="vga";}
239        /-network/ {type="net";}
240        /-multimedia/ {type="mul";}
241        /-usb/     {type="usb";}
242        /-firewire/ {type="fir";}
243        /-serial/  {type="bus";}
244        END        {if (type!="" && prod!="")
245                    print type"="vend,prod,size,vers;}
246      '
247# */ (comentario para Doxygen)
248}
249
250
251#/**
252#         ogListSoftware int_ndisk int_npartition
253#@brief   Lista el inventario de software instalado en un sistema operativo.
254#@param   int_ndisk      nº de orden del disco
255#@param   int_npartition nº de orden de la partición
256#@return  programa versión ...
257#@warning Se ignoran los parámetros de entrada.
258#@note    Requisitos: ...
259#@todo    Detectar software en Linux
260#@version 0.1 - Primeras pruebas con OpenGnSys
261#@author  Ramon Gomez, ETSII Universidad de Sevilla
262#@date    2009-09-23
263#@version 1.0.5 - Aproximación para inventario de software de Mac OS.
264#@author  Ramon Gomez, ETSII Universidad de Sevilla
265#@date    2013-10-08
266#@version 1.0.6 - Proceso depende del tipo de SO y sporte para FreeBSD.
267#@author  Ramon Gomez, ETSII Universidad de Sevilla
268#@date    2014-11-13
269#*/ ##
270function ogListSoftware ()
271{
272# Variables locales.
273local MNTDIR TYPE DPKGDIR RPMDIR PACMANDIR KEYS KEYS32 k PROG VERS
274
275# Si se solicita, mostrar ayuda.
276if [ "$*" == "help" ]; then
277    ogHelp "$FUNCNAME" "$FUNCNAME 1 1"
278    return
279fi
280# Error si no se reciben 2 parametros.
281[ $# = 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
282
283# Obtener tipo de sistema de archivos y montarlo.
284MNTDIR=$(ogMount $1 $2) || return $?
285TYPE=$(ogGetOsType $1 $2) || return $?
286
287case "$TYPE" in
288    Linux)          # Software de GNU/Linux.
289        # Procesar paquetes dpkg.
290        DPKGDIR="${MNTDIR}/var/lib/dpkg"
291        if [ -r $DPKGDIR ]; then
292        #    dpkg --admindir=$DPKGDIR -l | \
293            # Proceso de fichero en sistemas de 64 bits.
294            if [ -e $MNTDIR/lib64 ]; then
295                awk '/Package:/ {if (pack!="") print pack,vers;
296                                 sub(/-dev$/,"",$2);
297                                 pack=$2}
298                     /Version:/ {sub(/^.*:/,"",$2); sub(/-.*$/,"",$2);
299                                 vers=$2}
300                     /Status:/  {if ($2!="install") pack=vers=""}
301                     END        {if (pack!="") print pack,vers}
302                    ' $DPKGDIR/status | sort | uniq
303            else
304                # FIXME Sólo 32 bits
305                chroot "$MNTDIR" /usr/bin/dpkg -l | \
306                    awk '$1~/ii/ {sub(/-dev$/,"",$2); sub(/^.*:/,"",$3);
307                                  sub(/-.*$/,"",$3); print $2,$3}
308                        ' | sort | uniq
309            fi
310        fi
311        # Procesar paquetes RPM.
312        RPMDIR="${MNTDIR}/var/lib/rpm"
313        if [ -r $RPMDIR ]; then
314            # Listar si está instalado el paquete "rpm" en el cliente.
315            if which rpm &>/dev/null; then
316                rm -f ${RPMDIR}/__db.*
317                rpm --dbpath $RPMDIR -qa --qf "%{NAME} %{VERSION}\n" 2>/dev/null | \
318                    awk '$1!~/-devel$/ {sub(/-.*$/,"",$2); print $0}' | sort | uniq
319                rm -f ${RPMDIR}/__db.*
320            else
321                # Obtener el nombre de cada paquete en la BD de RPM.
322                python <<<"
323import re;
324import bsddb;
325db=bsddb.hashopen('$RPMDIR/Name','r');
326for k in db.keys():
327    print re.sub('-devel$','',k);" | sort | uniq
328            fi
329        fi
330        # Procesar paquetes pacman.
331        PACMANDIR="${MNTDIR}/var/lib/pacman/local"
332        if [ -r $PACMANDIR ]; then
333            # FIXME Separar nombre y versión de los paquetes
334            ls -A $PACMANDIR
335        fi
336        ;;
337    Windows)        # Software de Windows.
338        # Claves de registro para programas instalados: formato "{clave}".
339        KEYS=$(ogListRegistryKeys $MNTDIR software '\Microsoft\Windows\CurrentVersion\Uninstall')
340        KEYS32=$(ogListRegistryKeys $MNTDIR software '\Wow6432Node\Microsoft\Windows\CurrentVersion\Uninstall')
341        # Mostrar los valores "DisplayName" y "DisplayVersion" para cada clave.
342        (for k in $KEYS; do
343            PROG=$(ogGetRegistryValue $MNTDIR software "\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\$k\\DisplayName")
344            if [ -n "$PROG" ]; then
345                VERS=$(ogGetRegistryValue $MNTDIR software "\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\$k\\DisplayVersion")
346                echo "$PROG $VERS"
347            fi
348        done
349        for k in $KEYS32; do
350            PROG=$(ogGetRegistryValue $MNTDIR software "\\Wow6432Node\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\$k\\DisplayName")
351            if [ -n "$PROG" ]; then
352                VERS=$(ogGetRegistryValue $MNTDIR software "\\Wow6432Node\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\$k\\DisplayVersion")
353                echo "$PROG $VERS"
354            fi
355        done) | sort | uniq
356        ;;
357    MacOS)          # Software de Mac OS.
358        # Listar directorios de aplicaciones e intentar obtener la versión del fichero .plist (tanto original como descomprimido).
359        find "${MNTDIR}/Applications" -type d -name "*.app" -prune -print | \
360                while read k; do
361                    FILE="$k/Contents/version.plist"
362                    [ -s "$FILE" ] || FILE="$k/Contents/version.plist.uncompress"
363                    [ -s "$FILE" ] && VERSION=$(awk -F"[<>]" '/ShortVersionString/ {getline;v=$3}
364                                                              END {print v}' "$FILE")
365                    echo "$(basename "$k" .app) $VERSION"
366                done | sort
367        ;;
368    BSD)            # Software de FreeBSD.
369        sqlite3 $MNTDIR/var/db/pkg/local.sqlite <<<"SELECT name FROM pkg_search;" 2>/dev/null | \
370                sed 's/\(.*\)-\(.*\)/\1 \2/g' | sort
371        ;;
372    *)  ogRaiseError $OG_ERR_PARTITION "$1, $2"
373        return $? ;;
374esac
375}
376
377
378#/**  @function ogInfoCache: @brief muestra la informacion de la CACHE.
379#@param  sin parametros
380#@return  texto que se almacena en $IP.-InfoCache.  punto_montaje, tama?oTotal, TamanioOcupado, TaminioLibre, imagenes dentro de la cahce
381#@warning  Salidas de errores no determinada
382#@warning   printf no soportado por busybox
383#@attention
384#@version 0.1   Date: 27/10/2008 Author Antonio J. Doblas Viso. Universidad de Malaga
385#*/
386function ogInfoCache ()
387{
388local info infoFilesystem infoSize infoUsed infoUsedPorcet infoMountedOn content
389if ogMountCache
390then
391        info=`df -h | grep $OGCAC`
392        infoFilesystem=`echo $info | cut -f1 -d" "`
393        infoSize=`echo $info | cut -f2 -d" "`
394        infoUsed=`echo $info | cut -f3 -d" "`
395        infoAvail=`echo $info | cut -f4 -d" "`
396        infoUsedPorcet=`echo $info | cut -f5 -d" "`
397        infoMountedOn=`echo $info | cut -f2 -d" "`
398        if `ls  ${OGCAC}$OGIMG > /dev/null 2>&1`
399        then
400               cd ${OGCAC}${OPENGNSYS}
401                #content=`find images/ -type f -printf "%h/  %f  %s \n"`   busybox no soporta printf
402                content=`find images/ -type f`
403                cd /
404                echo $info
405                echo -ne $content
406                echo " "
407                #echo "$info" > ${OGLOG}/${IP}-InfoCache
408                #echo "$content" >> {$OGLOG}/${IP}-InfoCache
409        else
410                echo $info
411                #echo "$info" > {$OGLOG}/${IP}-InfoCache
412        fi
413        ogUnmountCache
414else
415        echo " "
416        #echo " " > {$OGLOG}/${IP}-InfoCache
417
418fi
419}
420
Note: See TracBrowser for help on using the repository browser.