summaryrefslogtreecommitdiffstats
path: root/lib/puppet/node.rb
diff options
context:
space:
mode:
authorLuke Kanies <luke@puppetlabs.com>2011-04-14 17:08:17 -0700
committerLuke Kanies <luke@puppetlabs.com>2011-04-14 17:08:17 -0700
commitd53c84de9985421e6c667f095a10574171ece159 (patch)
tree4b57f6e2852997faae127dd130c5f82f22c74c87 /lib/puppet/node.rb
parente945cea00512d33c3d9d262b8285896febf946a3 (diff)
parente424740d78b8b72dc6bd7ebbbe27b237347d67f5 (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.rb23
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