source: client/engine/FileSystem.lib @ a25cc03

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 a25cc03 was c114529, checked in by adv <adv@…>, 14 years ago

version 1.0 engine FileSystem?.lib

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

  • Property mode set to 100755
File size: 30.9 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#@version 1.0 -  Deteccion automatica del tamaño minimo adecuado
623#@author  Antonio J. Doblas Viso. Universidad de Malaga
624#@date    2011-02-24
625#*/ ##
626function ogReduceFs ()
627{
628# Variables locales
629local PART BLKS SIZE
630
631# Si se solicita, mostrar ayuda.
632if [ "$*" == "help" ]; then
633    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" \
634           "$FUNCNAME 1 1"
635    return
636fi
637# Error si no se reciben 2 parámetros.
638[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
639
640# Obtener partición.
641PART="$(ogDiskToDev $1 $2)" || return $?
642
643# Redimensionar según el tipo de particion.
644case "$(ogGetFsType $1 $2)" in
645    EXT[234])
646        ogUnmount $1 $2 2>/dev/null
647        # Ext2/3/4: Tamaño de los bloques del sistema de archivos
648        BLKS=$(tune2fs -l $PART | awk '/Block size/ {print int($3/512)}')
649        # Traduce el num. en sectores de 512B a tamano en MB.
650        #SIZE=$(resize2fs -P $PART 2>/dev/null | \
651                #       awk -v B=$BLKS '/minimum size/ {print int($7*1.1*B/2048)}')
652        #resize2fs -fp $PART "${SIZE}M" &>/dev/null || ogRaiseError $OG_ERR_PARTITION "$1,$2" || return $?
653        resize2fs -fpM $PART  &>/dev/null || ogRaiseError $OG_ERR_PARTITION "$1,$2" || return $?
654            ;;
655#    REISERFS)          # Usar "resize_reiserfs"
656#           ;;
657    NTFS|HNTFS)
658        ogDeleteFile $1 $2 pagefile.sys
659        ogDeleteFile $1 $2 hiberfile.sys
660        ogUnmount $1 $2 2>/dev/null
661        ## NTFS: Obtiene tamaño mínimo en MB.
662        #SIZE=$(ntfsresize -fi $PART | awk '/resize at/ {print int($8*1.1)}')
663        #ntfsresize -fns "${SIZE}M" $PART >/dev/null || ogRaiseError $OG_ERR_PARTITION "$1,$2" || return $?
664        #ntfsresize -fs "${SIZE}M" $PART <<<"y" >/dev/null || ogRaiseError $OG_ERR_PARTITION "$1,$2" || return $?
665                SIZE=$(ogReduceFsCheck $1 $2)
666            [ "$SIZE" == 0 ] && return 1       
667        ntfsresize -fs "${SIZE}M" $PART <<<"y"  || ogRaiseError $OG_ERR_PARTITION "error reduciendo $1,$2" || return $?
668            ;;
669    *)  ogRaiseError $OG_ERR_PARTITION "$1,$2"
670            return $? ;;
671esac
672#/// Mostrar nuevo tamaño en KB.
673#echo $[SIZE*1024]
674ogGetFsSize $1 $2
675}
676
677
678function ogReduceFsCheck ()
679{
680#IMPORTANTE: retorna el valor en MB que podrá reducir el FS de una particion ntfs
681#valor devuelto 0, y codigo error 1. No se puede reducir, probar a reiniciar windows y chkdsk
682
683
684local  PART RC MODE SIZE SIZEDATA
685[ $# == 2 ] && MODE=STAGE1
686[ $# == 3 ] && MODE=STAGE2
687[ -z $MODE ] && return
688
689PART="$(ogDiskToDev $1 $2)" || return $?
690ogUnmount $1 $2 &>/dev/null
691
692
693case $MODE in
694        STAGE1)
695        #       echo "primera etapa $*"
696                ntfsresize -fi $PART &>/dev/null
697                RC=`echo $?`
698        #       echo "RC es" $RC
699                if [ "$RC" -eq "1" ]
700                then
701                        echo "0"
702                        return 1       
703                fi 
704                SIZEDATA=$(ntfsresize -fi $PART | awk '/resize at/ {print $8+1000}')
705        #       echo "salida" $?
706        #       echo $SIZEDATA
707                ogReduceFsCheck $1 $2 $SIZEDATA
708                return 0
709       ;;
710        STAGE2)
711        #       echo "segunda etapa $*"
712                SIZEDATA=$3
713                ntfsresize -fns "${SIZEDATA}M" $PART &>/tmp/ntfsresize.txt
714                RC=$?
715                if [ "$RC" == "0" ]
716                then 
717                        SIZE=$SIZEDATA 
718                        echo $SIZE     
719                else
720                        SIZEEXTRA=$(cat /tmp/ntfsresize.txt | awk '/Needed relocations :/ {print $0}' | awk -F"(" '{print $2}' | awk '{print $1+500}')
721                        SIZE=$(expr $SIZEDATA + $SIZEEXTRA)
722                        ogReduceFsCheck $1 $2 $SIZE
723                        return 0
724                fi
725        ;;
726        *)
727        return
728        ;;
729esac
730}
731
732
733
734#/**
735#         ogUnlock int_ndisk int_npartition
736#@see     ogUnlockPartition
737#*/
738function ogUnlock ()
739{
740ogUnlockPartition "$@"
741}
742
743#/**
744#         ogUnlockPartition int_ndisk int_npartition
745#@brief   Elimina el fichero de bloqueo para una particion.
746#@param   int_ndisk      nº de orden del disco
747#@param   int_npartition nº de orden de la partición
748#@return  (nada)
749#@exception OG_ERR_FORMAT    Formato incorrecto.
750#@exception OG_ERR_NOTFOUND  Disco o particion no corresponden con un dispositivo.
751#@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 "-".
752#@version 0.9 - Primera versión para OpenGNSys.
753#@author  Ramon Gomez, ETSII Universidad de Sevilla
754#@date    2009-09-03
755#*/ ##
756function ogUnlockPartition ()
757{
758# Variables locales
759local PART LOCKFILE
760
761# Si se solicita, mostrar ayuda.
762if [ "$*" == "help" ]; then
763    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" \
764           "$FUNCNAME 1 1"
765    return
766fi
767# Error si no se reciben 2 parámetros.
768[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
769
770# Obtener partición.
771PART="$(ogDiskToDev $1 $2)" || return $?
772
773# Borrar archivo de bloqueo exclusivo.
774LOCKFILE="/var/lock/lock${PART//\//-}"
775rm -f $LOCKFILE
776}
777
778
779#/**
780#         ogUnmount int_ndisk int_npartition
781#@see     ogUnmountFs
782#*/
783function ogUnmount ()
784{
785ogUnmountFs "$@"
786}
787
788#/**
789#         ogUnmountFs int_ndisk int_npartition
790#@brief   Desmonta un sistema de archivos.
791#@param   int_ndisk      nº de orden del disco
792#@param   int_npartition nº de orden de la partición
793#@return  Nada
794#@exception OG_ERR_FORMAT    Formato incorrecto.
795#@exception OG_ERR_NOTFOUND  Disco o particion no corresponden con un dispositivo.
796#@warning La partición no está previamente montada o no se puede desmontar.
797#@version 0.1 -  Integracion para Opengnsys  -  EAC:  UmountPartition() en FileSystem.lib
798#@author  Antonio J. Doblas Viso. Universidad de Malaga
799#@date    2008-10-27
800#@version 0.9 - Primera version para OpenGNSys.
801#@author  Ramon Gomez, ETSII Universidad de Sevilla
802#@date    2009-09-28
803#*/ ##
804function ogUnmountFs ()
805{
806# Variables locales
807local PART MNTDIR
808
809# Si se solicita, mostrar ayuda.
810if [ "$*" == "help" ]; then
811    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" "$FUNCNAME 1 1"
812    return
813fi
814# Error si no se reciben 2 parámetros.
815[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
816
817# Obtener partición y punto de montaje.
818PART="$(ogDiskToDev $1 $2)" || return $?
819MNTDIR="$(ogGetMountPoint $1 $2)"
820
821# Si está montada, desmontarla.
822if [ -n "$MNTDIR" ]; then
823    # Error si la particion está bloqueada.
824    ogIsLocked $1 $2 && ogRaiseError $OG_ERR_LOCKED "$1 $2" && return $?
825    # Desmontar y borrar punto de montaje.
826    umount $PART 2>/dev/null || ogEcho warning "$FUNCNAME: $MSG_DONTUNMOUNT: \"$1,$2\""
827    rmdir $MNTDIR 2>/dev/null || rm -f $MNTDIR 2>/dev/null
828        # linea temporal durante desarrollo para testear nuevas herramientas con el cliente completo nfs
829    if grep -q nfsroot /proc/cmdline; then
830                cat /etc/mtab | grep -v $PART > /var/tmp/mtab.temporal && cp /var/tmp/mtab.temporal /var/tmp/mtab && rm /var/tmp/mtab.temporal
831        fi
832        # fin linea temporal.
833else
834    ogEcho warning "$MSG_DONTMOUNT: \"$1,$2\""
835fi
836}
837
838
839#/**
840#         ogUnmountAll int_ndisk
841#@brief   Desmonta todos los sistema de archivos de un disco, excepto el caché local.
842#@param   int_ndisk      nº de orden del disco
843#@return  Nada
844#@exception OG_ERR_FORMAT    Formato incorrecto.
845#@exception OG_ERR_NOTFOUND  Disco o particion no corresponden con un dispositivo.
846#@warning No se desmonta la partición marcada como caché local.
847#@version 0.9 - Versión para OpenGNSys.
848#@author  Ramon Gomez, ETSII Universidad de Sevilla
849#@date    2009/10/07
850#*/ ##
851function ogUnmountAll ()
852{
853# Variables locales
854local DISK PART
855# Si se solicita, mostrar ayuda.
856if [ "$*" == "help" ]; then
857    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk" "FUNCNAME 1"
858    return
859fi
860# Error si no se recibe 1 parámetro.
861[ $# == 1 ] || ogRaiseError $OG_ERR_FORMAT || return $?
862
863# Obtener partición y punto de montaje.
864DISK="$(ogDiskToDev $1)" || return $?
865for ((PART=1; PART<=$(ogGetPartitionsNumber $1); PART++)); do
866    case "$(ogGetFsType $1 $PART)" in
867        CACHE|LINUX-SWAP)
868           ;;
869        *)
870           ogUnmount $1 $PART ;;
871    esac
872done
873}
874
875#/**  @function ogGetFsSize: @brief Muestra el tamanio del sistema de archivos indicado, permite definir la unidad de medida, por defecto GB
876#@param  $1 int_diskEAC
877#@param $2 int_PartitionEAC
878#@param $3 str_UnidadMediada            parametro opcional, admite [ kB MB GB -default GB]
879#@return  cadena con int_TotalSize:int_DataSize:int_DataFree
880#@warning  Salidas de errores no determinada
881#@warning
882#@attention
883#@version 0.1 -  Integracion para Opengnsys  -  EAC:  SizeFileSystem() en FileSystem.lib
884#@author  Antonio J. Doblas Viso. Universidad de Malaga
885#@date    2008-10-27
886#*/
887function ogGetFsSize () {
888if [ $# = 0 ]
889then
890        echo "sintaxis: ogGetFsSize int_disco int_partition str_SizeOutput [ kB MB GB -default GB]-]" red
891        echo "devuelve int_size : int_data : int_free" red
892return
893fi
894if [ $# -ge 2 ]
895then
896        particion=`ogMount $1 $2 ` #1>/dev/null 2>&1
897        if [ -z $3 ]
898                then
899                        unit=kB  # s B kB MB GB TB %
900                else
901                        unit=$3
902        fi
903        case $unit in
904                kB)
905                        factor="1.024";
906                #       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}'`
907                        valor=`df | grep  $particion | awk -F" " '{size=$2*1.024; used=$3*1.024; free=$4*1.024; printf "%d", size}'`
908                ;;
909                MB)
910                        factor="1.024/1000";
911                        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}'`
912                ;;
913                GB)
914                        factor="1.024/1000000";
915                        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}'`
916                ;;
917        esac
918        #echo $valor
919        #NumberRound $valor
920        #valor=`NumberRound $valor`;
921        ogUnmount $1 $2 1>/dev/null 2>&1
922        echo $valor
923
924fi
925}
926
927function ogGetFreeSize () {
928if [ $# = 0 ]
929then
930        echo "sintaxis: ogGetFreeSize int_disco int_partition str_SizeOutput [ kB MB GB -default GB]-]" red
931        echo "devuelve int_size : int_data : int_free" red
932return
933fi
934if [ $# -ge 2 ]
935then
936        particion=`ogMount $1 $2 ` #1>/dev/null 2>&1
937        if [ -z $3 ]
938                then
939                        unit=kB  # s B kB MB GB TB %
940                else
941                        unit=$3
942        fi
943        case $unit in
944                kB)
945                        factor="1.024";
946                        #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}'`
947                        valor=`df | grep  $particion | awk -F" " '{size=$2*1.024; used=$3*1.024; free=$4*1.024; printf "%d", free}'`
948                        ;;
949                MB)
950                        factor="1.024/1000";
951                        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}'`
952                ;;
953                GB)
954                        factor="1.024/1000000";
955                        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}'`
956                ;;
957        esac
958        #echo $valor
959        #NumberRound $valor
960        #valor=`NumberRound $valor`;
961        ogUnmount $1 $2 1>/dev/null 2>&1
962        echo $valor
963
964fi
965}
966
967
968
969function ogDeletePartitionsLabels ()
970{
971# Si se solicita, mostrar ayuda.
972if [ "$*" == "help" ]; then
973    ogHelp "$FUNCNAME" "$FUNCNAME " \
974           "$FUNCNAME "
975    return
976fi
977rm /dev/disk/by-label/* 2>/dev/null   # */ COMENTARIO OBLIGATORIO PARA DOXYGEN
978}
979
980function ogDeletePartitionTable ()
981{
982
983# Variables locales.
984local DISK
985
986# Si se solicita, mostrar ayuda.
987if [ "$*" == "help" ]; then
988    ogHelp "$FUNCNAME int_disk"  \
989           "$FUNCNAME 1"
990    return
991fi
992# Error si no se reciben 1 parámetros.
993[ $# == 1 ] || ogRaiseError $OG_ERR_FORMAT || return $?
994
995# Obteniendo Identificador linux de la particion.
996DISK=$(ogDiskToDev $1) || return $?
997
998# Elimando las particiones con fdisk
999echo -ne "o\nw" | fdisk $DISK
1000}
Note: See TracBrowser for help on using the repository browser.