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,609 @@
1
+ # SOAP4R - Ruby type mapping utility.
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 'xsd/codegen/gensupport'
10
+ require 'soap/mapping/schemadefinition'
11
+
12
+
13
+ module SOAP
14
+
15
+
16
+ module Mapping
17
+ RubyTypeNamespace = 'http://www.ruby-lang.org/xmlns/ruby/type/1.6'
18
+ RubyTypeInstanceNamespace =
19
+ 'http://www.ruby-lang.org/xmlns/ruby/type-instance'
20
+ RubyCustomTypeNamespace = 'http://www.ruby-lang.org/xmlns/ruby/type/custom'
21
+ ApacheSOAPTypeNamespace = 'http://xml.apache.org/xml-soap'
22
+
23
+
24
+ module TraverseSupport
25
+ def mark_marshalled_obj(obj, soap_obj)
26
+ raise if obj.nil?
27
+ Thread.current[:SOAPMapping][:MarshalKey][obj.__id__] = soap_obj
28
+ end
29
+
30
+ def mark_unmarshalled_obj(node, obj)
31
+ return if obj.nil?
32
+ # node.id is not Object#id but SOAPReference#id
33
+ Thread.current[:SOAPMapping][:MarshalKey][node.id] = obj
34
+ end
35
+ end
36
+
37
+
38
+ EMPTY_OPT = {}.freeze
39
+ def self.obj2soap(obj, registry = nil, type = nil, opt = EMPTY_OPT)
40
+ registry ||= Mapping::DefaultRegistry
41
+ soap_obj = nil
42
+ protect_mapping(opt) do
43
+ soap_obj = _obj2soap(obj, registry, type)
44
+ end
45
+ soap_obj
46
+ end
47
+
48
+ def self.objs2soap(objs, registry = nil, types = nil, opt = EMPTY_OPT)
49
+ registry ||= Mapping::DefaultRegistry
50
+ ary = []
51
+ protect_mapping(opt) do
52
+ 0.upto(objs.length - 1) do |idx|
53
+ type = types ? types[idx] : nil
54
+ soap = _obj2soap(objs[idx], registry, type)
55
+ ary << soap
56
+ end
57
+ end
58
+ ary
59
+ end
60
+
61
+ def self.soap2obj(node, registry = nil, klass = nil, opt = EMPTY_OPT)
62
+ registry ||= Mapping::DefaultRegistry
63
+ obj = nil
64
+ protect_mapping(opt) do
65
+ obj = _soap2obj(node, registry, klass)
66
+ end
67
+ obj
68
+ end
69
+
70
+ def self.ary2soap(ary, type_ns = XSD::Namespace, typename = XSD::AnyTypeLiteral, registry = nil, opt = EMPTY_OPT)
71
+ registry ||= Mapping::DefaultRegistry
72
+ type = XSD::QName.new(type_ns, typename)
73
+ soap_ary = SOAPArray.new(ValueArrayName, 1, type)
74
+ protect_mapping(opt) do
75
+ ary.each do |ele|
76
+ soap_ary.add(_obj2soap(ele, registry, type))
77
+ end
78
+ end
79
+ soap_ary
80
+ end
81
+
82
+ def self.ary2md(ary, rank, type_ns = XSD::Namespace, typename = XSD::AnyTypeLiteral, registry = nil, opt = EMPTY_OPT)
83
+ registry ||= Mapping::DefaultRegistry
84
+ type = XSD::QName.new(type_ns, typename)
85
+ md_ary = SOAPArray.new(ValueArrayName, rank, type)
86
+ protect_mapping(opt) do
87
+ add_md_ary(md_ary, ary, [], registry)
88
+ end
89
+ md_ary
90
+ end
91
+
92
+ def self.fault2exception(fault, registry = nil)
93
+ registry ||= Mapping::DefaultRegistry
94
+ detail = if fault.detail
95
+ soap2obj(fault.detail, registry) || ""
96
+ else
97
+ ""
98
+ end
99
+ if detail.is_a?(Mapping::SOAPException)
100
+ begin
101
+ e = detail.to_e
102
+ remote_backtrace = e.backtrace
103
+ e.set_backtrace(nil)
104
+ raise e # ruby sets current caller as local backtrace of e => e2.
105
+ rescue Exception => e
106
+ e.set_backtrace(remote_backtrace + e.backtrace[1..-1])
107
+ raise
108
+ end
109
+ else
110
+ fault.detail = detail
111
+ fault.set_backtrace(
112
+ if detail.is_a?(Array)
113
+ detail
114
+ else
115
+ [detail.to_s]
116
+ end
117
+ )
118
+ raise
119
+ end
120
+ end
121
+
122
+ def self._obj2soap(obj, registry, type = nil)
123
+ if obj.respond_to?(:to_xmlpart)
124
+ SOAPRawData.new(obj)
125
+ elsif defined?(::REXML) and obj.is_a?(::REXML::Element)
126
+ SOAPRawData.new(SOAPREXMLElementWrap.new(obj))
127
+ elsif referent = Thread.current[:SOAPMapping][:MarshalKey][obj.__id__] and
128
+ !Thread.current[:SOAPMapping][:NoReference]
129
+ SOAPReference.new(referent)
130
+ elsif registry
131
+ registry.obj2soap(obj, type)
132
+ else
133
+ raise MappingError.new("no mapping registry given")
134
+ end
135
+ end
136
+
137
+ def self._soap2obj(node, registry, klass = nil)
138
+ if node.nil?
139
+ return nil
140
+ elsif node.is_a?(SOAPReference)
141
+ target = node.__getobj__
142
+ # target.id is not Object#id but SOAPReference#id
143
+ if referent = Thread.current[:SOAPMapping][:MarshalKey][target.id] and
144
+ !Thread.current[:SOAPMapping][:NoReference]
145
+ return referent
146
+ else
147
+ return _soap2obj(target, registry, klass)
148
+ end
149
+ end
150
+ return registry.soap2obj(node, klass)
151
+ end
152
+
153
+ if Object.respond_to?(:allocate)
154
+ # ruby/1.7 or later.
155
+ def self.create_empty_object(klass)
156
+ klass.allocate
157
+ end
158
+ else
159
+ MARSHAL_TAG = {
160
+ String => ['"', 1],
161
+ Regexp => ['/', 2],
162
+ Array => ['[', 1],
163
+ Hash => ['{', 1]
164
+ }
165
+ def self.create_empty_object(klass)
166
+ if klass <= Struct
167
+ name = klass.name
168
+ return ::Marshal.load(sprintf("\004\006S:%c%s\000", name.length + 5, name))
169
+ end
170
+ if MARSHAL_TAG.has_key?(klass)
171
+ tag, terminate = MARSHAL_TAG[klass]
172
+ return ::Marshal.load(sprintf("\004\006%s%s", tag, "\000" * terminate))
173
+ end
174
+ MARSHAL_TAG.each do |k, v|
175
+ if klass < k
176
+ name = klass.name
177
+ tag, terminate = v
178
+ return ::Marshal.load(sprintf("\004\006C:%c%s%s%s", name.length + 5, name, tag, "\000" * terminate))
179
+ end
180
+ end
181
+ name = klass.name
182
+ ::Marshal.load(sprintf("\004\006o:%c%s\000", name.length + 5, name))
183
+ end
184
+ end
185
+
186
+ # Allow only (Letter | '_') (Letter | Digit | '-' | '_')* here.
187
+ # Caution: '.' is not allowed here.
188
+ # To follow XML spec., it should be NCName.
189
+ # (denied chars) => .[0-F][0-F]
190
+ # ex. a.b => a.2eb
191
+ #
192
+ def self.name2elename(name)
193
+ name.gsub(/([^a-zA-Z0-9:_\-]+)/n) {
194
+ '.' << $1.unpack('H2' * $1.size).join('.')
195
+ }.gsub(/::/n, '..')
196
+ end
197
+
198
+ def self.elename2name(name)
199
+ name.gsub(/\.\./n, '::').gsub(/((?:\.[0-9a-fA-F]{2})+)/n) {
200
+ [$1.delete('.')].pack('H*')
201
+ }
202
+ end
203
+
204
+ def self.const_from_name(name, lenient = false)
205
+ const = ::Object
206
+ name.sub(/\A::/, '').split('::').each do |const_str|
207
+ if /\A[A-Z]/ =~ const_str
208
+ begin
209
+ if const.const_defined?(const_str)
210
+ const = const.const_get(const_str)
211
+ next
212
+ end
213
+ rescue NameError
214
+ end
215
+ end
216
+ if lenient
217
+ const_str = Mapping.safeconstname(const_str)
218
+ if const.const_defined?(const_str)
219
+ const = const.const_get(const_str)
220
+ next
221
+ end
222
+ end
223
+ return nil
224
+ end
225
+ const
226
+ end
227
+
228
+ def self.class_from_name(name, lenient = false)
229
+ unless lenient
230
+ const = const_from_name_nonlenient(name)
231
+ else
232
+ const = const_from_name(name, true)
233
+ end
234
+ if const.is_a?(::Class)
235
+ const
236
+ else
237
+ nil
238
+ end
239
+ end
240
+
241
+ def self.module_from_name(name, lenient = false)
242
+ unless lenient
243
+ const = const_from_name_nonlenient(name)
244
+ else
245
+ const = const_from_name(name, true)
246
+ end
247
+ if const.is_a?(::Module)
248
+ const
249
+ else
250
+ nil
251
+ end
252
+ end
253
+
254
+ def self.const_from_name_nonlenient(name)
255
+ if Thread.current[:SOAPMapping]
256
+ Thread.current[:SOAPMapping][:ConstFromName][name] ||=
257
+ const_from_name(name)
258
+ else
259
+ const_from_name(name)
260
+ end
261
+ end
262
+
263
+ def self.class2qname(klass)
264
+ name = schema_type_definition(klass)
265
+ namespace = schema_ns_definition(klass)
266
+ XSD::QName.new(namespace, name)
267
+ end
268
+
269
+ def self.class2element(klass)
270
+ name = schema_type_definition(klass) ||
271
+ Mapping.name2elename(klass.name)
272
+ namespace = schema_ns_definition(klass) || RubyCustomTypeNamespace
273
+ XSD::QName.new(namespace, name)
274
+ end
275
+
276
+ def self.obj2element(obj)
277
+ name = namespace = nil
278
+ ivars = obj.instance_variables
279
+ if ivars.include?('@schema_type')
280
+ name = obj.instance_variable_get('@schema_type')
281
+ end
282
+ if ivars.include?('@schema_ns')
283
+ namespace = obj.instance_variable_get('@schema_ns')
284
+ end
285
+ if !name or !namespace
286
+ class2qname(obj.class)
287
+ else
288
+ XSD::QName.new(namespace, name)
289
+ end
290
+ end
291
+
292
+ def self.to_qname(obj, ns = nil)
293
+ if obj.is_a?(XSD::QName)
294
+ obj
295
+ else
296
+ XSD::QName.new(ns, obj)
297
+ end
298
+ end
299
+
300
+ def self.define_singleton_method(obj, name, &block)
301
+ sclass = (class << obj; self; end)
302
+ sclass.class_eval {
303
+ define_method(name, &block)
304
+ }
305
+ end
306
+
307
+ def self.get_attributes(obj)
308
+ if obj.is_a?(::Hash)
309
+ obj
310
+ else
311
+ rs = {}
312
+ obj.instance_variables.each do |ele|
313
+ rs[ele.sub(/^@/, '')] = obj.instance_variable_get(ele)
314
+ end
315
+ rs
316
+ end
317
+ end
318
+
319
+ EMPTY_ATTRIBUTES = {}.freeze
320
+ def self.get_attributes_for_any(obj)
321
+ if obj.respond_to?(:__xmlele_any)
322
+ obj.__xmlele_any || EMPTY_ATTRIBUTES
323
+ else
324
+ get_attributes(obj)
325
+ end
326
+ end
327
+
328
+ def self.get_attribute(obj, attr_name)
329
+ case obj
330
+ when ::SOAP::Mapping::Object
331
+ return obj[attr_name]
332
+ when ::Hash
333
+ return obj[attr_name] || obj[attr_name.intern]
334
+ else
335
+ if obj.respond_to?(attr_name)
336
+ return obj.__send__(attr_name)
337
+ end
338
+ iv = obj.instance_variables
339
+ name = Mapping.safevarname(attr_name)
340
+ if iv.include?("@#{name}")
341
+ return obj.instance_variable_get("@#{name}")
342
+ elsif iv.include?("@#{attr_name}")
343
+ return obj.instance_variable_get("@#{attr_name}")
344
+ end
345
+ if obj.respond_to?(name)
346
+ return obj.__send__(name)
347
+ end
348
+ nil
349
+ end
350
+ end
351
+
352
+ def self.set_attributes(obj, values)
353
+ case obj
354
+ when ::SOAP::Mapping::Object
355
+ values.each do |attr_name, value|
356
+ obj.__add_xmlele_value(attr_name, value)
357
+ end
358
+ else
359
+ values.each do |attr_name, value|
360
+ # untaint depends GenSupport.safevarname
361
+ name = Mapping.safevarname(attr_name).untaint
362
+ setter = name + "="
363
+ if obj.respond_to?(setter)
364
+ obj.__send__(setter, value)
365
+ else
366
+ obj.instance_variable_set('@' + name, value)
367
+ begin
368
+ unless obj.respond_to?(name)
369
+ obj.instance_eval <<-EOS
370
+ def #{name}
371
+ @#{name}
372
+ end
373
+ EOS
374
+ end
375
+ unless self.respond_to?(name + "=")
376
+ obj.instance_eval <<-EOS
377
+ def #{name}=(value)
378
+ @#{name} = value
379
+ end
380
+ EOS
381
+ end
382
+ rescue TypeError
383
+ # singleton class may not exist (e.g. Float)
384
+ end
385
+ end
386
+ end
387
+ end
388
+ end
389
+
390
+ def self.safeconstname(name)
391
+ Thread.current[:SOAPMapping][:SafeConstName][name] ||=
392
+ XSD::CodeGen::GenSupport.safeconstname(name)
393
+ end
394
+
395
+ def self.safemethodname(name)
396
+ Thread.current[:SOAPMapping][:SafeMethodName][name] ||=
397
+ XSD::CodeGen::GenSupport.safemethodname(name)
398
+ end
399
+
400
+ def self.safevarname(name)
401
+ Thread.current[:SOAPMapping][:SafeVarName][name] ||=
402
+ XSD::CodeGen::GenSupport.safevarname(name)
403
+ end
404
+
405
+ def self.root_type_hint
406
+ Thread.current[:SOAPMapping][:RootTypeHint]
407
+ end
408
+
409
+ def self.reset_root_type_hint
410
+ Thread.current[:SOAPMapping][:RootTypeHint] = false
411
+ end
412
+
413
+ def self.external_ces
414
+ Thread.current[:SOAPMapping][:ExternalCES]
415
+ end
416
+
417
+ def self.schema_ns_definition(klass)
418
+ class_schema_variable(:schema_ns, klass)
419
+ end
420
+
421
+ def self.schema_name_definition(klass)
422
+ class_schema_variable(:schema_name, klass)
423
+ end
424
+
425
+ def self.schema_type_definition(klass)
426
+ class_schema_variable(:schema_type, klass)
427
+ end
428
+
429
+ def self.schema_qualified_definition(klass)
430
+ class_schema_variable(:schema_qualified, klass)
431
+ end
432
+
433
+ def self.schema_element_definition(klass)
434
+ class_schema_variable(:schema_element, klass)
435
+ end
436
+
437
+ def self.schema_attribute_definition(klass)
438
+ class_schema_variable(:schema_attribute, klass)
439
+ end
440
+
441
+ def self.schema_definition_classdef(klass)
442
+ if Thread.current[:SOAPMapping][:SchemaDefinition].key?(klass)
443
+ return Thread.current[:SOAPMapping][:SchemaDefinition][klass]
444
+ end
445
+ schema_ns = schema_ns_definition(klass)
446
+ schema_name = schema_name_definition(klass)
447
+ schema_type = schema_type_definition(klass)
448
+ qualified = schema_qualified_definition(klass)
449
+ elements = schema_element_definition(klass)
450
+ attributes = schema_attribute_definition(klass)
451
+ return nil if schema_name.nil? and schema_type.nil?
452
+ schema_name = Mapping.to_qname(schema_name, schema_ns) if schema_name
453
+ schema_type = Mapping.to_qname(schema_type, schema_ns) if schema_type
454
+ definition = create_schema_definition(klass,
455
+ :schema_name => schema_name,
456
+ :schema_type => schema_type,
457
+ :is_anonymous => false,
458
+ :schema_qualified => qualified,
459
+ :schema_element => elements,
460
+ :schema_attribute => attributes
461
+ )
462
+ Thread.current[:SOAPMapping][:SchemaDefinition][klass] = definition
463
+ definition
464
+ end
465
+
466
+ def self.create_schema_definition(klass, definition)
467
+ schema_ns = definition[:schema_ns]
468
+ schema_name = definition[:schema_name]
469
+ schema_type = definition[:schema_type]
470
+ is_anonymous = definition[:is_anonymous]
471
+ schema_basetype = definition[:schema_basetype]
472
+ # wrap if needed for backward compatibility
473
+ if schema_ns
474
+ schema_name = Mapping.to_qname(schema_name, schema_ns) if schema_name
475
+ schema_type = Mapping.to_qname(schema_type, schema_ns) if schema_type
476
+ # no need for schema_basetype bacause it's introduced later
477
+ end
478
+ schema_qualified = definition[:schema_qualified]
479
+ schema_element = definition[:schema_element]
480
+ schema_attributes = definition[:schema_attribute]
481
+ definition = SchemaDefinition.new(klass, schema_name, schema_type, is_anonymous, schema_qualified)
482
+ definition.basetype = schema_basetype
483
+ definition.attributes = schema_attributes
484
+ if schema_element
485
+ if schema_element.respond_to?(:is_concrete_definition) and
486
+ schema_element.is_concrete_definition
487
+ definition.elements = schema_element
488
+ else
489
+ default_ns = schema_name.namespace if schema_name
490
+ default_ns ||= schema_type.namespace if schema_type
491
+ definition.elements = parse_schema_definition(schema_element, default_ns)
492
+ if klass < ::Array
493
+ definition.elements.set_array
494
+ end
495
+ end
496
+ end
497
+ definition
498
+ end
499
+
500
+ # for backward compatibility
501
+ # returns SchemaComplexTypeDefinition
502
+ def self.parse_schema_definition(schema_element, default_ns)
503
+ definition = nil
504
+ if schema_element[0] == :choice
505
+ schema_element.shift
506
+ definition = SchemaChoiceDefinition.new
507
+ else
508
+ definition = SchemaSequenceDefinition.new
509
+ end
510
+ schema_element.each do |ele|
511
+ element_definition = parse_schema_element_definition(ele, default_ns)
512
+ definition << element_definition
513
+ end
514
+ definition
515
+ end
516
+
517
+ # returns SchemaElementDefinition
518
+ def self.parse_schema_element_definition(schema_element, default_ns)
519
+ if schema_element[0] == :choice
520
+ parse_schema_definition(schema_element, default_ns)
521
+ elsif schema_element[0].is_a?(Array)
522
+ parse_schema_definition(schema_element, default_ns)
523
+ else
524
+ varname, info, occurrence = schema_element
525
+ mapped_class_str, elename = info
526
+ if occurrence
527
+ minoccurs, maxoccurs = occurrence
528
+ else
529
+ # for backward compatibility
530
+ minoccurs, maxoccurs = 1, 1
531
+ end
532
+ as_any = as_array = false
533
+ if /\[\]$/ =~ mapped_class_str
534
+ mapped_class_str = mapped_class_str.sub(/\[\]$/, '')
535
+ if mapped_class_str.empty?
536
+ mapped_class_str = nil
537
+ end
538
+ as_array = true
539
+ end
540
+ if mapped_class_str
541
+ mapped_class = Mapping.class_from_name(mapped_class_str)
542
+ if mapped_class.nil?
543
+ warn("cannot find mapped class: #{mapped_class_str}")
544
+ end
545
+ end
546
+ if elename == XSD::AnyTypeName
547
+ as_any = true
548
+ elsif elename.nil?
549
+ elename = XSD::QName.new(default_ns, varname)
550
+ end
551
+ SchemaElementDefinition.new(
552
+ varname, mapped_class, elename, minoccurs, maxoccurs, as_any, as_array)
553
+ end
554
+ end
555
+
556
+ class << Mapping
557
+ public
558
+
559
+ def protect_threadvars(*symbols)
560
+ backup = {}
561
+ begin
562
+ symbols.each do |sym|
563
+ backup[sym] = Thread.current[sym]
564
+ end
565
+ yield
566
+ ensure
567
+ symbols.each do |sym|
568
+ Thread.current[sym] = backup[sym]
569
+ end
570
+ end
571
+ end
572
+
573
+ private
574
+
575
+ def class_schema_variable(sym, klass)
576
+ var = "@@#{sym}"
577
+ klass.class_variables.include?(var) ? klass.class_eval(var) : nil
578
+ end
579
+
580
+ def protect_mapping(opt)
581
+ protect_threadvars(:SOAPMapping) do
582
+ data = Thread.current[:SOAPMapping] = {}
583
+ data[:MarshalKey] = {}
584
+ data[:ExternalCES] = opt[:external_ces] || XSD::Charset.encoding
585
+ data[:NoReference] = opt[:no_reference]
586
+ data[:RootTypeHint] = opt[:root_type_hint]
587
+ data[:SchemaDefinition] = {}
588
+ data[:SafeConstName] = {}
589
+ data[:SafeMethodName] = {}
590
+ data[:SafeVarName] = {}
591
+ data[:ConstFromName] = {}
592
+ yield
593
+ end
594
+ end
595
+
596
+ def add_md_ary(md_ary, ary, indices, registry)
597
+ for idx in 0..(ary.size - 1)
598
+ if ary[idx].is_a?(Array)
599
+ add_md_ary(md_ary, ary[idx], indices + [idx], registry)
600
+ else
601
+ md_ary[*(indices + [idx])] = _obj2soap(ary[idx], registry)
602
+ end
603
+ end
604
+ end
605
+ end
606
+ end
607
+
608
+
609
+ end