We keep our puppet configuration in a revision control system and are
trying to facilitate developers using the same modules as production/
staging servers.

We define a variable ($servergroup) as test/staging/production and use
fileserver defaults from hostname to servergroup to generic.  The
hostname and $servergroup versions need to be confidential.  We have
modules specific to an application, say "helloworld" which include
configuration files (say, database.yml) that could contain sensitive
information.

Oversimplified example:

class apps::helloworld {
  file { "/home/apps/helloworld/config/database.yml":
    source  => [
        "puppet:///modules/apps/helloworld/database.yml.$hostname",
        "puppet:///modules/apps/helloworld/database.yml.$servergroup",
        "puppet:///modules/apps/helloworld/database.yml"
        ],
  }
}


We would like to be able to share the entire mercurial repository with
developers and others in the company, but the contents of all but the
default/generic database.yml need to be tightly controlled.

We had sort of solved this problem with a custom fileserver mount
point and a subrepo in our mercurial repo, but this only worked when
referring to content as puppet://hostname/custommountpoint.  As soon
as we switched to omitting the hostname ("puppet:///") we can't get
the references to the subrepo to work since it wasn't actually
modules.

In a perfect world, we could share the main puppet repo with everyone,
keep a tighter controlled subrepo of confidential data, and have local
development environments using the same class as live, but having
their otherwise confidential config created as an insecure default
file (containing generic development environment passwords, etc).
These local development environments might be using local copies of
the configuration (via vagrant & puppet apply, for example) and would
not have access to the puppet master.

If there's a better way to solve this by having the file contents be a
template output that would work too (while the above is an over
simplified example, nearly everything we have this problem with is
better done as a template anyways), but again some of the variables
would have to be hidden/confidential.

-Scott

-- 
You received this message because you are subscribed to the Google Groups 
"Puppet Users" group.
To post to this group, send email to puppet-users@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