soap4r_es 0.0.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/bin/wsdl2ruby.rb +140 -0
- data/bin/wsdl2ruby_rails.rb +140 -0
- data/bin/xsd2ruby.rb +92 -0
- data/lib/soap/attachment.rb +109 -0
- data/lib/soap/attrproxy.rb +35 -0
- data/lib/soap/baseData.rb +1095 -0
- data/lib/soap/element.rb +278 -0
- data/lib/soap/encodingstyle/aspDotNetHandler.rb +208 -0
- data/lib/soap/encodingstyle/handler.rb +121 -0
- data/lib/soap/encodingstyle/literalHandler.rb +196 -0
- data/lib/soap/encodingstyle/soapHandler.rb +560 -0
- data/lib/soap/filter/filterchain.rb +52 -0
- data/lib/soap/filter/handler.rb +32 -0
- data/lib/soap/filter/streamhandler.rb +30 -0
- data/lib/soap/filter.rb +14 -0
- data/lib/soap/generator.rb +299 -0
- data/lib/soap/header/handler.rb +64 -0
- data/lib/soap/header/handlerset.rb +78 -0
- data/lib/soap/header/mappinghandler.rb +48 -0
- data/lib/soap/header/simplehandler.rb +45 -0
- data/lib/soap/httpconfigloader.rb +140 -0
- data/lib/soap/mapping/encodedregistry.rb +541 -0
- data/lib/soap/mapping/factory.rb +389 -0
- data/lib/soap/mapping/literalregistry.rb +392 -0
- data/lib/soap/mapping/mapping.rb +577 -0
- data/lib/soap/mapping/registry.rb +297 -0
- data/lib/soap/mapping/rubytypeFactory.rb +446 -0
- data/lib/soap/mapping/schemadefinition.rb +171 -0
- data/lib/soap/mapping/typeMap.rb +107 -0
- data/lib/soap/mapping/wsdlencodedregistry.rb +212 -0
- data/lib/soap/mapping/wsdlliteralregistry.rb +249 -0
- data/lib/soap/mapping.rb +13 -0
- data/lib/soap/marshal.rb +60 -0
- data/lib/soap/mimemessage.rb +243 -0
- data/lib/soap/nestedexception.rb +43 -0
- data/lib/soap/netHttpClient.rb +242 -0
- data/lib/soap/ns.rb +39 -0
- data/lib/soap/parser.rb +253 -0
- data/lib/soap/processor.rb +67 -0
- data/lib/soap/property.rb +330 -0
- data/lib/soap/proxy.rb +15 -0
- data/lib/soap/rpc/cgistub.rb +249 -0
- data/lib/soap/rpc/driver.rb +222 -0
- data/lib/soap/rpc/element.rb +375 -0
- data/lib/soap/rpc/httpserver.rb +144 -0
- data/lib/soap/rpc/methodDef.rb +69 -0
- data/lib/soap/rpc/proxy.rb +573 -0
- data/lib/soap/rpc/router.rb +672 -0
- data/lib/soap/rpc/rpc.rb +26 -0
- data/lib/soap/rpc/soaplet.rb +201 -0
- data/lib/soap/rpc/standaloneServer.rb +44 -0
- data/lib/soap/soap.rb +163 -0
- data/lib/soap/streamHandler.rb +302 -0
- data/lib/soap/version.rb +12 -0
- data/lib/soap/wsdlDriver.rb +165 -0
- data/lib/wsdl/binding.rb +66 -0
- data/lib/wsdl/data.rb +65 -0
- data/lib/wsdl/definitions.rb +237 -0
- data/lib/wsdl/documentation.rb +33 -0
- data/lib/wsdl/import.rb +81 -0
- data/lib/wsdl/importer.rb +39 -0
- data/lib/wsdl/info.rb +51 -0
- data/lib/wsdl/message.rb +55 -0
- data/lib/wsdl/operation.rb +152 -0
- data/lib/wsdl/operationBinding.rb +241 -0
- data/lib/wsdl/param.rb +94 -0
- data/lib/wsdl/parser.rb +180 -0
- data/lib/wsdl/part.rb +53 -0
- data/lib/wsdl/port.rb +67 -0
- data/lib/wsdl/portType.rb +76 -0
- data/lib/wsdl/service.rb +62 -0
- data/lib/wsdl/soap/address.rb +41 -0
- data/lib/wsdl/soap/binding.rb +50 -0
- data/lib/wsdl/soap/body.rb +59 -0
- data/lib/wsdl/soap/cgiStubCreator.rb +93 -0
- data/lib/wsdl/soap/classDefCreator.rb +529 -0
- data/lib/wsdl/soap/classDefCreatorSupport.rb +242 -0
- data/lib/wsdl/soap/classNameCreator.rb +57 -0
- data/lib/wsdl/soap/clientSkeltonCreator.rb +107 -0
- data/lib/wsdl/soap/complexType.rb +174 -0
- data/lib/wsdl/soap/data.rb +43 -0
- data/lib/wsdl/soap/definitions.rb +201 -0
- data/lib/wsdl/soap/driverCreator.rb +121 -0
- data/lib/wsdl/soap/element.rb +34 -0
- data/lib/wsdl/soap/encodedMappingRegistryCreator.rb +74 -0
- data/lib/wsdl/soap/fault.rb +57 -0
- data/lib/wsdl/soap/header.rb +87 -0
- data/lib/wsdl/soap/headerfault.rb +57 -0
- data/lib/wsdl/soap/literalMappingRegistryCreator.rb +116 -0
- data/lib/wsdl/soap/mappingRegistryCreator.rb +59 -0
- data/lib/wsdl/soap/mappingRegistryCreatorSupport.rb +380 -0
- data/lib/wsdl/soap/methodDefCreator.rb +200 -0
- data/lib/wsdl/soap/operation.rb +113 -0
- data/lib/wsdl/soap/servantSkeltonCreator.rb +92 -0
- data/lib/wsdl/soap/servletStubCreator.rb +105 -0
- data/lib/wsdl/soap/standaloneServerStubCreator.rb +101 -0
- data/lib/wsdl/soap/wsdl2ruby.rb +249 -0
- data/lib/wsdl/types.rb +45 -0
- data/lib/wsdl/wsdl.rb +25 -0
- data/lib/wsdl/xmlSchema/all.rb +25 -0
- data/lib/wsdl/xmlSchema/annotation.rb +35 -0
- data/lib/wsdl/xmlSchema/any.rb +62 -0
- data/lib/wsdl/xmlSchema/anyAttribute.rb +49 -0
- data/lib/wsdl/xmlSchema/attribute.rb +105 -0
- data/lib/wsdl/xmlSchema/attributeGroup.rb +69 -0
- data/lib/wsdl/xmlSchema/choice.rb +59 -0
- data/lib/wsdl/xmlSchema/complexContent.rb +98 -0
- data/lib/wsdl/xmlSchema/complexExtension.rb +120 -0
- data/lib/wsdl/xmlSchema/complexRestriction.rb +105 -0
- data/lib/wsdl/xmlSchema/complexType.rb +194 -0
- data/lib/wsdl/xmlSchema/content.rb +96 -0
- data/lib/wsdl/xmlSchema/data.rb +117 -0
- data/lib/wsdl/xmlSchema/element.rb +154 -0
- data/lib/wsdl/xmlSchema/enumeration.rb +37 -0
- data/lib/wsdl/xmlSchema/fractiondigits.rb +38 -0
- data/lib/wsdl/xmlSchema/group.rb +101 -0
- data/lib/wsdl/xmlSchema/import.rb +53 -0
- data/lib/wsdl/xmlSchema/importHandler.rb +45 -0
- data/lib/wsdl/xmlSchema/importer.rb +103 -0
- data/lib/wsdl/xmlSchema/include.rb +48 -0
- data/lib/wsdl/xmlSchema/length.rb +38 -0
- data/lib/wsdl/xmlSchema/list.rb +49 -0
- data/lib/wsdl/xmlSchema/maxexclusive.rb +38 -0
- data/lib/wsdl/xmlSchema/maxinclusive.rb +38 -0
- data/lib/wsdl/xmlSchema/maxlength.rb +38 -0
- data/lib/wsdl/xmlSchema/minexclusive.rb +38 -0
- data/lib/wsdl/xmlSchema/mininclusive.rb +38 -0
- data/lib/wsdl/xmlSchema/minlength.rb +38 -0
- data/lib/wsdl/xmlSchema/parser.rb +168 -0
- data/lib/wsdl/xmlSchema/pattern.rb +37 -0
- data/lib/wsdl/xmlSchema/ref.rb +34 -0
- data/lib/wsdl/xmlSchema/schema.rb +179 -0
- data/lib/wsdl/xmlSchema/sequence.rb +55 -0
- data/lib/wsdl/xmlSchema/simpleContent.rb +70 -0
- data/lib/wsdl/xmlSchema/simpleExtension.rb +63 -0
- data/lib/wsdl/xmlSchema/simpleRestriction.rb +133 -0
- data/lib/wsdl/xmlSchema/simpleType.rb +88 -0
- data/lib/wsdl/xmlSchema/totaldigits.rb +38 -0
- data/lib/wsdl/xmlSchema/union.rb +36 -0
- data/lib/wsdl/xmlSchema/unique.rb +35 -0
- data/lib/wsdl/xmlSchema/whitespace.rb +38 -0
- data/lib/wsdl/xmlSchema/xsd2ruby.rb +177 -0
- data/lib/xsd/charset.rb +190 -0
- data/lib/xsd/codegen/classdef.rb +230 -0
- data/lib/xsd/codegen/commentdef.rb +35 -0
- data/lib/xsd/codegen/gensupport.rb +277 -0
- data/lib/xsd/codegen/methoddef.rb +71 -0
- data/lib/xsd/codegen/moduledef.rb +209 -0
- data/lib/xsd/codegen.rb +13 -0
- data/lib/xsd/datatypes.rb +1465 -0
- data/lib/xsd/datatypes1999.rb +21 -0
- data/lib/xsd/iconvcharset.rb +33 -0
- data/lib/xsd/mapping.rb +69 -0
- data/lib/xsd/namedelements.rb +133 -0
- data/lib/xsd/ns.rb +183 -0
- data/lib/xsd/qname.rb +80 -0
- data/lib/xsd/xmlparser/libxmlparser.rb +136 -0
- data/lib/xsd/xmlparser/nokogiriparser.rb +63 -0
- data/lib/xsd/xmlparser/ogaparser.rb +53 -0
- data/lib/xsd/xmlparser/oxparser.rb +97 -0
- data/lib/xsd/xmlparser/parser.rb +101 -0
- data/lib/xsd/xmlparser/rexmlparser.rb +54 -0
- data/lib/xsd/xmlparser.rb +81 -0
- 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
|