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,295 @@
1
+ # SOAP4R - Mapping registry.
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/baseData'
10
+ require 'soap/mapping/mapping'
11
+
12
+
13
+ module SOAP
14
+
15
+
16
+ module Marshallable
17
+ # @@type_ns = Mapping::RubyCustomTypeNamespace
18
+ end
19
+
20
+
21
+ module Mapping
22
+
23
+
24
+ module MappedException; end
25
+
26
+
27
+ RubyTypeName = XSD::QName.new(RubyTypeInstanceNamespace, 'rubyType')
28
+ RubyExtendName = XSD::QName.new(RubyTypeInstanceNamespace, 'extends')
29
+ RubyIVarName = XSD::QName.new(RubyTypeInstanceNamespace, 'ivars')
30
+
31
+
32
+ # For anyType object: SOAP::Mapping::Object not ::Object
33
+ class Object
34
+ def initialize
35
+ @__xmlele_type = {}
36
+ @__xmlele = []
37
+ @__xmlattr = {}
38
+ end
39
+
40
+ def inspect
41
+ sprintf("#<%s:0x%x%s>", self.class.name, __id__,
42
+ @__xmlele.collect { |name, value| " #{name}=#{value.inspect}" }.join)
43
+ end
44
+
45
+ def __xmlattr
46
+ @__xmlattr
47
+ end
48
+
49
+ def __xmlele
50
+ @__xmlele
51
+ end
52
+
53
+ def [](qname)
54
+ qname = Mapping.to_qname(qname)
55
+ @__xmlele.each do |k, v|
56
+ return v if k == qname
57
+ end
58
+ # fallback
59
+ @__xmlele.each do |k, v|
60
+ return v if k.name == qname.name
61
+ end
62
+ nil
63
+ end
64
+
65
+ def []=(qname, value)
66
+ qname = Mapping.to_qname(qname)
67
+ found = false
68
+ @__xmlele.each do |pair|
69
+ if pair[0] == qname
70
+ found = true
71
+ pair[1] = value
72
+ end
73
+ end
74
+ unless found
75
+ __define_attr_accessor(qname)
76
+ @__xmlele << [qname, value]
77
+ end
78
+ @__xmlele_type[qname] = :single
79
+ end
80
+
81
+ def __add_xmlele_value(qname, value)
82
+ found = false
83
+ @__xmlele.map! do |k, v|
84
+ if k == qname
85
+ found = true
86
+ [k, __set_xmlele_value(k, v, value)]
87
+ else
88
+ [k, v]
89
+ end
90
+ end
91
+ unless found
92
+ __define_attr_accessor(qname)
93
+ @__xmlele << [qname, value]
94
+ @__xmlele_type[qname] = :single
95
+ end
96
+ value
97
+ end
98
+
99
+ def marshal_load(dumpobj)
100
+ __import(dumpobj)
101
+ end
102
+
103
+ private
104
+
105
+ # Mapping.define_attr_accessor calls define_method with proc and it exhausts
106
+ # much memory for each singleton Object. just instance_eval instead of it.
107
+ def __define_attr_accessor(qname)
108
+ # untaint depends GenSupport.safemethodname
109
+ name = Mapping.safemethodname(qname.name).untaint
110
+ # untaint depends on QName#dump
111
+ qnamedump = qname.dump.untaint
112
+ singleton = false
113
+ unless self.respond_to?(name)
114
+ singleton = true
115
+ instance_eval <<-EOS
116
+ def #{name}
117
+ self[#{qnamedump}]
118
+ end
119
+ EOS
120
+ end
121
+ unless self.respond_to?(name + "=")
122
+ singleton = true
123
+ instance_eval <<-EOS
124
+ def #{name}=(value)
125
+ self[#{qnamedump}] = value
126
+ end
127
+ EOS
128
+ end
129
+ if singleton && !self.respond_to?(:marshal_dump)
130
+ instance_eval <<-EOS
131
+ def marshal_dump
132
+ __export
133
+ end
134
+ EOS
135
+ end
136
+ end
137
+
138
+ def __set_xmlele_value(key, org, value)
139
+ case @__xmlele_type[key]
140
+ when :multi
141
+ org << value
142
+ org
143
+ when :single
144
+ @__xmlele_type[key] = :multi
145
+ [org, value]
146
+ else
147
+ raise RuntimeError.new("unknown type")
148
+ end
149
+ end
150
+
151
+ def __export
152
+ dumpobj = ::SOAP::Mapping::Object.new
153
+ dumpobj.__xmlele.replace(@__xmlele)
154
+ dumpobj.__xmlattr.replace(@__xmlattr)
155
+ dumpobj
156
+ end
157
+
158
+ def __import(dumpobj)
159
+ @__xmlele_type = {}
160
+ @__xmlele = []
161
+ @__xmlattr = {}
162
+ dumpobj.__xmlele.each do |qname, value|
163
+ __add_xmlele_value(qname, value)
164
+ end
165
+ @__xmlattr.replace(dumpobj.__xmlattr)
166
+ end
167
+ end
168
+
169
+
170
+ class MappingError < Error; end
171
+
172
+
173
+ module RegistrySupport
174
+ def initialize
175
+ super()
176
+ @class_schema_definition = {}
177
+ @class_elename_schema_definition = {}
178
+ @elename_schema_definition = {}
179
+ @type_schema_definition = {}
180
+ end
181
+
182
+ def register(definition)
183
+ obj_class = definition[:class]
184
+ definition = Mapping.create_schema_definition(obj_class, definition)
185
+ # give complexType definition a priority explicitly
186
+ if !@class_schema_definition[obj_class] or definition.type
187
+ @class_schema_definition[obj_class] = definition
188
+ end
189
+ if definition.elename and !definition.is_anonymous?
190
+ @class_elename_schema_definition[obj_class] = definition
191
+ @elename_schema_definition[definition.elename] = definition
192
+ end
193
+ if definition.type
194
+ @type_schema_definition[definition.type] = definition
195
+ end
196
+ end
197
+
198
+ def schema_definition_from_class(klass)
199
+ @class_schema_definition[klass] || Mapping.schema_definition_classdef(klass)
200
+ end
201
+
202
+ def elename_schema_definition_from_class(klass)
203
+ @class_elename_schema_definition[klass]
204
+ end
205
+
206
+ def schema_definition_from_elename(qname)
207
+ @elename_schema_definition[qname]
208
+ end
209
+
210
+ def schema_definition_from_type(type)
211
+ @type_schema_definition[type]
212
+ end
213
+
214
+ def find_node_definition(node)
215
+ schema_definition_from_type(node.type) ||
216
+ schema_definition_from_elename(node.elename) ||
217
+ find_schema_definition(node.elename.name) ||
218
+ find_schema_definition(node.type.name)
219
+ end
220
+
221
+ def find_schema_definition(name)
222
+ return nil unless name
223
+ typestr = Mapping.safeconstname(name)
224
+ obj_class = Mapping.class_from_name(typestr)
225
+ if obj_class
226
+ schema_definition_from_class(obj_class)
227
+ end
228
+ end
229
+
230
+ def add_attributes2soap(obj, ele)
231
+ if definition = Mapping.schema_definition_classdef(obj.class)
232
+ add_definedattributes2soap(obj, ele, definition)
233
+ elsif obj.respond_to?(:__xmlattr)
234
+ obj.__xmlattr.each do |key, value|
235
+ ele.extraattr[key] = value
236
+ end
237
+ end
238
+ end
239
+
240
+ def add_definedattributes2soap(obj, ele, typedef)
241
+ if typedef.attributes
242
+ typedef.attributes.each do |qname, param|
243
+ value = get_xmlattr_value(obj, qname)
244
+ ele.extraattr[qname] = value unless value.nil?
245
+ end
246
+ end
247
+ end
248
+
249
+ def get_xmlattr_value(obj, qname)
250
+ attrname = 'xmlattr_' + qname.name
251
+ value = Mapping.get_attribute(obj, attrname)
252
+ if value.nil?
253
+ attrname = Mapping.safemethodname('xmlattr_' + qname.name)
254
+ value = Mapping.get_attribute(obj, attrname)
255
+ end
256
+ value
257
+ end
258
+
259
+ def base2soap(obj, type, qualified = nil)
260
+ return SOAPNil.new if obj.nil?
261
+ soap_obj = nil
262
+ if type <= XSD::XSDString
263
+ str = XSD::Charset.encoding_conv(obj.to_s, Mapping.external_ces,
264
+ XSD::Charset.encoding)
265
+ soap_obj = type.new(str)
266
+ else
267
+ soap_obj = type.new(obj)
268
+ end
269
+ soap_obj.qualified = qualified
270
+ soap_obj
271
+ end
272
+
273
+ def base2obj(value, klass)
274
+ v = if value.respond_to?(:data)
275
+ value.data
276
+ elsif value.respond_to?(:text)
277
+ value.text
278
+ else
279
+ nil
280
+ end
281
+ if value.is_a?(klass)
282
+ v
283
+ else
284
+ klass.to_data(v)
285
+ end
286
+ end
287
+
288
+ def is_stubobj_elements_for_array(vars)
289
+ vars.keys.size == 1 and vars.values[0].is_a?(::Array)
290
+ end
291
+ end
292
+
293
+
294
+ end
295
+ end
@@ -0,0 +1,478 @@
1
+ # SOAP4R - Ruby type mapping factory.
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
+ module SOAP
10
+ module Mapping
11
+
12
+
13
+ class RubytypeFactory < Factory
14
+ TYPE_STRING = XSD::QName.new(RubyTypeNamespace, 'String')
15
+ TYPE_TIME = XSD::QName.new(RubyTypeNamespace, 'Time')
16
+ TYPE_ARRAY = XSD::QName.new(RubyTypeNamespace, 'Array')
17
+ TYPE_REGEXP = XSD::QName.new(RubyTypeNamespace, 'Regexp')
18
+ TYPE_RANGE = XSD::QName.new(RubyTypeNamespace, 'Range')
19
+ TYPE_CLASS = XSD::QName.new(RubyTypeNamespace, 'Class')
20
+ TYPE_MODULE = XSD::QName.new(RubyTypeNamespace, 'Module')
21
+ TYPE_SYMBOL = XSD::QName.new(RubyTypeNamespace, 'Symbol')
22
+ TYPE_STRUCT = XSD::QName.new(RubyTypeNamespace, 'Struct')
23
+ TYPE_HASH = XSD::QName.new(RubyTypeNamespace, 'Map')
24
+
25
+ def initialize(config = {})
26
+ @config = config
27
+ @allow_untyped_struct = @config.key?(:allow_untyped_struct) ?
28
+ @config[:allow_untyped_struct] : true
29
+ @allow_original_mapping = @config.key?(:allow_original_mapping) ?
30
+ @config[:allow_original_mapping] : false
31
+ @string_factory = StringFactory_.new(true)
32
+ @basetype_factory = BasetypeFactory_.new(true)
33
+ @datetime_factory = DateTimeFactory_.new(true)
34
+ @array_factory = ArrayFactory_.new(true)
35
+ @hash_factory = HashFactory_.new(true)
36
+ end
37
+
38
+ def obj2soap(soap_class, obj, info, map)
39
+ param = nil
40
+ case obj
41
+ when ::String
42
+ unless @allow_original_mapping
43
+ return nil
44
+ end
45
+ param = @string_factory.obj2soap(SOAPString, obj, info, map)
46
+ if obj.class != String
47
+ param.extraattr[RubyTypeName] = obj.class.name
48
+ end
49
+ addiv2soapattr(param, obj, map)
50
+ when ::Time
51
+ unless @allow_original_mapping
52
+ return nil
53
+ end
54
+ param = @datetime_factory.obj2soap(SOAPDateTime, obj, info, map)
55
+ if obj.class != Time
56
+ param.extraattr[RubyTypeName] = obj.class.name
57
+ end
58
+ addiv2soapattr(param, obj, map)
59
+ when ::Array
60
+ unless @allow_original_mapping
61
+ return nil
62
+ end
63
+ param = @array_factory.obj2soap(nil, obj, info, map)
64
+ if obj.class != Array
65
+ param.extraattr[RubyTypeName] = obj.class.name
66
+ end
67
+ addiv2soapattr(param, obj, map)
68
+ when ::NilClass
69
+ unless @allow_original_mapping
70
+ return nil
71
+ end
72
+ param = @basetype_factory.obj2soap(SOAPNil, obj, info, map)
73
+ addiv2soapattr(param, obj, map)
74
+ when ::FalseClass, ::TrueClass
75
+ unless @allow_original_mapping
76
+ return nil
77
+ end
78
+ param = @basetype_factory.obj2soap(SOAPBoolean, obj, info, map)
79
+ addiv2soapattr(param, obj, map)
80
+ when ::Integer
81
+ unless @allow_original_mapping
82
+ return nil
83
+ end
84
+ param = @basetype_factory.obj2soap(SOAPInt, obj, info, map)
85
+ param ||= @basetype_factory.obj2soap(SOAPInteger, obj, info, map)
86
+ param ||= @basetype_factory.obj2soap(SOAPDecimal, obj, info, map)
87
+ addiv2soapattr(param, obj, map)
88
+ when ::Float
89
+ unless @allow_original_mapping
90
+ return nil
91
+ end
92
+ param = @basetype_factory.obj2soap(SOAPDouble, obj, info, map)
93
+ if obj.class != Float
94
+ param.extraattr[RubyTypeName] = obj.class.name
95
+ end
96
+ addiv2soapattr(param, obj, map)
97
+ when ::Hash
98
+ unless @allow_original_mapping
99
+ return nil
100
+ end
101
+ if obj.respond_to?(:default_proc) && obj.default_proc
102
+ raise TypeError.new("cannot dump hash with default proc")
103
+ end
104
+ param = SOAPStruct.new(TYPE_HASH)
105
+ mark_marshalled_obj(obj, param)
106
+ if obj.class != Hash
107
+ param.extraattr[RubyTypeName] = obj.class.name
108
+ end
109
+ obj.each do |key, value|
110
+ elem = SOAPStruct.new # Undefined type.
111
+ elem.add("key", Mapping._obj2soap(key, map))
112
+ elem.add("value", Mapping._obj2soap(value, map))
113
+ param.add("item", elem)
114
+ end
115
+ param.add('default', Mapping._obj2soap(obj.default, map))
116
+ addiv2soapattr(param, obj, map)
117
+ when ::Regexp
118
+ unless @allow_original_mapping
119
+ return nil
120
+ end
121
+ param = SOAPStruct.new(TYPE_REGEXP)
122
+ mark_marshalled_obj(obj, param)
123
+ if obj.class != Regexp
124
+ param.extraattr[RubyTypeName] = obj.class.name
125
+ end
126
+ param.add('source', SOAPBase64.new(obj.source))
127
+ if obj.respond_to?('options')
128
+ # Regexp#options is from Ruby/1.7
129
+ options = obj.options
130
+ else
131
+ options = 0
132
+ obj.inspect.sub(/^.*\//, '').each_byte do |c|
133
+ options += case c
134
+ when ?i
135
+ 1
136
+ when ?x
137
+ 2
138
+ when ?m
139
+ 4
140
+ when ?n
141
+ 16
142
+ when ?e
143
+ 32
144
+ when ?s
145
+ 48
146
+ when ?u
147
+ 64
148
+ end
149
+ end
150
+ end
151
+ param.add('options', SOAPInt.new(options))
152
+ addiv2soapattr(param, obj, map)
153
+ when ::Range
154
+ unless @allow_original_mapping
155
+ return nil
156
+ end
157
+ param = SOAPStruct.new(TYPE_RANGE)
158
+ mark_marshalled_obj(obj, param)
159
+ if obj.class != Range
160
+ param.extraattr[RubyTypeName] = obj.class.name
161
+ end
162
+ param.add('begin', Mapping._obj2soap(obj.begin, map))
163
+ param.add('end', Mapping._obj2soap(obj.end, map))
164
+ param.add('exclude_end', SOAP::SOAPBoolean.new(obj.exclude_end?))
165
+ addiv2soapattr(param, obj, map)
166
+ when ::Class
167
+ unless @allow_original_mapping
168
+ return nil
169
+ end
170
+ if obj.to_s[0] == ?#
171
+ raise TypeError.new("can't dump anonymous class #{obj}")
172
+ end
173
+ param = SOAPStruct.new(TYPE_CLASS)
174
+ mark_marshalled_obj(obj, param)
175
+ param.add('name', SOAPString.new(obj.name))
176
+ addiv2soapattr(param, obj, map)
177
+ when ::Module
178
+ unless @allow_original_mapping
179
+ return nil
180
+ end
181
+ if obj.to_s[0] == ?#
182
+ raise TypeError.new("can't dump anonymous module #{obj}")
183
+ end
184
+ param = SOAPStruct.new(TYPE_MODULE)
185
+ mark_marshalled_obj(obj, param)
186
+ param.add('name', SOAPString.new(obj.name))
187
+ addiv2soapattr(param, obj, map)
188
+ when ::Symbol
189
+ unless @allow_original_mapping
190
+ return nil
191
+ end
192
+ param = SOAPStruct.new(TYPE_SYMBOL)
193
+ mark_marshalled_obj(obj, param)
194
+ param.add('id', SOAPString.new(obj.id2name))
195
+ addiv2soapattr(param, obj, map)
196
+ when ::Struct
197
+ unless @allow_original_mapping
198
+ # treat it as an user defined class. [ruby-talk:104980]
199
+ #param = unknownobj2soap(soap_class, obj, info, map)
200
+ param = SOAPStruct.new(XSD::AnyTypeName)
201
+ mark_marshalled_obj(obj, param)
202
+ obj.members.each do |member|
203
+ param.add(Mapping.name2elename(member),
204
+ Mapping._obj2soap(obj[member], map))
205
+ end
206
+ else
207
+ param = SOAPStruct.new(TYPE_STRUCT)
208
+ mark_marshalled_obj(obj, param)
209
+ param.add('type', ele_type = SOAPString.new(obj.class.to_s))
210
+ ele_member = SOAPStruct.new
211
+ obj.members.each do |member|
212
+ ele_member.add(Mapping.name2elename(member),
213
+ Mapping._obj2soap(obj[member], map))
214
+ end
215
+ param.add('member', ele_member)
216
+ addiv2soapattr(param, obj, map)
217
+ end
218
+ when ::IO, ::Binding, ::Continuation, ::Data, ::Dir, ::File::Stat,
219
+ ::MatchData, Method, ::Proc, ::Thread, ::ThreadGroup
220
+ # from 1.8: Process::Status, UnboundMethod
221
+ return nil
222
+ when ::SOAP::Mapping::Object
223
+ param = SOAPStruct.new(XSD::AnyTypeName)
224
+ mark_marshalled_obj(obj, param)
225
+ obj.__xmlele.each do |key, value|
226
+ param.add(key.name, Mapping._obj2soap(value, map))
227
+ end
228
+ obj.__xmlattr.each do |key, value|
229
+ param.extraattr[key] = value
230
+ end
231
+ when ::Exception
232
+ typestr = Mapping.name2elename(obj.class.to_s)
233
+ param = SOAPStruct.new(XSD::QName.new(RubyTypeNamespace, typestr))
234
+ mark_marshalled_obj(obj, param)
235
+ param.add('message', Mapping._obj2soap(obj.message, map))
236
+ param.add('backtrace', Mapping._obj2soap(obj.backtrace, map))
237
+ addiv2soapattr(param, obj, map)
238
+ else
239
+ param = unknownobj2soap(soap_class, obj, info, map)
240
+ end
241
+ param
242
+ end
243
+
244
+ def soap2obj(obj_class, node, info, map)
245
+ rubytype = node.extraattr[RubyTypeName]
246
+ if rubytype or node.type.namespace == RubyTypeNamespace
247
+ rubytype2obj(node, info, map, rubytype)
248
+ elsif node.type == XSD::AnyTypeName or node.type == XSD::AnySimpleTypeName
249
+ anytype2obj(node, info, map)
250
+ else
251
+ unknowntype2obj(node, info, map)
252
+ end
253
+ end
254
+
255
+ private
256
+
257
+ def addiv2soapattr(node, obj, map)
258
+ return if obj.instance_variables.empty?
259
+ ivars = SOAPStruct.new # Undefined type.
260
+ setiv2soap(ivars, obj, map)
261
+ node.extraattr[RubyIVarName] = ivars
262
+ end
263
+
264
+ def unknownobj2soap(soap_class, obj, info, map)
265
+ if anonymous_class?(obj)
266
+ raise TypeError.new("can't dump anonymous class #{obj}")
267
+ end
268
+ singleton_class = class << obj; self; end
269
+ if !singleton_methods_true(obj).empty? or
270
+ !singleton_class.instance_variables.empty?
271
+ raise TypeError.new("singleton can't be dumped #{obj}")
272
+ end
273
+ if !(singleton_class.ancestors - obj.class.ancestors).empty?
274
+ typestr = Mapping.name2elename(obj.class.to_s)
275
+ type = XSD::QName.new(RubyTypeNamespace, typestr)
276
+ else
277
+ type = Mapping.class2element(obj.class)
278
+ end
279
+ param = SOAPStruct.new(type)
280
+ mark_marshalled_obj(obj, param)
281
+ setiv2soap(param, obj, map)
282
+ param
283
+ end
284
+
285
+ if RUBY_VERSION >= '1.8.0'
286
+ def singleton_methods_true(obj)
287
+ obj.singleton_methods(true)
288
+ end
289
+ else
290
+ def singleton_methods_true(obj)
291
+ obj.singleton_methods
292
+ end
293
+ end
294
+
295
+ def rubytype2obj(node, info, map, rubytype)
296
+ klass = rubytype ? Mapping.class_from_name(rubytype) : nil
297
+ obj = nil
298
+ case node
299
+ when SOAPString
300
+ return @string_factory.soap2obj(klass || String, node, info, map)
301
+ when SOAPDateTime
302
+ #return @datetime_factory.soap2obj(klass || Time, node, info, map)
303
+ klass ||= Time
304
+ t = node.to_time
305
+ arg = [t.year, t.month, t.mday, t.hour, t.min, t.sec, t.usec]
306
+ obj = t.gmt? ? klass.gm(*arg) : klass.local(*arg)
307
+ mark_unmarshalled_obj(node, obj)
308
+ return true, obj
309
+ when SOAPArray
310
+ return @array_factory.soap2obj(klass || Array, node, info, map)
311
+ when SOAPNil, SOAPBoolean, SOAPInt, SOAPInteger, SOAPDecimal, SOAPDouble
312
+ return @basetype_factory.soap2obj(nil, node, info, map)
313
+ when SOAPStruct
314
+ return rubytypestruct2obj(node, info, map, rubytype)
315
+ else
316
+ raise
317
+ end
318
+ end
319
+
320
+ def rubytypestruct2obj(node, info, map, rubytype)
321
+ klass = rubytype ? Mapping.class_from_name(rubytype) : nil
322
+ obj = nil
323
+ case node.type
324
+ when TYPE_HASH
325
+ klass = rubytype ? Mapping.class_from_name(rubytype) : Hash
326
+ obj = Mapping.create_empty_object(klass)
327
+ mark_unmarshalled_obj(node, obj)
328
+ node.each do |key, value|
329
+ next unless key == 'item'
330
+ obj[Mapping._soap2obj(value['key'], map)] =
331
+ Mapping._soap2obj(value['value'], map)
332
+ end
333
+ if node.key?('default')
334
+ obj.default = Mapping._soap2obj(node['default'], map)
335
+ end
336
+ when TYPE_REGEXP
337
+ klass = rubytype ? Mapping.class_from_name(rubytype) : Regexp
338
+ obj = Mapping.create_empty_object(klass)
339
+ mark_unmarshalled_obj(node, obj)
340
+ source = node['source'].string
341
+ options = node['options'].data || 0
342
+ Regexp.instance_method(:initialize).bind(obj).call(source, options)
343
+ when TYPE_RANGE
344
+ klass = rubytype ? Mapping.class_from_name(rubytype) : Range
345
+ obj = Mapping.create_empty_object(klass)
346
+ mark_unmarshalled_obj(node, obj)
347
+ first = Mapping._soap2obj(node['begin'], map)
348
+ last = Mapping._soap2obj(node['end'], map)
349
+ exclude_end = node['exclude_end'].data
350
+ Range.instance_method(:initialize).bind(obj).call(first, last, exclude_end)
351
+ when TYPE_CLASS
352
+ obj = Mapping.class_from_name(node['name'].data)
353
+ when TYPE_MODULE
354
+ obj = Mapping.class_from_name(node['name'].data)
355
+ when TYPE_SYMBOL
356
+ obj = node['id'].data.intern
357
+ when TYPE_STRUCT
358
+ typestr = Mapping.elename2name(node['type'].data)
359
+ klass = Mapping.class_from_name(typestr)
360
+ if klass.nil?
361
+ return false
362
+ end
363
+ unless klass <= ::Struct
364
+ return false
365
+ end
366
+ obj = Mapping.create_empty_object(klass)
367
+ mark_unmarshalled_obj(node, obj)
368
+ node['member'].each do |name, value|
369
+ obj[Mapping.elename2name(name)] = Mapping._soap2obj(value, map)
370
+ end
371
+ else
372
+ return unknowntype2obj(node, info, map)
373
+ end
374
+ return true, obj
375
+ end
376
+
377
+ def anytype2obj(node, info, map)
378
+ case node
379
+ when SOAPBasetype
380
+ return true, node.data
381
+ when SOAPStruct
382
+ klass = ::SOAP::Mapping::Object
383
+ obj = klass.new
384
+ mark_unmarshalled_obj(node, obj)
385
+ node.each do |name, value|
386
+ obj.__add_xmlele_value(XSD::QName.new(nil, name),
387
+ Mapping._soap2obj(value, map))
388
+ end
389
+ unless node.extraattr.empty?
390
+ obj.instance_variable_set('@__xmlattr', node.extraattr)
391
+ end
392
+ return true, obj
393
+ else
394
+ return false
395
+ end
396
+ end
397
+
398
+ def unknowntype2obj(node, info, map)
399
+ case node
400
+ when SOAPBasetype
401
+ return true, node.data
402
+ when SOAPArray
403
+ return @array_factory.soap2obj(Array, node, info, map)
404
+ when SOAPStruct
405
+ obj = unknownstruct2obj(node, info, map)
406
+ return true, obj if obj
407
+ if !@allow_untyped_struct
408
+ return false
409
+ end
410
+ return anytype2obj(node, info, map)
411
+ else
412
+ # Basetype which is not defined...
413
+ return false
414
+ end
415
+ end
416
+
417
+ def unknownstruct2obj(node, info, map)
418
+ unless node.type.name
419
+ return nil
420
+ end
421
+ typestr = Mapping.elename2name(node.type.name)
422
+ klass = Mapping.class_from_name(typestr)
423
+ if klass.respond_to?(:soap_marshallable) and !klass.soap_marshallable
424
+ return nil
425
+ end
426
+ if klass.nil? and @allow_untyped_struct
427
+ klass = Mapping.class_from_name(typestr, true) # lenient
428
+ end
429
+ if klass.nil?
430
+ return nil
431
+ end
432
+ if klass <= ::Exception
433
+ return exception2obj(klass, node, map)
434
+ end
435
+ klass_type = Mapping.class2qname(klass)
436
+ return nil unless node.type.match(klass_type)
437
+ obj = nil
438
+ begin
439
+ obj = Mapping.create_empty_object(klass)
440
+ rescue
441
+ # type name "data" tries Data.new which raises TypeError
442
+ nil
443
+ end
444
+ mark_unmarshalled_obj(node, obj)
445
+ setiv2obj(obj, node, map)
446
+ obj
447
+ end
448
+
449
+ def exception2obj(klass, node, map)
450
+ message = Mapping._soap2obj(node['message'], map)
451
+ backtrace = Mapping._soap2obj(node['backtrace'], map)
452
+ obj = Mapping.create_empty_object(klass)
453
+ obj = obj.exception(message)
454
+ mark_unmarshalled_obj(node, obj)
455
+ obj.set_backtrace(backtrace)
456
+ obj
457
+ end
458
+
459
+ # Only creates empty array. Do String#replace it with real string.
460
+ def array2obj(node, map, rubytype)
461
+ klass = rubytype ? Mapping.class_from_name(rubytype) : Array
462
+ obj = Mapping.create_empty_object(klass)
463
+ mark_unmarshalled_obj(node, obj)
464
+ obj
465
+ end
466
+
467
+ # Only creates empty string. Do String#replace it with real string.
468
+ def string2obj(node, map, rubytype)
469
+ klass = rubytype ? Mapping.class_from_name(rubytype) : String
470
+ obj = Mapping.create_empty_object(klass)
471
+ mark_unmarshalled_obj(node, obj)
472
+ obj
473
+ end
474
+ end
475
+
476
+
477
+ end
478
+ end