soap4r_es 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (165) hide show
  1. checksums.yaml +7 -0
  2. data/bin/wsdl2ruby.rb +140 -0
  3. data/bin/wsdl2ruby_rails.rb +140 -0
  4. data/bin/xsd2ruby.rb +92 -0
  5. data/lib/soap/attachment.rb +109 -0
  6. data/lib/soap/attrproxy.rb +35 -0
  7. data/lib/soap/baseData.rb +1095 -0
  8. data/lib/soap/element.rb +278 -0
  9. data/lib/soap/encodingstyle/aspDotNetHandler.rb +208 -0
  10. data/lib/soap/encodingstyle/handler.rb +121 -0
  11. data/lib/soap/encodingstyle/literalHandler.rb +196 -0
  12. data/lib/soap/encodingstyle/soapHandler.rb +560 -0
  13. data/lib/soap/filter/filterchain.rb +52 -0
  14. data/lib/soap/filter/handler.rb +32 -0
  15. data/lib/soap/filter/streamhandler.rb +30 -0
  16. data/lib/soap/filter.rb +14 -0
  17. data/lib/soap/generator.rb +299 -0
  18. data/lib/soap/header/handler.rb +64 -0
  19. data/lib/soap/header/handlerset.rb +78 -0
  20. data/lib/soap/header/mappinghandler.rb +48 -0
  21. data/lib/soap/header/simplehandler.rb +45 -0
  22. data/lib/soap/httpconfigloader.rb +140 -0
  23. data/lib/soap/mapping/encodedregistry.rb +541 -0
  24. data/lib/soap/mapping/factory.rb +389 -0
  25. data/lib/soap/mapping/literalregistry.rb +392 -0
  26. data/lib/soap/mapping/mapping.rb +577 -0
  27. data/lib/soap/mapping/registry.rb +297 -0
  28. data/lib/soap/mapping/rubytypeFactory.rb +446 -0
  29. data/lib/soap/mapping/schemadefinition.rb +171 -0
  30. data/lib/soap/mapping/typeMap.rb +107 -0
  31. data/lib/soap/mapping/wsdlencodedregistry.rb +212 -0
  32. data/lib/soap/mapping/wsdlliteralregistry.rb +249 -0
  33. data/lib/soap/mapping.rb +13 -0
  34. data/lib/soap/marshal.rb +60 -0
  35. data/lib/soap/mimemessage.rb +243 -0
  36. data/lib/soap/nestedexception.rb +43 -0
  37. data/lib/soap/netHttpClient.rb +242 -0
  38. data/lib/soap/ns.rb +39 -0
  39. data/lib/soap/parser.rb +253 -0
  40. data/lib/soap/processor.rb +67 -0
  41. data/lib/soap/property.rb +330 -0
  42. data/lib/soap/proxy.rb +15 -0
  43. data/lib/soap/rpc/cgistub.rb +249 -0
  44. data/lib/soap/rpc/driver.rb +222 -0
  45. data/lib/soap/rpc/element.rb +375 -0
  46. data/lib/soap/rpc/httpserver.rb +144 -0
  47. data/lib/soap/rpc/methodDef.rb +69 -0
  48. data/lib/soap/rpc/proxy.rb +573 -0
  49. data/lib/soap/rpc/router.rb +672 -0
  50. data/lib/soap/rpc/rpc.rb +26 -0
  51. data/lib/soap/rpc/soaplet.rb +201 -0
  52. data/lib/soap/rpc/standaloneServer.rb +44 -0
  53. data/lib/soap/soap.rb +163 -0
  54. data/lib/soap/streamHandler.rb +302 -0
  55. data/lib/soap/version.rb +12 -0
  56. data/lib/soap/wsdlDriver.rb +165 -0
  57. data/lib/wsdl/binding.rb +66 -0
  58. data/lib/wsdl/data.rb +65 -0
  59. data/lib/wsdl/definitions.rb +237 -0
  60. data/lib/wsdl/documentation.rb +33 -0
  61. data/lib/wsdl/import.rb +81 -0
  62. data/lib/wsdl/importer.rb +39 -0
  63. data/lib/wsdl/info.rb +51 -0
  64. data/lib/wsdl/message.rb +55 -0
  65. data/lib/wsdl/operation.rb +152 -0
  66. data/lib/wsdl/operationBinding.rb +241 -0
  67. data/lib/wsdl/param.rb +94 -0
  68. data/lib/wsdl/parser.rb +180 -0
  69. data/lib/wsdl/part.rb +53 -0
  70. data/lib/wsdl/port.rb +67 -0
  71. data/lib/wsdl/portType.rb +76 -0
  72. data/lib/wsdl/service.rb +62 -0
  73. data/lib/wsdl/soap/address.rb +41 -0
  74. data/lib/wsdl/soap/binding.rb +50 -0
  75. data/lib/wsdl/soap/body.rb +59 -0
  76. data/lib/wsdl/soap/cgiStubCreator.rb +93 -0
  77. data/lib/wsdl/soap/classDefCreator.rb +529 -0
  78. data/lib/wsdl/soap/classDefCreatorSupport.rb +242 -0
  79. data/lib/wsdl/soap/classNameCreator.rb +57 -0
  80. data/lib/wsdl/soap/clientSkeltonCreator.rb +107 -0
  81. data/lib/wsdl/soap/complexType.rb +174 -0
  82. data/lib/wsdl/soap/data.rb +43 -0
  83. data/lib/wsdl/soap/definitions.rb +201 -0
  84. data/lib/wsdl/soap/driverCreator.rb +121 -0
  85. data/lib/wsdl/soap/element.rb +34 -0
  86. data/lib/wsdl/soap/encodedMappingRegistryCreator.rb +74 -0
  87. data/lib/wsdl/soap/fault.rb +57 -0
  88. data/lib/wsdl/soap/header.rb +87 -0
  89. data/lib/wsdl/soap/headerfault.rb +57 -0
  90. data/lib/wsdl/soap/literalMappingRegistryCreator.rb +116 -0
  91. data/lib/wsdl/soap/mappingRegistryCreator.rb +59 -0
  92. data/lib/wsdl/soap/mappingRegistryCreatorSupport.rb +380 -0
  93. data/lib/wsdl/soap/methodDefCreator.rb +200 -0
  94. data/lib/wsdl/soap/operation.rb +113 -0
  95. data/lib/wsdl/soap/servantSkeltonCreator.rb +92 -0
  96. data/lib/wsdl/soap/servletStubCreator.rb +105 -0
  97. data/lib/wsdl/soap/standaloneServerStubCreator.rb +101 -0
  98. data/lib/wsdl/soap/wsdl2ruby.rb +249 -0
  99. data/lib/wsdl/types.rb +45 -0
  100. data/lib/wsdl/wsdl.rb +25 -0
  101. data/lib/wsdl/xmlSchema/all.rb +25 -0
  102. data/lib/wsdl/xmlSchema/annotation.rb +35 -0
  103. data/lib/wsdl/xmlSchema/any.rb +62 -0
  104. data/lib/wsdl/xmlSchema/anyAttribute.rb +49 -0
  105. data/lib/wsdl/xmlSchema/attribute.rb +105 -0
  106. data/lib/wsdl/xmlSchema/attributeGroup.rb +69 -0
  107. data/lib/wsdl/xmlSchema/choice.rb +59 -0
  108. data/lib/wsdl/xmlSchema/complexContent.rb +98 -0
  109. data/lib/wsdl/xmlSchema/complexExtension.rb +120 -0
  110. data/lib/wsdl/xmlSchema/complexRestriction.rb +105 -0
  111. data/lib/wsdl/xmlSchema/complexType.rb +194 -0
  112. data/lib/wsdl/xmlSchema/content.rb +96 -0
  113. data/lib/wsdl/xmlSchema/data.rb +117 -0
  114. data/lib/wsdl/xmlSchema/element.rb +154 -0
  115. data/lib/wsdl/xmlSchema/enumeration.rb +37 -0
  116. data/lib/wsdl/xmlSchema/fractiondigits.rb +38 -0
  117. data/lib/wsdl/xmlSchema/group.rb +101 -0
  118. data/lib/wsdl/xmlSchema/import.rb +53 -0
  119. data/lib/wsdl/xmlSchema/importHandler.rb +45 -0
  120. data/lib/wsdl/xmlSchema/importer.rb +103 -0
  121. data/lib/wsdl/xmlSchema/include.rb +48 -0
  122. data/lib/wsdl/xmlSchema/length.rb +38 -0
  123. data/lib/wsdl/xmlSchema/list.rb +49 -0
  124. data/lib/wsdl/xmlSchema/maxexclusive.rb +38 -0
  125. data/lib/wsdl/xmlSchema/maxinclusive.rb +38 -0
  126. data/lib/wsdl/xmlSchema/maxlength.rb +38 -0
  127. data/lib/wsdl/xmlSchema/minexclusive.rb +38 -0
  128. data/lib/wsdl/xmlSchema/mininclusive.rb +38 -0
  129. data/lib/wsdl/xmlSchema/minlength.rb +38 -0
  130. data/lib/wsdl/xmlSchema/parser.rb +168 -0
  131. data/lib/wsdl/xmlSchema/pattern.rb +37 -0
  132. data/lib/wsdl/xmlSchema/ref.rb +34 -0
  133. data/lib/wsdl/xmlSchema/schema.rb +179 -0
  134. data/lib/wsdl/xmlSchema/sequence.rb +55 -0
  135. data/lib/wsdl/xmlSchema/simpleContent.rb +70 -0
  136. data/lib/wsdl/xmlSchema/simpleExtension.rb +63 -0
  137. data/lib/wsdl/xmlSchema/simpleRestriction.rb +133 -0
  138. data/lib/wsdl/xmlSchema/simpleType.rb +88 -0
  139. data/lib/wsdl/xmlSchema/totaldigits.rb +38 -0
  140. data/lib/wsdl/xmlSchema/union.rb +36 -0
  141. data/lib/wsdl/xmlSchema/unique.rb +35 -0
  142. data/lib/wsdl/xmlSchema/whitespace.rb +38 -0
  143. data/lib/wsdl/xmlSchema/xsd2ruby.rb +177 -0
  144. data/lib/xsd/charset.rb +190 -0
  145. data/lib/xsd/codegen/classdef.rb +230 -0
  146. data/lib/xsd/codegen/commentdef.rb +35 -0
  147. data/lib/xsd/codegen/gensupport.rb +277 -0
  148. data/lib/xsd/codegen/methoddef.rb +71 -0
  149. data/lib/xsd/codegen/moduledef.rb +209 -0
  150. data/lib/xsd/codegen.rb +13 -0
  151. data/lib/xsd/datatypes.rb +1465 -0
  152. data/lib/xsd/datatypes1999.rb +21 -0
  153. data/lib/xsd/iconvcharset.rb +33 -0
  154. data/lib/xsd/mapping.rb +69 -0
  155. data/lib/xsd/namedelements.rb +133 -0
  156. data/lib/xsd/ns.rb +183 -0
  157. data/lib/xsd/qname.rb +80 -0
  158. data/lib/xsd/xmlparser/libxmlparser.rb +136 -0
  159. data/lib/xsd/xmlparser/nokogiriparser.rb +63 -0
  160. data/lib/xsd/xmlparser/ogaparser.rb +53 -0
  161. data/lib/xsd/xmlparser/oxparser.rb +97 -0
  162. data/lib/xsd/xmlparser/parser.rb +101 -0
  163. data/lib/xsd/xmlparser/rexmlparser.rb +54 -0
  164. data/lib/xsd/xmlparser.rb +81 -0
  165. metadata +240 -0
@@ -0,0 +1,107 @@
1
+ # encoding: UTF-8
2
+ # SOAP4R - Base type mapping definition
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
+
12
+
13
+ TypeMap = {
14
+ XSD::XSDAnySimpleType::Type => SOAPAnySimpleType,
15
+
16
+ XSD::XSDString::Type => SOAPString,
17
+ XSD::XSDNormalizedString::Type => SOAPNormalizedString,
18
+ XSD::XSDToken::Type => SOAPToken,
19
+ XSD::XSDLanguage::Type => SOAPLanguage,
20
+ XSD::XSDNMTOKEN::Type => SOAPNMTOKEN,
21
+ XSD::XSDNMTOKENS::Type => SOAPNMTOKENS,
22
+ XSD::XSDName::Type => SOAPName,
23
+ XSD::XSDNCName::Type => SOAPNCName,
24
+ XSD::XSDID::Type => SOAPID,
25
+ XSD::XSDIDREF::Type => SOAPIDREF,
26
+ XSD::XSDIDREFS::Type => SOAPIDREFS,
27
+ XSD::XSDENTITY::Type => SOAPENTITY,
28
+ XSD::XSDENTITIES::Type => SOAPENTITIES,
29
+ XSD::XSDBoolean::Type => SOAPBoolean,
30
+ XSD::XSDDecimal::Type => SOAPDecimal,
31
+ XSD::XSDFloat::Type => SOAPFloat,
32
+ XSD::XSDDouble::Type => SOAPDouble,
33
+ XSD::XSDDuration::Type => SOAPDuration,
34
+ XSD::XSDDateTime::Type => SOAPDateTime,
35
+ XSD::XSDTime::Type => SOAPTime,
36
+ XSD::XSDDate::Type => SOAPDate,
37
+ XSD::XSDGYearMonth::Type => SOAPGYearMonth,
38
+ XSD::XSDGYear::Type => SOAPGYear,
39
+ XSD::XSDGMonthDay::Type => SOAPGMonthDay,
40
+ XSD::XSDGDay::Type => SOAPGDay,
41
+ XSD::XSDGMonth::Type => SOAPGMonth,
42
+ XSD::XSDHexBinary::Type => SOAPHexBinary,
43
+ XSD::XSDBase64Binary::Type => SOAPBase64,
44
+ XSD::XSDAnyURI::Type => SOAPAnyURI,
45
+ XSD::XSDQName::Type => SOAPQName,
46
+ XSD::XSDInteger::Type => SOAPInteger,
47
+ XSD::XSDNonPositiveInteger::Type => SOAPNonPositiveInteger,
48
+ XSD::XSDNegativeInteger::Type => SOAPNegativeInteger,
49
+ XSD::XSDLong::Type => SOAPLong,
50
+ XSD::XSDInt::Type => SOAPInt,
51
+ XSD::XSDShort::Type => SOAPShort,
52
+ XSD::XSDByte::Type => SOAPByte,
53
+ XSD::XSDNonNegativeInteger::Type => SOAPNonNegativeInteger,
54
+ XSD::XSDUnsignedLong::Type => SOAPUnsignedLong,
55
+ XSD::XSDUnsignedInt::Type => SOAPUnsignedInt,
56
+ XSD::XSDUnsignedShort::Type => SOAPUnsignedShort,
57
+ XSD::XSDUnsignedByte::Type => SOAPUnsignedByte,
58
+ XSD::XSDPositiveInteger::Type => SOAPPositiveInteger,
59
+
60
+ # soap4r does not use soapenc types actively but it should be accepted.
61
+ SOAP::SOAPString::SOAPENCType => SOAPString,
62
+ SOAP::SOAPNormalizedString::Type => SOAPNormalizedString,
63
+ SOAP::SOAPToken::Type => SOAPToken,
64
+ SOAP::SOAPLanguage::Type => SOAPLanguage,
65
+ SOAP::SOAPNMTOKEN::Type => SOAPNMTOKEN,
66
+ SOAP::SOAPNMTOKENS::Type => SOAPNMTOKENS,
67
+ SOAP::SOAPName::Type => SOAPName,
68
+ SOAP::SOAPNCName::Type => SOAPNCName,
69
+ SOAP::SOAPID::Type => SOAPID,
70
+ SOAP::SOAPIDREF::Type => SOAPIDREF,
71
+ SOAP::SOAPIDREFS::Type => SOAPIDREFS,
72
+ SOAP::SOAPENTITY::Type => SOAPENTITY,
73
+ SOAP::SOAPENTITIES::Type => SOAPENTITIES,
74
+ SOAP::SOAPBoolean::SOAPENCType => SOAPBoolean,
75
+ SOAP::SOAPDecimal::SOAPENCType => SOAPDecimal,
76
+ SOAP::SOAPFloat::SOAPENCType => SOAPFloat,
77
+ SOAP::SOAPDouble::SOAPENCType => SOAPDouble,
78
+ SOAP::SOAPDuration::SOAPENCType => SOAPDuration,
79
+ SOAP::SOAPDateTime::SOAPENCType => SOAPDateTime,
80
+ SOAP::SOAPTime::SOAPENCType => SOAPTime,
81
+ SOAP::SOAPDate::SOAPENCType => SOAPDate,
82
+ SOAP::SOAPGYearMonth::SOAPENCType => SOAPGYearMonth,
83
+ SOAP::SOAPGYear::SOAPENCType => SOAPGYear,
84
+ SOAP::SOAPGMonthDay::SOAPENCType => SOAPGMonthDay,
85
+ SOAP::SOAPGDay::SOAPENCType => SOAPGDay,
86
+ SOAP::SOAPGMonth::SOAPENCType => SOAPGMonth,
87
+ SOAP::SOAPHexBinary::SOAPENCType => SOAPHexBinary,
88
+ SOAP::SOAPBase64::SOAPENCType => SOAPBase64,
89
+ SOAP::SOAPAnyURI::SOAPENCType => SOAPAnyURI,
90
+ SOAP::SOAPQName::SOAPENCType => SOAPQName,
91
+ SOAP::SOAPInteger::SOAPENCType => SOAPInteger,
92
+ SOAP::SOAPNonPositiveInteger::SOAPENCType => SOAPNonPositiveInteger,
93
+ SOAP::SOAPNegativeInteger::SOAPENCType => SOAPNegativeInteger,
94
+ SOAP::SOAPLong::SOAPENCType => SOAPLong,
95
+ SOAP::SOAPInt::SOAPENCType => SOAPInt,
96
+ SOAP::SOAPShort::SOAPENCType => SOAPShort,
97
+ SOAP::SOAPByte::SOAPENCType => SOAPByte,
98
+ SOAP::SOAPNonNegativeInteger::SOAPENCType => SOAPNonNegativeInteger,
99
+ SOAP::SOAPUnsignedLong::SOAPENCType => SOAPUnsignedLong,
100
+ SOAP::SOAPUnsignedInt::SOAPENCType => SOAPUnsignedInt,
101
+ SOAP::SOAPUnsignedShort::SOAPENCType => SOAPUnsignedShort,
102
+ SOAP::SOAPUnsignedByte::SOAPENCType => SOAPUnsignedByte,
103
+ SOAP::SOAPPositiveInteger::SOAPENCType => SOAPPositiveInteger,
104
+ }
105
+
106
+
107
+ end
@@ -0,0 +1,212 @@
1
+ # encoding: UTF-8
2
+ # SOAP4R - WSDL encoded mapping registry.
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/qname'
11
+ require 'xsd/namedelements'
12
+ require 'soap/baseData'
13
+ require 'soap/mapping/mapping'
14
+ require 'soap/mapping/typeMap'
15
+
16
+
17
+ module SOAP
18
+ module Mapping
19
+
20
+
21
+ class WSDLEncodedRegistry < EncodedRegistry
22
+ attr_reader :definedelements
23
+ attr_reader :definedtypes
24
+
25
+ def initialize(definedtypes = XSD::NamedElements::Empty)
26
+ super()
27
+ @definedtypes = definedtypes
28
+ # @definedelements = definedelements needed?
29
+ # For mapping AnyType element.
30
+ @rubytype_factory = RubytypeFactory.new(
31
+ :allow_untyped_struct => true,
32
+ :allow_original_mapping => true
33
+ )
34
+ end
35
+
36
+ def obj2soap(obj, qname = nil)
37
+ soap_obj = nil
38
+ if type = @definedtypes[qname]
39
+ soap_obj = obj2typesoap(obj, type)
40
+ else
41
+ soap_obj = any2soap(obj, qname)
42
+ end
43
+ return soap_obj if soap_obj
44
+ if @excn_handler_obj2soap
45
+ soap_obj = @excn_handler_obj2soap.call(obj) { |yield_obj|
46
+ Mapping._obj2soap(yield_obj, self)
47
+ }
48
+ return soap_obj if soap_obj
49
+ end
50
+ if qname
51
+ raise MappingError.new("cannot map #{obj.class.name} as #{qname}")
52
+ else
53
+ raise MappingError.new("cannot map #{obj.class.name} to SOAP/OM")
54
+ end
55
+ end
56
+
57
+ # map anything for now: must refer WSDL while mapping. [ToDo]
58
+ def soap2obj(node, obj_class = nil)
59
+ cause = nil
60
+ begin
61
+ unless obj_class
62
+ typestr = Mapping.safeconstname(node.elename.name)
63
+ obj_class = Mapping.class_from_name(typestr)
64
+ end
65
+ return Mapping._soap2obj(node, Mapping::DefaultRegistry, obj_class)
66
+ rescue MappingError
67
+ cause = $!
68
+ end
69
+ if @excn_handler_soap2obj
70
+ begin
71
+ return @excn_handler_soap2obj.call(node) { |yield_node|
72
+ Mapping._soap2obj(yield_node, self)
73
+ }
74
+ rescue Exception
75
+ end
76
+ end
77
+ raise MappingError.new("cannot map #{node.type.name} to Ruby object", cause)
78
+ end
79
+
80
+ private
81
+
82
+ def any2soap(obj, qname)
83
+ ele = nil
84
+ if obj.nil?
85
+ ele = SOAPNil.new
86
+ elsif qname.nil? or qname == XSD::AnyTypeName
87
+ ele = @rubytype_factory.obj2soap(nil, obj, nil, self)
88
+ elsif obj.is_a?(XSD::NSDBase)
89
+ ele = soap2soap(obj, qname)
90
+ elsif type = TypeMap[qname]
91
+ ele = base2soap(obj, type)
92
+ end
93
+ add_attributes2soap(obj, ele) unless ele.nil?
94
+ ele
95
+ end
96
+
97
+ def soap2soap(obj, type_qname)
98
+ if obj.is_a?(SOAPBasetype)
99
+ obj
100
+ elsif obj.is_a?(SOAPStruct) && (type = @definedtypes[type_qname])
101
+ soap_obj = obj
102
+ mark_marshalled_obj(obj, soap_obj)
103
+ elements2soap(obj, soap_obj, type.elements)
104
+ soap_obj
105
+ elsif obj.is_a?(SOAPArray) && (type = @definedtypes[type_qname])
106
+ soap_obj = obj
107
+ contenttype = type.child_type
108
+ mark_marshalled_obj(obj, soap_obj)
109
+ obj.replace do |ele|
110
+ Mapping._obj2soap(ele, self, contenttype)
111
+ end
112
+ soap_obj
113
+ else
114
+ nil
115
+ end
116
+ end
117
+
118
+ def obj2typesoap(obj, type)
119
+ if type.is_a?(::WSDL::XMLSchema::SimpleType)
120
+ simpleobj2soap(obj, type)
121
+ else
122
+ complexobj2soap(obj, type)
123
+ end
124
+ end
125
+
126
+ def simpleobj2soap(obj, type)
127
+ type.check_lexical_format(obj)
128
+ return SOAPNil.new if obj.nil? # TODO: check nillable.
129
+ if type.base
130
+ ele = base2soap(obj, TypeMap[type.base])
131
+ ele.type = type.name
132
+ elsif type.list
133
+ value = obj.is_a?(Array) ? obj.join(" ") : obj.to_s
134
+ ele = base2soap(value, SOAP::SOAPString)
135
+ else
136
+ raise MappingError.new("unsupported simpleType: #{type}")
137
+ end
138
+ ele
139
+ end
140
+
141
+ def complexobj2soap(obj, type)
142
+ case type.compoundtype
143
+ when :TYPE_STRUCT
144
+ struct2soap(obj, type.name, type)
145
+ when :TYPE_ARRAY
146
+ array2soap(obj, type.name, type)
147
+ when :TYPE_MAP
148
+ map2soap(obj, type.name, type)
149
+ when :TYPE_SIMPLE
150
+ simpleobj2soap(obj, type.simplecontent)
151
+ when :TYPE_EMPTY
152
+ raise MappingError.new("should be empty") unless obj.nil?
153
+ SOAPNil.new
154
+ else
155
+ raise MappingError.new("unknown compound type: #{type.compoundtype}")
156
+ end
157
+ end
158
+
159
+ def struct2soap(obj, type_qname, type)
160
+ return SOAPNil.new if obj.nil? # ToDo: check nillable.
161
+ soap_obj = SOAPStruct.new(type_qname)
162
+ mark_marshalled_obj(obj, soap_obj)
163
+ elements2soap(obj, soap_obj, type.elements)
164
+ soap_obj
165
+ end
166
+
167
+ def array2soap(obj, type_qname, type)
168
+ return SOAPNil.new if obj.nil? # ToDo: check nillable.
169
+ arytype = type.child_type
170
+ soap_obj = SOAPArray.new(ValueArrayName, 1, arytype)
171
+ unless obj.nil?
172
+ mark_marshalled_obj(obj, soap_obj)
173
+ obj.each do |item|
174
+ soap_obj.add(Mapping._obj2soap(item, self, arytype))
175
+ end
176
+ end
177
+ soap_obj
178
+ end
179
+
180
+ MapKeyName = XSD::QName.new(nil, "key")
181
+ MapValueName = XSD::QName.new(nil, "value")
182
+ def map2soap(obj, type_qname, type)
183
+ return SOAPNil.new if obj.nil? # ToDo: check nillable.
184
+ keytype = type.child_type(MapKeyName) || XSD::AnyTypeName
185
+ valuetype = type.child_type(MapValueName) || XSD::AnyTypeName
186
+ soap_obj = SOAPStruct.new(MapQName)
187
+ unless obj.nil?
188
+ mark_marshalled_obj(obj, soap_obj)
189
+ obj.each do |key, value|
190
+ elem = SOAPStruct.new
191
+ elem.add("key", Mapping._obj2soap(key, self, keytype))
192
+ elem.add("value", Mapping._obj2soap(value, self, valuetype))
193
+ # ApacheAxis allows only 'item' here.
194
+ soap_obj.add("item", elem)
195
+ end
196
+ end
197
+ soap_obj
198
+ end
199
+
200
+ def elements2soap(obj, soap_obj, elements)
201
+ elements.each do |element|
202
+ name = element.name.name
203
+ child_obj = Mapping.get_attribute(obj, name)
204
+ soap_obj.add(name,
205
+ Mapping._obj2soap(child_obj, self, element.type || element.name))
206
+ end
207
+ end
208
+ end
209
+
210
+
211
+ end
212
+ end
@@ -0,0 +1,249 @@
1
+ # encoding: UTF-8
2
+ # SOAP4R - WSDL literal mapping registry.
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/baseData'
11
+ require 'soap/mapping/mapping'
12
+ require 'soap/mapping/literalregistry'
13
+ require 'soap/mapping/typeMap'
14
+ require 'xsd/codegen/gensupport'
15
+ require 'xsd/namedelements'
16
+
17
+
18
+ module SOAP
19
+ module Mapping
20
+
21
+
22
+ class WSDLLiteralRegistry < LiteralRegistry
23
+ attr_reader :definedelements
24
+ attr_reader :definedtypes
25
+
26
+ def initialize(definedtypes = XSD::NamedElements::Empty,
27
+ definedelements = XSD::NamedElements::Empty)
28
+ super()
29
+ @definedtypes = definedtypes
30
+ @definedelements = definedelements
31
+ end
32
+
33
+ def obj2soap(obj, qname, obj_class = nil)
34
+ soap_obj = nil
35
+ if obj.is_a?(SOAPElement)
36
+ soap_obj = obj
37
+ elsif eledef = @definedelements[qname]
38
+ soap_obj = obj2elesoap(obj, eledef)
39
+ elsif type = @definedtypes[qname]
40
+ soap_obj = obj2typesoap(obj, type)
41
+ else
42
+ soap_obj = any2soap(obj, qname, obj_class)
43
+ end
44
+ return soap_obj if soap_obj
45
+ if @excn_handler_obj2soap
46
+ soap_obj = @excn_handler_obj2soap.call(obj) { |yield_obj|
47
+ Mapping.obj2soap(yield_obj, nil, nil, MAPPING_OPT)
48
+ }
49
+ return soap_obj if soap_obj
50
+ end
51
+ raise MappingError.new("cannot map #{obj.class.name} as #{qname}")
52
+ end
53
+
54
+ # node should be a SOAPElement
55
+ def soap2obj(node, obj_class = nil)
56
+ cause = nil
57
+ begin
58
+ return any2obj(node, obj_class)
59
+ rescue MappingError
60
+ cause = $!
61
+ end
62
+ if @excn_handler_soap2obj
63
+ begin
64
+ return @excn_handler_soap2obj.call(node) { |yield_node|
65
+ Mapping.soap2obj(yield_node, nil, nil, MAPPING_OPT)
66
+ }
67
+ rescue Exception
68
+ end
69
+ end
70
+ if node.respond_to?(:type)
71
+ raise MappingError.new("cannot map #{node.type.name} to Ruby object", cause)
72
+ else
73
+ raise MappingError.new("cannot map #{node.elename.name} to Ruby object", cause)
74
+ end
75
+ end
76
+
77
+ private
78
+
79
+ def obj2elesoap(obj, eledef)
80
+ ele = nil
81
+ qualified = (eledef.elementform == 'qualified')
82
+ if obj.is_a?(SOAPNil)
83
+ ele = obj
84
+ elsif eledef.type
85
+ if type = @definedtypes[eledef.type]
86
+ ele = obj2typesoap(obj, type)
87
+ elsif type = TypeMap[eledef.type]
88
+ ele = base2soap(obj, type)
89
+ else
90
+ raise MappingError.new("cannot find type #{eledef.type}")
91
+ end
92
+ elsif eledef.local_complextype
93
+ ele = obj2typesoap(obj, eledef.local_complextype)
94
+ elsif eledef.local_simpletype
95
+ ele = obj2typesoap(obj, eledef.local_simpletype)
96
+ else
97
+ raise MappingError.new('illegal schema?')
98
+ end
99
+ ele.elename = eledef.name
100
+ ele.qualified = qualified
101
+ ele
102
+ end
103
+
104
+ def obj2typesoap(obj, type)
105
+ ele = nil
106
+ if type.is_a?(::WSDL::XMLSchema::SimpleType)
107
+ ele = simpleobj2soap(obj, type)
108
+ else # complexType
109
+ if type.simplecontent
110
+ ele = simpleobj2soap(obj, type.simplecontent)
111
+ else
112
+ ele = complexobj2soap(obj, type)
113
+ end
114
+ ele.type = type.name
115
+ if type.base or Mapping.root_type_hint
116
+ Mapping.reset_root_type_hint
117
+ ele.force_typed = true
118
+ end
119
+ add_definedattributes2soap(obj, ele, type)
120
+ end
121
+ ele
122
+ end
123
+
124
+ def simpleobj2soap(obj, type)
125
+ type.check_lexical_format(obj)
126
+ return SOAPNil.new if obj.nil?
127
+ if type.base
128
+ ele = base2soap(obj, TypeMap[type.base])
129
+ elsif type.list
130
+ value = obj.is_a?(Array) ? obj.join(" ") : obj.to_s
131
+ ele = base2soap(value, SOAP::SOAPString)
132
+ else
133
+ raise MappingError.new("unsupported simpleType: #{type}")
134
+ end
135
+ ele
136
+ end
137
+
138
+ def complexobj2soap(obj, type)
139
+ ele = SOAPElement.new(type.name)
140
+ complexobj2sequencesoap(obj, ele, type, type.choice?, type.choice?)
141
+ ele
142
+ end
143
+
144
+ def complexobj2sequencesoap(obj, soap, type, nillable, is_choice)
145
+ added = false
146
+ type.elements.each do |child_ele|
147
+ case child_ele
148
+ when WSDL::XMLSchema::Any
149
+ any = Mapping.get_attributes_for_any(obj)
150
+ SOAPElement.from_objs(any).each do |child|
151
+ soap.add(child)
152
+ end
153
+ ele_added = true
154
+ when WSDL::XMLSchema::Element
155
+ ele_added = complexobj2soapchildren(obj, soap, child_ele, nillable)
156
+ when WSDL::XMLSchema::Sequence
157
+ ele_added = complexobj2sequencesoap(obj, soap, child_ele, nillable, false)
158
+ when WSDL::XMLSchema::Choice
159
+ ele_added = complexobj2sequencesoap(obj, soap, child_ele, true, true)
160
+ else
161
+ raise MappingError.new("unknown type: #{child_ele}")
162
+ end
163
+ added = true if ele_added
164
+ break if is_choice and ele_added
165
+ end
166
+ added
167
+ end
168
+
169
+ def complexobj2soapchildren(obj, soap, child_ele, nillable = false)
170
+ if child_ele.map_as_array?
171
+ complexobj2soapchildren_array(obj, soap, child_ele, nillable)
172
+ else
173
+ complexobj2soapchildren_single(obj, soap, child_ele, nillable)
174
+ end
175
+ end
176
+
177
+ def complexobj2soapchildren_array(obj, soap, child_ele, nillable)
178
+ child = Mapping.get_attribute(obj, child_ele.name.name)
179
+ if child.nil? and obj.is_a?(::Array)
180
+ child = obj
181
+ end
182
+ if child.nil?
183
+ return false if nillable
184
+ if child_soap = nil2soap(child_ele)
185
+ soap.add(child_soap)
186
+ return true
187
+ else
188
+ return false
189
+ end
190
+ end
191
+ unless child.respond_to?(:each)
192
+ return false
193
+ end
194
+ child.each do |item|
195
+ if item.is_a?(SOAPElement)
196
+ soap.add(item)
197
+ else
198
+ child_soap = obj2elesoap(item, child_ele)
199
+ soap.add(child_soap)
200
+ end
201
+ end
202
+ true
203
+ end
204
+
205
+ def complexobj2soapchildren_single(obj, soap, child_ele, nillable)
206
+ child = Mapping.get_attribute(obj, child_ele.name.name)
207
+ case child
208
+ when NilClass
209
+ return false if nillable
210
+ if child_soap = nil2soap(child_ele)
211
+ soap.add(child_soap)
212
+ true
213
+ else
214
+ false
215
+ end
216
+ when SOAPElement
217
+ soap.add(child)
218
+ true
219
+ else
220
+ child_soap = obj2elesoap(child, child_ele)
221
+ soap.add(child_soap)
222
+ true
223
+ end
224
+ end
225
+
226
+ def nil2soap(ele)
227
+ if ele.nillable
228
+ obj2elesoap(nil, ele) # add an empty element
229
+ elsif ele.minoccurs == 0
230
+ nil # intends no element
231
+ else
232
+ warn("nil not allowed: #{ele.name.name}")
233
+ nil
234
+ end
235
+ end
236
+
237
+ def add_definedattributes2soap(obj, ele, typedef)
238
+ if typedef.attributes
239
+ typedef.attributes.each do |at|
240
+ value = get_xmlattr_value(obj, at.name)
241
+ ele.extraattr[at.name] = value unless value.nil?
242
+ end
243
+ end
244
+ end
245
+ end
246
+
247
+
248
+ end
249
+ end
@@ -0,0 +1,13 @@
1
+ # encoding: UTF-8
2
+ # SOAP4R - Ruby type mapping 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 'soap/mapping/mapping'
11
+ require 'soap/mapping/registry'
12
+ require 'soap/mapping/encodedregistry'
13
+ require 'soap/mapping/literalregistry'
@@ -0,0 +1,60 @@
1
+ # encoding: UTF-8
2
+ # SOAP4R - Marshalling/Unmarshalling Ruby's object using SOAP Encoding.
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/mapping"
11
+ require "soap/processor"
12
+
13
+
14
+ module SOAP
15
+
16
+
17
+ module Marshal
18
+ # Trying xsd:dateTime data to be recovered as aTime.
19
+ MarshalMappingRegistry = Mapping::EncodedRegistry.new(
20
+ :allow_original_mapping => true)
21
+ MarshalMappingRegistry.add(
22
+ Time,
23
+ ::SOAP::SOAPDateTime,
24
+ ::SOAP::Mapping::EncodedRegistry::DateTimeFactory
25
+ )
26
+
27
+ class << self
28
+ public
29
+ def dump(obj, io = nil)
30
+ marshal(obj, MarshalMappingRegistry, io)
31
+ end
32
+
33
+ def load(stream)
34
+ unmarshal(stream, MarshalMappingRegistry)
35
+ end
36
+
37
+ def marshal(obj, mapping_registry = MarshalMappingRegistry, io = nil)
38
+ elename = Mapping.name2elename(obj.class.to_s)
39
+ soap_obj = Mapping.obj2soap(obj, mapping_registry)
40
+ body = SOAPBody.new
41
+ body.add(elename, soap_obj)
42
+ env = SOAPEnvelope.new(nil, body)
43
+ SOAP::Processor.marshal(env, {}, io)
44
+ end
45
+
46
+ def unmarshal(stream, mapping_registry = MarshalMappingRegistry)
47
+ env = SOAP::Processor.unmarshal(stream)
48
+ if env.nil?
49
+ raise ArgumentError.new("Illegal SOAP marshal format.")
50
+ end
51
+ Mapping.soap2obj(env.body.root_node, mapping_registry)
52
+ end
53
+ end
54
+ end
55
+
56
+
57
+ end
58
+
59
+
60
+ SOAPMarshal = SOAP::Marshal