David, thanks a ton for the suggestions. Being the only puppeteer at work
doesn't offer enough code reviews.

On Tue, Jul 13, 2010 at 11:27 PM, David Schmitt <da...@dasz.at> wrote:

> Hi Matthew,
>
> I've got no idea what's happening with NIS there, but here are some tips
> for improving the rest of your manifest:
>
>
> On 13.07.2010 18:39, Matthew Finlayson wrote:
>
>> class hostinghome {
>>
>>   createhostinghome {
>>     someuser: username => "someuser"; # Of course I actually have a lot
>> more users.
>>   }
>> }
>>
>> define createhostinghome ( $username ) {
>>
>
> You get the "title" as $name for free, so you can remove the $username:
>
> define hostinghome() { ... }
>
> hostinghome{ [ "user1", "user2", "user3" ]: }
>
>
>
> Defines define resources, so they should be called like objects, not like
> actions.
>
>
>      file {
>> "/home/$username" :
>>
>
> When you put a variable in a string, use ${...} to avoid ambiguities with
> the surroundings: e.g. "blah_$foo_blah" is equivalent to "blah_${foo_blah}",
> which might not be the intended usage.
>
>
>          ensure => directory,
>>         mode => 755,
>>         owner => "$username",
>>
>
> No quotes needed here.
>
>          require => [ Service['ypbind'] ];
>>
>
> You can require the whole Class['nis::client'] here. This reduces your need
> to track internal changes across modules.
>
>
>
>> "/home/$username/.ssh" :
>>         ensure => directory,
>>         require => [ File["/home/$username"] ],
>>
>
> The File type automatically requires its parent, so you can drop this
> require here.
>
>
>          mode => 755,
>>         owner => "$username";
>>
>> "/home/$username/.bashrc" :
>>         ensure => present,
>>         source => "puppet:///modules/hostinghome/bashrc",
>>         require => [ File["/home/$username"] ],
>>         mode => 755,
>>         owner => "$username";
>>
>> "/home/$username/.bash_profile" :
>>         ensure => present,
>>         source => "puppet:///modules/hostinghome/bash_profile",
>>         require => [ File["/home/$username"] ],
>>         mode => 755,
>>         owner => "$username";
>>
>> "/home/$username/.ssh/authorized_keys" :
>>         ensure => present,
>>         source => "puppet:///modules/hostinghome/$username.id_rsa.pub",
>>         require => [ File["/home/$username/.ssh"] ],
>>         mode => 755,
>>         owner => "$username";
>>
>>     }
>> }
>>
>>
>  The createhostinghome function fails on first run every time with the
>> following error:
>>
>> Jul 12 17:14:16 hostname puppetd[3374]:
>> (//nis::client/File[/etc/sysconfig/network]/content) content changed
>> '{md5}72d98a65b2c24b801e6146823237621b' to 'unknown checksum'c
>> Jul 12 17:14:17 hostname ypbind: bound to NIS server
>> dns.vmhosted.domainname.com <http://dns.vmhosted.domainname.com>
>>
>> Jul 12 17:14:18 hostname puppetd[3374]:
>> (//nis::client/Service[ypbind]/ensure) ensure changed 'stopped' to
>> 'running'e
>> Jul 12 17:14:18 hostname puppetd[3374]: (//nis::client/Service[ypbind])
>> Triggering 'refresh' from 3 dependenciesr
>> Jul 12 17:14:19 hostname ypbind: bound to NIS server
>> dns.vmhosted.domainname.com <http://dns.vmhosted.domainname.com>
>>
>> Jul 12 17:14:19 hostname puppetd[3374]:
>> (//hostinghome/Createhostinghome[someuser]/File[/home/someuser]/ensure)
>> change from absent to directory failed: Could not set directory on
>> ensure: Could not find user someuser at
>> /etc/puppet/modules/hostinghome/manifests/init.pp:66c
>>
>> On the second run the home directories and ownership are set correctly.
>> I've played with various require statements as well as before with no
>> success. Any help or suggestions would be appreciated.
>>
>
> Since it works on the second run, it might be possible, that puppet
> pre-loads the users on startup, but I'm not sure. Someone else has any
> ideas/experiences?
>
>
> Best Regards, David
>
>
> --
> You received this message because you are subscribed to the Google Groups
> "Puppet Users" group.
> To post to this group, send email to puppet-us...@googlegroups.com.
> To unsubscribe from this group, send email to
> puppet-users+unsubscr...@googlegroups.com<puppet-users%2bunsubscr...@googlegroups.com>
> .
> For more options, visit this group at
> http://groups.google.com/group/puppet-users?hl=en.
>
>

-- 
You received this message because you are subscribed to the Google Groups 
"Puppet Users" group.
To post to this group, send email to puppet-us...@googlegroups.com.
To unsubscribe from this group, send email to 
puppet-users+unsubscr...@googlegroups.com.
For more options, visit this group at 
http://groups.google.com/group/puppet-users?hl=en.

Reply via email to