Module: Puppet::Util::PsychSupport
- Included in:
- Graph::SimpleGraph, Indirector::Request, Node, Node::Facts, Relationship, Resource, Resource::Status, Transaction::Report, Log, Metric
- Defined in:
- lib/puppet/util/psych_support.rb
Overview
This module should be included when a class can be serialized to yaml and needs to handle the deserialization from Psych with more control. Psych normally pokes values directly into an instance using ‘instance_variable_set` which completely bypasses encapsulation.
The class that includes this module must implement an instance method ‘initialize_from_hash` that is given a hash with attribute to value mappings.
Instance Method Summary collapse
-
#encode_with(psych_encoder) ⇒ Object
This method is called from the Psych Yaml serializer The serializer will call this method to create a hash that will be serialized to YAML.
-
#init_with(psych_coder) ⇒ Object
This method is called from the Psych Yaml deserializer when it encounters a tag in the form !ruby/object:<class name>.
Instance Method Details
#encode_with(psych_encoder) ⇒ Object
This method is called from the Psych Yaml serializer The serializer will call this method to create a hash that will be serialized to YAML. Instead of using the object itself during the mapping process we use what is returned by calling ‘to_data_hash` on the object itself since some of the objects we manage have asymmetrical serialization and deserialization.
26 27 28 29 |
# File 'lib/puppet/util/psych_support.rb', line 26 def encode_with(psych_encoder) tag = Psych.[self.class] || "!ruby/object:#{self.class.name}" psych_encoder.represent_map(tag, to_data_hash) end |
#init_with(psych_coder) ⇒ Object
This method is called from the Psych Yaml deserializer when it encounters a tag in the form !ruby/object:<class name>.
13 14 15 16 17 18 |
# File 'lib/puppet/util/psych_support.rb', line 13 def init_with(psych_coder) # The PsychCoder has a hashmap of instance variable name (sans the @ symbol) to values # to set, and can thus directly be fed to initialize_from_hash. # initialize_from_hash(psych_coder.map) end |