soap2r 1.5.8

Sign up to get free protection for your applications and to get access to all the features.
Files changed (161) hide show
  1. data/bin/wsdl2ruby.rb +137 -0
  2. data/bin/xsd2ruby.rb +90 -0
  3. data/lib/soap/attachment.rb +108 -0
  4. data/lib/soap/attrproxy.rb +34 -0
  5. data/lib/soap/baseData.rb +1094 -0
  6. data/lib/soap/element.rb +277 -0
  7. data/lib/soap/encodingstyle/aspDotNetHandler.rb +207 -0
  8. data/lib/soap/encodingstyle/handler.rb +120 -0
  9. data/lib/soap/encodingstyle/literalHandler.rb +195 -0
  10. data/lib/soap/encodingstyle/soapHandler.rb +559 -0
  11. data/lib/soap/filter.rb +13 -0
  12. data/lib/soap/filter/filterchain.rb +51 -0
  13. data/lib/soap/filter/handler.rb +31 -0
  14. data/lib/soap/filter/streamhandler.rb +29 -0
  15. data/lib/soap/generator.rb +299 -0
  16. data/lib/soap/header/handler.rb +61 -0
  17. data/lib/soap/header/handlerset.rb +70 -0
  18. data/lib/soap/header/mappinghandler.rb +47 -0
  19. data/lib/soap/header/simplehandler.rb +44 -0
  20. data/lib/soap/httpconfigloader.rb +141 -0
  21. data/lib/soap/mapping.rb +12 -0
  22. data/lib/soap/mapping/encodedregistry.rb +537 -0
  23. data/lib/soap/mapping/factory.rb +388 -0
  24. data/lib/soap/mapping/literalregistry.rb +391 -0
  25. data/lib/soap/mapping/mapping.rb +576 -0
  26. data/lib/soap/mapping/registry.rb +295 -0
  27. data/lib/soap/mapping/rubytypeFactory.rb +446 -0
  28. data/lib/soap/mapping/schemadefinition.rb +170 -0
  29. data/lib/soap/mapping/typeMap.rb +106 -0
  30. data/lib/soap/mapping/wsdlencodedregistry.rb +211 -0
  31. data/lib/soap/mapping/wsdlliteralregistry.rb +248 -0
  32. data/lib/soap/marshal.rb +59 -0
  33. data/lib/soap/mimemessage.rb +241 -0
  34. data/lib/soap/nestedexception.rb +42 -0
  35. data/lib/soap/netHttpClient.rb +241 -0
  36. data/lib/soap/ns.rb +34 -0
  37. data/lib/soap/parser.rb +252 -0
  38. data/lib/soap/processor.rb +66 -0
  39. data/lib/soap/property.rb +319 -0
  40. data/lib/soap/proxy.rb +14 -0
  41. data/lib/soap/rpc/cgistub.rb +247 -0
  42. data/lib/soap/rpc/driver.rb +221 -0
  43. data/lib/soap/rpc/element.rb +374 -0
  44. data/lib/soap/rpc/httpserver.rb +142 -0
  45. data/lib/soap/rpc/methodDef.rb +68 -0
  46. data/lib/soap/rpc/proxy.rb +572 -0
  47. data/lib/soap/rpc/router.rb +662 -0
  48. data/lib/soap/rpc/rpc.rb +25 -0
  49. data/lib/soap/rpc/soaplet.rb +200 -0
  50. data/lib/soap/rpc/standaloneServer.rb +43 -0
  51. data/lib/soap/soap.rb +151 -0
  52. data/lib/soap/streamHandler.rb +301 -0
  53. data/lib/soap/wsdlDriver.rb +164 -0
  54. data/lib/wsdl/binding.rb +65 -0
  55. data/lib/wsdl/data.rb +64 -0
  56. data/lib/wsdl/definitions.rb +236 -0
  57. data/lib/wsdl/documentation.rb +32 -0
  58. data/lib/wsdl/import.rb +80 -0
  59. data/lib/wsdl/importer.rb +38 -0
  60. data/lib/wsdl/info.rb +50 -0
  61. data/lib/wsdl/message.rb +54 -0
  62. data/lib/wsdl/operation.rb +151 -0
  63. data/lib/wsdl/operationBinding.rb +240 -0
  64. data/lib/wsdl/param.rb +93 -0
  65. data/lib/wsdl/parser.rb +164 -0
  66. data/lib/wsdl/part.rb +52 -0
  67. data/lib/wsdl/port.rb +66 -0
  68. data/lib/wsdl/portType.rb +75 -0
  69. data/lib/wsdl/service.rb +61 -0
  70. data/lib/wsdl/soap/address.rb +40 -0
  71. data/lib/wsdl/soap/binding.rb +49 -0
  72. data/lib/wsdl/soap/body.rb +58 -0
  73. data/lib/wsdl/soap/cgiStubCreator.rb +92 -0
  74. data/lib/wsdl/soap/classDefCreator.rb +433 -0
  75. data/lib/wsdl/soap/classDefCreatorSupport.rb +240 -0
  76. data/lib/wsdl/soap/classNameCreator.rb +54 -0
  77. data/lib/wsdl/soap/clientSkeltonCreator.rb +104 -0
  78. data/lib/wsdl/soap/complexType.rb +173 -0
  79. data/lib/wsdl/soap/data.rb +42 -0
  80. data/lib/wsdl/soap/definitions.rb +200 -0
  81. data/lib/wsdl/soap/driverCreator.rb +118 -0
  82. data/lib/wsdl/soap/element.rb +33 -0
  83. data/lib/wsdl/soap/encodedMappingRegistryCreator.rb +73 -0
  84. data/lib/wsdl/soap/fault.rb +56 -0
  85. data/lib/wsdl/soap/header.rb +86 -0
  86. data/lib/wsdl/soap/headerfault.rb +56 -0
  87. data/lib/wsdl/soap/literalMappingRegistryCreator.rb +115 -0
  88. data/lib/wsdl/soap/mappingRegistryCreator.rb +58 -0
  89. data/lib/wsdl/soap/mappingRegistryCreatorSupport.rb +376 -0
  90. data/lib/wsdl/soap/methodDefCreator.rb +199 -0
  91. data/lib/wsdl/soap/operation.rb +112 -0
  92. data/lib/wsdl/soap/servantSkeltonCreator.rb +89 -0
  93. data/lib/wsdl/soap/servletStubCreator.rb +104 -0
  94. data/lib/wsdl/soap/standaloneServerStubCreator.rb +100 -0
  95. data/lib/wsdl/soap/wsdl2ruby.rb +217 -0
  96. data/lib/wsdl/types.rb +44 -0
  97. data/lib/wsdl/wsdl.rb +24 -0
  98. data/lib/wsdl/xmlSchema/all.rb +24 -0
  99. data/lib/wsdl/xmlSchema/annotation.rb +34 -0
  100. data/lib/wsdl/xmlSchema/any.rb +61 -0
  101. data/lib/wsdl/xmlSchema/anyAttribute.rb +48 -0
  102. data/lib/wsdl/xmlSchema/attribute.rb +104 -0
  103. data/lib/wsdl/xmlSchema/attributeGroup.rb +68 -0
  104. data/lib/wsdl/xmlSchema/choice.rb +58 -0
  105. data/lib/wsdl/xmlSchema/complexContent.rb +97 -0
  106. data/lib/wsdl/xmlSchema/complexExtension.rb +119 -0
  107. data/lib/wsdl/xmlSchema/complexRestriction.rb +104 -0
  108. data/lib/wsdl/xmlSchema/complexType.rb +193 -0
  109. data/lib/wsdl/xmlSchema/content.rb +95 -0
  110. data/lib/wsdl/xmlSchema/data.rb +116 -0
  111. data/lib/wsdl/xmlSchema/element.rb +153 -0
  112. data/lib/wsdl/xmlSchema/enumeration.rb +36 -0
  113. data/lib/wsdl/xmlSchema/fractiondigits.rb +37 -0
  114. data/lib/wsdl/xmlSchema/group.rb +100 -0
  115. data/lib/wsdl/xmlSchema/import.rb +53 -0
  116. data/lib/wsdl/xmlSchema/importHandler.rb +45 -0
  117. data/lib/wsdl/xmlSchema/importer.rb +102 -0
  118. data/lib/wsdl/xmlSchema/include.rb +48 -0
  119. data/lib/wsdl/xmlSchema/length.rb +37 -0
  120. data/lib/wsdl/xmlSchema/list.rb +48 -0
  121. data/lib/wsdl/xmlSchema/maxexclusive.rb +37 -0
  122. data/lib/wsdl/xmlSchema/maxinclusive.rb +37 -0
  123. data/lib/wsdl/xmlSchema/maxlength.rb +37 -0
  124. data/lib/wsdl/xmlSchema/minexclusive.rb +37 -0
  125. data/lib/wsdl/xmlSchema/mininclusive.rb +37 -0
  126. data/lib/wsdl/xmlSchema/minlength.rb +37 -0
  127. data/lib/wsdl/xmlSchema/parser.rb +167 -0
  128. data/lib/wsdl/xmlSchema/pattern.rb +36 -0
  129. data/lib/wsdl/xmlSchema/ref.rb +33 -0
  130. data/lib/wsdl/xmlSchema/schema.rb +178 -0
  131. data/lib/wsdl/xmlSchema/sequence.rb +54 -0
  132. data/lib/wsdl/xmlSchema/simpleContent.rb +69 -0
  133. data/lib/wsdl/xmlSchema/simpleExtension.rb +62 -0
  134. data/lib/wsdl/xmlSchema/simpleRestriction.rb +132 -0
  135. data/lib/wsdl/xmlSchema/simpleType.rb +87 -0
  136. data/lib/wsdl/xmlSchema/totaldigits.rb +37 -0
  137. data/lib/wsdl/xmlSchema/union.rb +35 -0
  138. data/lib/wsdl/xmlSchema/unique.rb +34 -0
  139. data/lib/wsdl/xmlSchema/whitespace.rb +37 -0
  140. data/lib/wsdl/xmlSchema/xsd2ruby.rb +174 -0
  141. data/lib/xsd/charset.rb +193 -0
  142. data/lib/xsd/codegen.rb +12 -0
  143. data/lib/xsd/codegen/classdef.rb +208 -0
  144. data/lib/xsd/codegen/commentdef.rb +34 -0
  145. data/lib/xsd/codegen/gensupport.rb +273 -0
  146. data/lib/xsd/codegen/methoddef.rb +70 -0
  147. data/lib/xsd/codegen/moduledef.rb +208 -0
  148. data/lib/xsd/datatypes.rb +1466 -0
  149. data/lib/xsd/datatypes1999.rb +20 -0
  150. data/lib/xsd/iconvcharset.rb +39 -0
  151. data/lib/xsd/mapping.rb +68 -0
  152. data/lib/xsd/namedelements.rb +132 -0
  153. data/lib/xsd/ns.rb +182 -0
  154. data/lib/xsd/qname.rb +79 -0
  155. data/lib/xsd/xmlparser.rb +76 -0
  156. data/lib/xsd/xmlparser/libxmlparser.rb +115 -0
  157. data/lib/xsd/xmlparser/parser.rb +100 -0
  158. data/lib/xsd/xmlparser/rexmlparser.rb +58 -0
  159. data/lib/xsd/xmlparser/xmlparser.rb +50 -0
  160. data/lib/xsd/xmlparser/xmlscanner.rb +149 -0
  161. metadata +224 -0
@@ -0,0 +1,66 @@
1
+ # SOAP4R - marshal/unmarshal interface.
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/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
+ Generator.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,319 @@
1
+ # soap/property.rb: SOAP4R - Property implementation.
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
+ 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('^(?:#.*|)$', nil)
69
+ CATDEF_REGEXP = Regexp.new("^\\[\\s*#{KEY_REGSRC}\\s*\\]$", nil)
70
+ LINE_REGEXP = Regexp.new("^#{DEF_REGSRC}$", nil)
71
+ def load(stream)
72
+ key_prefix = ""
73
+ stream.each_with_index do |line, lineno|
74
+ line.sub!(/\r?\n\z/u, '')
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(/[^.\\]+(?:\\.[^.\\])*/u) # 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(/\\./u) { |c| eval("\"#{c}\"") }
315
+ end
316
+ end
317
+
318
+
319
+ end
@@ -0,0 +1,14 @@
1
+ # SOAP4R - Proxy library.
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 'soap/rpc/proxy'
10
+
11
+
12
+ module SOAP
13
+ SOAPProxy = RPC::Proxy
14
+ end
@@ -0,0 +1,247 @@
1
+ # SOAP4R - CGI/mod_ruby stub library
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 'soap/streamHandler'
10
+ require 'webrick/httpresponse'
11
+ require 'webrick/httpstatus'
12
+ require 'logger'
13
+ require 'soap/rpc/soaplet'
14
+
15
+
16
+ module SOAP
17
+ module RPC
18
+
19
+
20
+ ###
21
+ # SYNOPSIS
22
+ # CGIStub.new
23
+ #
24
+ # DESCRIPTION
25
+ # To be written...
26
+ #
27
+ class CGIStub < Logger::Application
28
+ include SOAP
29
+ include WEBrick
30
+
31
+ class SOAPRequest
32
+ attr_reader :body
33
+
34
+ def [](var); end
35
+
36
+ def meta_vars; end
37
+
38
+ EMPTY_COOKIES = [].freeze
39
+ def cookies; EMPTY_COOKIES; end
40
+
41
+ def user; end
42
+ end
43
+
44
+ class SOAPStdinRequest < SOAPRequest
45
+ attr_reader :body
46
+
47
+ def initialize(stream)
48
+ size = ENV['CONTENT_LENGTH'].to_i || 0
49
+ @body = stream.read(size)
50
+ end
51
+
52
+ def [](var)
53
+ ENV[var.gsub(/-/, '_').upcase]
54
+ end
55
+
56
+ def meta_vars
57
+ {
58
+ 'HTTP_SOAPACTION' => ENV['HTTP_SOAPAction']
59
+ }
60
+ end
61
+
62
+ def cookies
63
+ if cookie = ENV['HTTP_Cookie'] || ENV['Cookie']
64
+ [WEBrick::Cookie.parse(cookie)]
65
+ else
66
+ EMPTY_COOKIES
67
+ end
68
+ end
69
+
70
+ def user
71
+ ENV['REMOTE_USER']
72
+ end
73
+ end
74
+
75
+ class SOAPFCGIRequest < SOAPRequest
76
+ attr_reader :body
77
+
78
+ def initialize(request)
79
+ @request = request
80
+ @body = @request.in.read
81
+ end
82
+
83
+ def [](var)
84
+ @request.env[var.gsub(/-/, '_').upcase]
85
+ end
86
+
87
+ def meta_vars
88
+ {
89
+ 'HTTP_SOAPACTION' => @request.env['HTTP_SOAPAction']
90
+ }
91
+ end
92
+
93
+ def cookies
94
+ if cookie = @request.env['HTTP_Cookie'] || @request.env['Cookie']
95
+ [WEBrick::Cookie.parse(cookie)]
96
+ else
97
+ EMPTY_COOKIES
98
+ end
99
+ end
100
+
101
+ def user
102
+ @request.env['REMOTE_USER']
103
+ end
104
+ end
105
+
106
+ def initialize(appname, default_namespace)
107
+ super(appname)
108
+ set_log(STDERR)
109
+ self.level = ERROR
110
+ @default_namespace = default_namespace
111
+ @remote_host = ENV['REMOTE_HOST'] || ENV['REMOTE_ADDR'] || 'unknown'
112
+ @router = ::SOAP::RPC::Router.new(self.class.name)
113
+ @soaplet = ::SOAP::RPC::SOAPlet.new(@router)
114
+ on_init
115
+ end
116
+
117
+ def on_init
118
+ # do extra initialization in a derived class if needed.
119
+ end
120
+
121
+ def mapping_registry
122
+ @router.mapping_registry
123
+ end
124
+
125
+ def mapping_registry=(mapping_registry)
126
+ @router.mapping_registry = mapping_registry
127
+ end
128
+
129
+ def literal_mapping_registry
130
+ @router.literal_mapping_registry
131
+ end
132
+
133
+ def literal_mapping_registry=(literal_mapping_registry)
134
+ @router.literal_mapping_registry = literal_mapping_registry
135
+ end
136
+
137
+ def generate_explicit_type
138
+ @router.generate_explicit_type
139
+ end
140
+
141
+ def generate_explicit_type=(generate_explicit_type)
142
+ @router.generate_explicit_type = generate_explicit_type
143
+ end
144
+
145
+ # servant entry interface
146
+
147
+ def add_rpc_servant(obj, namespace = @default_namespace)
148
+ @router.add_rpc_servant(obj, namespace)
149
+ end
150
+ alias add_servant add_rpc_servant
151
+
152
+ def add_headerhandler(obj)
153
+ @router.add_headerhandler(obj)
154
+ end
155
+ alias add_rpc_headerhandler add_headerhandler
156
+
157
+ def filterchain
158
+ @router.filterchain
159
+ end
160
+
161
+ # method entry interface
162
+
163
+ def add_rpc_method(obj, name, *param)
164
+ add_rpc_method_with_namespace_as(@default_namespace, obj, name, name, *param)
165
+ end
166
+ alias add_method add_rpc_method
167
+
168
+ def add_rpc_method_as(obj, name, name_as, *param)
169
+ add_rpc_method_with_namespace_as(@default_namespace, obj, name, name_as, *param)
170
+ end
171
+ alias add_method_as add_rpc_method_as
172
+
173
+ def add_rpc_method_with_namespace(namespace, obj, name, *param)
174
+ add_rpc_method_with_namespace_as(namespace, obj, name, name, *param)
175
+ end
176
+ alias add_method_with_namespace add_rpc_method_with_namespace
177
+
178
+ def add_rpc_method_with_namespace_as(namespace, obj, name, name_as, *param)
179
+ qname = XSD::QName.new(namespace, name_as)
180
+ soapaction = nil
181
+ param_def = SOAPMethod.derive_rpc_param_def(obj, name, *param)
182
+ @router.add_rpc_operation(obj, qname, soapaction, name, param_def)
183
+ end
184
+ alias add_method_with_namespace_as add_rpc_method_with_namespace_as
185
+
186
+ def add_rpc_operation(receiver, qname, soapaction, name, param_def, opt = {})
187
+ @router.add_rpc_operation(receiver, qname, soapaction, name, param_def, opt)
188
+ end
189
+
190
+ def add_document_operation(receiver, soapaction, name, param_def, opt = {})
191
+ @router.add_document_operation(receiver, soapaction, name, param_def, opt)
192
+ end
193
+
194
+ def set_fcgi_request(request)
195
+ @fcgi = request
196
+ end
197
+
198
+ private
199
+
200
+ HTTPVersion = WEBrick::HTTPVersion.new('1.0') # dummy; ignored
201
+
202
+ def run
203
+ res = WEBrick::HTTPResponse.new({:HTTPVersion => HTTPVersion})
204
+ begin
205
+ @log.info { "received a request from '#{ @remote_host }'" }
206
+ if @fcgi
207
+ req = SOAPFCGIRequest.new(@fcgi)
208
+ else
209
+ req = SOAPStdinRequest.new($stdin)
210
+ end
211
+ @soaplet.do_POST(req, res)
212
+ rescue HTTPStatus::EOFError, HTTPStatus::RequestTimeout => ex
213
+ res.set_error(ex)
214
+ rescue HTTPStatus::Error => ex
215
+ res.set_error(ex)
216
+ rescue HTTPStatus::Status => ex
217
+ res.status = ex.code
218
+ rescue StandardError, NameError => ex # for Ruby 1.6
219
+ res.set_error(ex, true)
220
+ ensure
221
+ if defined?(MOD_RUBY)
222
+ r = Apache.request
223
+ r.status = res.status
224
+ r.content_type = res.content_type
225
+ r.send_http_header
226
+ buf = res.body
227
+ else
228
+ buf = ''
229
+ res.send_response(buf)
230
+ buf.sub!(/^[^\r]+\r\n/, '') # Trim status line.
231
+ end
232
+ @log.debug { "SOAP CGI Response:\n#{ buf }" }
233
+ if @fcgi
234
+ @fcgi.out.print buf
235
+ @fcgi.finish
236
+ @fcgi = nil
237
+ else
238
+ print buf
239
+ end
240
+ end
241
+ 0
242
+ end
243
+ end
244
+
245
+
246
+ end
247
+ end