bogdanRada/washout_builder

View on GitHub
lib/washout_builder/soap.rb

Summary

Maintainability
A
50 mins
Test Coverage
require 'active_support/concern'

module WashoutBuilder
  # the module that is used for soap actions to parse their definition and hold the infoirmation about
  # their arguments and return types
  module SOAP
    extend ActiveSupport::Concern
    included do
      # Define a SOAP action +action+. The function has two required +options+:
      # :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.
      # @param  [Symbol, Class]  action the action that is requested
      # @param [Hash] options  the options used for
      #
      # @return [void]
      #
      # @api public
      def soap_action(action, options = {})
        original_soap_action(action, options)

        if action.is_a?(Symbol)
          if soap_config.camelize_wsdl.to_s == 'lower'
            action = action.to_s.camelize(:lower)
          elsif soap_config.camelize_wsdl
            action = action.to_s.camelize
          end
        end
        builder_soap_action(action, options)
      end

      private

      def builder_soap_action(action, options = {})
        current_action = soap_actions[action]
        base_param_class = WashoutBuilder::Type.base_param_class
        return if base_param_class.blank?
        current_action[:builder_in] = base_param_class.parse_def(soap_config, options[:args])
        current_action[:builder_out] = base_param_class.parse_def(soap_config, options[:return])
        current_action[:args_description] = options[:args_description].present? && options[:args_description].is_a?(Hash) ? options[:args_description].stringify_keys : {}
        current_action
      end
    end
  end
end