diff options
| author | Luke Kanies <luke@puppetlabs.com> | 2011-04-14 17:08:17 -0700 |
|---|---|---|
| committer | Luke Kanies <luke@puppetlabs.com> | 2011-04-14 17:08:17 -0700 |
| commit | d53c84de9985421e6c667f095a10574171ece159 (patch) | |
| tree | 4b57f6e2852997faae127dd130c5f82f22c74c87 /lib/puppet/node.rb | |
| parent | e945cea00512d33c3d9d262b8285896febf946a3 (diff) | |
| parent | e424740d78b8b72dc6bd7ebbbe27b237347d67f5 (diff) | |
Merge branch 'tickets/next/7080-serializable_indirector_requests' into 2.7.x
Diffstat (limited to 'lib/puppet/node.rb')
| -rw-r--r-- | lib/puppet/node.rb | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/lib/puppet/node.rb b/lib/puppet/node.rb index 5b0a98615..4bd4d1de6 100644 --- a/lib/puppet/node.rb +++ b/lib/puppet/node.rb @@ -20,6 +20,29 @@ class Puppet::Node attr_accessor :name, :classes, :source, :ipaddress, :parameters attr_reader :time + def self.from_pson(pson) + raise ArgumentError, "No name provided in pson data" unless name = pson['name'] + + node = new(name) + node.classes = pson['classes'] + node.parameters = pson['parameters'] + node.environment = pson['environment'] + node + end + + def to_pson(*args) + result = { + 'document_type' => "Puppet::Node", + 'data' => {} + } + result['data']['name'] = name + result['data']['classes'] = classes unless classes.empty? + result['data']['parameters'] = parameters unless parameters.empty? + result['data']['environment'] = environment.name + + result.to_pson(*args) + end + def environment return super if @environment |
