Class: MCollective::RPC::Reply
- Inherits:
-
Object
- Object
- MCollective::RPC::Reply
- Defined in:
- lib/mcollective/rpc/reply.rb
Overview
Simple class to manage compliant replies to MCollective::RPC
Instance Attribute Summary collapse
-
#data ⇒ Object
Returns the value of attribute data.
-
#statuscode ⇒ Object
Returns the value of attribute statuscode.
-
#statusmsg ⇒ Object
Returns the value of attribute statusmsg.
Instance Method Summary collapse
-
#[](key) ⇒ Object
Read from the data hash.
-
#[]=(key, val) ⇒ Object
Write to the data hash.
-
#fail(msg, code = 1) ⇒ Object
Helper to fill in statusmsg and code on failure.
-
#fail!(msg, code = 1) ⇒ Object
Helper that fills in statusmsg and code but also raises an appropriate error.
- #fetch(key, default) ⇒ Object
-
#initialize(action, ddl) ⇒ Reply
constructor
A new instance of Reply.
- #initialize_data ⇒ Object
-
#to_hash ⇒ Object
Returns a compliant Hash of the reply that should be sent over the middleware.
Constructor Details
#initialize(action, ddl) ⇒ Reply
Returns a new instance of Reply.
7 8 9 10 11 12 13 14 15 16 17 18 19 |
# File 'lib/mcollective/rpc/reply.rb', line 7 def initialize(action, ddl) @data = {} @statuscode = 0 @statusmsg = "OK" @ddl = ddl @action = action begin initialize_data rescue Exception => e Log.warn("Could not pre-populate reply data from the DDL: %s: %s" % [e.class, e.to_s ]) end end |
Instance Attribute Details
#data ⇒ Object
Returns the value of attribute data.
5 6 7 |
# File 'lib/mcollective/rpc/reply.rb', line 5 def data @data end |
#statuscode ⇒ Object
Returns the value of attribute statuscode.
5 6 7 |
# File 'lib/mcollective/rpc/reply.rb', line 5 def statuscode @statuscode end |
#statusmsg ⇒ Object
Returns the value of attribute statusmsg.
5 6 7 |
# File 'lib/mcollective/rpc/reply.rb', line 5 def statusmsg @statusmsg end |
Instance Method Details
#[](key) ⇒ Object
Read from the data hash
70 71 72 |
# File 'lib/mcollective/rpc/reply.rb', line 70 def [](key) @data[key] end |
#[]=(key, val) ⇒ Object
Write to the data hash
65 66 67 |
# File 'lib/mcollective/rpc/reply.rb', line 65 def []=(key, val) @data[key] = val end |
#fail(msg, code = 1) ⇒ Object
Helper to fill in statusmsg and code on failure
36 37 38 39 |
# File 'lib/mcollective/rpc/reply.rb', line 36 def fail(msg, code=1) @statusmsg = msg @statuscode = code end |
#fail!(msg, code = 1) ⇒ Object
Helper that fills in statusmsg and code but also raises an appropriate error
42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 |
# File 'lib/mcollective/rpc/reply.rb', line 42 def fail!(msg, code=1) @statusmsg = msg @statuscode = code case code when 1 raise RPCAborted, msg when 2 raise UnknownRPCAction, msg when 3 raise MissingRPCData, msg when 4 raise InvalidRPCData, msg else raise UnknownRPCError, msg end end |
#fetch(key, default) ⇒ Object
74 75 76 |
# File 'lib/mcollective/rpc/reply.rb', line 74 def fetch(key, default) @data.fetch(key, default) end |
#initialize_data ⇒ Object
21 22 23 24 25 26 27 28 29 30 31 32 33 |
# File 'lib/mcollective/rpc/reply.rb', line 21 def initialize_data unless @ddl.actions.include?(@action) raise "No action '%s' defined for agent '%s' in the DDL" % [@action, @ddl.pluginname] end interface = @ddl.action_interface(@action) interface[:output].keys.each do |output| # must deep clone this data to avoid accidental updates of the DDL in cases where the # default is for example a string and someone does << on it @data[output] = Marshal.load(Marshal.dump(interface[:output][output].fetch(:default, nil))) end end |
#to_hash ⇒ Object
Returns a compliant Hash of the reply that should be sent over the middleware
80 81 82 83 84 |
# File 'lib/mcollective/rpc/reply.rb', line 80 def to_hash return {:statuscode => @statuscode, :statusmsg => @statusmsg, :data => @data} end |