Estoy creando un usuario de la siguiente manera
user { $username:
comment => "$name",
shell => "$shell",
managehome => false,
password => "$password",
groups => $groups
}
Ahora, como pueden ver, estoy haciendo un inicio de gestión es falso Ahora, más adelante en el camino, necesito insertar un archivo en el directorio de inicio del usuario.
$key = "${homedir}/${name}/file"
file { $key:
ensure => present,
owner => $username,
group => $username,
mode => 600,
content => "$keyvalue",
subscribe => User[$username],
}
¿Cómo puedo obtener el directorio de inicio del usuario para esto?
Traté de encontrar una solución para el mismo problema, y resultó que es mejor adoptar un enfoque ligeramente diferente.
Defina el directorio de inicio explícitamente, por ejemplo:
Cuando
managehome
es falso, el directorio de inicio ni siquiera se crea. Entonces tienes que definirlo específicamente. A menudo es mejor hacer una definición personalizada para todo el usuario:Puede agregar más parámetros, por ejemplo
$keyvalue
, y crear un archivo de claves si se proporciona ese parámetro.También puede definir una variable global
$home = "/home"
(específica del sistema operativo, si es necesario) y obtener el directorio de inicio con"${home}/${username}"
.Editar: uso de hash para definir directorios de inicio específicos del usuario
Las versiones más recientes de Puppet (> = 2.6) admiten hashes. Sería posible definir un hash que contenga
username => /path/to/home
asignaciones para cada usuario:Para cualquier nombre de usuario, es fácil obtener el directorio de inicio
$home['username']
.Hash de directorio de inicio con respaldo
La mayoría de las veces, sería mejor tener un "valor predeterminado de reserva" si el usuario no existe en el hash. En teoría esto es posible, aunque la sintaxis se vuelve un poco críptica e hinchada:
fuente
Esta pregunta es antigua, pero sigue siendo relevante. De hecho, hay una mejor manera ahora. Agregue un hecho personalizado a [module] /lib/facter/home_dirs.rb que contenga lo siguiente:
Entonces puede acceder a los datos en el manifiesto de esta manera:
Tenga en cuenta que esto solo funciona si el usuario ya existe antes de la ejecución de la marioneta. Si el usuario se crea durante la ejecución, el directorio de inicio ya debe ser conocido o al menos predecible. Puppet está diseñado para crear orden, después de todo.
Espero que esto ayude a alguien.
fuente