Ho cercato di trovare una soluzione per lo stesso identico problema e alla fine è stato meglio adottare un approccio leggermente diverso.
Definire esplicitamente la home directory, ad esempio:
user { $username:
comment => "comment",
home => "/home/${username}",
managehome => false,
# ...
}
Quando managehome
è falso, la home directory non viene nemmeno creata. Quindi devi definirlo in modo specifico. Spesso è meglio fare una definizione personalizzata per l'intero utente:
define custom_user($username, $password) {
user { $username:
home => "/home/${username}",
password => $password,
# etc.
}
file { "/home/${username}":
ensure => directory,
owner => $username,
require => User[$username],
# etc.
}
}
È possibile aggiungere più parametri, ad esempio $keyvalue
, e creare un file di chiavi se viene fornito quel parametro.
Puoi anche definire una variabile globale $home = "/home"
(specifica del sistema operativo, se necessario) e ottenere home directory con "${home}/${username}"
.
Modifica: utilizzo dell'hash per definire home directory specifiche dell'utente
Le versioni più recenti di Puppet (> = 2.6) supportano gli hash. Sarebbe possibile definire un hash contenente username => /path/to/home
mappature per ciascun utente:
$home = {
normal_user => '/home/normal_user',
backup => '/var/backup',
mysql => '/var/lib/mysql'
}
Per qualsiasi nome utente, è quindi facile ottenere home directory con $home['username']
.
Hash della directory home con fallback
Il più delle volte, sarebbe meglio avere un "default di fallback" se l'utente non esiste nell'hash. In teoria questo è possibile, sebbene la sintassi diventi un po 'criptica e gonfia:
$home = { ... }
$default_home = '/home'
user {$username:
home => has_key($home, $username) ? {
true => $home[$username],
false => "${default_home}/${username}"
}
# ...
}