On 8/17/12 9:43 AM, Douglas Garstang wrote:
> On Fri, Aug 17, 2012 at 9:33 AM, Douglas Garstang
> <doug.garst...@gmail.com> wrote:
>> On Fri, Aug 17, 2012 at 12:52 AM, Denmat <tu2bg...@gmail.com> wrote:
>>>
>>>
>>> On 17/08/2012, at 17:19, Douglas Garstang <doug.garst...@gmail.com> wrote:
>>>
>>>> On Thu, Aug 16, 2012 at 11:34 PM, Garrett Honeycutt
>>>> <garr...@puppetlabs.com> wrote:
>>>>> On 8/16/12 10:44 PM, Douglas Garstang wrote:
>>>>>> So, this has always puzzled me a bit. By convention, init.pp contains
>>>>>> one class, named the same as the module. However, what is the
>>>>>> convention when the module may have multiple external access points?
>>>>>> Say you have a module called 'syslog' which provides both a client and
>>>>>> a server class. I typically have used syslog::server and
>>>>>> syslog::client. I've ended up using this convention more than init.pp
>>>>>> because I don't know when I first put the class together exactly what
>>>>>> it's going to do. In module mymodule, rather than create init.pp with
>>>>>> class mymodule, I'll call it mymodule::base or something and stick it
>>>>>> in base.pp. Confused...
>>>>>>
>>>>>> Doug
>>>>>>
>>>>>
>>>>> Not all classes are meant to be directly included by nodes. A common
>>>>> practice would be having a module where you might have a base class,
>>>>> such as syslog and other sub classes, such as syslog::client and
>>>>> syslog::server. Class syslog would contain resources that were common to
>>>>> both syslog::client and syslog::server (ie: they both have a package and
>>>>> a config file). Both syslog::client and syslog::server might include (or
>>>>> possibly inherit) the syslog class. In this setup, a node might include
>>>>> syslog::server or syslog::client, but not syslog directly. When using
>>>>> this pattern, be sure to comment in your base class that it is not meant
>>>>> to be included directly.
>>>>
>>>> Garrett, thanks. Aware of all that, but I'm not sure you really answer
>>>> my question. :)
>>>>
>>>> Doug.
>>>>
>>> Well you can leave init.pp blank, ie,
>>> class name {
>>> }
>>>
>>> Then you can put whatever you like in the module's manifest dir.
>>>
>>> I tend to write 90% of modules with the following:
>>> name::config
>>> name::install
>>> name::service
>>> name::client
>>> name::server
>>>
>>> All of those refer to individual .pp files of course.
>>>
>>> Then something like:
>>> include name::server
>>
>> I guess you would normally include ::client or ::server, and it would
>> in turn, include (inherit?) ::config, ::install and ::service?
>>
>> Ie:
>>
>> class foo::client {
>>     include foo::config
>>     include foo::install
>>     include foo::service
>> }
>>
>> If variables are defined in ::config, does that cause any issues with scope?
> 
> So... I just gave this a try, and variables I defined in ::config have
> gone out of scope in ::install. *sigh*
> 
> Doug.
> 

I would be careful of using imperative terms such as install, configure,
build..

Puppet ensures state, so these words can be misleading.

-g

-- 
Garrett Honeycutt

206.414.8658
http://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-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