rubysl-soap 0.0.1 → 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (49) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +0 -1
  3. data/.travis.yml +8 -0
  4. data/README.md +2 -2
  5. data/Rakefile +0 -1
  6. data/lib/rubysl/soap.rb +1 -0
  7. data/lib/rubysl/soap/version.rb +5 -0
  8. data/lib/soap/attachment.rb +107 -0
  9. data/lib/soap/baseData.rb +942 -0
  10. data/lib/soap/element.rb +258 -0
  11. data/lib/soap/encodingstyle/aspDotNetHandler.rb +213 -0
  12. data/lib/soap/encodingstyle/handler.rb +100 -0
  13. data/lib/soap/encodingstyle/literalHandler.rb +226 -0
  14. data/lib/soap/encodingstyle/soapHandler.rb +582 -0
  15. data/lib/soap/generator.rb +268 -0
  16. data/lib/soap/header/handler.rb +57 -0
  17. data/lib/soap/header/handlerset.rb +70 -0
  18. data/lib/soap/header/simplehandler.rb +44 -0
  19. data/lib/soap/httpconfigloader.rb +119 -0
  20. data/lib/soap/mapping.rb +10 -0
  21. data/lib/soap/mapping/factory.rb +355 -0
  22. data/lib/soap/mapping/mapping.rb +381 -0
  23. data/lib/soap/mapping/registry.rb +541 -0
  24. data/lib/soap/mapping/rubytypeFactory.rb +475 -0
  25. data/lib/soap/mapping/typeMap.rb +50 -0
  26. data/lib/soap/mapping/wsdlencodedregistry.rb +280 -0
  27. data/lib/soap/mapping/wsdlliteralregistry.rb +418 -0
  28. data/lib/soap/marshal.rb +59 -0
  29. data/lib/soap/mimemessage.rb +240 -0
  30. data/lib/soap/netHttpClient.rb +190 -0
  31. data/lib/soap/parser.rb +251 -0
  32. data/lib/soap/processor.rb +66 -0
  33. data/lib/soap/property.rb +333 -0
  34. data/lib/soap/rpc/cgistub.rb +206 -0
  35. data/lib/soap/rpc/driver.rb +254 -0
  36. data/lib/soap/rpc/element.rb +325 -0
  37. data/lib/soap/rpc/httpserver.rb +129 -0
  38. data/lib/soap/rpc/proxy.rb +497 -0
  39. data/lib/soap/rpc/router.rb +594 -0
  40. data/lib/soap/rpc/rpc.rb +25 -0
  41. data/lib/soap/rpc/soaplet.rb +162 -0
  42. data/lib/soap/rpc/standaloneServer.rb +43 -0
  43. data/lib/soap/soap.rb +140 -0
  44. data/lib/soap/streamHandler.rb +229 -0
  45. data/lib/soap/wsdlDriver.rb +575 -0
  46. data/rubysl-soap.gemspec +19 -18
  47. metadata +115 -86
  48. data/lib/rubysl-soap.rb +0 -7
  49. data/lib/rubysl-soap/version.rb +0 -5
@@ -0,0 +1,251 @@
1
+ # SOAP4R - SOAP XML Instance Parser library.
2
+ # Copyright (C) 2001, 2003 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/ns'
10
+ require 'xsd/xmlparser'
11
+ require 'soap/soap'
12
+ require 'soap/baseData'
13
+ require 'soap/encodingstyle/handler'
14
+
15
+
16
+ module SOAP
17
+
18
+
19
+ class Parser
20
+ include SOAP
21
+
22
+ class ParseError < Error; end
23
+ class FormatDecodeError < ParseError; end
24
+ class UnexpectedElementError < ParseError; end
25
+
26
+ private
27
+
28
+ class ParseFrame
29
+ attr_reader :node
30
+ attr_reader :name
31
+ attr_reader :ns, :encodingstyle
32
+
33
+ class NodeContainer
34
+ def initialize(node)
35
+ @node = node
36
+ end
37
+
38
+ def node
39
+ @node
40
+ end
41
+
42
+ def replace_node(node)
43
+ @node = node
44
+ end
45
+ end
46
+
47
+ public
48
+
49
+ def initialize(ns, name, node, encodingstyle)
50
+ @ns = ns
51
+ @name = name
52
+ self.node = node
53
+ @encodingstyle = encodingstyle
54
+ end
55
+
56
+ def node=(node)
57
+ @node = NodeContainer.new(node)
58
+ end
59
+ end
60
+
61
+ public
62
+
63
+ attr_accessor :envelopenamespace
64
+ attr_accessor :default_encodingstyle
65
+ attr_accessor :decode_typemap
66
+ attr_accessor :allow_unqualified_element
67
+
68
+ def initialize(opt = {})
69
+ @opt = opt
70
+ @parser = XSD::XMLParser.create_parser(self, opt)
71
+ @parsestack = nil
72
+ @lastnode = nil
73
+ @handlers = {}
74
+ @envelopenamespace = opt[:envelopenamespace] || EnvelopeNamespace
75
+ @default_encodingstyle = opt[:default_encodingstyle] || EncodingNamespace
76
+ @decode_typemap = opt[:decode_typemap] || nil
77
+ @allow_unqualified_element = opt[:allow_unqualified_element] || false
78
+ end
79
+
80
+ def charset
81
+ @parser.charset
82
+ end
83
+
84
+ def parse(string_or_readable)
85
+ @parsestack = []
86
+ @lastnode = nil
87
+
88
+ @handlers.each do |uri, handler|
89
+ handler.decode_prologue
90
+ end
91
+
92
+ @parser.do_parse(string_or_readable)
93
+
94
+ unless @parsestack.empty?
95
+ raise FormatDecodeError.new("Unbalanced tag in XML.")
96
+ end
97
+
98
+ @handlers.each do |uri, handler|
99
+ handler.decode_epilogue
100
+ end
101
+
102
+ @lastnode
103
+ end
104
+
105
+ def start_element(name, attrs)
106
+ lastframe = @parsestack.last
107
+ ns = parent = parent_encodingstyle = nil
108
+ if lastframe
109
+ ns = lastframe.ns.clone_ns
110
+ parent = lastframe.node
111
+ parent_encodingstyle = lastframe.encodingstyle
112
+ else
113
+ ns = XSD::NS.new
114
+ parent = ParseFrame::NodeContainer.new(nil)
115
+ parent_encodingstyle = nil
116
+ end
117
+
118
+ attrs = XSD::XMLParser.filter_ns(ns, attrs)
119
+ encodingstyle = find_encodingstyle(ns, attrs)
120
+
121
+ # Children's encodingstyle is derived from its parent.
122
+ if encodingstyle.nil?
123
+ if parent.node.is_a?(SOAPHeader)
124
+ encodingstyle = LiteralNamespace
125
+ else
126
+ encodingstyle = parent_encodingstyle || @default_encodingstyle
127
+ end
128
+ end
129
+
130
+ node = decode_tag(ns, name, attrs, parent, encodingstyle)
131
+
132
+ @parsestack << ParseFrame.new(ns, name, node, encodingstyle)
133
+ end
134
+
135
+ def characters(text)
136
+ lastframe = @parsestack.last
137
+ if lastframe
138
+ # Need not to be cloned because character does not have attr.
139
+ decode_text(lastframe.ns, text, lastframe.encodingstyle)
140
+ else
141
+ # Ignore Text outside of SOAP Envelope.
142
+ p text if $DEBUG
143
+ end
144
+ end
145
+
146
+ def end_element(name)
147
+ lastframe = @parsestack.pop
148
+ unless name == lastframe.name
149
+ raise UnexpectedElementError.new("Closing element name '#{ name }' does not match with opening element '#{ lastframe.name }'.")
150
+ end
151
+ decode_tag_end(lastframe.ns, lastframe.node, lastframe.encodingstyle)
152
+ @lastnode = lastframe.node.node
153
+ end
154
+
155
+ private
156
+
157
+ def find_encodingstyle(ns, attrs)
158
+ attrs.each do |key, value|
159
+ if (ns.compare(@envelopenamespace, AttrEncodingStyle, key))
160
+ return value
161
+ end
162
+ end
163
+ nil
164
+ end
165
+
166
+ def decode_tag(ns, name, attrs, parent, encodingstyle)
167
+ ele = ns.parse(name)
168
+
169
+ # Envelope based parsing.
170
+ if ((ele.namespace == @envelopenamespace) ||
171
+ (@allow_unqualified_element && ele.namespace.nil?))
172
+ o = decode_soap_envelope(ns, ele, attrs, parent)
173
+ return o if o
174
+ end
175
+
176
+ # Encoding based parsing.
177
+ handler = find_handler(encodingstyle)
178
+ if handler
179
+ return handler.decode_tag(ns, ele, attrs, parent)
180
+ else
181
+ raise FormatDecodeError.new("Unknown encodingStyle: #{ encodingstyle }.")
182
+ end
183
+ end
184
+
185
+ def decode_tag_end(ns, node, encodingstyle)
186
+ return unless encodingstyle
187
+
188
+ handler = find_handler(encodingstyle)
189
+ if handler
190
+ return handler.decode_tag_end(ns, node)
191
+ else
192
+ raise FormatDecodeError.new("Unknown encodingStyle: #{ encodingstyle }.")
193
+ end
194
+ end
195
+
196
+ def decode_text(ns, text, encodingstyle)
197
+ handler = find_handler(encodingstyle)
198
+
199
+ if handler
200
+ handler.decode_text(ns, text)
201
+ else
202
+ # How should I do?
203
+ end
204
+ end
205
+
206
+ def decode_soap_envelope(ns, ele, attrs, parent)
207
+ o = nil
208
+ if ele.name == EleEnvelope
209
+ o = SOAPEnvelope.new
210
+ if ext = @opt[:external_content]
211
+ ext.each do |k, v|
212
+ o.external_content[k] = v
213
+ end
214
+ end
215
+ elsif ele.name == EleHeader
216
+ unless parent.node.is_a?(SOAPEnvelope)
217
+ raise FormatDecodeError.new("Header should be a child of Envelope.")
218
+ end
219
+ o = SOAPHeader.new
220
+ parent.node.header = o
221
+ elsif ele.name == EleBody
222
+ unless parent.node.is_a?(SOAPEnvelope)
223
+ raise FormatDecodeError.new("Body should be a child of Envelope.")
224
+ end
225
+ o = SOAPBody.new
226
+ parent.node.body = o
227
+ elsif ele.name == EleFault
228
+ unless parent.node.is_a?(SOAPBody)
229
+ raise FormatDecodeError.new("Fault should be a child of Body.")
230
+ end
231
+ o = SOAPFault.new
232
+ parent.node.fault = o
233
+ end
234
+ o
235
+ end
236
+
237
+ def find_handler(encodingstyle)
238
+ unless @handlers.key?(encodingstyle)
239
+ handler_factory = SOAP::EncodingStyle::Handler.handler(encodingstyle) ||
240
+ SOAP::EncodingStyle::Handler.handler(EncodingNamespace)
241
+ handler = handler_factory.new(@parser.charset)
242
+ handler.decode_typemap = @decode_typemap
243
+ handler.decode_prologue
244
+ @handlers[encodingstyle] = handler
245
+ end
246
+ @handlers[encodingstyle]
247
+ end
248
+ end
249
+
250
+
251
+ end
@@ -0,0 +1,66 @@
1
+ # SOAP4R - marshal/unmarshal interface.
2
+ # Copyright (C) 2000, 2001, 2003 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/datatypes'
10
+ require 'soap/soap'
11
+ require 'soap/element'
12
+ require 'soap/parser'
13
+ require 'soap/generator'
14
+ require 'soap/encodingstyle/soapHandler'
15
+ require 'soap/encodingstyle/literalHandler'
16
+ require 'soap/encodingstyle/aspDotNetHandler'
17
+
18
+
19
+ module SOAP
20
+
21
+
22
+ module Processor
23
+ @@default_parser_option = {}
24
+
25
+ class << self
26
+ public
27
+
28
+ def marshal(env, opt = {}, io = nil)
29
+ generator = create_generator(opt)
30
+ marshalled_str = generator.generate(env, io)
31
+ unless env.external_content.empty?
32
+ opt[:external_content] = env.external_content
33
+ end
34
+ marshalled_str
35
+ end
36
+
37
+ def unmarshal(stream, opt = {})
38
+ parser = create_parser(opt)
39
+ parser.parse(stream)
40
+ end
41
+
42
+ def default_parser_option=(rhs)
43
+ @@default_parser_option = rhs
44
+ end
45
+
46
+ def default_parser_option
47
+ @@default_parser_option
48
+ end
49
+
50
+ private
51
+
52
+ def create_generator(opt)
53
+ SOAPGenerator.new(opt)
54
+ end
55
+
56
+ def create_parser(opt)
57
+ if opt.empty?
58
+ opt = @@default_parser_option
59
+ end
60
+ ::SOAP::Parser.new(opt)
61
+ end
62
+ end
63
+ end
64
+
65
+
66
+ end
@@ -0,0 +1,333 @@
1
+ # soap/property.rb: SOAP4R - Property implementation.
2
+ # Copyright (C) 2003 NAKAMURA, Hiroshi <nahi@ruby-lang.org>.
3
+
4
+ # This program is copyrighted free software by NAKAMURA, Hiroshi. You can
5
+ # redistribute it and/or modify it under the same terms of Ruby's license;
6
+ # either the dual license version in 2003, or any later version.
7
+
8
+
9
+ module SOAP
10
+
11
+
12
+ # Property stream format:
13
+ #
14
+ # line separator is \r?\n. 1 line per a property.
15
+ # line which begins with '#' is a comment line. empty line is ignored, too.
16
+ # key/value separator is ':' or '='.
17
+ # '\' as escape character. but line separator cannot be escaped.
18
+ # \s at the head/tail of key/value are trimmed.
19
+ #
20
+ # '[' + key + ']' indicates property section. for example,
21
+ #
22
+ # [aaa.bbb]
23
+ # ccc = ddd
24
+ # eee.fff = ggg
25
+ # []
26
+ # aaa.hhh = iii
27
+ #
28
+ # is the same as;
29
+ #
30
+ # aaa.bbb.ccc = ddd
31
+ # aaa.bbb.eee.fff = ggg
32
+ # aaa.hhh = iii
33
+ #
34
+ class Property
35
+ FrozenError = (RUBY_VERSION >= "1.9.0") ? RuntimeError : TypeError
36
+
37
+ include Enumerable
38
+
39
+ module Util
40
+ def const_from_name(fqname)
41
+ fqname.split("::").inject(Kernel) { |klass, name| klass.const_get(name) }
42
+ end
43
+ module_function :const_from_name
44
+
45
+ def require_from_name(fqname)
46
+ require File.join(fqname.split("::").collect { |ele| ele.downcase })
47
+ end
48
+ module_function :require_from_name
49
+ end
50
+
51
+ def self.load(stream)
52
+ new.load(stream)
53
+ end
54
+
55
+ def self.loadproperty(propname)
56
+ new.loadproperty(propname)
57
+ end
58
+
59
+ def initialize
60
+ @store = Hash.new
61
+ @hook = Hash.new
62
+ @self_hook = Array.new
63
+ @locked = false
64
+ end
65
+
66
+ KEY_REGSRC = '([^=:\\\\]*(?:\\\\.[^=:\\\\]*)*)'
67
+ DEF_REGSRC = '\\s*' + KEY_REGSRC + '\\s*[=:]\\s*(.*)'
68
+ COMMENT_REGEXP = Regexp.new('^(?:#.*|)$')
69
+ CATDEF_REGEXP = Regexp.new("^\\[\\s*#{KEY_REGSRC}\\s*\\]$")
70
+ LINE_REGEXP = Regexp.new("^#{DEF_REGSRC}$")
71
+ def load(stream)
72
+ key_prefix = ""
73
+ stream.each_with_index do |line, lineno|
74
+ line.sub!(/\r?\n\z/, '')
75
+ case line
76
+ when COMMENT_REGEXP
77
+ next
78
+ when CATDEF_REGEXP
79
+ key_prefix = $1.strip
80
+ when LINE_REGEXP
81
+ key, value = $1.strip, $2.strip
82
+ key = "#{key_prefix}.#{key}" unless key_prefix.empty?
83
+ key, value = loadstr(key), loadstr(value)
84
+ self[key] = value
85
+ else
86
+ raise TypeError.new(
87
+ "property format error at line #{lineno + 1}: `#{line}'")
88
+ end
89
+ end
90
+ self
91
+ end
92
+
93
+ # find property from $:.
94
+ def loadproperty(propname)
95
+ return loadpropertyfile(propname) if File.file?(propname)
96
+ $:.each do |path|
97
+ if File.file?(file = File.join(path, propname))
98
+ return loadpropertyfile(file)
99
+ end
100
+ end
101
+ nil
102
+ end
103
+
104
+ # name: a Symbol, String or an Array
105
+ def [](name)
106
+ referent(name_to_a(name))
107
+ end
108
+
109
+ # name: a Symbol, String or an Array
110
+ # value: an Object
111
+ def []=(name, value)
112
+ name_pair = name_to_a(name).freeze
113
+ hooks = assign(name_pair, value)
114
+ hooks.each do |hook|
115
+ hook.call(name_pair, value)
116
+ end
117
+ value
118
+ end
119
+
120
+ # value: an Object
121
+ # key is generated by property
122
+ def <<(value)
123
+ self[generate_new_key] = value
124
+ end
125
+
126
+ # name: a Symbol, String or an Array; nil means hook to the root
127
+ # cascade: true/false; for cascading hook of sub key
128
+ # hook: block which will be called with 2 args, name and value
129
+ def add_hook(name = nil, cascade = false, &hook)
130
+ if name == nil or name == true or name == false
131
+ cascade = name
132
+ assign_self_hook(cascade, &hook)
133
+ else
134
+ assign_hook(name_to_a(name), cascade, &hook)
135
+ end
136
+ end
137
+
138
+ def each
139
+ @store.each do |key, value|
140
+ yield(key, value)
141
+ end
142
+ end
143
+
144
+ def empty?
145
+ @store.empty?
146
+ end
147
+
148
+ def keys
149
+ @store.keys
150
+ end
151
+
152
+ def values
153
+ @store.values
154
+ end
155
+
156
+ def lock(cascade = false)
157
+ if cascade
158
+ each_key do |key|
159
+ key.lock(cascade)
160
+ end
161
+ end
162
+ @locked = true
163
+ self
164
+ end
165
+
166
+ def unlock(cascade = false)
167
+ @locked = false
168
+ if cascade
169
+ each_key do |key|
170
+ key.unlock(cascade)
171
+ end
172
+ end
173
+ self
174
+ end
175
+
176
+ def locked?
177
+ @locked
178
+ end
179
+
180
+ protected
181
+
182
+ def deref_key(key)
183
+ check_lock(key)
184
+ ref = @store[key] ||= self.class.new
185
+ unless propkey?(ref)
186
+ raise ArgumentError.new("key `#{key}' already defined as a value")
187
+ end
188
+ ref
189
+ end
190
+
191
+ def local_referent(key)
192
+ check_lock(key)
193
+ if propkey?(@store[key]) and @store[key].locked?
194
+ raise FrozenError.new("cannot split any key from locked property")
195
+ end
196
+ @store[key]
197
+ end
198
+
199
+ def local_assign(key, value)
200
+ check_lock(key)
201
+ if @locked
202
+ if propkey?(value)
203
+ raise FrozenError.new("cannot add any key to locked property")
204
+ elsif propkey?(@store[key])
205
+ raise FrozenError.new("cannot override any key in locked property")
206
+ end
207
+ end
208
+ @store[key] = value
209
+ end
210
+
211
+ def local_hook(key, direct)
212
+ hooks = []
213
+ (@self_hook + (@hook[key] || NO_HOOK)).each do |hook, cascade|
214
+ hooks << hook if direct or cascade
215
+ end
216
+ hooks
217
+ end
218
+
219
+ def local_assign_hook(key, cascade, &hook)
220
+ check_lock(key)
221
+ @store[key] ||= nil
222
+ (@hook[key] ||= []) << [hook, cascade]
223
+ end
224
+
225
+ private
226
+
227
+ NO_HOOK = [].freeze
228
+
229
+ def referent(ary)
230
+ ary[0..-2].inject(self) { |ref, name|
231
+ ref.deref_key(to_key(name))
232
+ }.local_referent(to_key(ary.last))
233
+ end
234
+
235
+ def assign(ary, value)
236
+ ref = self
237
+ hook = NO_HOOK
238
+ ary[0..-2].each do |name|
239
+ key = to_key(name)
240
+ hook += ref.local_hook(key, false)
241
+ ref = ref.deref_key(key)
242
+ end
243
+ last_key = to_key(ary.last)
244
+ ref.local_assign(last_key, value)
245
+ hook + ref.local_hook(last_key, true)
246
+ end
247
+
248
+ def assign_hook(ary, cascade, &hook)
249
+ ary[0..-2].inject(self) { |ref, name|
250
+ ref.deref_key(to_key(name))
251
+ }.local_assign_hook(to_key(ary.last), cascade, &hook)
252
+ end
253
+
254
+ def assign_self_hook(cascade, &hook)
255
+ check_lock(nil)
256
+ @self_hook << [hook, cascade]
257
+ end
258
+
259
+ def each_key
260
+ self.each do |key, value|
261
+ if propkey?(value)
262
+ yield(value)
263
+ end
264
+ end
265
+ end
266
+
267
+ def check_lock(key)
268
+ if @locked and (key.nil? or !@store.key?(key))
269
+ raise FrozenError.new("cannot add any key to locked property")
270
+ end
271
+ end
272
+
273
+ def propkey?(value)
274
+ value.is_a?(::SOAP::Property)
275
+ end
276
+
277
+ def name_to_a(name)
278
+ case name
279
+ when Symbol
280
+ [name]
281
+ when String
282
+ name.scan(/[^.\\]+(?:\\.[^.\\])*/) # split with unescaped '.'
283
+ when Array
284
+ name
285
+ else
286
+ raise ArgumentError.new("Unknown name #{name}(#{name.class})")
287
+ end
288
+ end
289
+
290
+ def to_key(name)
291
+ name.to_s.downcase
292
+ end
293
+
294
+ def generate_new_key
295
+ if @store.empty?
296
+ "0"
297
+ else
298
+ (key_max + 1).to_s
299
+ end
300
+ end
301
+
302
+ def key_max
303
+ (@store.keys.max { |l, r| l.to_s.to_i <=> r.to_s.to_i }).to_s.to_i
304
+ end
305
+
306
+ def loadpropertyfile(file)
307
+ puts "find property at #{file}" if $DEBUG
308
+ File.open(file) do |f|
309
+ load(f)
310
+ end
311
+ end
312
+
313
+ def loadstr(str)
314
+ str.gsub(/\\./) { |c| eval("\"#{c}\"") }
315
+ end
316
+ end
317
+
318
+
319
+ end
320
+
321
+
322
+ # for ruby/1.6.
323
+ unless Enumerable.instance_methods.include?('inject')
324
+ module Enumerable
325
+ def inject(init)
326
+ result = init
327
+ each do |item|
328
+ result = yield(result, item)
329
+ end
330
+ result
331
+ end
332
+ end
333
+ end