source: client/engine/FileSystem.lib @ 8850d1b

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 8850d1b was 697a9ee, checked in by ramon <ramongomez@…>, 14 years ago

Corrección en la detección de partición Linux sin formatear y marcada como activa.
Soporte para detectar tipo de partición HFS/HFS+.
Solución errata para sintaxis de Doxygen en librería System.
Close #297.

git-svn-id: https://opengnsys.es/svn/trunk@1469 a21b9725-9963-47de-94b9-378ad31fedc9

  • Property mode set to 100755
File size: 27.4 KB
Line 
1#!/bin/bash
2#/**
3#@file    FileSystem.lib
4#@brief   Librería o clase FileSystem
5#@class   FileSystem
6#@brief   Funciones para gestión de sistemas de archivos.
7#@version 0.9
8#@warning License: GNU GPLv3+
9#*/
10
11
12#/**
13#         ogCheckFs int_ndisk int_npartition
14#@brief   Comprueba el estado de un sistema de archivos.
15#@param   int_ndisk      nº de orden del disco
16#@param   int_npartition nº de orden de la partición
17#@return  (nada)
18#@exception OG_ERR_FORMAT    Formato incorrecto.
19#@exception OG_ERR_NOTFOUND  Disco o particion no corresponden con un dispositivo.
20#@exception OG_ERR_PARTITION Partición desconocida o no accesible.
21#@note    Requisitos: *fsck*
22#@warning No se comprueban sistemas de archivos montados o bloqueados.
23#@todo    Definir salidas.
24#@version 0.9 - Primera adaptación para OpenGNSys.
25#@author  Ramon Gomez, ETSII Universidad de Sevilla
26#@date    2009-10-07
27#*/
28function ogCheckFs ()
29{
30# Variables locales.
31local PART TYPE PROG PARAMS
32
33#/// Error si no se reciben 2 parámetros.
34[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
35#/// Obtener partición.
36PART="$(ogDiskToDev $1 $2)" || return $?
37
38TYPE=$(ogGetFsType $1 $2)
39case "$TYPE" in
40    EXT[234])     PROG="e2fsck" ;;
41    REISERFS)     PROG="reiserfsck"; PARAMS="<<<\"Yes\"" ;;
42    JFS)          PROG="fsck.jfs" ;;
43    XFS)          PROG="fsck.xfs" ;;
44    NTFS|HNTFS)   PROG="ntfsfix" ;;
45    FAT32|HFAT32) PROG="dosfsck"; PARAMS="-a" ;;
46    FAT16|HFAT16) PROG="dosfsck"; PARAMS="-a" ;;
47    FAT12|HFAT12) PROG="dosfsck"; PARAMS="-a" ;;
48    *)            ogRaiseError $OG_ERR_PARTITION "$1, $2, $TYPE"
49                      return $? ;;
50esac
51#/// Error si el sistema de archivos esta montado o bloqueado.
52if ogIsMounted $1 $2; then
53    ogRaiseError $OG_ERR_PARTITION "$1 $2"       # Indicar nuevo error
54    return $?
55fi
56if ogIsLocked $1 $2; then
57    ogRaiseError $OG_ERR_LOCKED "$1 $2"
58    return $?
59fi
60#/// Comprobar en modo uso exclusivo.
61ogLock $1 $2
62eval $PROG $PARAMS $PART
63ERRCODE=$?
64case $ERRCODE in
65    0)    ;;
66    127)  ogRaiseError $OG_ERR_NOTEXEC "$PROG" ;;
67    *)    ogRaiseError $OG_ERR_PARTITION "$1 $2" ;;
68esac
69ogUnlock $1 $2
70return $ERRCODE
71}
72
73
74#/**
75#         ogExtendFs int_ndisk int_npartition
76#@brief   Extiende un sistema de archivos al tamaño de su partición.
77#@param   int_ndisk      nº de orden del disco
78#@param   int_npartition nº de orden de la partición
79#@return  (nada)
80#@exception OG_ERR_FORMAT   Formato incorrecto.
81#@exception OG_ERR_NOTFOUND Disco o particion no corresponden con un dispositivo.
82#@exception OG_ERR_PARTITION Partición desconocida o no accesible.
83#@note    Requisitos: *resize*
84#@version 0.1 -  Integracion para Opengnsys  -  EAC:   EnlargeFileSystem() en ATA.lib
85#@author  Antonio J. Doblas Viso. Universidad de Malaga
86#@date    2008-10-27
87#@version 0.9 - Primera adaptacion para OpenGNSys.
88#@author  Ramon Gomez, ETSII Universidad de Sevilla
89#@date    2009-09-23
90#*/
91function ogExtendFs ()
92{
93# Variables locales.
94local PART PROG PARAMS
95
96#/// Si se solicita, mostrar ayuda.
97if [ "$*" == "help" ]; then
98    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" \
99           "$FUNCNAME 1 1"
100    return
101fi
102#/// Error si no se reciben 2 parámetros.
103[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
104
105#/// Obtener partición.
106PART="$(ogDiskToDev $1 $2)" || return $?
107
108ogUnmount $1 $2 2>/dev/null
109#/// Redimensionar al tamano máximo según el tipo de partición.
110TYPE=$(ogGetFsType $1 $2)
111case "$TYPE" in
112    EXT[234])   PROG="resize2fs"; PARAMS="-f" ;;
113    REISERFS)   PROG="resize_reiserfs"; PARAMS="-f" ;;
114    NTFS|HNTFS) PROG="ntfsresize"; PARAMS="<<<\"y\" -f" ;;
115    *)          ogRaiseError $OG_ERR_PARTITION "$1 $2 $TYPE"
116                return $? ;;
117esac
118#/// Error si el sistema de archivos está montado o bloqueado.
119if ogIsMounted $1 $2; then
120    ogRaiseError $OG_ERR_PARTITION "$1 $2"       # Indicar nuevo error
121    return $?
122fi
123if ogIsLocked $1 $2; then
124    ogRaiseError $OG_ERR_LOCKED "$1 $2"
125    return $?
126fi
127#/// Redimensionar en modo uso exclusivo.
128ogLock $1 $2
129eval $PROG $PARAMS $PART &>/dev/null
130ERRCODE=$?
131case $ERRCODE in
132    0)    ;;
133    127)  ogRaiseError $OG_ERR_NOTEXEC "$PROG" ;;
134    *)    ogRaiseError $OG_ERR_PARTITION "$1 $2" ;;
135esac
136ogUnlock $1 $2
137return $ERRCODE
138}
139
140
141#/**
142#         ogFormat int_ndisk int_npartition | CACHE
143#@see     ogFormatFs ogFormatCache
144#*/
145function ogFormat ()
146{
147case "$*" in
148    CACHE|cache)  ogFormatCache ;;
149    *)            ogFormatFs "$@" ;;
150esac
151}
152
153
154#/**
155#         ogFormatFs int_ndisk int_npartition [type_fstype] [str_label]
156#@brief   Formatea un sistema de ficheros según el tipo de su partición.
157#@param   int_ndisk      nº de orden del disco
158#@param   int_npartition nº de orden de la partición
159#@param   type_fstype    mnemónico de sistema de ficheros a formatear
160#@param   str_label      etiqueta de volumen (opcional)
161#@return  (por determinar)
162#@exception OG_ERR_FORMAT    Formato incorrecto.
163#@exception OG_ERR_NOTFOUND  Disco o particion no corresponden con un dispositivo.
164#@exception OG_ERR_PARTITION Partición no accesible o desconocida.
165#@note    Requisitos:   mkfs*
166#@warning No formatea particiones montadas ni bloqueadas.
167#@todo    Definir salidas.
168#@version 0.9 - Primera versión para OpenGNSys.
169#@author  Ramon Gomez, ETSII Universidad de Sevilla
170#@date    2009-10-08
171#*/ ##
172function ogFormatFs ()
173{
174# Variables locales
175local PART ID TYPE LABEL PROG PARAMS ERRCODE
176
177# Si se solicita, mostrar ayuda.
178if [ "$*" == "help" ]; then
179    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition [str_label]" \
180           "$FUNCNAME 1 1" \
181           "$FUNCNAME 1 1 EXT4" \
182           "$FUNCNAME 1 1 \"DATA\"" \
183           "$FUNCNAME 1 1 EXT4 \"DATA\""
184    return
185fi
186# Error si no se reciben entre 2 y 4 parámetros.
187[ $# -ge 2 -a $# -le 4 ] || ogRaiseError $OG_ERR_FORMAT || return $?
188# Obtener dispositivo y tipo de sisitema de archivos.
189PART="$(ogDiskToDev $1 $2)" || return $?
190TYPE="$(ogGetFsType $1 $2)" || return $?
191
192# Elegir tipo de formato segun el tipo de particion.
193case "$3" in
194    EXT2)      ID=83; PROG="mkfs.ext2";;
195    EXT3)      ID=83; PROG="mkfs.ext3";;
196    EXT4)      ID=83; PROG="mkfs.ext4";;
197    REISERFS)  ID=83; PROG="mkfs.reiserfs"; PARAMS="-f" ;;
198    REISER4)   ID=83; PROG="mkfs.reiser4";;
199    XFS)       ID=83; PROG="mkfs.xfs"; PARAMS="-f" ;;
200    JFS)       ID=83; PROG="mkfs.jfs"; PARAMS="<<<\"y\"";;
201    NTFS)      ID=7;  PROG="mkntfs"; PARAMS="-f" ;;
202    HNTFS)     ID=17; PROG="mkntfs"; PARAMS="-f" ;;
203    FAT32)     ID=b;  PROG="mkdosfs"; PARAMS="-F 32" ;;
204    HFAT32)    ID=1b; PROG="mkdosfs"; PARAMS="-F 32" ;;
205    FAT16)     ID=6;  PROG="mkdosfs"; PARAMS="-F 16" ;;
206    HFAT16)    ID=16; PROG="mkdosfs"; PARAMS="-F 16" ;;
207    FAT12)     ID=1;  PROG="mkdosfs"; PARAMS="-F 12" ;;
208    HFAT12)    ID=11; PROG="mkdosfs"; PARAMS="-F 12" ;;
209    *)         LABEL="$3" ;;
210esac
211# Si no se indica explícitamente, detectar el tipo de sistema de archivos.
212if [ -z "$PROG" ]; then
213    case "$TYPE" in
214        EXT2)         PROG="mkfs.ext2";;
215        EXT3)         PROG="mkfs.ext3";;
216        EXT4)         PROG="mkfs.ext4";;
217        REISERFS)     PROG="mkfs.reiserfs"; PARAMS="-f" ;;
218        REISER4)      PROG="mkfs.reiser4";;
219        XFS)          PROG="mkfs.xfs"; PARAMS="-f" ;;
220        JFS)          PROG="mkfs.jfs"; PARAMS="<<<\"y\"";;
221        NTFS|HNTFS)   PROG="mkntfs"; PARAMS="-f" ;;
222        FAT32|HFAT32) PROG="mkdosfs"; PARAMS="-F 32" ;;
223        FAT16|HFAT16) PROG="mkdosfs"; PARAMS="-F 16" ;;
224        FAT12|HFAT12) PROG="mkdosfs"; PARAMS="-F 12" ;;
225        *)            ogRaiseError $OG_ERR_PARTITION "$1 $2 $TYPE"
226                      return $? ;;
227    esac
228else
229    [ $TYPE == "$3" -o $ID == "$(ogGetPartitionId $1 $2)" ] || ogRaiseError $OG_ERR_PARTITION "$3 != $TYPE" || return $?
230fi
231# Comprobar consistencia entre id. de partición y tipo de sistema de archivos.
232[ -n "$PROG" ] || ogRaiseError $OG_ERR_PARTITION "$3 != $TYPE" || return $?
233
234# Etiquetas de particion.
235if [ -z "$LABEL" ]; then
236    [ "$4" != "CACHE" ] || ogRaiseError $OG_ERR_FORMAT "$MSG_RESERVEDVALUE: CACHE" || return $?
237    [ -n "$4" ] && PARAMS="$PARAMS -L $4"
238else
239    PARAMS="$PARAMS -L $LABEL"
240fi
241
242# Error si la particion esta montada o está bloqueada.
243if ogIsMounted $1 $2; then
244    ogRaiseError $OG_ERR_PARTITION "$1 $2"       # Indicar nuevo error
245    return $?
246fi
247if ogIsLocked $1 $2; then
248    ogRaiseError $OG_ERR_LOCKED "$1 $2"
249    return $?
250fi
251# Formatear en modo uso exclusivo.
252ogLock $1 $2
253eval $PROG $PARAMS $PART 2>/dev/null
254ERRCODE=$?
255case $ERRCODE in
256    0)    ;;
257    127)  ogRaiseError $OG_ERR_NOTEXEC "$PROG" ;;
258    *)    ogRaiseError $OG_ERR_PARTITION "$1 $2" ;;
259esac
260ogUnlock $1 $2
261return $ERRCODE
262}
263
264
265#/**
266#         ogGetFsType int_ndisk int_npartition
267#@brief   Devuelve el mnemonico con el tipo de sistema de archivos.
268#@param   int_ndisk      nº de orden del disco
269#@param   int_npartition nº de orden de la partición
270#@return  Mnemonico
271#@note    Mnemonico: { EXT2, EXT3, EXT4, REISERFS, XFS, JFS, LINUX-SWAP, LINUX-LVM, LINUX-RAID, SOLARIS, FAT16, HFAT16, FAT32, HFAT32, NTFS, HNTFS, WIN-DYNAMIC, CACHE, EMPTY, EXTENDED, UNKNOWN }
272#@exception OG_ERR_FORMAT   Formato incorrecto.
273#@exception OG_ERR_NOTFOUND Disco o particion no corresponden con un dispositivo.
274#@version 0.1 -  Integracion para Opengnsys  -  EAC:   TypeFS() en ATA.lib
275#@author  Antonio J. Doblas Viso. Universidad de Malaga
276#@date    2008-10-27
277#@version 0.9 - Primera adaptacion para OpenGNSys.
278#@author  Ramon Gomez, ETSII Universidad de Sevilla
279#@date    2009-07-21
280#*/ ##
281function ogGetFsType () {
282
283# Variables locales.
284local ID TYPE
285
286# Si se solicita, mostrar ayuda.
287if [ "$*" == "help" ]; then
288    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" \
289           "$FUNCNAME 1 1  =>  NTFS"
290    return
291fi
292# Error si no se reciben 2 parámetros.
293[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
294
295# Detectar id. de tipo de partición y codificar al mnemonico.
296DISK=$(ogDiskToDev "$1") || return $?
297ID=$(ogGetPartitionId "$1" "$2") || return $?
298case "$ID" in
299     0)         TYPE="EMPTY" ;;
300     1)         TYPE="FAT12" ;;
301     5|f)       TYPE="EXTENDED" ;;
302     [6e])      TYPE="FAT16" ;;
303     7)         TYPE="NTFS" ;;          # Nota: también puede ser EXFAT
304     [bc])      TYPE="FAT32" ;;
305     11)        TYPE="HFAT12" ;;
306     12)        TYPE="COMPAQDIAG" ;;
307     1[6e])     TYPE="HFAT16" ;;
308     17)        TYPE="HNTFS" ;;
309     1[bc])     TYPE="HFAT32" ;;
310     42)        TYPE="WIN-DYNAMIC" ;;
311     82)        TYPE="LINUX-SWAP" ;;
312     83)        TYPE="$(parted -sm $DISK print 2>/dev/null | \
313                            awk -F: -v fs=$2 '{if ($1==fs) {print toupper($5)}}')"
314                TYPE=${TYPE:-"EXT3"}
315                ;;
316     8e)        TYPE="LINUX-LVM" ;;
317     a7)        TYPE="CACHE" ;;         # (compatibilidad con Brutalix)
318     af)        TYPE="HFS" ;;
319     bf)        TYPE="SOLARIS" ;;
320     ca)        TYPE="CACHE" ;;
321     fd)        TYPE="LINUX-RAID" ;;
322     *)         TYPE="UNKNOWN" ;;
323esac
324echo $TYPE
325}
326
327
328#/**
329#         ogGetMountPoint int_ndisk int_npartition
330#@brief   Devuelve el punto de montaje de un sistema de archivos.
331#@param   int_ndisk      nº de orden del disco
332#@param   int_npartition nº de orden de la partición
333#@return  Punto de montaje
334#@exception OG_ERR_FORMAT    Formato incorrecto.
335#@exception OG_ERR_NOTFOUND  Disco o particion no corresponden con un dispositivo.
336#@note    Requisitos: \c mount* \c awk
337#@version 0.9 - Primera versión para OpenGNSys.
338#@author  Ramon Gomez, ETSII Universidad de Sevilla
339#@date    2009-10-15
340#*/ ##
341function ogGetMountPoint ()
342{
343# Variables locales
344local PART
345# Si se solicita, mostrar ayuda.
346if [ "$*" == "help" ]; then
347    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" \
348           "$FUNCNAME 1 1  =>  /mnt/sda1"
349    return
350fi
351# Error si no se reciben 2 parámetros.
352[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
353# Obtener partición.
354PART="$(ogDiskToDev $1 $2)" || return $?
355
356echo $(mount | awk -v P=$PART '{if ($1==P) {print $3}}')
357}
358
359
360#/**
361#         ogIsFormated int_ndisk int_npartition
362#@brief   Comprueba si un sistema de archivos está formateado.
363#@param   int_ndisk      nº de orden del disco o volumen.
364#@param   int_npartition nº de orden del sistema de archivos.
365#@return  int_code       Código de salida
366#@version 0.91 - Adaptación inicial para comprobar que existe caché.
367#@author  Ramon Gomez, ETSII Universidad de Sevilla
368#@date    2010-03-18
369#*/ ##
370function ogIsFormated ()
371{
372# Variables locales
373local DISK
374if [ "$*" == "help" ]; then
375    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" \
376           "if $FUNCNAME 1 1; then ... ; fi"
377    return
378fi
379# Error si no se reciben 2 parámetros.
380[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
381
382DISK=$(ogDiskToDev "$1")
383test -n "$(parted -sm $DISK print 2>/dev/null | \
384                      awk -F: -v fs=$2 '{if ($1==fs) print $5}')"
385}
386
387
388#/**
389#         ogIsMounted int_ndisk int_npartition
390#@brief   Comprueba si un sistema de archivos está montado.
391#@param   int_ndisk      nº de orden del disco
392#@param   int_npartition nº de orden de la partición
393#@return  Código de salida: 0 - sin montar, 1 - montado.
394#@version 0.9 - Primera versión para OpenGNSys.
395#@author  Ramon Gomez, ETSII Universidad de Sevilla
396#@date    2009-10-15
397#*/ ##
398function ogIsMounted ()
399{
400# Si se solicita, mostrar ayuda.
401if [ "$*" == "help" ]; then
402    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" \
403           "if $FUNCNAME 1 1; then ... ; fi"
404    return
405fi
406# Error si no se reciben 2 parámetros.
407[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
408
409test -n "$(ogGetMountPoint $1 $2)"
410}
411
412
413#/**
414#         ogIsLocked int_ndisk int_npartition
415#@brief   Comprueba si una partición está bloqueada por una operación de uso exclusivo.
416#@param   int_ndisk      nº de orden del disco
417#@param   int_npartition nº de orden de la partición
418#@return  Código de salida: 0 - sin bloquear, 1 - bloqueada.
419#@note    El fichero de bloqueo se localiza en \c /var/lock/part, siendo \c part el dispositivo de la partición, sustituyendo el carácter "/" por "-".
420#@version 0.9 - Primera versión para OpenGNSys.
421#@author  Ramon Gomez, ETSII Universidad de Sevilla
422#@date    2009-09-03
423#*/ ##
424function ogIsLocked ()
425{
426# Variables locales
427local PART LOCKFILE
428
429# Si se solicita, mostrar ayuda.
430if [ "$*" == "help" ]; then
431    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" \
432           "if $FUNCNAME 1 1; then ... ; fi"
433    return
434fi
435# Error si no se reciben 2 parámetros.
436[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
437
438# Obtener partición.
439PART="$(ogDiskToDev $1 $2)" || return $?
440
441# Comprobar existencia del fichero de bloqueo.
442LOCKFILE="/var/lock/lock${PART//\//-}"
443test -f $LOCKFILE
444}
445
446
447#/**
448#         ogLock int_ndisk int_npartition
449#@see     ogLockPartition
450#*/
451function ogLock ()
452{
453ogLockPartition "$@"
454}
455
456#/**
457#         ogLockPartition int_ndisk int_npartition
458#@brief   Genera un fichero de bloqueo para una partición en uso exlusivo.
459#@param   int_ndisk      nº de orden del disco
460#@param   int_npartition nº de orden de la partición
461#@return  (nada)
462#@exception OG_ERR_FORMAT    Formato incorrecto.
463#@exception OG_ERR_NOTFOUND  Disco o particion no corresponden con un dispositivo.
464#@note    El fichero de bloqueo se localiza en \c /var/lock/part, siendo \c part el dispositivo de la partición, sustituyendo el carácter "/" por "-".
465#@version 0.9 - Primera versión para OpenGNSys.
466#@author  Ramon Gomez, ETSII Universidad de Sevilla
467#@date    2009-09-03
468#*/ ##
469function ogLockPartition ()
470{
471# Variables locales
472local PART LOCKFILE
473
474# Si se solicita, mostrar ayuda.
475if [ "$*" == "help" ]; then
476    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" \
477           "$FUNCNAME 1 1"
478    return
479fi
480# Error si no se reciben 2 parámetros.
481[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
482
483# Obtener partición.
484PART="$(ogDiskToDev $1 $2)" || return $?
485
486# Crear archivo de bloqueo exclusivo.
487LOCKFILE="/var/lock/lock${PART//\//-}"
488touch $LOCKFILE
489}
490
491
492#/**
493#         ogMount int_ndisk int_npartition
494#@see     ogMountFs ogMountCache ogMountCdrom
495#*/ ##
496function ogMount ()
497{
498case "$*" in
499    CACHE|cache)
500        ogMountCache ;;
501    CDROM|cdrom)
502        ogMountCdrom ;;
503    *)  ogMountFs "$@" ;;
504esac
505}
506
507
508#/**
509#         ogMountFs int_ndisk int_npartition
510#@brief   Monta un sistema de archivos.
511#@param   int_ndisk      nº de orden del disco
512#@param   int_npartition nº de orden de la partición
513#@return  Punto de montaje
514#@exception OG_ERR_FORMAT    Formato incorrecto.
515#@exception OG_ERR_NOTFOUND  Disco o particion no corresponden con un dispositivo.
516#@exception OG_ERR_PARTITION Tipo de particion desconocido o no se puede montar.
517#@version 0.1 -  Integracion para Opengnsys  -  EAC:   MountPartition() en FileSystem.lib
518#@author  Antonio J. Doblas Viso. Universidad de Malaga
519#@date    2008-10-27
520#@version 0.9 - Primera version para OpenGNSys.
521#@author  Ramon Gomez, ETSII Universidad de Sevilla
522#@date    2009-09-28
523#*/ ##
524function ogMountFs ()
525{
526# Variables locales
527local PART TYPE MNTDIR MOUNT PARAMS
528
529# Si se solicita, mostrar ayuda.
530if [ "$*" == "help" ]; then
531    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" \
532           "$FUNCNAME 1 1  =>  /mnt/sda1"
533    return
534fi
535# Error si no se reciben 2 parámetros.
536[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
537
538# Obtener partición.
539PART="$(ogDiskToDev $1 $2)" || return $?
540
541# Comprobar si el sistema de archivos ya está montada.
542MNTDIR="$(ogGetMountPoint $1 $2)"
543# Si no, montarla en un directorio de sistema
544if [ -z "$MNTDIR" ]; then
545    # Error si la particion esta bloqueada.
546    ogIsLocked $1 $2 && ogRaiseError $OG_ERR_LOCKED "$1 $2" && return $?
547    # Crear punto de montaje o enlace símbolico para Caché local.
548    MNTDIR=${PART/dev/mnt}
549    TYPE="$(ogGetFsType $1 $2)" || return $?
550    if [ "$TYPE" == "CACHE" -a -n "$OGCAC" ]; then
551        ln -fs $OGCAC $MNTDIR
552    else
553        mkdir -p $MNTDIR
554    fi
555    # Montar según el tipo de sitema de archivos.
556    case "$TYPE" in
557        CACHE)      MOUNT=mount ;;
558        EXT[234])   MOUNT=mount ;;
559        REISERFS)   insmod /lib/modules/$(uname -r)/kernel/fs/reiserfs/reiserfs.ko 2>/dev/null
560                    MOUNT=mount ;;
561        JFS)        insmod /lib/modules/$(uname -r)/kernel/fs/jfs/jfs.ko 2>/dev/null
562                    MOUNT=mount ;;
563        XFS)        insmod /lib/modules/$(uname -r)/kernel/fs/xfs/xfs.ko 2>/dev/null
564                    MOUNT=mount ;;
565        NTFS|HNTFS) MOUNT=ntfs-3g ;;
566        FAT16|FAT32|HFAT16|HFAT32)
567                    MOUNT=mount; PARAMS="-t vfat" ;;
568        *)  #/// Error, si la partición no es montable.
569            rmdir $MNTDIR
570            ogRaiseError $OG_ERR_PARTITION "$1, $2, $TYPE"
571            return $OG_ERR_PARTITION
572            ;;
573    esac
574    $MOUNT $PARAMS $PART $MNTDIR || $MOUNT $PARAMS $PART $MNTDIR -o force,remove_hiberfile || ogRaiseError $OG_ERR_PARTITION "$1, $2, $TYPE" || return $?
575        # linea temporal durante desarrollo para poder usar el cliente completo nfs y testeas nuevas herramientas.
576    if grep -q nfsroot /proc/cmdline; then
577                echo "$PART $MNTDIR" >> /etc/mtab
578        fi
579        # fin linea temporal.
580fi
581echo $MNTDIR
582}
583
584
585#####  PRUEBAS
586# Montar CDROM
587function ogMountCdrom ()
588{
589local DEV MNTDIR
590DEV="/dev/cdrom"            # Por defecto
591MNTDIR=$(mount | awk -v D=$DEV '{if ($1==D) {print $3}}')
592if [ -z "$MNTDIR" ]; then
593    MNTDIR=${DEV/dev/mnt}
594    mkdir -p $MNTDIR
595    mount -t iso9660 $DEV $MNTDIR || ogRaiseError $OG_ERR_PARTITION "cdrom" || return $?
596fi
597echo $MNTDIR
598}
599
600
601#/**
602#         ogReduceFs int_ndisk int_npartition
603#@brief   Reduce el tamaño del sistema de archivos, sin tener en cuenta el espacio libre.
604#@param   int_ndisk      nº de orden del disco
605#@param   int_npartition nº de orden de la partición
606#@return  int_tamañoKB - tamaño en KB
607#@exception OG_ERR_FORMAT    Formato incorrecto.
608#@exception OG_ERR_NOTFOUND  Disco o particion no corresponden con un dispositivo.
609#@exception OG_ERR_PARTITION Partición desconocida o no accesible.
610#@warning En Windows, se borran los ficheros pagefile.sys e hiberfile.sys
611#@warning El sistema de archivos se amplía al mínimo + 10%.
612#@note    Requisitos:   *resize*
613#@version 0.1 -  Integracion para Opengnsys  -  EAC:   ReduceFileSystem() en ATA.lib
614#@author  Antonio J. Doblas Viso. Universidad de Malaga
615#@date    2008-10-27
616#@version 0.9 - Primera version para OpenGNSys.
617#@author  Ramon Gomez, ETSII Universidad de Sevilla
618#@date    2009-09-23
619#@version 0.9.2 - Añadir un 10% al tamaño mínimo requerido.
620#@author  Ramon Gomez, ETSII Universidad de Sevilla
621#@date    2010-09-27
622#*/ ##
623function ogReduceFs ()
624{
625# Variables locales
626local PART BLKS SIZE
627
628# Si se solicita, mostrar ayuda.
629if [ "$*" == "help" ]; then
630    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" \
631           "$FUNCNAME 1 1"
632    return
633fi
634# Error si no se reciben 2 parámetros.
635[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
636
637# Obtener partición.
638PART="$(ogDiskToDev $1 $2)" || return $?
639
640# Redimensionar según el tipo de particion.
641case "$(ogGetFsType $1 $2)" in
642    EXT[234])
643        ogUnmount $1 $2 2>/dev/null
644        # Ext2/3/4: Tamaño de los bloques del sistema de archivos
645        BLKS=$(tune2fs -l $PART | awk '/Block size/ {print int($3/512)}')
646        # Traduce el num. en sectores de 512B a tamano en MB.
647        SIZE=$(resize2fs -P $PART 2>/dev/null | \
648                       awk -v B=$BLKS '/minimum size/ {print int($7*1.1*B/2048)}')
649        resize2fs -fp $PART "${SIZE}M" &>/dev/null || ogRaiseError $OG_ERR_PARTITION "$1,$2" || return $?
650            ;;
651#    REISERFS)          # Usar "resize_reiserfs"
652#           ;;
653    NTFS|HNTFS)
654        ogDeleteFile $1 $2 pagefile.sys
655        ogDeleteFile $1 $2 hiberfile.sys
656        ogUnmount $1 $2 2>/dev/null
657        # NTFS: Obtiene tamaño mínimo en MB.
658        SIZE=$(ntfsresize -fi $PART | awk '/resize at/ {print int($8*1.1)}')
659        ntfsresize -fns "${SIZE}M" $PART >/dev/null || ogRaiseError $OG_ERR_PARTITION "$1,$2" || return $?
660        ntfsresize -fs "${SIZE}M" $PART <<<"y" >/dev/null || ogRaiseError $OG_ERR_PARTITION "$1,$2" || return $?
661            ;;
662    *)  ogRaiseError $OG_ERR_PARTITION "$1,$2"
663            return $? ;;
664esac
665#/// Mostrar nuevo tamaño en KB.
666echo $[SIZE*1024]
667}
668
669
670#/**
671#         ogUnlock int_ndisk int_npartition
672#@see     ogUnlockPartition
673#*/
674function ogUnlock ()
675{
676ogUnlockPartition "$@"
677}
678
679#/**
680#         ogUnlockPartition int_ndisk int_npartition
681#@brief   Elimina el fichero de bloqueo para una particion.
682#@param   int_ndisk      nº de orden del disco
683#@param   int_npartition nº de orden de la partición
684#@return  (nada)
685#@exception OG_ERR_FORMAT    Formato incorrecto.
686#@exception OG_ERR_NOTFOUND  Disco o particion no corresponden con un dispositivo.
687#@note    El fichero de bloqueo se localiza en \c /var/lock/part, siendo \c part el dispositivo de la partición, sustituyendo el carácter "/" por "-".
688#@version 0.9 - Primera versión para OpenGNSys.
689#@author  Ramon Gomez, ETSII Universidad de Sevilla
690#@date    2009-09-03
691#*/ ##
692function ogUnlockPartition ()
693{
694# Variables locales
695local PART LOCKFILE
696
697# Si se solicita, mostrar ayuda.
698if [ "$*" == "help" ]; then
699    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" \
700           "$FUNCNAME 1 1"
701    return
702fi
703# Error si no se reciben 2 parámetros.
704[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
705
706# Obtener partición.
707PART="$(ogDiskToDev $1 $2)" || return $?
708
709# Borrar archivo de bloqueo exclusivo.
710LOCKFILE="/var/lock/lock${PART//\//-}"
711rm -f $LOCKFILE
712}
713
714
715#/**
716#         ogUnmount int_ndisk int_npartition
717#@see     ogUnmountFs
718#*/
719function ogUnmount ()
720{
721ogUnmountFs "$@"
722}
723
724#/**
725#         ogUnmountFs int_ndisk int_npartition
726#@brief   Desmonta un sistema de archivos.
727#@param   int_ndisk      nº de orden del disco
728#@param   int_npartition nº de orden de la partición
729#@return  Nada
730#@exception OG_ERR_FORMAT    Formato incorrecto.
731#@exception OG_ERR_NOTFOUND  Disco o particion no corresponden con un dispositivo.
732#@warning La partición no está previamente montada o no se puede desmontar.
733#@version 0.1 -  Integracion para Opengnsys  -  EAC:  UmountPartition() en FileSystem.lib
734#@author  Antonio J. Doblas Viso. Universidad de Malaga
735#@date    2008-10-27
736#@version 0.9 - Primera version para OpenGNSys.
737#@author  Ramon Gomez, ETSII Universidad de Sevilla
738#@date    2009-09-28
739#*/ ##
740function ogUnmountFs ()
741{
742# Variables locales
743local PART MNTDIR
744
745# Si se solicita, mostrar ayuda.
746if [ "$*" == "help" ]; then
747    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" "$FUNCNAME 1 1"
748    return
749fi
750# Error si no se reciben 2 parámetros.
751[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
752
753# Obtener partición y punto de montaje.
754PART="$(ogDiskToDev $1 $2)" || return $?
755MNTDIR="$(ogGetMountPoint $1 $2)"
756
757# Si está montada, desmontarla.
758if [ -n "$MNTDIR" ]; then
759    # Error si la particion está bloqueada.
760    ogIsLocked $1 $2 && ogRaiseError $OG_ERR_LOCKED "$1 $2" && return $?
761    # Desmontar y borrar punto de montaje.
762    umount $PART 2>/dev/null || ogEcho warning "$FUNCNAME: $MSG_DONTUNMOUNT: \"$1,$2\""
763    rmdir $MNTDIR 2>/dev/null || rm -f $MNTDIR 2>/dev/null
764        # linea temporal durante desarrollo para testear nuevas herramientas con el cliente completo nfs
765    if grep -q nfsroot /proc/cmdline; then
766                cat /etc/mtab | grep -v $PART > /var/tmp/mtab.temporal && cp /var/tmp/mtab.temporal /var/tmp/mtab && rm /var/tmp/mtab.temporal
767        fi
768        # fin linea temporal.
769else
770    ogEcho warning "$MSG_DONTMOUNT: \"$1,$2\""
771fi
772}
773
774
775#/**
776#         ogUnmountAll int_ndisk
777#@brief   Desmonta todos los sistema de archivos de un disco, excepto el caché local.
778#@param   int_ndisk      nº de orden del disco
779#@return  Nada
780#@exception OG_ERR_FORMAT    Formato incorrecto.
781#@exception OG_ERR_NOTFOUND  Disco o particion no corresponden con un dispositivo.
782#@warning No se desmonta la partición marcada como caché local.
783#@version 0.9 - Versión para OpenGNSys.
784#@author  Ramon Gomez, ETSII Universidad de Sevilla
785#@date    2009/10/07
786#*/ ##
787function ogUnmountAll ()
788{
789# Variables locales
790local DISK PART
791# Si se solicita, mostrar ayuda.
792if [ "$*" == "help" ]; then
793    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk" "FUNCNAME 1"
794    return
795fi
796# Error si no se recibe 1 parámetro.
797[ $# == 1 ] || ogRaiseError $OG_ERR_FORMAT || return $?
798
799# Obtener partición y punto de montaje.
800DISK="$(ogDiskToDev $1)" || return $?
801for ((PART=1; PART<=$(ogGetPartitionsNumber $1); PART++)); do
802    case "$(ogGetFsType $1 $PART)" in
803        CACHE|LINUX-SWAP)
804           ;;
805        *)
806           ogUnmount $1 $PART ;;
807    esac
808done
809}
810
811#/**  @function ogGetFsSize: @brief Muestra el tamanio del sistema de archivos indicado, permite definir la unidad de medida, por defecto GB
812#@param  $1 int_diskEAC
813#@param $2 int_PartitionEAC
814#@param $3 str_UnidadMediada            parametro opcional, admite [ kB MB GB -default GB]
815#@return  cadena con int_TotalSize:int_DataSize:int_DataFree
816#@warning  Salidas de errores no determinada
817#@warning
818#@attention
819#@version 0.1 -  Integracion para Opengnsys  -  EAC:  SizeFileSystem() en FileSystem.lib
820#@author  Antonio J. Doblas Viso. Universidad de Malaga
821#@date    2008-10-27
822#*/
823function ogGetFsSize () {
824if [ $# = 0 ]
825then
826        echo "sintaxis: ogGetFsSize int_disco int_partition str_SizeOutput [ kB MB GB -default GB]-]" red
827        echo "devuelve int_size : int_data : int_free" red
828return
829fi
830if [ $# -ge 2 ]
831then
832        particion=`ogMount $1 $2 ` #1>/dev/null 2>&1
833        if [ -z $3 ]
834                then
835                        unit=GB  # s B kB MB GB TB %
836                else
837                        unit=$3
838        fi
839        case $unit in
840                kB)
841                        factor="1.024";
842                        valor=`df | grep  $particion | awk -F" " '{size=$2*1.024; used=$3*1.024; free=$4*1.024; printf "%d:%d:%d", size,used,free}'`
843                ;;
844                MB)
845                        factor="1.024/1000";
846                        valor=`df | grep  $particion | awk -F" " '{size=$2*1.024/1000; used=$3*1.024/1000; free=$4*1.024/1000; printf "%d:%d:%d", size,used,free}'`
847                ;;
848                GB)
849                        factor="1.024/1000000";
850                        valor=`df | grep $particion | awk -F" " '{size=$2*1.024/1000000; used=$3*1.024/1000000; free=$4*1.024/1000000; printf "%f:%f:%f", size,used,free}'`
851                ;;
852        esac
853        #echo $valor
854        #NumberRound $valor
855        #valor=`NumberRound $valor`;
856        ogUnmount $1 $2 1>/dev/null 2>&1
857        echo $valor
858
859fi
860
861}
Note: See TracBrowser for help on using the repository browser.