lib/wash_out/soap.rb in wash_out-0.11.0.beta.2 vs lib/wash_out/soap.rb in wash_out-0.11.0
- old
+ new
@@ -11,11 +11,19 @@
# :args and :return. Each is a type +definition+ of format described in
# WashOut::Param#parse_def.
#
# An optional option :to can be passed to allow for names of SOAP actions
# which are not valid Ruby function names.
+ # There is also an optional :header_return option to specify the format of the
+ # SOAP response's header tag (<env:Header></env:Header>). If unspecified, there will
+ # be no header tag in the response.
def soap_action(action, options={})
+ if options[:as].present?
+ options[:to] ||= action
+ action = options[:as]
+ end
+
if action.is_a?(Symbol)
if soap_config.camelize_wsdl.to_s == 'lower'
options[:to] ||= action.to_s
action = action.to_s.camelize(:lower)
elsif soap_config.camelize_wsdl
@@ -26,13 +34,15 @@
end
default_response_tag = soap_config.camelize_wsdl ? 'Response' : '_response'
default_response_tag = action+default_response_tag
+
self.soap_actions[action] = options.merge(
:in => WashOut::Param.parse_def(soap_config, options[:args]),
:request_tag => options[:as] || action,
:out => WashOut::Param.parse_def(soap_config, options[:return]),
+ :header_out => options[:header_return].present? ? WashOut::Param.parse_def(soap_config, options[:header_return]) : nil,
:to => options[:to] || action,
:response_tag => options[:response_tag] || default_response_tag
)
end
end