On Sat, Oct 30, 2010 at 9:46 AM, Patrick <kc7...@gmail.com> wrote:
>
> On Oct 30, 2010, at 8:45 AM, Nigel Kersten wrote:
>
>> http://projects.puppetlabs.com/issues/5158
>>
>> ----------------------- Ticket description ---------------
>>
>> We have four main ways we can specify file content in a file resource.
>>
>>
>> The source parameter
>> The content parameter
>> The file function
>> The template function
>>
>> These behave inconsistently in the following ways.
>>
>> The source parameter, file function and template function all can take
>> an array. For source/file, the first file that exists will be used.
>> For the template function, we concatenate the templates instead.
>>
>> The file function takes fully qualified paths only. The template
>> function takes fully qualified paths, or dereferences relative paths
>> as follows. ‘foo/bar.erb’ –> modules/foo/templates/bar.erb
>>
>> The latter problem is relatively easily solved, particularly if we
>> implement #4885
>>
>> We are going to have to break backwards compatibility to solve the
>> first problem however.
>>
>> My feeling is that more people make use of the multi-select logic in
>> the source parameter/file function than make use of the concatenation
>> of the template function.
>> -----------------------
>>
>> I'm opening this up for discussion here on the user list as we need to
>> all agree whether it's worth chasing consistency here at the cost of
>> breaking backwards compatibility.
>>
>> It appears that people use both the concatenation and multi-select
>> logic. How can we provide both bits of functionality for all these
>> methods?
>>
>> Here's a terrible suggestion that hopefully inspires a better one.
>> An array indicates multi-select logic, separation with a colon means
>> concatenate.
>>
>> 1a. Use the first source that exists.
>>
>> file { "/tmp/somefile":
>>  source => ["puppet:///modules/foo/somefile.$hostname",
>>                   "puppet:///modules/foo/somefile.default",]
>> }
>>
>> file { "/tmp/somefile":
>>  content => template("foo/somefile.$hostname.erb",
>>                                "foo/somefile.default.erb"),
>> }
>>
>> 1b. Concatenate multiple objects
>>
>> file { "/tmp/somefile":
>>  source => 
>> "puppet:///modules/foo/somefile.$hostname:puppet:///modules/foo/somefile.default",
>> }
>>
>> file { "/tmp/somefile":
>>  content => template("foo/somefile.$hostname.erb:foo/somefile.default.erb"),
>> }
>>
>> Is this so unsatisfactory that we need to add more parameters? What if
>> we pluralized for the concatenation with "sources" and "contents" ?
>>
>> 2b. New parameter for concatenation.
>>
>> file { "/tmp/somefile":
>>  sources => ["puppet:///modules/foo/somefile.$hostname",
>>                    "puppet:///modules/foo/somefile.default",]
>> }
>>
>> file { "/tmp/somefile":
>>  contents => [template("foo/somefile.$hostname.erb",
>>                     template("foo/somefile.default.erb")],
>> }
>>
>> Alternatively, do we really need to fix this? I think we do, as
>> consistency matters a lot to me, but maybe I'm on my own here?
>
> The best solution I can come up with is this.
>
> source - Unchanged because this is used so much.  Tries each source in turn 
> and uses the first one that works.  Fails if none work.
> content - Deprecated but kept for backwards compatibility
> source_concat - Concatenates all the given sources and causes the resource to 
> fail if any are missing.
> content_concat - behaves the same way as content does now and takes 
> precedence over content.
>
> Throw an error if two or more are used at the same time, except allow content 
> and content_concat to exist at the same time for backwards compatibility.

Would it be better if we could make the template function be aware of
a boolean parameter "concatenate" that changed the behavior when an
array is passed to it? (and we do the same thing for source)


> I also think the inconsistencies between "file()" and "template()" should be 
> addressed, but this would simplify it.

Absolutely. I would prefer to leave the existing behavior around for a
while and we implement http://projects.puppetlabs.com/issues/4885
which I think was your suggestion anyway :)



>
> --
> 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.
>
>



-- 
Nigel Kersten - Puppet Labs -  http://www.puppetlabs.com

-- 
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