During on of the last talks of the last day of FOSDEM, some person asked in one of the tracks (paraphrased):

Why do we need tools like Puppet or Chef when we have XML?

This question was relayed to me second-hand, so I apologize if I’m butchering it. The question itself is so mind-boggling that I can only assume one of three things about the asker:

  • He/she is a rather talented troll
  • He/she has some crucial misunderstandings about configuration management, in which case I’m hoping somebody politely explained things.
  • He/she understands CM but has a serious fetish for XML.

Regardless of their intention, I have them to thank for inspiring what might be the innovation breakthrough of 2012:

Puppet/XML

I’ve long found Puppet’s DSL syntax to be too sparse, easy to type and semantically boring, take for example this block:

class users {
    group {
        "tyler" :
            ensure => present;
    }
    user {
        "tyler" :
            require => Group["tyler"],
            ensure  => present;
    }
}

How terrible! Let’s turn that into Puppet/XML!

<?xml version="1.0"?>
<puppet>
    <classes>
        <class name="users">
            <resources>
                <group name="tyler">
                    <ensure>present</ensure>
                </group>
                <user name="tyler">
                    <requires>
                        <require>Group["tyler"]</require>
                    </requires>
                    <ensure>present</ensure>
                </user>
            </resources>
        </class>
    </classes>
</puppet>

Not only is that easier to understand, it’s more enterprise ready!

Currently Puppet/XML is in pre-alpha and in this repository on GitHub. Thus far it’s only been tested with puppet apply (i.e. standalone mode) under Vagrant, an example run is below:

[default] Running Puppet with /tmp/vagrant-puppet/manifests/base.ppx...
stdin: is not a tty
Thanks for using Puppet/XML - A brand new synergy

info: Retrieving plugin
info: Applying configuration version '1328719113'
notice: /Stage[main]/Users/User[tyler]/ensure: created
notice: /Stage[main]//Node[default]/Group[puppet]/ensure: created
info: Creating state file /var/lib/puppet/state/state.yaml
notice: Finished catalog run in 0.62 seconds

Stay tuned for new innovations and more middleware that your enterprise can leverage to help meet your business objectives.


Disclaimer: Unfortunately the code currently relies on transcribing the Puppet/XML to Puppet’s “native” DSL, this means more complex things like conditionals and function calls are not yet supported. After spending about an hour and a half trying to generate the appropriate Puppet::AST structures, I gave up and went the route which guaranteed lulz sooner.