I. About

    This project helps you to create high quality Puppet modules in a fast and
    comfortable way. Main targets are to boost your efficiency and Puppet code
    quality. Use it if you want to get Puppet module skeletons with:

    - tidy and easily extendable structure
    - good documentation
    - source code which follows the official style guide [1]
    - parameterized classes [2]

    Just call the "new module wizard", answer the questions and start editing.
    If you want to get an impression of what to expect, you may have a look at
    the "puppet-boilerplate-modules-example-content" [3] repository.

    [1] <http://docs.puppetlabs.com/guides/style_guide.html>
    [2] <http://docs.puppetlabs.com/guides/parameterized_classes.html>
    [3] <http://j.mp/JVPxKL>



  II. Usage

    1. Clone the repository:
       $ git clone git://github.com/bitkollektiv/puppet-boilerplate-modules.git

    2. Call the wizard to create the module skeleton for a new module:
       $ ./puppet-boilerplate-modules/newmodule.sh
       You can provide the answers by using parameters. Use "newmodule.sh -h" to
       get a listing.

    3. ???

    4. Profit!!!

    The "puppet-boilerplate-modules-example-content" [1] repository is your
    friend if you need more help. It provides example modules including detailed
    creation transcripts.

    [1] <http://j.mp/JVPxKL>



  III. How to add a new boilerplate

    The existing boilerplates may not fit your needs. Therefore it might make
    sense to add your own boilerplate. The newmodule.sh will list every
    directory as boilerplate if it can find a "/manifests/init.pp" file in it.
    So all you have to do is:

    1. Create a directory for the new boilerplate (name: [a-zA-Z0-9-_] only).

    2. Optional but recommended: put a DESCRIPTION file into the boilerplate's
       root dir. The newmodule.sh will show the file content when listing the
       available boilerplates as description then.

    3. Add everything your boilerplate needs. Please note that all files have
       to be UTF-8 encoded so take care your editor can handle UTF-8.

    4. The newmodule.sh executes different actions when creating a new skeleton.
       It copies the chosen boilerplate to the specified target dir, renames
       files/dirs and does some string replacements to create a useful module
       skeleton. You can use placeholders for your new boilerplate and
       newmodule.sh inserts the real data it asked the user for.

       - The following case sensitive string replacements will be done in every
         file of your boilerplate:
           John Doe               gets replaced with   the author name
           john.doe@example.com   gets replaced with   the author email address
           YYYY                   gets replaced with   the current year
           boilerplate            gets replaced with   the module name

       - "boilerplate" gets replaced with the module name in every file name and
          dir name. Example: If the user told newmodule.sh that the name for the
          new module is "test", the file "/manifests/fooboilerplatebar.pp" would
          be renamed into "/manifests/footestbar.pp".



  IV. How to remove a boilerplate

    The newmodule.sh will list every directory as boilerplate if it can find a
    "/manifests/init.pp" file in it. So you may just delete the boilerplate's
    directory to remove it or e.g. rename the boilerplate's "/manifests/init.pp"
    to prevent its listing.



  V. Contact

    If you think you have found a bug or have a useful idea (a.k.a. "feature
    request"), create an issue [1] on GitHub (preferred), or contact us by
    mail [2].

    Feel free to submit patches as GitHub pull requests (preferred) or by mail
    as well. However, please try to respect the official style guide [3] as this
    project follows its rules.

    [1] <https://github.com/bitkollektiv/puppet-boilerplate-modules/issues>
    [2] Andreas Haerter <ah@bitkollektiv.org>
        Andreas Wolf <aw@bitkollektiv.org>
    [3] <http://docs.puppetlabs.com/guides/style_guide.html>



  VI. Other notes

    If you like this free project, you might buy us a coffee [1], or get some
    cool QR Code merchandise [2]. Thank you! :-)

    [1] <http://bitkollektiv.org/donate/puppet-modules/>
    [2] <http://goqr.me/>