railsware-soap4r 1.5.8.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (174) hide show
  1. data/README +5 -0
  2. data/TODO +0 -0
  3. data/bin/wsdl2ruby.rb +137 -0
  4. data/bin/xsd2ruby.rb +90 -0
  5. data/lib/soap/XMLSchemaDatatypes.rb +9 -0
  6. data/lib/soap/XMLSchemaDatatypes1999.rb +10 -0
  7. data/lib/soap/attachment.rb +108 -0
  8. data/lib/soap/baseData.rb +1092 -0
  9. data/lib/soap/cgistub.rb +9 -0
  10. data/lib/soap/charset.rb +9 -0
  11. data/lib/soap/compat.rb +182 -0
  12. data/lib/soap/driver.rb +9 -0
  13. data/lib/soap/element.rb +277 -0
  14. data/lib/soap/encodingstyle/aspDotNetHandler.rb +207 -0
  15. data/lib/soap/encodingstyle/handler.rb +120 -0
  16. data/lib/soap/encodingstyle/literalHandler.rb +192 -0
  17. data/lib/soap/encodingstyle/soapHandler.rb +559 -0
  18. data/lib/soap/filter.rb +13 -0
  19. data/lib/soap/filter/filterchain.rb +51 -0
  20. data/lib/soap/filter/handler.rb +31 -0
  21. data/lib/soap/filter/streamhandler.rb +29 -0
  22. data/lib/soap/generator.rb +304 -0
  23. data/lib/soap/header/handler.rb +61 -0
  24. data/lib/soap/header/handlerset.rb +70 -0
  25. data/lib/soap/header/mappinghandler.rb +47 -0
  26. data/lib/soap/header/simplehandler.rb +44 -0
  27. data/lib/soap/httpconfigloader.rb +139 -0
  28. data/lib/soap/mapping.rb +12 -0
  29. data/lib/soap/mapping/encodedregistry.rb +548 -0
  30. data/lib/soap/mapping/factory.rb +388 -0
  31. data/lib/soap/mapping/literalregistry.rb +388 -0
  32. data/lib/soap/mapping/mapping.rb +609 -0
  33. data/lib/soap/mapping/registry.rb +295 -0
  34. data/lib/soap/mapping/rubytypeFactory.rb +478 -0
  35. data/lib/soap/mapping/schemadefinition.rb +170 -0
  36. data/lib/soap/mapping/typeMap.rb +106 -0
  37. data/lib/soap/mapping/wsdlencodedregistry.rb +211 -0
  38. data/lib/soap/mapping/wsdlliteralregistry.rb +243 -0
  39. data/lib/soap/mappingRegistry.rb +9 -0
  40. data/lib/soap/marshal.rb +59 -0
  41. data/lib/soap/mimemessage.rb +241 -0
  42. data/lib/soap/namespace.rb +9 -0
  43. data/lib/soap/nestedexception.rb +42 -0
  44. data/lib/soap/netHttpClient.rb +241 -0
  45. data/lib/soap/ns.rb +34 -0
  46. data/lib/soap/parser.rb +252 -0
  47. data/lib/soap/processor.rb +66 -0
  48. data/lib/soap/property.rb +333 -0
  49. data/lib/soap/proxy.rb +14 -0
  50. data/lib/soap/qname.rb +9 -0
  51. data/lib/soap/rpc/cgistub.rb +247 -0
  52. data/lib/soap/rpc/driver.rb +247 -0
  53. data/lib/soap/rpc/element.rb +369 -0
  54. data/lib/soap/rpc/httpserver.rb +169 -0
  55. data/lib/soap/rpc/proxy.rb +576 -0
  56. data/lib/soap/rpc/router.rb +669 -0
  57. data/lib/soap/rpc/rpc.rb +25 -0
  58. data/lib/soap/rpc/soaplet.rb +210 -0
  59. data/lib/soap/rpc/standaloneServer.rb +43 -0
  60. data/lib/soap/rpcRouter.rb +9 -0
  61. data/lib/soap/rpcUtils.rb +9 -0
  62. data/lib/soap/server.rb +9 -0
  63. data/lib/soap/soap.rb +151 -0
  64. data/lib/soap/standaloneServer.rb +9 -0
  65. data/lib/soap/streamHandler.rb +302 -0
  66. data/lib/soap/wsdlDriver.rb +597 -0
  67. data/lib/tags +5690 -0
  68. data/lib/wsdl/binding.rb +65 -0
  69. data/lib/wsdl/data.rb +64 -0
  70. data/lib/wsdl/definitions.rb +236 -0
  71. data/lib/wsdl/documentation.rb +32 -0
  72. data/lib/wsdl/import.rb +80 -0
  73. data/lib/wsdl/importer.rb +38 -0
  74. data/lib/wsdl/info.rb +50 -0
  75. data/lib/wsdl/message.rb +54 -0
  76. data/lib/wsdl/operation.rb +178 -0
  77. data/lib/wsdl/operationBinding.rb +130 -0
  78. data/lib/wsdl/param.rb +93 -0
  79. data/lib/wsdl/parser.rb +164 -0
  80. data/lib/wsdl/part.rb +52 -0
  81. data/lib/wsdl/port.rb +84 -0
  82. data/lib/wsdl/portType.rb +75 -0
  83. data/lib/wsdl/service.rb +61 -0
  84. data/lib/wsdl/soap/address.rb +40 -0
  85. data/lib/wsdl/soap/binding.rb +49 -0
  86. data/lib/wsdl/soap/body.rb +58 -0
  87. data/lib/wsdl/soap/cgiStubCreator.rb +93 -0
  88. data/lib/wsdl/soap/classDefCreator.rb +433 -0
  89. data/lib/wsdl/soap/classDefCreatorSupport.rb +230 -0
  90. data/lib/wsdl/soap/classNameCreator.rb +54 -0
  91. data/lib/wsdl/soap/clientSkeltonCreator.rb +95 -0
  92. data/lib/wsdl/soap/complexType.rb +172 -0
  93. data/lib/wsdl/soap/data.rb +42 -0
  94. data/lib/wsdl/soap/definitions.rb +200 -0
  95. data/lib/wsdl/soap/driverCreator.rb +118 -0
  96. data/lib/wsdl/soap/element.rb +33 -0
  97. data/lib/wsdl/soap/encodedMappingRegistryCreator.rb +73 -0
  98. data/lib/wsdl/soap/fault.rb +56 -0
  99. data/lib/wsdl/soap/header.rb +86 -0
  100. data/lib/wsdl/soap/headerfault.rb +56 -0
  101. data/lib/wsdl/soap/literalMappingRegistryCreator.rb +115 -0
  102. data/lib/wsdl/soap/mappingRegistryCreator.rb +58 -0
  103. data/lib/wsdl/soap/mappingRegistryCreatorSupport.rb +376 -0
  104. data/lib/wsdl/soap/methodDefCreator.rb +263 -0
  105. data/lib/wsdl/soap/operation.rb +122 -0
  106. data/lib/wsdl/soap/servantSkeltonCreator.rb +80 -0
  107. data/lib/wsdl/soap/servletStubCreator.rb +107 -0
  108. data/lib/wsdl/soap/standaloneServerStubCreator.rb +103 -0
  109. data/lib/wsdl/soap/wsdl2ruby.rb +217 -0
  110. data/lib/wsdl/types.rb +44 -0
  111. data/lib/wsdl/wsdl.rb +24 -0
  112. data/lib/wsdl/xmlSchema/all.rb +24 -0
  113. data/lib/wsdl/xmlSchema/annotation.rb +34 -0
  114. data/lib/wsdl/xmlSchema/any.rb +61 -0
  115. data/lib/wsdl/xmlSchema/anyAttribute.rb +48 -0
  116. data/lib/wsdl/xmlSchema/attribute.rb +123 -0
  117. data/lib/wsdl/xmlSchema/attributeGroup.rb +86 -0
  118. data/lib/wsdl/xmlSchema/choice.rb +58 -0
  119. data/lib/wsdl/xmlSchema/complexContent.rb +97 -0
  120. data/lib/wsdl/xmlSchema/complexExtension.rb +119 -0
  121. data/lib/wsdl/xmlSchema/complexRestriction.rb +104 -0
  122. data/lib/wsdl/xmlSchema/complexType.rb +193 -0
  123. data/lib/wsdl/xmlSchema/content.rb +95 -0
  124. data/lib/wsdl/xmlSchema/data.rb +116 -0
  125. data/lib/wsdl/xmlSchema/element.rb +173 -0
  126. data/lib/wsdl/xmlSchema/enumeration.rb +36 -0
  127. data/lib/wsdl/xmlSchema/fractiondigits.rb +37 -0
  128. data/lib/wsdl/xmlSchema/group.rb +118 -0
  129. data/lib/wsdl/xmlSchema/import.rb +53 -0
  130. data/lib/wsdl/xmlSchema/importHandler.rb +45 -0
  131. data/lib/wsdl/xmlSchema/importer.rb +102 -0
  132. data/lib/wsdl/xmlSchema/include.rb +48 -0
  133. data/lib/wsdl/xmlSchema/length.rb +37 -0
  134. data/lib/wsdl/xmlSchema/list.rb +48 -0
  135. data/lib/wsdl/xmlSchema/maxexclusive.rb +37 -0
  136. data/lib/wsdl/xmlSchema/maxinclusive.rb +37 -0
  137. data/lib/wsdl/xmlSchema/maxlength.rb +37 -0
  138. data/lib/wsdl/xmlSchema/minexclusive.rb +37 -0
  139. data/lib/wsdl/xmlSchema/mininclusive.rb +37 -0
  140. data/lib/wsdl/xmlSchema/minlength.rb +37 -0
  141. data/lib/wsdl/xmlSchema/parser.rb +167 -0
  142. data/lib/wsdl/xmlSchema/pattern.rb +36 -0
  143. data/lib/wsdl/xmlSchema/schema.rb +178 -0
  144. data/lib/wsdl/xmlSchema/sequence.rb +54 -0
  145. data/lib/wsdl/xmlSchema/simpleContent.rb +69 -0
  146. data/lib/wsdl/xmlSchema/simpleExtension.rb +62 -0
  147. data/lib/wsdl/xmlSchema/simpleRestriction.rb +132 -0
  148. data/lib/wsdl/xmlSchema/simpleType.rb +87 -0
  149. data/lib/wsdl/xmlSchema/totaldigits.rb +37 -0
  150. data/lib/wsdl/xmlSchema/union.rb +35 -0
  151. data/lib/wsdl/xmlSchema/unique.rb +34 -0
  152. data/lib/wsdl/xmlSchema/whitespace.rb +37 -0
  153. data/lib/wsdl/xmlSchema/xsd2ruby.rb +174 -0
  154. data/lib/xsd/charset.rb +189 -0
  155. data/lib/xsd/codegen.rb +12 -0
  156. data/lib/xsd/codegen/classdef.rb +208 -0
  157. data/lib/xsd/codegen/commentdef.rb +34 -0
  158. data/lib/xsd/codegen/gensupport.rb +273 -0
  159. data/lib/xsd/codegen/methoddef.rb +70 -0
  160. data/lib/xsd/codegen/moduledef.rb +208 -0
  161. data/lib/xsd/datatypes.rb +1466 -0
  162. data/lib/xsd/datatypes1999.rb +20 -0
  163. data/lib/xsd/iconvcharset.rb +33 -0
  164. data/lib/xsd/mapping.rb +67 -0
  165. data/lib/xsd/namedelements.rb +132 -0
  166. data/lib/xsd/ns.rb +182 -0
  167. data/lib/xsd/qname.rb +79 -0
  168. data/lib/xsd/xmlparser.rb +75 -0
  169. data/lib/xsd/xmlparser/parser.rb +100 -0
  170. data/lib/xsd/xmlparser/rexmlparser.rb +58 -0
  171. data/lib/xsd/xmlparser/xmlparser.rb +50 -0
  172. data/lib/xsd/xmlparser/xmlscanner.rb +149 -0
  173. data/soap4r.gemspec +218 -0
  174. metadata +233 -0
@@ -0,0 +1,169 @@
1
+ # SOAP4R - WEBrick HTTP Server
2
+ # Copyright (C) 2000-2007 NAKAMURA, Hiroshi <nahi@ruby-lang.org>.
3
+
4
+ # This program is copyrighted free software by NAKAMURA, Hiroshi. You can
5
+ # redistribute it and/or modify it under the same terms of Ruby's license;
6
+ # either the dual license version in 2003, or any later version.
7
+
8
+
9
+ require 'logger'
10
+ require 'soap/rpc/soaplet'
11
+ require 'soap/streamHandler'
12
+ require 'webrick'
13
+
14
+
15
+ module SOAP
16
+ module RPC
17
+
18
+
19
+ class HTTPServer < Logger::Application
20
+ attr_reader :server
21
+ attr_accessor :default_namespace
22
+
23
+ class << self
24
+ if RUBY_VERSION >= "1.7.0"
25
+ def __attr_proxy(symbol, assignable = false)
26
+ name = symbol.to_s
27
+ define_method(name) {
28
+ @router.__send__(name)
29
+ }
30
+ if assignable
31
+ aname = name + '='
32
+ define_method(aname) { |rhs|
33
+ @router.__send__(aname, rhs)
34
+ }
35
+ end
36
+ end
37
+ else
38
+ def __attr_proxy(symbol, assignable = false)
39
+ name = symbol.to_s
40
+ module_eval <<-EOS
41
+ def #{name}
42
+ @router.#{name}
43
+ end
44
+ EOS
45
+ if assignable
46
+ module_eval <<-EOS
47
+ def #{name}=(value)
48
+ @router.#{name} = value
49
+ end
50
+ EOS
51
+ end
52
+ end
53
+ end
54
+ end
55
+
56
+ __attr_proxy :mapping_registry, true
57
+ __attr_proxy :literal_mapping_registry, true
58
+ __attr_proxy :generate_explicit_type, true
59
+ __attr_proxy :use_default_namespace, true
60
+
61
+ def initialize(config)
62
+ actor = config[:SOAPHTTPServerApplicationName] || self.class.name
63
+ super(actor)
64
+ @default_namespace = config[:SOAPDefaultNamespace]
65
+ @webrick_config = config.dup
66
+ self.level = Logger::Severity::ERROR # keep silent by default
67
+ @webrick_config[:Logger] ||= @log
68
+ @log = @webrick_config[:Logger] # sync logger of App and HTTPServer
69
+ @router = ::SOAP::RPC::Router.new(actor)
70
+ @soaplet = ::SOAP::RPC::SOAPlet.new(@router)
71
+ on_init
72
+ @server = WEBrick::HTTPServer.new(@webrick_config)
73
+ @server.mount('/soaprouter', @soaplet)
74
+ if wsdldir = config[:WSDLDocumentDirectory]
75
+ @server.mount('/wsdl', WEBrick::HTTPServlet::FileHandler, wsdldir)
76
+ end
77
+ # for backward compatibility
78
+ @server.mount('/', @soaplet)
79
+ end
80
+
81
+ def on_init
82
+ # do extra initialization in a derived class if needed.
83
+ end
84
+
85
+ def status
86
+ @server.status if @server
87
+ end
88
+
89
+ def shutdown
90
+ @server.shutdown if @server
91
+ end
92
+
93
+ def authenticator
94
+ @soaplet.authenticator
95
+ end
96
+
97
+ def authenticator=(authenticator)
98
+ @soaplet.authenticator = authenticator
99
+ end
100
+
101
+ # servant entry interface
102
+
103
+ def add_rpc_request_servant(factory, namespace = @default_namespace)
104
+ @router.add_rpc_request_servant(factory, namespace)
105
+ end
106
+
107
+ def add_rpc_servant(obj, namespace = @default_namespace)
108
+ @router.add_rpc_servant(obj, namespace)
109
+ end
110
+
111
+ def add_request_headerhandler(factory)
112
+ @router.add_request_headerhandler(factory)
113
+ end
114
+
115
+ def add_headerhandler(obj)
116
+ @router.add_headerhandler(obj)
117
+ end
118
+ alias add_rpc_headerhandler add_headerhandler
119
+
120
+ def filterchain
121
+ @router.filterchain
122
+ end
123
+
124
+ # method entry interface
125
+
126
+ def add_rpc_method(obj, name, *param)
127
+ add_rpc_method_as(obj, name, name, *param)
128
+ end
129
+ alias add_method add_rpc_method
130
+
131
+ def add_rpc_method_as(obj, name, name_as, *param)
132
+ qname = XSD::QName.new(@default_namespace, name_as)
133
+ soapaction = nil
134
+ param_def = SOAPMethod.derive_rpc_param_def(obj, name, *param)
135
+ @router.add_rpc_operation(obj, qname, soapaction, name, param_def)
136
+ end
137
+ alias add_method_as add_rpc_method_as
138
+
139
+ def add_document_method(obj, soapaction, name, req_qnames, res_qnames)
140
+ param_def = SOAPMethod.create_doc_param_def(req_qnames, res_qnames)
141
+ @router.add_document_operation(obj, soapaction, name, param_def)
142
+ end
143
+
144
+ def add_rpc_operation(receiver, qname, soapaction, name, param_def, opt = {})
145
+ @router.add_rpc_operation(receiver, qname, soapaction, name, param_def, opt)
146
+ end
147
+
148
+ def add_rpc_request_operation(factory, qname, soapaction, name, param_def, opt = {})
149
+ @router.add_rpc_request_operation(factory, qname, soapaction, name, param_def, opt)
150
+ end
151
+
152
+ def add_document_operation(receiver, soapaction, name, param_def, opt = {})
153
+ @router.add_document_operation(receiver, soapaction, name, param_def, opt)
154
+ end
155
+
156
+ def add_document_request_operation(factory, soapaction, name, param_def, opt = {})
157
+ @router.add_document_request_operation(factory, soapaction, name, param_def, opt)
158
+ end
159
+
160
+ private
161
+
162
+ def run
163
+ @server.start
164
+ end
165
+ end
166
+
167
+
168
+ end
169
+ end
@@ -0,0 +1,576 @@
1
+ # SOAP4R - RPC Proxy library.
2
+ # Copyright (C) 2000-2007 NAKAMURA, Hiroshi <nahi@ruby-lang.org>.
3
+
4
+ # This program is copyrighted free software by NAKAMURA, Hiroshi. You can
5
+ # redistribute it and/or modify it under the same terms of Ruby's license;
6
+ # either the dual license version in 2003, or any later version.
7
+
8
+
9
+ require 'soap/soap'
10
+ require 'soap/processor'
11
+ require 'soap/mapping'
12
+ require 'soap/mapping/literalregistry'
13
+ require 'soap/rpc/rpc'
14
+ require 'soap/rpc/element'
15
+ require 'soap/header/handlerset'
16
+ require 'soap/filter'
17
+ require 'soap/streamHandler'
18
+ require 'soap/mimemessage'
19
+
20
+
21
+ module SOAP
22
+ module RPC
23
+
24
+
25
+ class Proxy
26
+ include SOAP
27
+
28
+ public
29
+
30
+ attr_accessor :soapaction
31
+ attr_accessor :mandatorycharset
32
+ attr_accessor :allow_unqualified_element
33
+ attr_accessor :default_encodingstyle
34
+ attr_accessor :generate_explicit_type
35
+ attr_accessor :use_default_namespace
36
+ attr_accessor :return_response_as_xml
37
+ attr_reader :headerhandler
38
+ attr_reader :filterchain
39
+ attr_reader :streamhandler
40
+
41
+ attr_accessor :mapping_registry
42
+ attr_accessor :literal_mapping_registry
43
+
44
+ attr_reader :operation
45
+
46
+ def initialize(endpoint_url, soapaction, options)
47
+ @endpoint_url = endpoint_url
48
+ @soapaction = soapaction
49
+ @options = options
50
+ @protocol_option = options["protocol"] ||= ::SOAP::Property.new
51
+ initialize_streamhandler(@protocol_option)
52
+ @operation = {}
53
+ @operation_by_qname = {}
54
+ @operation_by_soapaction = {}
55
+ @mandatorycharset = nil
56
+ # TODO: set to false by default or drop thie option in 1.6.0
57
+ @allow_unqualified_element = true
58
+ @default_encodingstyle = nil
59
+ @generate_explicit_type = true
60
+ @use_default_namespace = false
61
+ @return_response_as_xml = false
62
+ @headerhandler = Header::HandlerSet.new
63
+ @filterchain = Filter::FilterChain.new
64
+ @mapping_registry = nil
65
+ @literal_mapping_registry = ::SOAP::Mapping::LiteralRegistry.new
66
+ end
67
+
68
+ def inspect
69
+ "#<#{self.class}:#{@endpoint_url}>"
70
+ end
71
+
72
+ def endpoint_url
73
+ @endpoint_url
74
+ end
75
+
76
+ def endpoint_url=(endpoint_url)
77
+ @endpoint_url = endpoint_url
78
+ reset_stream
79
+ end
80
+
81
+ def reset_stream
82
+ @streamhandler.reset(@endpoint_url)
83
+ end
84
+
85
+ def set_wiredump_file_base(wiredump_file_base)
86
+ @streamhandler.wiredump_file_base = wiredump_file_base
87
+ end
88
+
89
+ def test_loopback_response
90
+ @streamhandler.test_loopback_response
91
+ end
92
+
93
+ def add_rpc_operation(qname, soapaction, name, param_def, opt = {})
94
+ ensure_styleuse_option(opt, :rpc, :encoded)
95
+ opt[:request_qname] = qname
96
+ op = Operation.new(soapaction, param_def, opt)
97
+ assign_operation(name, qname, soapaction, op)
98
+ end
99
+
100
+ def add_document_operation(soapaction, name, param_def, opt = {})
101
+ ensure_styleuse_option(opt, :document, :literal)
102
+ op = Operation.new(soapaction, param_def, opt)
103
+ assign_operation(name, nil, soapaction, op)
104
+ end
105
+
106
+ # add_method is for shortcut of typical rpc/encoded method definition.
107
+ alias add_method add_rpc_operation
108
+ alias add_rpc_method add_rpc_operation
109
+ alias add_document_method add_document_operation
110
+
111
+ def invoke(req_header, req_body, opt = nil)
112
+ opt ||= create_encoding_opt
113
+ env = route(req_header, req_body, opt, opt)
114
+ if @return_response_as_xml
115
+ opt[:response_as_xml]
116
+ else
117
+ env
118
+ end
119
+ end
120
+
121
+ def call(name, *params)
122
+ # name must be used only for lookup
123
+ op_info = lookup_operation(name)
124
+ mapping_opt = create_mapping_opt
125
+ req_header = create_request_header
126
+ req_body = SOAPBody.new(
127
+ op_info.request_body(params, @mapping_registry,
128
+ @literal_mapping_registry, mapping_opt)
129
+ )
130
+ reqopt = create_encoding_opt(
131
+ :soapaction => op_info.soapaction || @soapaction,
132
+ :envelopenamespace => @options["soap.envelope.requestnamespace"],
133
+ :default_encodingstyle =>
134
+ @default_encodingstyle || op_info.request_default_encodingstyle,
135
+ :use_default_namespace =>
136
+ op_info.use_default_namespace || @use_default_namespace
137
+ )
138
+ resopt = create_encoding_opt(
139
+ :envelopenamespace => @options["soap.envelope.responsenamespace"],
140
+ :default_encodingstyle =>
141
+ @default_encodingstyle || op_info.response_default_encodingstyle
142
+ )
143
+ env = route(req_header, req_body, reqopt, resopt)
144
+ if op_info.response_use.nil?
145
+ return nil
146
+ end
147
+ raise EmptyResponseError unless env
148
+ receive_headers(env.header)
149
+ begin
150
+ check_fault(env.body)
151
+ rescue ::SOAP::FaultError => e
152
+ op_info.raise_fault(e, @mapping_registry, @literal_mapping_registry)
153
+ end
154
+ if @return_response_as_xml
155
+ resopt[:response_as_xml]
156
+ else
157
+ op_info.response_obj(env.body, @mapping_registry,
158
+ @literal_mapping_registry, mapping_opt)
159
+ end
160
+ end
161
+
162
+ def route(req_header, req_body, reqopt, resopt)
163
+ req_env = ::SOAP::SOAPEnvelope.new(req_header, req_body)
164
+ unless reqopt[:envelopenamespace].nil?
165
+ set_envelopenamespace(req_env, reqopt[:envelopenamespace])
166
+ end
167
+ reqopt[:external_content] = nil
168
+ conn_data = marshal(req_env, reqopt)
169
+ if ext = reqopt[:external_content]
170
+ mime = MIMEMessage.new
171
+ ext.each do |k, v|
172
+ mime.add_attachment(v.data)
173
+ end
174
+ mime.add_part(conn_data.send_string + "\r\n")
175
+ mime.close
176
+ conn_data.send_string = mime.content_str
177
+ conn_data.send_contenttype = mime.headers['content-type'].str
178
+ end
179
+ conn_data = @streamhandler.send(@endpoint_url, conn_data,
180
+ reqopt[:soapaction])
181
+ if conn_data.receive_string.empty?
182
+ return nil
183
+ end
184
+ unmarshal(conn_data, resopt)
185
+ end
186
+
187
+ def check_fault(body)
188
+ if body.fault
189
+ raise SOAP::FaultError.new(body.fault)
190
+ end
191
+ end
192
+
193
+ private
194
+
195
+ def ensure_styleuse_option(opt, style, use)
196
+ if opt[:request_style] || opt[:response_style] || opt[:request_use] || opt[:response_use]
197
+ # do not edit
198
+ else
199
+ opt[:request_style] ||= style
200
+ opt[:response_style] ||= style
201
+ opt[:request_use] ||= use
202
+ opt[:response_use] ||= use
203
+ end
204
+ end
205
+
206
+ def initialize_streamhandler(options)
207
+ value = options["streamhandler"]
208
+ if value and !value.empty?
209
+ factory = Property::Util.const_from_name(value)
210
+ else
211
+ factory = HTTPStreamHandler
212
+ end
213
+ @streamhandler = factory.create(options)
214
+ options.add_hook("streamhandler") do |key, value|
215
+ @streamhandler.reset
216
+ if value.respond_to?(:create)
217
+ factory = value
218
+ elsif value and !value.to_str.empty?
219
+ factory = Property::Util.const_from_name(value.to_str)
220
+ else
221
+ factory = HTTPStreamHandler
222
+ end
223
+ options.unlock(true)
224
+ @streamhandler = factory.create(options)
225
+ end
226
+ end
227
+
228
+ def set_envelopenamespace(env, namespace)
229
+ env.elename = XSD::QName.new(namespace, env.elename.name)
230
+ if env.header
231
+ env.header.elename = XSD::QName.new(namespace, env.header.elename.name)
232
+ end
233
+ if env.body
234
+ env.body.elename = XSD::QName.new(namespace, env.body.elename.name)
235
+ end
236
+ end
237
+
238
+ def create_request_header
239
+ header = ::SOAP::SOAPHeader.new
240
+ items = @headerhandler.on_outbound(header)
241
+ items.each do |item|
242
+ header.add(item.elename.name, item)
243
+ end
244
+ header
245
+ end
246
+
247
+ def receive_headers(header)
248
+ @headerhandler.on_inbound(header) if header
249
+ end
250
+
251
+ def marshal(env, opt)
252
+ @filterchain.each do |filter|
253
+ env = filter.on_outbound(env, opt)
254
+ break unless env
255
+ end
256
+ send_string = Processor.marshal(env, opt)
257
+ StreamHandler::ConnectionData.new(send_string)
258
+ end
259
+
260
+ def unmarshal(conn_data, opt)
261
+ contenttype = conn_data.receive_contenttype
262
+ xml = nil
263
+ if /#{MIMEMessage::MultipartContentType}/i =~ contenttype
264
+ opt[:external_content] = {}
265
+ mime = MIMEMessage.parse("Content-Type: " + contenttype,
266
+ conn_data.receive_string)
267
+ mime.parts.each do |part|
268
+ value = Attachment.new(part.content)
269
+ value.contentid = part.contentid
270
+ obj = SOAPAttachment.new(value)
271
+ opt[:external_content][value.contentid] = obj if value.contentid
272
+ end
273
+ opt[:charset] = @mandatorycharset ||
274
+ StreamHandler.parse_media_type(mime.root.headers['content-type'].str)
275
+ xml = mime.root.content
276
+ else
277
+ opt[:charset] = @mandatorycharset ||
278
+ ::SOAP::StreamHandler.parse_media_type(contenttype)
279
+ xml = conn_data.receive_string
280
+ end
281
+ @filterchain.reverse_each do |filter|
282
+ xml = filter.on_inbound(xml, opt)
283
+ break unless xml
284
+ end
285
+ env = Processor.unmarshal(xml, opt)
286
+ if @return_response_as_xml
287
+ opt[:response_as_xml] = xml
288
+ end
289
+ unless env.is_a?(::SOAP::SOAPEnvelope)
290
+ raise ResponseFormatError.new("response is not a SOAP envelope: #{env}")
291
+ end
292
+ env
293
+ end
294
+
295
+ def create_encoding_opt(hash = nil)
296
+ opt = {}
297
+ opt[:default_encodingstyle] = @default_encodingstyle
298
+ opt[:allow_unqualified_element] = @allow_unqualified_element
299
+ opt[:generate_explicit_type] = @generate_explicit_type
300
+ opt[:no_indent] = @options["soap.envelope.no_indent"]
301
+ opt[:use_numeric_character_reference] =
302
+ @options["soap.envelope.use_numeric_character_reference"]
303
+ opt.update(hash) if hash
304
+ opt
305
+ end
306
+
307
+ def create_mapping_opt(hash = nil)
308
+ opt = {
309
+ :external_ces => @options["soap.mapping.external_ces"]
310
+ }
311
+ opt.update(hash) if hash
312
+ opt
313
+ end
314
+
315
+ def assign_operation(name, qname, soapaction, op)
316
+ assigned = false
317
+ if name and !name.empty?
318
+ @operation[name] = op
319
+ assigned = true
320
+ end
321
+ if qname
322
+ @operation_by_qname[qname] = op
323
+ assigned = true
324
+ end
325
+ if soapaction and !soapaction.empty?
326
+ @operation_by_soapaction[soapaction] = op
327
+ assigned = true
328
+ end
329
+ unless assigned
330
+ raise MethodDefinitionError.new("cannot assign operation")
331
+ end
332
+ end
333
+
334
+ def lookup_operation(name_or_qname_or_soapaction)
335
+ if op = @operation[name_or_qname_or_soapaction]
336
+ return op
337
+ end
338
+ if op = @operation_by_qname[name_or_qname_or_soapaction]
339
+ return op
340
+ end
341
+ if op = @operation_by_soapaction[name_or_qname_or_soapaction]
342
+ return op
343
+ end
344
+ raise MethodDefinitionError.new(
345
+ "operation: #{name_or_qname_or_soapaction} not supported")
346
+ end
347
+
348
+ class Operation
349
+ attr_reader :soapaction
350
+ attr_reader :request_style
351
+ attr_reader :response_style
352
+ attr_reader :request_use
353
+ attr_reader :response_use
354
+ attr_reader :use_default_namespace
355
+
356
+ def initialize(soapaction, param_def, opt)
357
+ @soapaction = soapaction
358
+ @request_style = opt[:request_style]
359
+ @response_style = opt[:response_style]
360
+ @request_use = opt[:request_use]
361
+ @response_use = opt[:response_use]
362
+ @use_default_namespace =
363
+ opt[:use_default_namespace] || opt[:elementformdefault]
364
+ if opt.key?(:elementformdefault)
365
+ warn("option :elementformdefault is deprecated. use :use_default_namespace instead")
366
+ end
367
+ check_style(@request_style)
368
+ check_style(@response_style)
369
+ check_use(@request_use)
370
+ check_use(@response_use)
371
+ if @request_style == :rpc
372
+ @rpc_request_qname = opt[:request_qname]
373
+ if @rpc_request_qname.nil?
374
+ raise MethodDefinitionError.new("rpc_request_qname must be given")
375
+ end
376
+ @rpc_method_factory =
377
+ RPC::SOAPMethodRequest.new(@rpc_request_qname, param_def, @soapaction)
378
+ else
379
+ @doc_request_qnames = []
380
+ @doc_request_qualified = []
381
+ @doc_response_qnames = []
382
+ @doc_response_qualified = []
383
+ param_def.each do |inout, paramname, typeinfo, eleinfo|
384
+ klass_not_used, nsdef, namedef = typeinfo
385
+ qualified = eleinfo
386
+ if namedef.nil?
387
+ raise MethodDefinitionError.new("qname must be given")
388
+ end
389
+ case inout
390
+ when SOAPMethod::IN
391
+ @doc_request_qnames << XSD::QName.new(nsdef, namedef)
392
+ @doc_request_qualified << qualified
393
+ when SOAPMethod::OUT
394
+ @doc_response_qnames << XSD::QName.new(nsdef, namedef)
395
+ @doc_response_qualified << qualified
396
+ else
397
+ raise MethodDefinitionError.new(
398
+ "illegal inout definition for document style: #{inout}")
399
+ end
400
+ end
401
+ end
402
+ end
403
+
404
+ def request_default_encodingstyle
405
+ (@request_use == :encoded) ? EncodingNamespace : LiteralNamespace
406
+ end
407
+
408
+ def response_default_encodingstyle
409
+ (@response_use == :encoded) ? EncodingNamespace : LiteralNamespace
410
+ end
411
+
412
+ def request_body(values, mapping_registry, literal_mapping_registry, opt)
413
+ if @request_style == :rpc
414
+ request_rpc(values, mapping_registry, literal_mapping_registry, opt)
415
+ else
416
+ request_doc(values, mapping_registry, literal_mapping_registry, opt)
417
+ end
418
+ end
419
+
420
+ def response_obj(body, mapping_registry, literal_mapping_registry, opt)
421
+ if @response_style == :rpc
422
+ response_rpc(body, mapping_registry, literal_mapping_registry, opt)
423
+ else
424
+ unique_result_for_one_element_array(
425
+ response_doc(body, mapping_registry, literal_mapping_registry, opt))
426
+ end
427
+ end
428
+
429
+ def raise_fault(e, mapping_registry, literal_mapping_registry)
430
+ if @response_style == :rpc
431
+ Mapping.fault2exception(e, mapping_registry)
432
+ else
433
+ Mapping.fault2exception(e, literal_mapping_registry)
434
+ end
435
+ end
436
+
437
+ private
438
+
439
+ # nil for [] / 1 for [1] / [1, 2] for [1, 2]
440
+ def unique_result_for_one_element_array(ary)
441
+ ary.size <= 1 ? ary[0] : ary
442
+ end
443
+
444
+ def check_style(style)
445
+ unless [:rpc, :document].include?(style)
446
+ raise MethodDefinitionError.new("unknown style: #{style}")
447
+ end
448
+ end
449
+
450
+ # nil means oneway
451
+ def check_use(use)
452
+ unless [:encoded, :literal, nil].include?(use)
453
+ raise MethodDefinitionError.new("unknown use: #{use}")
454
+ end
455
+ end
456
+
457
+ def request_rpc(values, mapping_registry, literal_mapping_registry, opt)
458
+ if @request_use == :encoded
459
+ request_rpc_enc(values, mapping_registry, opt)
460
+ else
461
+ request_rpc_lit(values, literal_mapping_registry, opt)
462
+ end
463
+ end
464
+
465
+ def request_doc(values, mapping_registry, literal_mapping_registry, opt)
466
+ if @request_use == :encoded
467
+ request_doc_enc(values, mapping_registry, opt)
468
+ else
469
+ request_doc_lit(values, literal_mapping_registry, opt)
470
+ end
471
+ end
472
+
473
+ def request_rpc_enc(values, mapping_registry, opt)
474
+ method = @rpc_method_factory.dup
475
+ names = method.input_params
476
+ types = method.input_param_types
477
+ ary = Mapping.objs2soap(values, mapping_registry, types, opt)
478
+ soap = {}
479
+ 0.upto(ary.length - 1) do |idx|
480
+ soap[names[idx]] = ary[idx]
481
+ end
482
+ method.set_param(soap)
483
+ method
484
+ end
485
+
486
+ def request_rpc_lit(values, mapping_registry, opt)
487
+ method = @rpc_method_factory.dup
488
+ names = method.input_params
489
+ types = method.get_paramtypes(names)
490
+ params = {}
491
+ idx = 0
492
+ names.each do |name|
493
+ params[name] = Mapping.obj2soap(values[idx], mapping_registry,
494
+ types[idx], opt)
495
+ params[name].elename = XSD::QName.new(nil, name)
496
+ idx += 1
497
+ end
498
+ method.set_param(params)
499
+ method
500
+ end
501
+
502
+ def request_doc_enc(values, mapping_registry, opt)
503
+ (0...values.size).collect { |idx|
504
+ ele = Mapping.obj2soap(values[idx], mapping_registry, nil, opt)
505
+ ele.elename = @doc_request_qnames[idx]
506
+ ele.qualified = @doc_request_qualified[idx]
507
+ ele
508
+ }
509
+ end
510
+
511
+ def request_doc_lit(values, mapping_registry, opt)
512
+ (0...values.size).collect { |idx|
513
+ ele = Mapping.obj2soap(values[idx], mapping_registry,
514
+ @doc_request_qnames[idx], opt)
515
+ ele.encodingstyle = LiteralNamespace
516
+ ele.qualified = @doc_request_qualified[idx]
517
+ ele
518
+ }
519
+ end
520
+
521
+ def response_rpc(body, mapping_registry, literal_mapping_registry, opt)
522
+ if @response_use == :encoded
523
+ response_rpc_enc(body, mapping_registry, opt)
524
+ else
525
+ response_rpc_lit(body, literal_mapping_registry, opt)
526
+ end
527
+ end
528
+
529
+ def response_doc(body, mapping_registry, literal_mapping_registry, opt)
530
+ if @response_use == :encoded
531
+ response_doc_enc(body, mapping_registry, opt)
532
+ else
533
+ response_doc_lit(body, literal_mapping_registry, opt)
534
+ end
535
+ end
536
+
537
+ def response_rpc_enc(body, mapping_registry, opt)
538
+ ret = nil
539
+ if body.response
540
+ ret = Mapping.soap2obj(body.response, mapping_registry,
541
+ @rpc_method_factory.retval_class_name, opt)
542
+ end
543
+ if body.outparams
544
+ outparams = body.outparams.collect { |outparam|
545
+ Mapping.soap2obj(outparam, mapping_registry, nil, opt)
546
+ }
547
+ [ret].concat(outparams)
548
+ else
549
+ ret
550
+ end
551
+ end
552
+
553
+ def response_rpc_lit(body, mapping_registry, opt)
554
+ body.root_node.collect { |key, value|
555
+ Mapping.soap2obj(value, mapping_registry,
556
+ @rpc_method_factory.retval_class_name, opt)
557
+ }
558
+ end
559
+
560
+ def response_doc_enc(body, mapping_registry, opt)
561
+ body.collect { |key, value|
562
+ Mapping.soap2obj(value, mapping_registry, nil, opt)
563
+ }
564
+ end
565
+
566
+ def response_doc_lit(body, mapping_registry, opt)
567
+ body.collect { |key, value|
568
+ Mapping.soap2obj(value, mapping_registry)
569
+ }
570
+ end
571
+ end
572
+ end
573
+
574
+
575
+ end
576
+ end