soap4r_es 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (165) hide show
  1. checksums.yaml +7 -0
  2. data/bin/wsdl2ruby.rb +140 -0
  3. data/bin/wsdl2ruby_rails.rb +140 -0
  4. data/bin/xsd2ruby.rb +92 -0
  5. data/lib/soap/attachment.rb +109 -0
  6. data/lib/soap/attrproxy.rb +35 -0
  7. data/lib/soap/baseData.rb +1095 -0
  8. data/lib/soap/element.rb +278 -0
  9. data/lib/soap/encodingstyle/aspDotNetHandler.rb +208 -0
  10. data/lib/soap/encodingstyle/handler.rb +121 -0
  11. data/lib/soap/encodingstyle/literalHandler.rb +196 -0
  12. data/lib/soap/encodingstyle/soapHandler.rb +560 -0
  13. data/lib/soap/filter/filterchain.rb +52 -0
  14. data/lib/soap/filter/handler.rb +32 -0
  15. data/lib/soap/filter/streamhandler.rb +30 -0
  16. data/lib/soap/filter.rb +14 -0
  17. data/lib/soap/generator.rb +299 -0
  18. data/lib/soap/header/handler.rb +64 -0
  19. data/lib/soap/header/handlerset.rb +78 -0
  20. data/lib/soap/header/mappinghandler.rb +48 -0
  21. data/lib/soap/header/simplehandler.rb +45 -0
  22. data/lib/soap/httpconfigloader.rb +140 -0
  23. data/lib/soap/mapping/encodedregistry.rb +541 -0
  24. data/lib/soap/mapping/factory.rb +389 -0
  25. data/lib/soap/mapping/literalregistry.rb +392 -0
  26. data/lib/soap/mapping/mapping.rb +577 -0
  27. data/lib/soap/mapping/registry.rb +297 -0
  28. data/lib/soap/mapping/rubytypeFactory.rb +446 -0
  29. data/lib/soap/mapping/schemadefinition.rb +171 -0
  30. data/lib/soap/mapping/typeMap.rb +107 -0
  31. data/lib/soap/mapping/wsdlencodedregistry.rb +212 -0
  32. data/lib/soap/mapping/wsdlliteralregistry.rb +249 -0
  33. data/lib/soap/mapping.rb +13 -0
  34. data/lib/soap/marshal.rb +60 -0
  35. data/lib/soap/mimemessage.rb +243 -0
  36. data/lib/soap/nestedexception.rb +43 -0
  37. data/lib/soap/netHttpClient.rb +242 -0
  38. data/lib/soap/ns.rb +39 -0
  39. data/lib/soap/parser.rb +253 -0
  40. data/lib/soap/processor.rb +67 -0
  41. data/lib/soap/property.rb +330 -0
  42. data/lib/soap/proxy.rb +15 -0
  43. data/lib/soap/rpc/cgistub.rb +249 -0
  44. data/lib/soap/rpc/driver.rb +222 -0
  45. data/lib/soap/rpc/element.rb +375 -0
  46. data/lib/soap/rpc/httpserver.rb +144 -0
  47. data/lib/soap/rpc/methodDef.rb +69 -0
  48. data/lib/soap/rpc/proxy.rb +573 -0
  49. data/lib/soap/rpc/router.rb +672 -0
  50. data/lib/soap/rpc/rpc.rb +26 -0
  51. data/lib/soap/rpc/soaplet.rb +201 -0
  52. data/lib/soap/rpc/standaloneServer.rb +44 -0
  53. data/lib/soap/soap.rb +163 -0
  54. data/lib/soap/streamHandler.rb +302 -0
  55. data/lib/soap/version.rb +12 -0
  56. data/lib/soap/wsdlDriver.rb +165 -0
  57. data/lib/wsdl/binding.rb +66 -0
  58. data/lib/wsdl/data.rb +65 -0
  59. data/lib/wsdl/definitions.rb +237 -0
  60. data/lib/wsdl/documentation.rb +33 -0
  61. data/lib/wsdl/import.rb +81 -0
  62. data/lib/wsdl/importer.rb +39 -0
  63. data/lib/wsdl/info.rb +51 -0
  64. data/lib/wsdl/message.rb +55 -0
  65. data/lib/wsdl/operation.rb +152 -0
  66. data/lib/wsdl/operationBinding.rb +241 -0
  67. data/lib/wsdl/param.rb +94 -0
  68. data/lib/wsdl/parser.rb +180 -0
  69. data/lib/wsdl/part.rb +53 -0
  70. data/lib/wsdl/port.rb +67 -0
  71. data/lib/wsdl/portType.rb +76 -0
  72. data/lib/wsdl/service.rb +62 -0
  73. data/lib/wsdl/soap/address.rb +41 -0
  74. data/lib/wsdl/soap/binding.rb +50 -0
  75. data/lib/wsdl/soap/body.rb +59 -0
  76. data/lib/wsdl/soap/cgiStubCreator.rb +93 -0
  77. data/lib/wsdl/soap/classDefCreator.rb +529 -0
  78. data/lib/wsdl/soap/classDefCreatorSupport.rb +242 -0
  79. data/lib/wsdl/soap/classNameCreator.rb +57 -0
  80. data/lib/wsdl/soap/clientSkeltonCreator.rb +107 -0
  81. data/lib/wsdl/soap/complexType.rb +174 -0
  82. data/lib/wsdl/soap/data.rb +43 -0
  83. data/lib/wsdl/soap/definitions.rb +201 -0
  84. data/lib/wsdl/soap/driverCreator.rb +121 -0
  85. data/lib/wsdl/soap/element.rb +34 -0
  86. data/lib/wsdl/soap/encodedMappingRegistryCreator.rb +74 -0
  87. data/lib/wsdl/soap/fault.rb +57 -0
  88. data/lib/wsdl/soap/header.rb +87 -0
  89. data/lib/wsdl/soap/headerfault.rb +57 -0
  90. data/lib/wsdl/soap/literalMappingRegistryCreator.rb +116 -0
  91. data/lib/wsdl/soap/mappingRegistryCreator.rb +59 -0
  92. data/lib/wsdl/soap/mappingRegistryCreatorSupport.rb +380 -0
  93. data/lib/wsdl/soap/methodDefCreator.rb +200 -0
  94. data/lib/wsdl/soap/operation.rb +113 -0
  95. data/lib/wsdl/soap/servantSkeltonCreator.rb +92 -0
  96. data/lib/wsdl/soap/servletStubCreator.rb +105 -0
  97. data/lib/wsdl/soap/standaloneServerStubCreator.rb +101 -0
  98. data/lib/wsdl/soap/wsdl2ruby.rb +249 -0
  99. data/lib/wsdl/types.rb +45 -0
  100. data/lib/wsdl/wsdl.rb +25 -0
  101. data/lib/wsdl/xmlSchema/all.rb +25 -0
  102. data/lib/wsdl/xmlSchema/annotation.rb +35 -0
  103. data/lib/wsdl/xmlSchema/any.rb +62 -0
  104. data/lib/wsdl/xmlSchema/anyAttribute.rb +49 -0
  105. data/lib/wsdl/xmlSchema/attribute.rb +105 -0
  106. data/lib/wsdl/xmlSchema/attributeGroup.rb +69 -0
  107. data/lib/wsdl/xmlSchema/choice.rb +59 -0
  108. data/lib/wsdl/xmlSchema/complexContent.rb +98 -0
  109. data/lib/wsdl/xmlSchema/complexExtension.rb +120 -0
  110. data/lib/wsdl/xmlSchema/complexRestriction.rb +105 -0
  111. data/lib/wsdl/xmlSchema/complexType.rb +194 -0
  112. data/lib/wsdl/xmlSchema/content.rb +96 -0
  113. data/lib/wsdl/xmlSchema/data.rb +117 -0
  114. data/lib/wsdl/xmlSchema/element.rb +154 -0
  115. data/lib/wsdl/xmlSchema/enumeration.rb +37 -0
  116. data/lib/wsdl/xmlSchema/fractiondigits.rb +38 -0
  117. data/lib/wsdl/xmlSchema/group.rb +101 -0
  118. data/lib/wsdl/xmlSchema/import.rb +53 -0
  119. data/lib/wsdl/xmlSchema/importHandler.rb +45 -0
  120. data/lib/wsdl/xmlSchema/importer.rb +103 -0
  121. data/lib/wsdl/xmlSchema/include.rb +48 -0
  122. data/lib/wsdl/xmlSchema/length.rb +38 -0
  123. data/lib/wsdl/xmlSchema/list.rb +49 -0
  124. data/lib/wsdl/xmlSchema/maxexclusive.rb +38 -0
  125. data/lib/wsdl/xmlSchema/maxinclusive.rb +38 -0
  126. data/lib/wsdl/xmlSchema/maxlength.rb +38 -0
  127. data/lib/wsdl/xmlSchema/minexclusive.rb +38 -0
  128. data/lib/wsdl/xmlSchema/mininclusive.rb +38 -0
  129. data/lib/wsdl/xmlSchema/minlength.rb +38 -0
  130. data/lib/wsdl/xmlSchema/parser.rb +168 -0
  131. data/lib/wsdl/xmlSchema/pattern.rb +37 -0
  132. data/lib/wsdl/xmlSchema/ref.rb +34 -0
  133. data/lib/wsdl/xmlSchema/schema.rb +179 -0
  134. data/lib/wsdl/xmlSchema/sequence.rb +55 -0
  135. data/lib/wsdl/xmlSchema/simpleContent.rb +70 -0
  136. data/lib/wsdl/xmlSchema/simpleExtension.rb +63 -0
  137. data/lib/wsdl/xmlSchema/simpleRestriction.rb +133 -0
  138. data/lib/wsdl/xmlSchema/simpleType.rb +88 -0
  139. data/lib/wsdl/xmlSchema/totaldigits.rb +38 -0
  140. data/lib/wsdl/xmlSchema/union.rb +36 -0
  141. data/lib/wsdl/xmlSchema/unique.rb +35 -0
  142. data/lib/wsdl/xmlSchema/whitespace.rb +38 -0
  143. data/lib/wsdl/xmlSchema/xsd2ruby.rb +177 -0
  144. data/lib/xsd/charset.rb +190 -0
  145. data/lib/xsd/codegen/classdef.rb +230 -0
  146. data/lib/xsd/codegen/commentdef.rb +35 -0
  147. data/lib/xsd/codegen/gensupport.rb +277 -0
  148. data/lib/xsd/codegen/methoddef.rb +71 -0
  149. data/lib/xsd/codegen/moduledef.rb +209 -0
  150. data/lib/xsd/codegen.rb +13 -0
  151. data/lib/xsd/datatypes.rb +1465 -0
  152. data/lib/xsd/datatypes1999.rb +21 -0
  153. data/lib/xsd/iconvcharset.rb +33 -0
  154. data/lib/xsd/mapping.rb +69 -0
  155. data/lib/xsd/namedelements.rb +133 -0
  156. data/lib/xsd/ns.rb +183 -0
  157. data/lib/xsd/qname.rb +80 -0
  158. data/lib/xsd/xmlparser/libxmlparser.rb +136 -0
  159. data/lib/xsd/xmlparser/nokogiriparser.rb +63 -0
  160. data/lib/xsd/xmlparser/ogaparser.rb +53 -0
  161. data/lib/xsd/xmlparser/oxparser.rb +97 -0
  162. data/lib/xsd/xmlparser/parser.rb +101 -0
  163. data/lib/xsd/xmlparser/rexmlparser.rb +54 -0
  164. data/lib/xsd/xmlparser.rb +81 -0
  165. metadata +240 -0
@@ -0,0 +1,446 @@
1
+ # encoding: UTF-8
2
+ # SOAP4R - Ruby type mapping factory.
3
+ # Copyright (C) 2000-2007 NAKAMURA, Hiroshi <nahi@ruby-lang.org>.
4
+
5
+ # This program is copyrighted free software by NAKAMURA, Hiroshi. You can
6
+ # redistribute it and/or modify it under the same terms of Ruby's license;
7
+ # either the dual license version in 2003, or any later version.
8
+
9
+
10
+ module SOAP
11
+ module Mapping
12
+
13
+
14
+ class RubytypeFactory < Factory
15
+ TYPE_STRING = XSD::QName.new(RubyTypeNamespace, 'String')
16
+ TYPE_TIME = XSD::QName.new(RubyTypeNamespace, 'Time')
17
+ TYPE_ARRAY = XSD::QName.new(RubyTypeNamespace, 'Array')
18
+ TYPE_REGEXP = XSD::QName.new(RubyTypeNamespace, 'Regexp')
19
+ TYPE_RANGE = XSD::QName.new(RubyTypeNamespace, 'Range')
20
+ TYPE_CLASS = XSD::QName.new(RubyTypeNamespace, 'Class')
21
+ TYPE_MODULE = XSD::QName.new(RubyTypeNamespace, 'Module')
22
+ TYPE_SYMBOL = XSD::QName.new(RubyTypeNamespace, 'Symbol')
23
+ TYPE_STRUCT = XSD::QName.new(RubyTypeNamespace, 'Struct')
24
+ TYPE_HASH = XSD::QName.new(RubyTypeNamespace, 'Map')
25
+
26
+ def initialize(config = {})
27
+ @config = config
28
+ @allow_untyped_struct = @config.key?(:allow_untyped_struct) ?
29
+ @config[:allow_untyped_struct] : true
30
+ @allow_original_mapping = @config.key?(:allow_original_mapping) ?
31
+ @config[:allow_original_mapping] : false
32
+ @string_factory = StringFactory_.new(true)
33
+ @basetype_factory = BasetypeFactory_.new(true)
34
+ @datetime_factory = DateTimeFactory_.new(true)
35
+ @array_factory = ArrayFactory_.new(true)
36
+ @hash_factory = HashFactory_.new(true)
37
+ end
38
+
39
+ def obj2soap(soap_class, obj, info, map)
40
+ param = nil
41
+ case obj
42
+ when ::String
43
+ unless @allow_original_mapping
44
+ return nil
45
+ end
46
+ param = @string_factory.obj2soap(SOAPString, obj, info, map)
47
+ if obj.class != String
48
+ param.extraattr[RubyTypeName] = obj.class.name
49
+ end
50
+ addiv2soapattr(param, obj, map)
51
+ when ::Time
52
+ unless @allow_original_mapping
53
+ return nil
54
+ end
55
+ param = @datetime_factory.obj2soap(SOAPDateTime, obj, info, map)
56
+ if obj.class != Time
57
+ param.extraattr[RubyTypeName] = obj.class.name
58
+ end
59
+ addiv2soapattr(param, obj, map)
60
+ when ::Array
61
+ unless @allow_original_mapping
62
+ return nil
63
+ end
64
+ param = @array_factory.obj2soap(nil, obj, info, map)
65
+ if obj.class != Array
66
+ param.extraattr[RubyTypeName] = obj.class.name
67
+ end
68
+ addiv2soapattr(param, obj, map)
69
+ when ::NilClass
70
+ unless @allow_original_mapping
71
+ return nil
72
+ end
73
+ param = @basetype_factory.obj2soap(SOAPNil, obj, info, map)
74
+ addiv2soapattr(param, obj, map)
75
+ when ::FalseClass, ::TrueClass
76
+ unless @allow_original_mapping
77
+ return nil
78
+ end
79
+ param = @basetype_factory.obj2soap(SOAPBoolean, obj, info, map)
80
+ addiv2soapattr(param, obj, map)
81
+ when ::Integer
82
+ unless @allow_original_mapping
83
+ return nil
84
+ end
85
+ param = @basetype_factory.obj2soap(SOAPInt, obj, info, map)
86
+ param ||= @basetype_factory.obj2soap(SOAPInteger, obj, info, map)
87
+ param ||= @basetype_factory.obj2soap(SOAPDecimal, obj, info, map)
88
+ addiv2soapattr(param, obj, map)
89
+ when ::Float
90
+ unless @allow_original_mapping
91
+ return nil
92
+ end
93
+ param = @basetype_factory.obj2soap(SOAPDouble, obj, info, map)
94
+ if obj.class != Float
95
+ param.extraattr[RubyTypeName] = obj.class.name
96
+ end
97
+ addiv2soapattr(param, obj, map)
98
+ when ::Hash
99
+ unless @allow_original_mapping
100
+ return nil
101
+ end
102
+ if obj.respond_to?(:default_proc) && obj.default_proc
103
+ raise TypeError.new("cannot dump hash with default proc")
104
+ end
105
+ param = SOAPStruct.new(TYPE_HASH)
106
+ mark_marshalled_obj(obj, param)
107
+ if obj.class != Hash
108
+ param.extraattr[RubyTypeName] = obj.class.name
109
+ end
110
+ obj.each do |key, value|
111
+ elem = SOAPStruct.new # Undefined type.
112
+ elem.add("key", Mapping._obj2soap(key, map))
113
+ elem.add("value", Mapping._obj2soap(value, map))
114
+ param.add("item", elem)
115
+ end
116
+ param.add('default', Mapping._obj2soap(obj.default, map))
117
+ addiv2soapattr(param, obj, map)
118
+ when ::Regexp
119
+ unless @allow_original_mapping
120
+ return nil
121
+ end
122
+ param = SOAPStruct.new(TYPE_REGEXP)
123
+ mark_marshalled_obj(obj, param)
124
+ if obj.class != Regexp
125
+ param.extraattr[RubyTypeName] = obj.class.name
126
+ end
127
+ param.add('source', SOAPBase64.new(obj.source))
128
+ options = obj.options
129
+ param.add('options', SOAPInt.new(options))
130
+ addiv2soapattr(param, obj, map)
131
+ when ::Range
132
+ unless @allow_original_mapping
133
+ return nil
134
+ end
135
+ param = SOAPStruct.new(TYPE_RANGE)
136
+ mark_marshalled_obj(obj, param)
137
+ if obj.class != Range
138
+ param.extraattr[RubyTypeName] = obj.class.name
139
+ end
140
+ param.add('begin', Mapping._obj2soap(obj.begin, map))
141
+ param.add('end', Mapping._obj2soap(obj.end, map))
142
+ param.add('exclude_end', SOAP::SOAPBoolean.new(obj.exclude_end?))
143
+ addiv2soapattr(param, obj, map)
144
+ when ::Class
145
+ unless @allow_original_mapping
146
+ return nil
147
+ end
148
+ if obj.to_s[0] == ?#
149
+ raise TypeError.new("can't dump anonymous class #{obj}")
150
+ end
151
+ param = SOAPStruct.new(TYPE_CLASS)
152
+ mark_marshalled_obj(obj, param)
153
+ param.add('name', SOAPString.new(obj.name))
154
+ addiv2soapattr(param, obj, map)
155
+ when ::Module
156
+ unless @allow_original_mapping
157
+ return nil
158
+ end
159
+ if obj.to_s[0] == ?#
160
+ raise TypeError.new("can't dump anonymous module #{obj}")
161
+ end
162
+ param = SOAPStruct.new(TYPE_MODULE)
163
+ mark_marshalled_obj(obj, param)
164
+ param.add('name', SOAPString.new(obj.name))
165
+ addiv2soapattr(param, obj, map)
166
+ when ::Symbol
167
+ unless @allow_original_mapping
168
+ return nil
169
+ end
170
+ param = SOAPStruct.new(TYPE_SYMBOL)
171
+ mark_marshalled_obj(obj, param)
172
+ param.add('id', SOAPString.new(obj.id2name))
173
+ addiv2soapattr(param, obj, map)
174
+ when ::Struct
175
+ unless @allow_original_mapping
176
+ # treat it as an user defined class. [ruby-talk:104980]
177
+ #param = unknownobj2soap(soap_class, obj, info, map)
178
+ param = SOAPStruct.new(XSD::AnyTypeName)
179
+ mark_marshalled_obj(obj, param)
180
+ obj.members.each do |member|
181
+ param.add(Mapping.name2elename(member),
182
+ Mapping._obj2soap(obj[member], map))
183
+ end
184
+ else
185
+ param = SOAPStruct.new(TYPE_STRUCT)
186
+ mark_marshalled_obj(obj, param)
187
+ param.add('type', ele_type = SOAPString.new(obj.class.to_s))
188
+ ele_member = SOAPStruct.new
189
+ obj.members.each do |member|
190
+ ele_member.add(Mapping.name2elename(member),
191
+ Mapping._obj2soap(obj[member], map))
192
+ end
193
+ param.add('member', ele_member)
194
+ addiv2soapattr(param, obj, map)
195
+ end
196
+ when ::IO, ::Binding, ::Data, ::Dir, ::File::Stat,
197
+ ::MatchData, Method, ::Proc, ::Process::Status, ::Thread,
198
+ ::ThreadGroup, ::UnboundMethod
199
+ return nil
200
+ when ::SOAP::Mapping::Object
201
+ param = SOAPStruct.new(XSD::AnyTypeName)
202
+ mark_marshalled_obj(obj, param)
203
+ obj.__xmlele.each do |key, value|
204
+ param.add(key.name, Mapping._obj2soap(value, map))
205
+ end
206
+ obj.__xmlattr.each do |key, value|
207
+ param.extraattr[key] = value
208
+ end
209
+ when ::Exception
210
+ typestr = Mapping.name2elename(obj.class.to_s)
211
+ param = SOAPStruct.new(XSD::QName.new(RubyTypeNamespace, typestr))
212
+ mark_marshalled_obj(obj, param)
213
+ param.add('message', Mapping._obj2soap(obj.message, map))
214
+ param.add('backtrace', Mapping._obj2soap(obj.backtrace, map))
215
+ addiv2soapattr(param, obj, map)
216
+ else
217
+ param = unknownobj2soap(soap_class, obj, info, map)
218
+ end
219
+ param
220
+ end
221
+
222
+ def soap2obj(obj_class, node, info, map)
223
+ rubytype = node.extraattr[RubyTypeName]
224
+ if rubytype or node.type.namespace == RubyTypeNamespace
225
+ rubytype2obj(node, info, map, rubytype)
226
+ elsif node.type == XSD::AnyTypeName or node.type == XSD::AnySimpleTypeName
227
+ anytype2obj(node, info, map)
228
+ else
229
+ unknowntype2obj(node, info, map)
230
+ end
231
+ end
232
+
233
+ private
234
+
235
+ def addiv2soapattr(node, obj, map)
236
+ return if obj.instance_variables.empty?
237
+ ivars = SOAPStruct.new # Undefined type.
238
+ setiv2soap(ivars, obj, map)
239
+ node.extraattr[RubyIVarName] = ivars
240
+ end
241
+
242
+ def unknownobj2soap(soap_class, obj, info, map)
243
+ if anonymous_class?(obj)
244
+ raise TypeError.new("can't dump anonymous class #{obj}")
245
+ end
246
+ singleton_class = class << obj; self; end
247
+ if !obj.singleton_methods(true).empty? or
248
+ !singleton_class.instance_variables.empty?
249
+ raise TypeError.new("singleton can't be dumped #{obj}")
250
+ end
251
+ if !(singleton_class.ancestors - obj.class.ancestors).empty?
252
+ typestr = Mapping.name2elename(obj.class.to_s)
253
+ type = XSD::QName.new(RubyTypeNamespace, typestr)
254
+ else
255
+ type = Mapping.class2element(obj.class)
256
+ end
257
+ param = SOAPStruct.new(type)
258
+ mark_marshalled_obj(obj, param)
259
+ setiv2soap(param, obj, map)
260
+ param
261
+ end
262
+
263
+ def rubytype2obj(node, info, map, rubytype)
264
+ klass = rubytype ? Mapping.class_from_name(rubytype) : nil
265
+ obj = nil
266
+ case node
267
+ when SOAPString
268
+ return @string_factory.soap2obj(klass || String, node, info, map)
269
+ when SOAPDateTime
270
+ #return @datetime_factory.soap2obj(klass || Time, node, info, map)
271
+ klass ||= Time
272
+ t = node.to_time
273
+ arg = [t.year, t.month, t.mday, t.hour, t.min, t.sec, t.usec]
274
+ obj = t.gmt? ? klass.gm(*arg) : klass.local(*arg)
275
+ mark_unmarshalled_obj(node, obj)
276
+ return true, obj
277
+ when SOAPArray
278
+ return @array_factory.soap2obj(klass || Array, node, info, map)
279
+ when SOAPNil, SOAPBoolean, SOAPInt, SOAPInteger, SOAPDecimal, SOAPDouble
280
+ return @basetype_factory.soap2obj(nil, node, info, map)
281
+ when SOAPStruct
282
+ return rubytypestruct2obj(node, info, map, rubytype)
283
+ else
284
+ raise
285
+ end
286
+ end
287
+
288
+ def rubytypestruct2obj(node, info, map, rubytype)
289
+ klass = rubytype ? Mapping.class_from_name(rubytype) : nil
290
+ obj = nil
291
+ case node.type
292
+ when TYPE_HASH
293
+ klass = rubytype ? Mapping.class_from_name(rubytype) : Hash
294
+ obj = Mapping.create_empty_object(klass)
295
+ mark_unmarshalled_obj(node, obj)
296
+ node.each do |key, value|
297
+ next unless key == 'item'
298
+ obj[Mapping._soap2obj(value['key'], map)] =
299
+ Mapping._soap2obj(value['value'], map)
300
+ end
301
+ if node.key?('default')
302
+ obj.default = Mapping._soap2obj(node['default'], map)
303
+ end
304
+ when TYPE_REGEXP
305
+ klass = rubytype ? Mapping.class_from_name(rubytype) : Regexp
306
+ obj = Mapping.create_empty_object(klass)
307
+ mark_unmarshalled_obj(node, obj)
308
+ source = node['source'].string
309
+ options = node['options'].data || 0
310
+ Regexp.instance_method(:initialize).bind(obj).call(source, options)
311
+ when TYPE_RANGE
312
+ klass = rubytype ? Mapping.class_from_name(rubytype) : Range
313
+ obj = Mapping.create_empty_object(klass)
314
+ mark_unmarshalled_obj(node, obj)
315
+ first = Mapping._soap2obj(node['begin'], map)
316
+ last = Mapping._soap2obj(node['end'], map)
317
+ exclude_end = node['exclude_end'].data
318
+ Range.instance_method(:initialize).bind(obj).call(first, last, exclude_end)
319
+ when TYPE_CLASS
320
+ obj = Mapping.class_from_name(node['name'].data)
321
+ when TYPE_MODULE
322
+ obj = Mapping.class_from_name(node['name'].data)
323
+ when TYPE_SYMBOL
324
+ obj = node['id'].data.intern
325
+ when TYPE_STRUCT
326
+ typestr = Mapping.elename2name(node['type'].data)
327
+ klass = Mapping.class_from_name(typestr)
328
+ if klass.nil?
329
+ return false
330
+ end
331
+ unless klass <= ::Struct
332
+ return false
333
+ end
334
+ obj = Mapping.create_empty_object(klass)
335
+ mark_unmarshalled_obj(node, obj)
336
+ node['member'].each do |name, value|
337
+ obj[Mapping.elename2name(name)] = Mapping._soap2obj(value, map)
338
+ end
339
+ else
340
+ return unknowntype2obj(node, info, map)
341
+ end
342
+ return true, obj
343
+ end
344
+
345
+ def anytype2obj(node, info, map)
346
+ case node
347
+ when SOAPBasetype
348
+ return true, node.data
349
+ when SOAPStruct
350
+ klass = ::SOAP::Mapping::Object
351
+ obj = klass.new
352
+ mark_unmarshalled_obj(node, obj)
353
+ node.each do |name, value|
354
+ obj.__add_xmlele_value(XSD::QName.new(nil, name),
355
+ Mapping._soap2obj(value, map))
356
+ end
357
+ unless node.extraattr.empty?
358
+ obj.instance_variable_set('@__xmlattr', node.extraattr)
359
+ end
360
+ return true, obj
361
+ else
362
+ return false
363
+ end
364
+ end
365
+
366
+ def unknowntype2obj(node, info, map)
367
+ case node
368
+ when SOAPBasetype
369
+ return true, node.data
370
+ when SOAPArray
371
+ return @array_factory.soap2obj(Array, node, info, map)
372
+ when SOAPStruct
373
+ obj = unknownstruct2obj(node, info, map)
374
+ return true, obj if obj
375
+ if !@allow_untyped_struct
376
+ return false
377
+ end
378
+ return anytype2obj(node, info, map)
379
+ else
380
+ # Basetype which is not defined...
381
+ return false
382
+ end
383
+ end
384
+
385
+ def unknownstruct2obj(node, info, map)
386
+ unless node.type.name
387
+ return nil
388
+ end
389
+ typestr = Mapping.elename2name(node.type.name)
390
+ klass = Mapping.class_from_name(typestr)
391
+ if klass.respond_to?(:soap_marshallable) and !klass.soap_marshallable
392
+ return nil
393
+ end
394
+ if klass.nil? and @allow_untyped_struct
395
+ klass = Mapping.class_from_name(typestr, true) # lenient
396
+ end
397
+ if klass.nil?
398
+ return nil
399
+ end
400
+ if klass <= ::Exception
401
+ return exception2obj(klass, node, map)
402
+ end
403
+ klass_type = Mapping.class2qname(klass)
404
+ return nil unless node.type.match(klass_type)
405
+ obj = nil
406
+ begin
407
+ obj = Mapping.create_empty_object(klass)
408
+ rescue
409
+ # type name "data" tries Data.new which raises TypeError
410
+ nil
411
+ end
412
+ mark_unmarshalled_obj(node, obj)
413
+ setiv2obj(obj, node, map)
414
+ obj
415
+ end
416
+
417
+ def exception2obj(klass, node, map)
418
+ message = Mapping._soap2obj(node['message'], map)
419
+ backtrace = Mapping._soap2obj(node['backtrace'], map)
420
+ obj = Mapping.create_empty_object(klass)
421
+ obj = obj.exception(message)
422
+ mark_unmarshalled_obj(node, obj)
423
+ obj.set_backtrace(backtrace)
424
+ obj
425
+ end
426
+
427
+ # Only creates empty array. Do String#replace it with real string.
428
+ def array2obj(node, map, rubytype)
429
+ klass = rubytype ? Mapping.class_from_name(rubytype) : Array
430
+ obj = Mapping.create_empty_object(klass)
431
+ mark_unmarshalled_obj(node, obj)
432
+ obj
433
+ end
434
+
435
+ # Only creates empty string. Do String#replace it with real string.
436
+ def string2obj(node, map, rubytype)
437
+ klass = rubytype ? Mapping.class_from_name(rubytype) : String
438
+ obj = Mapping.create_empty_object(klass)
439
+ mark_unmarshalled_obj(node, obj)
440
+ obj
441
+ end
442
+ end
443
+
444
+
445
+ end
446
+ end
@@ -0,0 +1,171 @@
1
+ # encoding: UTF-8
2
+ # SOAP4R - Ruby type mapping schema definition utility.
3
+ # Copyright (C) 2000-2007 NAKAMURA Hiroshi <nahi@ruby-lang.org>.
4
+
5
+ # This program is copyrighted free software by NAKAMURA, Hiroshi. You can
6
+ # redistribute it and/or modify it under the same terms of Ruby's license;
7
+ # either the dual license version in 2003, or any later version.
8
+
9
+
10
+ require 'xsd/codegen/gensupport'
11
+
12
+
13
+ module SOAP
14
+ module Mapping
15
+
16
+
17
+ class SchemaElementDefinition
18
+ attr_reader :varname, :mapped_class, :elename, :minoccurs, :maxoccurs
19
+
20
+ def initialize(varname, mapped_class, elename, minoccurs, maxoccurs,
21
+ as_any, as_array)
22
+ @varname = varname
23
+ @mapped_class = mapped_class
24
+ @elename = elename
25
+ @minoccurs = minoccurs
26
+ @maxoccurs = maxoccurs
27
+ @as_any = as_any
28
+ @as_array = as_array
29
+ end
30
+
31
+ def as_any?
32
+ @as_any
33
+ end
34
+
35
+ def as_array?
36
+ @as_array
37
+ end
38
+ end
39
+
40
+ module SchemaComplexTypeDefinition
41
+ include Enumerable
42
+
43
+ def initialize
44
+ @content = []
45
+ @element_cache = {}
46
+ end
47
+
48
+ def is_concrete_definition
49
+ true
50
+ end
51
+
52
+ def <<(ele)
53
+ @content << ele
54
+ end
55
+
56
+ def each
57
+ @content.each do |ele|
58
+ yield ele
59
+ end
60
+ end
61
+
62
+ def size
63
+ @content.size
64
+ end
65
+
66
+ def as_any?
67
+ false
68
+ end
69
+
70
+ def as_array?
71
+ false
72
+ end
73
+
74
+ def find_element(qname)
75
+ @element_cache[qname] ||= search_element(qname)
76
+ end
77
+
78
+ private
79
+
80
+ def search_element(qname)
81
+ each do |ele|
82
+ if ele.respond_to?(:find_element)
83
+ found = ele.find_element(qname)
84
+ return found if found
85
+ else
86
+ # relaxed match
87
+ if ele.elename == qname or
88
+ (qname.namespace.nil? and ele.elename.name == qname.name)
89
+ return ele
90
+ end
91
+ end
92
+ end
93
+ nil
94
+ end
95
+ end
96
+
97
+ class SchemaEmptyDefinition
98
+ include SchemaComplexTypeDefinition
99
+
100
+ def initialize
101
+ super()
102
+ @content.freeze
103
+ end
104
+ end
105
+
106
+ class SchemaSequenceDefinition
107
+ include SchemaComplexTypeDefinition
108
+
109
+ def initialize
110
+ super()
111
+ end
112
+
113
+ def choice?
114
+ false
115
+ end
116
+
117
+ # override
118
+ def as_array?
119
+ @as_array ||= false
120
+ end
121
+
122
+ def set_array
123
+ @as_array = true
124
+ end
125
+ end
126
+
127
+ class SchemaChoiceDefinition
128
+ include SchemaComplexTypeDefinition
129
+
130
+ def initialize
131
+ super()
132
+ end
133
+
134
+ def choice?
135
+ true
136
+ end
137
+ end
138
+
139
+ class SchemaDefinition
140
+ EMPTY = SchemaEmptyDefinition.new
141
+
142
+ attr_reader :class_for
143
+ attr_reader :elename, :type
144
+ attr_reader :qualified
145
+ attr_accessor :basetype
146
+ attr_accessor :attributes
147
+ attr_accessor :elements
148
+
149
+ def initialize(class_for, elename, type, anonymous, qualified)
150
+ @class_for = class_for
151
+ @elename = elename
152
+ @type = type
153
+ @anonymous = anonymous
154
+ @qualified = qualified
155
+ @basetype = nil
156
+ @elements = EMPTY
157
+ @attributes = nil
158
+ end
159
+
160
+ def is_anonymous?
161
+ @anonymous
162
+ end
163
+
164
+ def choice?
165
+ @elements.choice?
166
+ end
167
+ end
168
+
169
+
170
+ end
171
+ end