木偶:获取用户主目录

我正在创build一个用户如下

user { $username: comment => "$name", shell => "$shell", managehome => false, password => "$password", groups => $groups } 

现在,你可以看到我正在做一个pipe理家是错误的现在稍后在通道我需要将文件推送到用户的主目录。

 $key = "${homedir}/${name}/file" file { $key: ensure => present, owner => $username, group => $username, mode => 600, content => "$keyvalue", subscribe => User[$username], } 

我怎样才能得到这个用户的主目录

嗯,我想在那里你需要一个模块来做到这一点和一个小哈克清单文件…

facter模块:这将为所有用户注册factervariables。 像“home_root”或“home_apache”。

 require 'etc' Etc.passwd { |user| Facter.add("home_#{user.name}") do setcode do user.dir end end } 

然后你可以像这样在你的清单文件中使用它们:

 $username = "root" $home = "home_$username" $home_path = inline_template("<%= scope.lookupvar('::$home') %>") file { "$home_path/test.txt": content => "huhu", } 

也许有更好的办法,但我恐怕不是。

我试图find一个完全相同的问题的解决scheme,事实certificate,最好采取一个稍微不同的方法。

明确定义主目录,例如:

 user { $username: comment => "comment", home => "/home/${username}", managehome => false, # ... } 

managehome为false时,甚至不创build主目录。 所以你必须明确地定义它。 通常最好为整个用户制定一个自定义的定义:

 define custom_user($username, $password) { user { $username: home => "/home/${username}", password => $password, # etc. } file { "/home/${username}": ensure => directory, owner => $username, require => User[$username], # etc. } } 

你可以添加更多的参数,例如$keyvalue ,如果给出了这个参数,就创build一个密钥文件。

你也可以定义一个全局variables$home = "/home" (如果需要,操作系统特定的),然后用"${home}/${username}"得到主目录。

编辑:使用散列来定义用户特定的主目录

更新的Puppet版本(> = 2.6)支持哈希。 可以为每个用户定义一个包含username => /path/to/home映射的散列:

 $home = { normal_user => '/home/normal_user', backup => '/var/backup', mysql => '/var/lib/mysql' } 

对于任何用户名,使用$home['username']可以轻松获得主目录。

主目录散列与回退

大多数情况下,如果用户不在散列中,最好有一个“后备默认”。 理论上这是可能的,尽pipe语法变得有点神秘和臃肿:

 $home = { ... } $default_home = '/home' user {$username: home => has_key($home, $username) ? { true => $home[$username], false => "${default_home}/${username}" } # ... }