soap4r_es 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- 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,560 @@
|
|
|
1
|
+
# encoding: UTF-8
|
|
2
|
+
# SOAP4R - SOAP EncodingStyle handler library
|
|
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 'soap/encodingstyle/handler'
|
|
11
|
+
require 'soap/mapping/registry'
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
module SOAP
|
|
15
|
+
module EncodingStyle
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
class SOAPHandler < Handler
|
|
19
|
+
Namespace = SOAP::EncodingNamespace
|
|
20
|
+
add_handler
|
|
21
|
+
|
|
22
|
+
def initialize(charset = nil)
|
|
23
|
+
super(charset)
|
|
24
|
+
@refpool = []
|
|
25
|
+
@idpool = []
|
|
26
|
+
@textbuf = []
|
|
27
|
+
@is_first_top_ele = true
|
|
28
|
+
end
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
###
|
|
32
|
+
## encode interface.
|
|
33
|
+
#
|
|
34
|
+
def encode_data(generator, ns, data, parent)
|
|
35
|
+
attrs = encode_attrs(generator, ns, data, parent)
|
|
36
|
+
if parent && parent.is_a?(SOAPArray) && parent.position
|
|
37
|
+
attrs[ns.name(AttrPositionName)] = "[#{parent.position.join(',')}]"
|
|
38
|
+
end
|
|
39
|
+
name = generator.encode_name(ns, data, attrs)
|
|
40
|
+
case data
|
|
41
|
+
when SOAPReference
|
|
42
|
+
attrs['href'] = data.refidstr
|
|
43
|
+
generator.encode_tag(name, attrs)
|
|
44
|
+
when SOAPExternalReference
|
|
45
|
+
data.referred
|
|
46
|
+
attrs['href'] = data.refidstr
|
|
47
|
+
generator.encode_tag(name, attrs)
|
|
48
|
+
when SOAPRawString
|
|
49
|
+
generator.encode_tag(name, attrs)
|
|
50
|
+
generator.encode_rawstring(data.to_s)
|
|
51
|
+
when XSD::XSDString
|
|
52
|
+
generator.encode_tag(name, attrs)
|
|
53
|
+
generator.encode_string(@charset ?
|
|
54
|
+
XSD::Charset.encoding_to_xml(data.to_s, @charset) : data.to_s)
|
|
55
|
+
when XSD::XSDAnySimpleType
|
|
56
|
+
generator.encode_tag(name, attrs)
|
|
57
|
+
generator.encode_string(data.to_s)
|
|
58
|
+
when SOAPStruct
|
|
59
|
+
generator.encode_tag(name, attrs)
|
|
60
|
+
data.each do |key, value|
|
|
61
|
+
generator.encode_child(ns, value, data)
|
|
62
|
+
end
|
|
63
|
+
when SOAPArray
|
|
64
|
+
generator.encode_tag(name, attrs)
|
|
65
|
+
data.traverse do |child, *rank|
|
|
66
|
+
data.position = data.sparse ? rank : nil
|
|
67
|
+
generator.encode_child(ns, child, data)
|
|
68
|
+
end
|
|
69
|
+
else
|
|
70
|
+
raise EncodingStyleError.new(
|
|
71
|
+
"unknown object:#{data} in this encodingStyle")
|
|
72
|
+
end
|
|
73
|
+
end
|
|
74
|
+
|
|
75
|
+
def encode_data_end(generator, ns, data, parent)
|
|
76
|
+
name = generator.encode_name_end(ns, data)
|
|
77
|
+
cr = (data.is_a?(SOAPCompoundtype) and data.have_member)
|
|
78
|
+
generator.encode_tag_end(name, cr)
|
|
79
|
+
end
|
|
80
|
+
|
|
81
|
+
|
|
82
|
+
###
|
|
83
|
+
## decode interface.
|
|
84
|
+
#
|
|
85
|
+
class SOAPTemporalObject
|
|
86
|
+
attr_accessor :parent
|
|
87
|
+
attr_accessor :position
|
|
88
|
+
attr_accessor :id
|
|
89
|
+
attr_accessor :root
|
|
90
|
+
|
|
91
|
+
def initialize
|
|
92
|
+
@parent = nil
|
|
93
|
+
@position = nil
|
|
94
|
+
@id = nil
|
|
95
|
+
@root = nil
|
|
96
|
+
end
|
|
97
|
+
end
|
|
98
|
+
|
|
99
|
+
class SOAPUnknown < SOAPTemporalObject
|
|
100
|
+
attr_reader :type
|
|
101
|
+
attr_accessor :definedtype
|
|
102
|
+
attr_reader :extraattr
|
|
103
|
+
|
|
104
|
+
def initialize(handler, elename, type, extraattr)
|
|
105
|
+
super()
|
|
106
|
+
@handler = handler
|
|
107
|
+
@elename = elename
|
|
108
|
+
@type = type
|
|
109
|
+
@extraattr = extraattr
|
|
110
|
+
@definedtype = nil
|
|
111
|
+
end
|
|
112
|
+
|
|
113
|
+
def as_struct
|
|
114
|
+
if @extraattr[XSD::AttrNilName] == 'true'
|
|
115
|
+
return as_nil
|
|
116
|
+
end
|
|
117
|
+
o = SOAPStruct.decode(@elename, @type)
|
|
118
|
+
o.id = @id
|
|
119
|
+
o.root = @root
|
|
120
|
+
o.parent = @parent
|
|
121
|
+
o.position = @position
|
|
122
|
+
o.extraattr.update(@extraattr)
|
|
123
|
+
@handler.decode_parent(@parent, o)
|
|
124
|
+
o
|
|
125
|
+
end
|
|
126
|
+
|
|
127
|
+
def as_string
|
|
128
|
+
if @extraattr[XSD::AttrNilName] == 'true'
|
|
129
|
+
return as_nil
|
|
130
|
+
end
|
|
131
|
+
o = SOAPString.decode(@elename)
|
|
132
|
+
o.id = @id
|
|
133
|
+
o.root = @root
|
|
134
|
+
o.parent = @parent
|
|
135
|
+
o.position = @position
|
|
136
|
+
o.extraattr.update(@extraattr)
|
|
137
|
+
@handler.decode_parent(@parent, o)
|
|
138
|
+
o
|
|
139
|
+
end
|
|
140
|
+
|
|
141
|
+
def as_nil
|
|
142
|
+
o = SOAPNil.decode(@elename)
|
|
143
|
+
o.id = @id
|
|
144
|
+
o.root = @root
|
|
145
|
+
o.parent = @parent
|
|
146
|
+
o.position = @position
|
|
147
|
+
o.extraattr.update(@extraattr)
|
|
148
|
+
@handler.decode_parent(@parent, o)
|
|
149
|
+
o
|
|
150
|
+
end
|
|
151
|
+
end
|
|
152
|
+
|
|
153
|
+
def decode_tag(ns, elename, attrs, parent)
|
|
154
|
+
@textbuf.clear
|
|
155
|
+
is_nil, type, arytype, root, offset, position, href, id =
|
|
156
|
+
extract_attrs(ns, attrs)
|
|
157
|
+
o = nil
|
|
158
|
+
if is_nil
|
|
159
|
+
o = SOAPNil.decode(elename)
|
|
160
|
+
elsif href
|
|
161
|
+
o = SOAPReference.decode(elename, href)
|
|
162
|
+
@refpool << o
|
|
163
|
+
elsif @decode_typemap
|
|
164
|
+
o = decode_tag_by_wsdl(ns, elename, type, parent.node, arytype, attrs)
|
|
165
|
+
else
|
|
166
|
+
o = decode_tag_by_type(ns, elename, type, parent.node, arytype, attrs)
|
|
167
|
+
end
|
|
168
|
+
|
|
169
|
+
if o.is_a?(SOAPArray)
|
|
170
|
+
if offset
|
|
171
|
+
o.offset = decode_arypos(offset)
|
|
172
|
+
o.sparse = true
|
|
173
|
+
else
|
|
174
|
+
o.sparse = false
|
|
175
|
+
end
|
|
176
|
+
end
|
|
177
|
+
|
|
178
|
+
o.parent = parent
|
|
179
|
+
o.id = id
|
|
180
|
+
o.root = root
|
|
181
|
+
o.position = position
|
|
182
|
+
|
|
183
|
+
unless o.is_a?(SOAPTemporalObject)
|
|
184
|
+
@idpool << o if o.id
|
|
185
|
+
decode_parent(parent, o)
|
|
186
|
+
end
|
|
187
|
+
o
|
|
188
|
+
end
|
|
189
|
+
|
|
190
|
+
def decode_tag_end(ns, node)
|
|
191
|
+
textbufstr = @textbuf.join
|
|
192
|
+
@textbuf.clear
|
|
193
|
+
o = node.node
|
|
194
|
+
if o.is_a?(SOAPUnknown)
|
|
195
|
+
newnode = if /\A\s*\z/ =~ textbufstr
|
|
196
|
+
o.as_struct
|
|
197
|
+
else
|
|
198
|
+
o.as_string
|
|
199
|
+
end
|
|
200
|
+
if newnode.id
|
|
201
|
+
@idpool << newnode
|
|
202
|
+
end
|
|
203
|
+
node.replace_node(newnode)
|
|
204
|
+
o = node.node
|
|
205
|
+
end
|
|
206
|
+
decode_textbuf(o, textbufstr)
|
|
207
|
+
# unlink definedtype
|
|
208
|
+
o.definedtype = nil
|
|
209
|
+
end
|
|
210
|
+
|
|
211
|
+
def decode_text(ns, text)
|
|
212
|
+
@textbuf << text
|
|
213
|
+
end
|
|
214
|
+
|
|
215
|
+
def decode_prologue
|
|
216
|
+
@refpool.clear
|
|
217
|
+
@idpool.clear
|
|
218
|
+
@is_first_top_ele = true
|
|
219
|
+
end
|
|
220
|
+
|
|
221
|
+
def decode_epilogue
|
|
222
|
+
decode_resolve_id
|
|
223
|
+
end
|
|
224
|
+
|
|
225
|
+
def decode_parent(parent, node)
|
|
226
|
+
return unless parent.node
|
|
227
|
+
case parent.node
|
|
228
|
+
when SOAPUnknown
|
|
229
|
+
newparent = parent.node.as_struct
|
|
230
|
+
node.parent = newparent
|
|
231
|
+
if newparent.id
|
|
232
|
+
@idpool << newparent
|
|
233
|
+
end
|
|
234
|
+
parent.replace_node(newparent)
|
|
235
|
+
decode_parent(parent, node)
|
|
236
|
+
when SOAPStruct
|
|
237
|
+
parent.node.add(node.elename.name, node)
|
|
238
|
+
node.parent = parent.node
|
|
239
|
+
when SOAPArray
|
|
240
|
+
if node.position
|
|
241
|
+
parent.node[*(decode_arypos(node.position))] = node
|
|
242
|
+
parent.node.sparse = true
|
|
243
|
+
else
|
|
244
|
+
parent.node.add(node)
|
|
245
|
+
end
|
|
246
|
+
node.parent = parent.node
|
|
247
|
+
else
|
|
248
|
+
raise EncodingStyleError.new("illegal parent: #{parent.node}")
|
|
249
|
+
end
|
|
250
|
+
end
|
|
251
|
+
|
|
252
|
+
private
|
|
253
|
+
|
|
254
|
+
def content_ranksize(typename)
|
|
255
|
+
typename.scan(/\[[\d,]*\]$/)[0]
|
|
256
|
+
end
|
|
257
|
+
|
|
258
|
+
def content_typename(typename)
|
|
259
|
+
typename.sub(/\[,*\]$/, '')
|
|
260
|
+
end
|
|
261
|
+
|
|
262
|
+
def create_arytype(ns, data)
|
|
263
|
+
XSD::QName.new(data.arytype.namespace,
|
|
264
|
+
content_typename(data.arytype.name) + "[#{data.size.join(',')}]")
|
|
265
|
+
end
|
|
266
|
+
|
|
267
|
+
def encode_attrs(generator, ns, data, parent)
|
|
268
|
+
attrs = {}
|
|
269
|
+
return attrs if data.is_a?(SOAPReference)
|
|
270
|
+
|
|
271
|
+
if !parent || parent.encodingstyle != EncodingNamespace
|
|
272
|
+
if @generate_explicit_type
|
|
273
|
+
Generator.assign_ns(attrs, ns, EnvelopeNamespace)
|
|
274
|
+
attrs[ns.name(AttrEncodingStyleName)] = EncodingNamespace
|
|
275
|
+
end
|
|
276
|
+
data.encodingstyle = EncodingNamespace
|
|
277
|
+
end
|
|
278
|
+
|
|
279
|
+
if data.is_a?(SOAPNil)
|
|
280
|
+
attrs[ns.name(XSD::AttrNilName)] = XSD::NilValue
|
|
281
|
+
elsif @generate_explicit_type
|
|
282
|
+
if data.type.namespace
|
|
283
|
+
Generator.assign_ns(attrs, ns, data.type.namespace)
|
|
284
|
+
end
|
|
285
|
+
if data.is_a?(SOAPArray)
|
|
286
|
+
if data.arytype.namespace
|
|
287
|
+
Generator.assign_ns(attrs, ns, data.arytype.namespace)
|
|
288
|
+
end
|
|
289
|
+
Generator.assign_ns(attrs, ns, EncodingNamespace)
|
|
290
|
+
attrs[ns.name(AttrArrayTypeName)] = ns.name(create_arytype(ns, data))
|
|
291
|
+
if data.type.name
|
|
292
|
+
attrs[ns.name(XSD::AttrTypeName)] = ns.name(data.type)
|
|
293
|
+
end
|
|
294
|
+
elsif parent && parent.is_a?(SOAPArray) && (parent.arytype == data.type)
|
|
295
|
+
# No need to add.
|
|
296
|
+
elsif !data.type.namespace
|
|
297
|
+
# No need to add.
|
|
298
|
+
else
|
|
299
|
+
attrs[ns.name(XSD::AttrTypeName)] = ns.name(data.type)
|
|
300
|
+
end
|
|
301
|
+
end
|
|
302
|
+
data.extraattr.each do |key, value|
|
|
303
|
+
keytag = key
|
|
304
|
+
if key.is_a?(XSD::QName)
|
|
305
|
+
keytag = encode_attr_key(attrs, ns, key)
|
|
306
|
+
end
|
|
307
|
+
if value.is_a?(XSD::QName)
|
|
308
|
+
value = encode_qname(attrs, ns, value)
|
|
309
|
+
else
|
|
310
|
+
value = encode_attr_value(generator, ns, key, value)
|
|
311
|
+
end
|
|
312
|
+
attrs[keytag] = value
|
|
313
|
+
end
|
|
314
|
+
if data.id
|
|
315
|
+
attrs['id'] = data.id
|
|
316
|
+
end
|
|
317
|
+
attrs
|
|
318
|
+
end
|
|
319
|
+
|
|
320
|
+
def encode_attr_value(generator, ns, qname, value)
|
|
321
|
+
case value
|
|
322
|
+
when SOAPType
|
|
323
|
+
ref = SOAPReference.new(value)
|
|
324
|
+
generator.add_reftarget(qname.name, value)
|
|
325
|
+
ref.refidstr
|
|
326
|
+
else
|
|
327
|
+
value.to_s
|
|
328
|
+
end
|
|
329
|
+
end
|
|
330
|
+
|
|
331
|
+
def decode_tag_by_wsdl(ns, elename, typestr, parent, arytypestr, attrs)
|
|
332
|
+
o = nil
|
|
333
|
+
if parent.class == SOAPBody
|
|
334
|
+
# root element: should branch by root attribute?
|
|
335
|
+
if @is_first_top_ele
|
|
336
|
+
# Unqualified name is allowed here.
|
|
337
|
+
@is_first_top_ele = false
|
|
338
|
+
type = @decode_typemap[elename] ||
|
|
339
|
+
@decode_typemap.find_name(elename.name)
|
|
340
|
+
if type
|
|
341
|
+
o = SOAPStruct.new(elename)
|
|
342
|
+
o.elename = elename
|
|
343
|
+
o.definedtype = type
|
|
344
|
+
return o
|
|
345
|
+
end
|
|
346
|
+
end
|
|
347
|
+
# multi-ref element.
|
|
348
|
+
if typestr
|
|
349
|
+
typename = ns.parse(typestr)
|
|
350
|
+
typedef = @decode_typemap[typename]
|
|
351
|
+
if typedef
|
|
352
|
+
return decode_definedtype(elename, typename, typedef, arytypestr)
|
|
353
|
+
end
|
|
354
|
+
end
|
|
355
|
+
return decode_tag_by_type(ns, elename, typestr, parent, arytypestr, attrs)
|
|
356
|
+
end
|
|
357
|
+
|
|
358
|
+
if parent.type == XSD::AnyTypeName
|
|
359
|
+
return decode_tag_by_type(ns, elename, typestr, parent, arytypestr, attrs)
|
|
360
|
+
end
|
|
361
|
+
|
|
362
|
+
# parent.definedtype == nil means the parent is SOAPUnknown. SOAPUnknown
|
|
363
|
+
# is generated by decode_tag_by_type when its type is anyType.
|
|
364
|
+
parenttype = parent.definedtype || @decode_typemap[parent.type]
|
|
365
|
+
unless parenttype
|
|
366
|
+
return decode_tag_by_type(ns, elename, typestr, parent, arytypestr, attrs)
|
|
367
|
+
end
|
|
368
|
+
|
|
369
|
+
definedtype_name = parenttype.child_type(elename)
|
|
370
|
+
if definedtype_name and (klass = TypeMap[definedtype_name])
|
|
371
|
+
return decode_basetype(klass, elename)
|
|
372
|
+
elsif definedtype_name == XSD::AnyTypeName
|
|
373
|
+
return decode_tag_by_type(ns, elename, typestr, parent, arytypestr, attrs)
|
|
374
|
+
end
|
|
375
|
+
|
|
376
|
+
if definedtype_name
|
|
377
|
+
typedef = @decode_typemap[definedtype_name]
|
|
378
|
+
else
|
|
379
|
+
typedef = parenttype.child_defined_complextype(elename)
|
|
380
|
+
end
|
|
381
|
+
decode_definedtype(elename, definedtype_name, typedef, arytypestr)
|
|
382
|
+
end
|
|
383
|
+
|
|
384
|
+
def decode_definedtype(elename, typename, typedef, arytypestr)
|
|
385
|
+
unless typedef
|
|
386
|
+
raise EncodingStyleError.new("unknown type '#{typename}'")
|
|
387
|
+
end
|
|
388
|
+
if typedef.is_a?(::WSDL::XMLSchema::SimpleType)
|
|
389
|
+
decode_defined_simpletype(elename, typename, typedef, arytypestr)
|
|
390
|
+
else
|
|
391
|
+
decode_defined_complextype(elename, typename, typedef, arytypestr)
|
|
392
|
+
end
|
|
393
|
+
end
|
|
394
|
+
|
|
395
|
+
def decode_basetype(klass, elename)
|
|
396
|
+
klass.decode(elename)
|
|
397
|
+
end
|
|
398
|
+
|
|
399
|
+
def decode_defined_simpletype(elename, typename, typedef, arytypestr)
|
|
400
|
+
if typedef.base
|
|
401
|
+
o = decode_basetype(TypeMap[typedef.base], elename)
|
|
402
|
+
o.definedtype = typedef
|
|
403
|
+
o
|
|
404
|
+
else
|
|
405
|
+
raise RuntimeError.new("unsupported simpleType: #{typedef}")
|
|
406
|
+
end
|
|
407
|
+
end
|
|
408
|
+
|
|
409
|
+
def decode_defined_complextype(elename, typename, typedef, arytypestr)
|
|
410
|
+
case typedef.compoundtype
|
|
411
|
+
when :TYPE_STRUCT, :TYPE_MAP
|
|
412
|
+
o = SOAPStruct.decode(elename, typename)
|
|
413
|
+
o.definedtype = typedef
|
|
414
|
+
return o
|
|
415
|
+
when :TYPE_ARRAY
|
|
416
|
+
expected_arytype = typedef.find_arytype
|
|
417
|
+
if arytypestr
|
|
418
|
+
actual_arytype = XSD::QName.new(expected_arytype.namespace,
|
|
419
|
+
content_typename(expected_arytype.name) <<
|
|
420
|
+
content_ranksize(arytypestr))
|
|
421
|
+
o = SOAPArray.decode(elename, typename, actual_arytype)
|
|
422
|
+
else
|
|
423
|
+
o = SOAPArray.new(typename, 1, expected_arytype)
|
|
424
|
+
o.elename = elename
|
|
425
|
+
end
|
|
426
|
+
o.definedtype = typedef
|
|
427
|
+
return o
|
|
428
|
+
when :TYPE_EMPTY
|
|
429
|
+
o = SOAPNil.decode(elename)
|
|
430
|
+
o.definedtype = typedef
|
|
431
|
+
return o
|
|
432
|
+
else
|
|
433
|
+
raise RuntimeError.new(
|
|
434
|
+
"Unknown kind of complexType: #{typedef.compoundtype}")
|
|
435
|
+
end
|
|
436
|
+
nil
|
|
437
|
+
end
|
|
438
|
+
|
|
439
|
+
def decode_tag_by_type(ns, elename, typestr, parent, arytypestr, attrs)
|
|
440
|
+
if arytypestr
|
|
441
|
+
type = typestr ? ns.parse(typestr) : ValueArrayName
|
|
442
|
+
node = SOAPArray.decode(elename, type, ns.parse(arytypestr))
|
|
443
|
+
node.extraattr.update(attrs)
|
|
444
|
+
return node
|
|
445
|
+
end
|
|
446
|
+
|
|
447
|
+
type = nil
|
|
448
|
+
if typestr
|
|
449
|
+
type = ns.parse(typestr)
|
|
450
|
+
elsif parent.is_a?(SOAPArray)
|
|
451
|
+
type = parent.arytype
|
|
452
|
+
else
|
|
453
|
+
# Since it's in dynamic(without any type) encoding process,
|
|
454
|
+
# assumes entity as its type itself.
|
|
455
|
+
# <SOAP-ENC:Array ...> => type Array in SOAP-ENC.
|
|
456
|
+
# <Country xmlns="foo"> => type Country in foo.
|
|
457
|
+
type = elename
|
|
458
|
+
end
|
|
459
|
+
|
|
460
|
+
if klass = TypeMap[type]
|
|
461
|
+
node = decode_basetype(klass, elename)
|
|
462
|
+
node.extraattr.update(attrs)
|
|
463
|
+
return node
|
|
464
|
+
end
|
|
465
|
+
|
|
466
|
+
# Unknown type... Struct or String
|
|
467
|
+
SOAPUnknown.new(self, elename, type, attrs)
|
|
468
|
+
end
|
|
469
|
+
|
|
470
|
+
def decode_textbuf(node, textbufstr)
|
|
471
|
+
case node
|
|
472
|
+
when XSD::XSDHexBinary, XSD::XSDBase64Binary
|
|
473
|
+
node.set_encoded(textbufstr)
|
|
474
|
+
when XSD::XSDString
|
|
475
|
+
if @charset
|
|
476
|
+
textbufstr = XSD::Charset.encoding_from_xml(textbufstr, @charset)
|
|
477
|
+
end
|
|
478
|
+
if node.definedtype
|
|
479
|
+
node.definedtype.check_lexical_format(textbufstr)
|
|
480
|
+
end
|
|
481
|
+
node.set(textbufstr)
|
|
482
|
+
when SOAPNil
|
|
483
|
+
# Nothing to do.
|
|
484
|
+
when SOAPBasetype
|
|
485
|
+
node.set(textbufstr)
|
|
486
|
+
else
|
|
487
|
+
# Nothing to do...
|
|
488
|
+
end
|
|
489
|
+
end
|
|
490
|
+
|
|
491
|
+
NilLiteralMap = {
|
|
492
|
+
'true' => true,
|
|
493
|
+
'1' => true,
|
|
494
|
+
'false' => false,
|
|
495
|
+
'0' => false
|
|
496
|
+
}
|
|
497
|
+
RootLiteralMap = {
|
|
498
|
+
'1' => 1,
|
|
499
|
+
'0' => 0
|
|
500
|
+
}
|
|
501
|
+
def extract_attrs(ns, attrs)
|
|
502
|
+
is_nil = NilLiteralMap[attrs[XSD::AttrNilName]]
|
|
503
|
+
type = attrs[XSD::AttrTypeName]
|
|
504
|
+
arytype = attrs[AttrArrayTypeName]
|
|
505
|
+
root = attrs[AttrRootName]
|
|
506
|
+
offset = attrs[AttrOffsetName]
|
|
507
|
+
position = attrs[AttrPositionName]
|
|
508
|
+
href = attrs[AttrHrefName]
|
|
509
|
+
id = attrs[AttrIdName]
|
|
510
|
+
if attrs.key?(Mapping::RubyIVarName)
|
|
511
|
+
attrs[Mapping::RubyIVarName] =
|
|
512
|
+
decode_ref_value(ns, attrs[Mapping::RubyIVarName])
|
|
513
|
+
end
|
|
514
|
+
return is_nil, type, arytype, root, offset, position, href, id
|
|
515
|
+
end
|
|
516
|
+
|
|
517
|
+
def decode_ref_value(ns, value)
|
|
518
|
+
if /\A#/ =~ value
|
|
519
|
+
o = SOAPReference.decode(nil, value)
|
|
520
|
+
@refpool << o
|
|
521
|
+
o
|
|
522
|
+
else
|
|
523
|
+
value
|
|
524
|
+
end
|
|
525
|
+
end
|
|
526
|
+
|
|
527
|
+
def decode_arypos(position)
|
|
528
|
+
/^\[(.+)\]$/ =~ position
|
|
529
|
+
$1.split(',').collect { |s| s.to_i }
|
|
530
|
+
end
|
|
531
|
+
|
|
532
|
+
def decode_resolve_id
|
|
533
|
+
count = @refpool.length # To avoid infinite loop
|
|
534
|
+
while !@refpool.empty? && count > 0
|
|
535
|
+
@refpool = @refpool.find_all { |ref|
|
|
536
|
+
o = @idpool.find { |item|
|
|
537
|
+
item.id == ref.refid
|
|
538
|
+
}
|
|
539
|
+
if o.is_a?(SOAPReference)
|
|
540
|
+
true # link of link.
|
|
541
|
+
elsif o
|
|
542
|
+
ref.__setobj__(o)
|
|
543
|
+
false
|
|
544
|
+
elsif o = ref.rootnode.external_content[ref.refid]
|
|
545
|
+
ref.__setobj__(o)
|
|
546
|
+
false
|
|
547
|
+
else
|
|
548
|
+
raise EncodingStyleError.new("unresolved reference: #{ref.refid}")
|
|
549
|
+
end
|
|
550
|
+
}
|
|
551
|
+
count -= 1
|
|
552
|
+
end
|
|
553
|
+
end
|
|
554
|
+
end
|
|
555
|
+
|
|
556
|
+
SOAPHandler.new
|
|
557
|
+
|
|
558
|
+
|
|
559
|
+
end
|
|
560
|
+
end
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
# encoding: UTF-8
|
|
2
|
+
# SOAP4R - SOAP filter chain.
|
|
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 'soap/filter/handler'
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
module SOAP
|
|
14
|
+
module Filter
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
class FilterChain
|
|
18
|
+
|
|
19
|
+
def each
|
|
20
|
+
@array.each do |filter|
|
|
21
|
+
yield filter
|
|
22
|
+
end
|
|
23
|
+
end
|
|
24
|
+
|
|
25
|
+
def reverse_each
|
|
26
|
+
@array.reverse_each do |filter|
|
|
27
|
+
yield filter
|
|
28
|
+
end
|
|
29
|
+
end
|
|
30
|
+
|
|
31
|
+
def initialize
|
|
32
|
+
@array = []
|
|
33
|
+
end
|
|
34
|
+
|
|
35
|
+
def add(filter)
|
|
36
|
+
@array << filter
|
|
37
|
+
end
|
|
38
|
+
alias << add
|
|
39
|
+
|
|
40
|
+
def delete(filter)
|
|
41
|
+
@array.delete(filter)
|
|
42
|
+
end
|
|
43
|
+
|
|
44
|
+
def include?(filter)
|
|
45
|
+
@array.include?(filter)
|
|
46
|
+
end
|
|
47
|
+
|
|
48
|
+
end
|
|
49
|
+
|
|
50
|
+
|
|
51
|
+
end
|
|
52
|
+
end
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
# encoding: UTF-8
|
|
2
|
+
# SOAP4R - SOAP envelope filter base class.
|
|
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 Filter
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
class Handler
|
|
15
|
+
|
|
16
|
+
# should return envelope. opt can be updated for other filters.
|
|
17
|
+
def on_outbound(envelope, opt)
|
|
18
|
+
# do something.
|
|
19
|
+
envelope
|
|
20
|
+
end
|
|
21
|
+
|
|
22
|
+
# should return xml. opt can be updated for other filters.
|
|
23
|
+
def on_inbound(xml, opt)
|
|
24
|
+
# do something.
|
|
25
|
+
xml
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
end
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
end
|
|
32
|
+
end
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
# encoding: UTF-8
|
|
2
|
+
# SOAP4R - SOAP stream filter base class.
|
|
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 Filter
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
class StreamHandler
|
|
15
|
+
|
|
16
|
+
# no returning value expected.
|
|
17
|
+
def on_http_outbound(req)
|
|
18
|
+
# do something.
|
|
19
|
+
end
|
|
20
|
+
|
|
21
|
+
# no returning value expected.
|
|
22
|
+
def on_http_inbound(req, res)
|
|
23
|
+
# do something.
|
|
24
|
+
end
|
|
25
|
+
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
end
|
|
30
|
+
end
|
data/lib/soap/filter.rb
ADDED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
# encoding: UTF-8
|
|
2
|
+
# SOAP4R - SOAP filter.
|
|
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 'soap/filter/filterchain'
|
|
11
|
+
# envelope filter
|
|
12
|
+
require 'soap/filter/handler'
|
|
13
|
+
# steram filter
|
|
14
|
+
require 'soap/filter/streamhandler'
|