Ir al contenido principal

Listas de acceso (ACL) en GNU/Linux


Introducción
El presente artículo muestra las posibilidades del modelo de permisos basado en listas de control de acceso o ACLs. Sobre todo debido a que el modelo de permiso de accesos UGO (User, Group, Others) tradicional de GNU/Linux es bastante limitado. Una de las características que se echan en falta en los sistemas GNU/Linux actuales, especialmente en entornos corporativos, es la posibilidad de especificar los permisos de acceso a los ficheros con mayor granularidad que en el sistema tradicional.

Hay un dato que se suele desconocer sin embargo y es que el sistema de ficheros ext2, desde su diseño original, previó la inclusión de este tipo de sistemas de control de acceso y estaban incluidos los enganches (hooks) necesarios para su implementación posterior, de forma 100% transparente y compatible hacia atrás.

Listas de control de acceso (ACL)
  1. Es un estándar Posix que extiende las posibilidades de los permisos admitiendo permisos específicos para usuarios/grupos sobre objetos concretos. 
  2. En GNU/Linux está disponible en ext2/ext3/xfs/jfs/Reiserfs... 
  3. Cada fichero/directorio tiene asociado una lista ACL compuesta por una serie de entradas (Access Control Entry, ACE). Cada ACE define un par (usuario/grupo, permiso).
Prerrequisitos
  • El sistema de ficheros tiene que estar montado con la opción acl:
$sudo mount -o remount,acl /
  • Instalación de las utilidades para la gestión de las listas de acceso:
$sudo apt-get install acl
  • Configurar el fstab para que el sistema de ficheros soporte las ACLs:
    • Editar el fichero y buscar la línea correspondiente a (raíz) o al sistema de ficheros que le vamos a aplicar las ACLs.
    • Añadir acl, (ojo con la coma, es obligatoria) justo antes de donde pone errors=remount, pegadito y sin espacios, es decir, al inicio de la sección de opciones.
    • Realizar el montaje del sistema de ficheros:
      $sudo mount -a
Buscar el programa a restringir
Hay veces que no sabemos el nombre del programa al que queremos aplicarle las ACL. La mejor opción de que disponemos es ejecutar el programa y, a continuación, ver que se está ejecutando por ese usuario:
$sudo ps -ef | grep "nombre_usuario"
En la lista buscaremos el programa, casi siempre estará en último lugar, si no es lo último que se ha ejecutado.

Restringir los permisos
Establecer los permisos al fichero /usr/bin/gnome-control-center, por ejemplo. Tienes que ser root, no te vale con el sudo.
  • Quitar acls anteriores:
    setfacl -b -k -R /usr/bin/gnome-control-center
  • Permiso de solo lectura para el usuario que especifiques:
    setfacl -m u:nombre_usuario:r /usr/bin/gnome-control-center
  • Ver los permisos poniendo: 
    getfacl /usr/bin/gnome-control-center
Problemas
  • Si por alguna razón el sistema da el mensaje: setfacl: /usr/bin/gnome-control-center: La operación no está soportada, hay que comprobar si el sistema de ficheros se montó correctamente con la opción acl. Ejecutamos el comando mount para ver los sistemas de archivos montados:
    #mount
    Este comando debe mostrar las opciones de montado de los sistemas de ficheros, algo así como:
    
    /dev/sda1 on / type ext4 (rw,acl,errors=remount-ro)
    proc on /proc type proc (rw,noexec,nosuid,nodev)
    none on /sys type sysfs (rw,noexec,nosuid,nodev)
    fusectl on /sys/fs/fuse/connections type fusectl (rw)
    none on /sys/kernel/debug type debugfs (rw)
    none on /sys/kernel/security type securityfs (rw)
    none on /dev type devtmpfs (rw,mode=0755)
    none on /dev/pts type devpts (rw,noexec,nosuid,gid=5,mode=0620)
    none on /dev/shm type tmpfs (rw,nosuid,nodev)
    none on /var/run type tmpfs (rw,nosuid,mode=0755)
    none on /var/lock type tmpfs (rw,noexec,nosuid,nodev)
    binfmt_misc on /proc/sys/fs/binfmt_misc type binfmt_misc (rw,noexec,nosuid,nodev)
    
    Vemos que la partición raíz ha sido montada con opciones para las acl. En el caso de que no aparezca con esas opciones habría que ejecutar el comando mount -o, tal y como se explicó más arriba, para que se vuelva a montar y así el comando setfacl no de error.

El uso de las ACLs en GNU/Linux puede sernos de gran utilidad. Recomiendo, como siempre, consultar las páginas del manual para ver una referencia completa de cada comando utilizado en este artículo. Las acciones llevadas a cabo en este artículo han sido probadas en sistemas con la distribución de Ubuntu 10.10, 11.04, 11.10 instaladas. 

Comentarios

Entradas populares de este blog

Atom ha muerto, viva Zed

El día 8 de junio de 2022, Microsoft anunció que a partir del día 31 de diciembre de este mismo año dejaría de dar soporte para el editor de código Atom .  ¿En qué nos afecta esto a nosotros? Bueno, pues si me han seguido en artículos anteriores saben que tras una comparativa de varios IDEs había decidido utilizar Atom para los ejemplos que tuviera que hacer en este blog. Sobre todo los artículos que prepararé para ilustrar el uso de Laravel . Amén de los miles de programadores que actualmente usan Atom  en sus proyectos, claro. Pero, ¿qué editor de código abierto podremos utilizar para sustituir a Atom ? En el mismo comunicado, Microsoft explicaba que el abandono del proyecto Atom  se debía a que querían volcar todos sus esfuerzos en el Visual Studio Code y, por supuesto, recomendó a los usuarios de Atom la utilización del mismo como alternativa natural. No quiero entrar en las bondades o defectos del Visual Studio Code  si quieres elegirlo como tu IDE para d...

Gestión de la red usando la línea de comandos (III): gestión DNS

  Introducción En este nuevo artículo de la serie vamos a hablar de la gestión del DNS, Domain Name System. El sistema de resolución de nombres nos permite traducir los nombres de los dominios de Internet en direcciones IP númericas. Más difíciles de recordar para los humanos.  El DNS fue concebido a mediados de los años 80. Hasta esa época, los ordenadores conectados a una red disponían de una dirección numérica, la dirección IP. Pero con el tiempo, cada vez había más ordenadores conectados a las redes. Esto hacía que cada vez fuera más difícil recordar las direcciones IP. Sobre el año 1983, Paul Mockapetris , un informático estadounidense, desarrolló un sistema jerárquico de nombres para identificar a los ordenadores conectados a una red. Y, a mediados de la década, ya se convirtió en un estándar. Pueden consultar más información sobre el sistema DNS consultando el artículo de la Wikipedia: Sistema de nombres de dominio . En este artículo, no vamos a explicar como montar un ...

Gestión de la red usando la línea de comandos (IV): monitorización de conexiones

  Introducción En este artículo de la serie de gestión de la red usando la línea de comandos nos vamos a centrar en la monitorización de las conexiones. Para ello vamos a utilizar el comando netstat , que es el decano de los comandos de monitorización de la red. También mostraremos el comando ss , que viene a sustituir a netstat  en las funciones de monitorización de conexiones de red. Asimismo mostraré una breve explicación de los conceptos que se van a trabajar en el artículo. S ockets, puertos, protocolos y procesos En primer lugar vamos a empezar con un poco de teoría para alumbrar lo que luego se explicará en el artículo. Si ya sabes de lo que estamos hablando, sáltate esta sección y ve al meollo del asunto [1] . Nos referiremos al contexto de la conexiones TCP/IP. Dentro de este contexto, cada conexión queda definida por dos endpoints , puntos finales, uno en el host , equipo, que establece la conexión y otro en el host con el que se comunica. Generalmente este último es...