1 | #!/bin/bash |
---|
2 | #/** |
---|
3 | #@file listclientlive |
---|
4 | #@brief Lista la distribución ogLive asociada a los clientes, ya sea un equipo o un aula. |
---|
5 | #@usage listclientlive Ambito |
---|
6 | #@param Ambito nombre de ordenador o nombre de aula |
---|
7 | #@version 1.1.0 - Versión inicial basada en el script "listclientmode" |
---|
8 | #@author Ramón M. Gómez, ETSII Universidad de Sevilla |
---|
9 | #@date 2017-06-01 |
---|
10 | #**/ |
---|
11 | |
---|
12 | |
---|
13 | # Variables. |
---|
14 | OPENGNSYS=${OPENGNSYS:-"/opt/opengnsys"} |
---|
15 | SERVERCONF=$OPENGNSYS/etc/ogserver.json |
---|
16 | TFTPDIR=$OPENGNSYS/tftpboot |
---|
17 | |
---|
18 | source $OPENGNSYS/lib/ogfunctions.sh || exit 1 |
---|
19 | |
---|
20 | # Control básico de errores. |
---|
21 | [ "$*" == "help" ] && help |
---|
22 | [ "$*" == "version" ] && version |
---|
23 | [ $# -eq 1 ] || raiseError usage |
---|
24 | [ "$USER" != "root" ] && raiseError access "Need to be root" |
---|
25 | source_json_config $SERVERCONF 2>/dev/null || raiseError access "Sin acceso a fichero de configuración" |
---|
26 | |
---|
27 | # Sustituir caracteres ' por \' para evitar inyección SQL. |
---|
28 | RESOURCE="${1//\'/\\\'}" |
---|
29 | # Obtener nombre de ordenador individual o todos los de una aula e indicar su plantilla asociada. |
---|
30 | dbexec "SELECT CONCAT_WS('', 'Equipo \"', ord.nombreordenador, '\" asociado a cliente \"', |
---|
31 | ord.oglivedir, '\" $([ -e $TFTPDIR/$OGLIVE ] || echo "(inexistente)")') |
---|
32 | FROM ordenadores AS ord |
---|
33 | JOIN aulas USING (idaula) |
---|
34 | WHERE aulas.nombreaula='$RESOURCE' |
---|
35 | OR ord.nombreordenador='$RESOURCE';" |
---|
36 | |
---|