From ab31bf0d4d44942e46d98d8848b788ac6df32a46 Mon Sep 17 00:00:00 2001 From: nahi Date: Sat, 3 Jul 2004 15:29:32 +0000 Subject: * added files * lib/soap/attachment.rb * lib/soap/header * lib/soap/mimemessage.rb * lib/soap/rpc/httpserver.rb * lib/wsdl/soap/cgiStubCreator.rb * lib/wsdl/soap/classDefCreator.rb * lib/wsdl/soap/classDefCreatorSupport.rb * lib/wsdl/soap/clientSkeltonCreator.rb * lib/wsdl/soap/driverCreator.rb * lib/wsdl/soap/mappingRegistryCreator.rb * lib/wsdl/soap/methodDefCreator.rb * lib/wsdl/soap/servantSkeltonCreator.rb * lib/wsdl/soap/standaloneServerStubCreator.rb * lib/wsdl/xmlSchema/enumeration.rb * lib/wsdl/xmlSchema/simpleRestriction.rb * lib/wsdl/xmlSchema/simpleType.rb * lib/xsd/codegen * lib/xsd/codegen.rb * sample/soap/authheader * sample/soap/raa2.4 * sample/soap/ssl * sample/soap/swa * sample/soap/whois.rb * sample/soap/calc/samplehttpd.conf * sample/soap/exchange/samplehttpd.conf * sample/soap/sampleStruct/samplehttpd.conf * sample/wsdl/raa2.4 * sample/wsdl/googleSearch/samplehttpd.conf * test/openssl/_test_ssl.rb * test/soap/header * test/soap/ssl * test/soap/struct * test/soap/swa * test/soap/wsdlDriver * test/wsdl/multiplefault.wsdl * test/wsdl/simpletype * test/wsdl/test_multiplefault.rb * modified files * lib/soap/baseData.rb * lib/soap/element.rb * lib/soap/generator.rb * lib/soap/marshal.rb * lib/soap/netHttpClient.rb * lib/soap/parser.rb * lib/soap/processor.rb * lib/soap/property.rb * lib/soap/soap.rb * lib/soap/streamHandler.rb * lib/soap/wsdlDriver.rb * lib/soap/encodingstyle/handler.rb * lib/soap/encodingstyle/literalHandler.rb * lib/soap/encodingstyle/soapHandler.rb * lib/soap/mapping/factory.rb * lib/soap/mapping/mapping.rb * lib/soap/mapping/registry.rb * lib/soap/mapping/rubytypeFactory.rb * lib/soap/mapping/wsdlRegistry.rb * lib/soap/rpc/cgistub.rb * lib/soap/rpc/driver.rb * lib/soap/rpc/element.rb * lib/soap/rpc/proxy.rb * lib/soap/rpc/router.rb * lib/soap/rpc/soaplet.rb * lib/soap/rpc/standaloneServer.rb * lib/wsdl/data.rb * lib/wsdl/definitions.rb * lib/wsdl/operation.rb * lib/wsdl/parser.rb * lib/wsdl/soap/definitions.rb * lib/wsdl/xmlSchema/complexContent.rb * lib/wsdl/xmlSchema/complexType.rb * lib/wsdl/xmlSchema/data.rb * lib/wsdl/xmlSchema/parser.rb * lib/wsdl/xmlSchema/schema.rb * lib/xsd/datatypes.rb * lib/xsd/qname.rb * sample/soap/calc/httpd.rb * sample/soap/exchange/httpd.rb * sample/soap/sampleStruct/httpd.rb * sample/soap/sampleStruct/server.rb * sample/wsdl/amazon/AmazonSearch.rb * sample/wsdl/amazon/AmazonSearchDriver.rb * sample/wsdl/googleSearch/httpd.rb * test/soap/test_basetype.rb * test/soap/test_property.rb * test/soap/test_streamhandler.rb * test/soap/calc/test_calc.rb * test/soap/calc/test_calc2.rb * test/soap/calc/test_calc_cgi.rb * test/soap/helloworld/test_helloworld.rb * test/wsdl/test_emptycomplextype.rb * test/wsdl/axisArray/test_axisarray.rb * test/wsdl/datetime/test_datetime.rb * test/wsdl/raa/test_raa.rb * test/xsd/test_xmlschemaparser.rb * test/xsd/test_xsd.rb * summary * add SOAP Header mustUnderstand support. * add HTTP client SSL configuration and Cookies support (works completely with http-access2). * add header handler for handling sending/receiving SOAP Header. * map Ruby's anonymous Struct to common SOAP Struct in SOAP Object Model. it caused error. * add WSDL simpleType support to restrict lexical value space. * add SOAP with Attachment support. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@6567 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 116 ++ lib/soap/baseData.rb | 168 +- lib/soap/element.rb | 70 +- lib/soap/encodingstyle/handler.rb | 4 +- lib/soap/encodingstyle/literalHandler.rb | 50 +- lib/soap/encodingstyle/soapHandler.rb | 93 +- lib/soap/generator.rb | 15 +- lib/soap/mapping/factory.rb | 1 + lib/soap/mapping/mapping.rb | 24 +- lib/soap/mapping/registry.rb | 99 +- lib/soap/mapping/rubytypeFactory.rb | 73 +- lib/soap/mapping/wsdlRegistry.rb | 48 +- lib/soap/marshal.rb | 9 +- lib/soap/netHttpClient.rb | 14 +- lib/soap/parser.rb | 15 +- lib/soap/processor.rb | 16 +- lib/soap/property.rb | 88 +- lib/soap/rpc/cgistub.rb | 52 +- lib/soap/rpc/driver.rb | 57 +- lib/soap/rpc/element.rb | 5 +- lib/soap/rpc/proxy.rb | 56 +- lib/soap/rpc/router.rb | 110 +- lib/soap/rpc/soaplet.rb | 108 +- lib/soap/rpc/standaloneServer.rb | 102 +- lib/soap/soap.rb | 5 +- lib/soap/streamHandler.rb | 116 +- lib/soap/wsdlDriver.rb | 182 +- lib/wsdl/data.rb | 1 + lib/wsdl/definitions.rb | 21 +- lib/wsdl/operation.rb | 2 +- lib/wsdl/parser.rb | 3 +- lib/wsdl/soap/definitions.rb | 28 + lib/wsdl/xmlSchema/complexContent.rb | 4 + lib/wsdl/xmlSchema/complexType.rb | 22 +- lib/wsdl/xmlSchema/data.rb | 7 +- lib/wsdl/xmlSchema/parser.rb | 3 +- lib/wsdl/xmlSchema/schema.rb | 13 +- lib/xsd/datatypes.rb | 296 ++-- lib/xsd/qname.rb | 9 +- sample/soap/calc/httpd.rb | 13 +- sample/soap/exchange/httpd.rb | 13 +- sample/soap/sampleStruct/httpd.rb | 13 +- sample/soap/sampleStruct/server.rb | 6 +- sample/wsdl/amazon/AmazonSearch.rb | 2708 ++++++------------------------ sample/wsdl/amazon/AmazonSearchDriver.rb | 345 ++-- sample/wsdl/googleSearch/httpd.rb | 13 +- test/soap/calc/test_calc.rb | 4 - test/soap/calc/test_calc2.rb | 5 +- test/soap/calc/test_calc_cgi.rb | 1 + test/soap/helloworld/test_helloworld.rb | 4 - test/soap/test_basetype.rb | 40 +- test/soap/test_property.rb | 70 +- test/soap/test_streamhandler.rb | 13 +- test/wsdl/axisArray/test_axisarray.rb | 5 +- test/wsdl/datetime/test_datetime.rb | 4 +- test/wsdl/raa/test_raa.rb | 8 +- test/wsdl/test_emptycomplextype.rb | 4 +- test/xsd/test_xmlschemaparser.rb | 2 +- test/xsd/test_xsd.rb | 40 +- version.h | 6 +- 60 files changed, 2257 insertions(+), 3165 deletions(-) diff --git a/ChangeLog b/ChangeLog index c354758f3d..f5d65fff10 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,119 @@ +Sun Jul 4 00:24:40 2004 NAKAMURA, Hiroshi + + * added files + * lib/soap/attachment.rb + * lib/soap/header + * lib/soap/mimemessage.rb + * lib/soap/rpc/httpserver.rb + * lib/wsdl/soap/cgiStubCreator.rb + * lib/wsdl/soap/classDefCreator.rb + * lib/wsdl/soap/classDefCreatorSupport.rb + * lib/wsdl/soap/clientSkeltonCreator.rb + * lib/wsdl/soap/driverCreator.rb + * lib/wsdl/soap/mappingRegistryCreator.rb + * lib/wsdl/soap/methodDefCreator.rb + * lib/wsdl/soap/servantSkeltonCreator.rb + * lib/wsdl/soap/standaloneServerStubCreator.rb + * lib/wsdl/xmlSchema/enumeration.rb + * lib/wsdl/xmlSchema/simpleRestriction.rb + * lib/wsdl/xmlSchema/simpleType.rb + * lib/xsd/codegen + * lib/xsd/codegen.rb + * sample/soap/authheader + * sample/soap/raa2.4 + * sample/soap/ssl + * sample/soap/swa + * sample/soap/whois.rb + * sample/soap/calc/samplehttpd.conf + * sample/soap/exchange/samplehttpd.conf + * sample/soap/sampleStruct/samplehttpd.conf + * sample/wsdl/raa2.4 + * sample/wsdl/googleSearch/samplehttpd.conf + * test/openssl/_test_ssl.rb + * test/soap/header + * test/soap/ssl + * test/soap/struct + * test/soap/swa + * test/soap/wsdlDriver + * test/wsdl/multiplefault.wsdl + * test/wsdl/simpletype + * test/wsdl/test_multiplefault.rb + + * modified files + * lib/soap/baseData.rb + * lib/soap/element.rb + * lib/soap/generator.rb + * lib/soap/marshal.rb + * lib/soap/netHttpClient.rb + * lib/soap/parser.rb + * lib/soap/processor.rb + * lib/soap/property.rb + * lib/soap/soap.rb + * lib/soap/streamHandler.rb + * lib/soap/wsdlDriver.rb + * lib/soap/encodingstyle/handler.rb + * lib/soap/encodingstyle/literalHandler.rb + * lib/soap/encodingstyle/soapHandler.rb + * lib/soap/mapping/factory.rb + * lib/soap/mapping/mapping.rb + * lib/soap/mapping/registry.rb + * lib/soap/mapping/rubytypeFactory.rb + * lib/soap/mapping/wsdlRegistry.rb + * lib/soap/rpc/cgistub.rb + * lib/soap/rpc/driver.rb + * lib/soap/rpc/element.rb + * lib/soap/rpc/proxy.rb + * lib/soap/rpc/router.rb + * lib/soap/rpc/soaplet.rb + * lib/soap/rpc/standaloneServer.rb + * lib/wsdl/data.rb + * lib/wsdl/definitions.rb + * lib/wsdl/operation.rb + * lib/wsdl/parser.rb + * lib/wsdl/soap/definitions.rb + * lib/wsdl/xmlSchema/complexContent.rb + * lib/wsdl/xmlSchema/complexType.rb + * lib/wsdl/xmlSchema/data.rb + * lib/wsdl/xmlSchema/parser.rb + * lib/wsdl/xmlSchema/schema.rb + * lib/xsd/datatypes.rb + * lib/xsd/qname.rb + * sample/soap/calc/httpd.rb + * sample/soap/exchange/httpd.rb + * sample/soap/sampleStruct/httpd.rb + * sample/soap/sampleStruct/server.rb + * sample/wsdl/amazon/AmazonSearch.rb + * sample/wsdl/amazon/AmazonSearchDriver.rb + * sample/wsdl/googleSearch/httpd.rb + * test/soap/test_basetype.rb + * test/soap/test_property.rb + * test/soap/test_streamhandler.rb + * test/soap/calc/test_calc.rb + * test/soap/calc/test_calc2.rb + * test/soap/calc/test_calc_cgi.rb + * test/soap/helloworld/test_helloworld.rb + * test/wsdl/test_emptycomplextype.rb + * test/wsdl/axisArray/test_axisarray.rb + * test/wsdl/datetime/test_datetime.rb + * test/wsdl/raa/test_raa.rb + * test/xsd/test_xmlschemaparser.rb + * test/xsd/test_xsd.rb + + * summary + * add SOAP Header mustUnderstand support. + + * add HTTP client SSL configuration and Cookies support (works + completely with http-access2). + + * add header handler for handling sending/receiving SOAP Header. + + * map Ruby's anonymous Struct to common SOAP Struct in SOAP Object + Model. it caused error. + + * add WSDL simpleType support to restrict lexical value space. + + * add SOAP with Attachment support. + Sat Jul 3 17:19:44 2004 WATANABE Hirofumi * ext/tk/lib/tkextlib/tkDND.rb: fix syntax error. diff --git a/lib/soap/baseData.rb b/lib/soap/baseData.rb index 91f5a0433f..49c1d2d1f4 100644 --- a/lib/soap/baseData.rb +++ b/lib/soap/baseData.rb @@ -1,5 +1,5 @@ # soap/baseData.rb: SOAP4R - Base type library -# Copyright (C) 2000, 2001, 2003 NAKAMURA, Hiroshi . +# Copyright (C) 2000, 2001, 2003, 2004 NAKAMURA, Hiroshi . # This program is copyrighted free software by NAKAMURA, Hiroshi. You can # redistribute it and/or modify it under the same terms of Ruby's license; @@ -30,20 +30,10 @@ end ### -## Marker of SOAP/DM types. +## for SOAP type(base and compound) # -module SOAPType; end - - -### -## Mix-in module for SOAP base type instances. -# -module SOAPBasetype - include SOAPType - include SOAP - +module SOAPType attr_accessor :encodingstyle - attr_accessor :elename attr_accessor :id attr_reader :precedents @@ -51,55 +41,53 @@ module SOAPBasetype attr_accessor :parent attr_accessor :position attr_reader :extraattr + attr_accessor :definedtype -public - - def initialize(*vars) - super(*vars) + def initialize(*arg) + super(*arg) @encodingstyle = nil @elename = XSD::QName.new @id = nil @precedents = [] + @root = false @parent = nil @position = nil + @definedtype = nil @extraattr = {} end + + def rootnode + node = self + while node = node.parent + break if SOAPEnvelope === node + end + node + end end ### -## Mix-in module for SOAP compound type instances. +## for SOAP base type # -module SOAPCompoundtype +module SOAPBasetype include SOAPType include SOAP - attr_accessor :encodingstyle - - attr_accessor :elename - attr_accessor :id - attr_reader :precedents - attr_accessor :root - attr_accessor :parent - attr_accessor :position - attr_reader :extraattr + def initialize(*arg) + super(*arg) + end +end - attr_accessor :definedtype -public +### +## for SOAP compound type +# +module SOAPCompoundtype + include SOAPType + include SOAP - def initialize(type) - super() - @type = type - @encodingstyle = nil - @elename = XSD::QName.new - @id = nil - @precedents = [] - @root = false - @parent = nil - @position = nil - @definedtype = nil - @extraattr = {} + def initialize(*arg) + super(*arg) end end @@ -114,20 +102,14 @@ class SOAPReference < XSD::NSDBase public attr_accessor :refid - attr_accessor :elename # Override the definition in SOAPBasetype. - def initialize(refid = nil) + def initialize(obj = nil) super() @type = XSD::QName.new - @encodingstyle = nil - @elename = XSD::QName.new - @id = nil - @precedents = [] - @root = false - @parent = nil - @refid = refid + @refid = nil @obj = nil + __setobj__(obj) if obj end def __getobj__ @@ -136,7 +118,7 @@ public def __setobj__(obj) @obj = obj - @refid = SOAPReference.create_refid(@obj) + @refid = @obj.id || SOAPReference.create_refid(@obj) @obj.id = @refid unless @obj.id @obj.precedents << self # Copies NSDBase information @@ -159,17 +141,54 @@ public end end - def self.decode(elename, refid) + def refidstr + '#' + @refid + end + + def self.create_refid(obj) + 'id' + obj.__id__.to_s + end + + def self.decode(elename, refidstr) + if /\A#(.*)\z/ =~ refidstr + refid = $1 + elsif /\Acid:(.*)\z/ =~ refidstr + refid = $1 + else + raise ArgumentError.new("illegal refid #{refidstr}") + end d = super(elename) d.refid = refid d end +end - def self.create_refid(obj) - 'id' << obj.__id__.to_s + +class SOAPExternalReference < XSD::NSDBase + include SOAPBasetype + extend SOAPModuleUtils + + def initialize + super() + @type = XSD::QName.new + end + + def referred + rootnode.external_content[external_contentid] = self + end + + def refidstr + 'cid:' + external_contentid + end + +private + + def external_contentid + raise NotImplementedError.new end end + class SOAPNil < XSD::XSDNil include SOAPBasetype extend SOAPModuleUtils @@ -326,7 +345,8 @@ class SOAPStruct < XSD::NSDBase public def initialize(type = nil) - super(type || XSD::QName.new) + super() + @type = type || XSD::QName.new @array = [] @data = [] end @@ -362,6 +382,7 @@ public def []=(idx, data) if @array.include?(idx) + data.parent = self if data.respond_to?(:parent=) @data[@array.index(idx)] = data else add(idx, data) @@ -401,31 +422,42 @@ private @array.push(name) value.elename = value.elename.dup_name(name) @data.push(value) + value.parent = self if value.respond_to?(:parent=) + value end end -# SOAPElement is not typed so it does not derive NSDBase. +# SOAPElement is not typed so it is not derived from NSDBase. class SOAPElement include Enumerable attr_accessor :encodingstyle - attr_accessor :extraattr + + attr_accessor :elename + attr_accessor :id attr_reader :precedents + attr_accessor :root + attr_accessor :parent + attr_accessor :position + attr_accessor :extraattr attr_accessor :qualified - attr_accessor :elename def initialize(elename, text = nil) if !elename.is_a?(XSD::QName) elename = XSD::QName.new(nil, elename) end @encodingstyle = LiteralNamespace - @extraattr = {} + @elename = elename + @id = nil @precedents = [] + @root = false + @parent = nil + @position = nil + @extraattr = {} @qualified = false - @elename = elename @array = [] @data = [] @@ -450,6 +482,7 @@ class SOAPElement def []=(idx, data) if @array.include?(idx) + data.parent = self if data.respond_to?(:parent=) @data[@array.index(idx)] = data else add(data) @@ -470,7 +503,7 @@ class SOAPElement else hash = {} each do |k, v| - hash[k] = v.to_obj + hash[k] = v.is_a?(SOAPElement) ? v.to_obj : v.to_s end hash end @@ -483,8 +516,7 @@ class SOAPElement end def self.decode(elename) - o = SOAPElement.new - o.elename = elename + o = SOAPElement.new(elename) o end @@ -493,7 +525,7 @@ class SOAPElement if hash_or_string.is_a?(Hash) hash_or_string.each do |k, v| child = self.from_obj(v) - child.elename = XSD::QName.new(nil, k) + child.elename = k.is_a?(XSD::QName) ? k : XSD::QName.new(nil, k.to_s) o.add(child) end else @@ -508,6 +540,8 @@ private add_accessor(name) @array.push(name) @data.push(value) + value.parent = self if value.respond_to?(:parent=) + value end def add_accessor(name) @@ -550,7 +584,8 @@ public attr_reader :arytype def initialize(type = nil, rank = 1, arytype = nil) - super(type || XSD::QName.new) + super() + @type = type || XSD::QName.new @rank = rank @data = Array.new @sparse = false @@ -609,6 +644,7 @@ public end @offset = idxary + value.parent = self if value.respond_to?(:parent=) offsetnext end diff --git a/lib/soap/element.rb b/lib/soap/element.rb index ae600a08e2..1494cd61dd 100644 --- a/lib/soap/element.rb +++ b/lib/soap/element.rb @@ -1,5 +1,5 @@ # SOAP4R - SOAP elements library -# Copyright (C) 2000, 2001, 2003 NAKAMURA, Hiroshi . +# Copyright (C) 2000, 2001, 2003, 2004 NAKAMURA, Hiroshi . # This program is copyrighted free software by NAKAMURA, Hiroshi. You can # redistribute it and/or modify it under the same terms of Ruby's license; @@ -71,6 +71,10 @@ public self.faultactor.elename = EleFaultActorName if self.faultactor self.detail.elename = EleFaultDetailName if self.detail end + faultcode.parent = self if faultcode + faultstring.parent = self if faultstring + faultactor.parent = self if faultactor + detail.parent = self if detail end def encode(generator, ns, attrs = {}) @@ -91,8 +95,6 @@ end class SOAPBody < SOAPStruct include SOAPEnvelopeElement -public - def initialize(data = nil, is_fault = false) super(nil) @elename = EleBodyName @@ -138,38 +140,39 @@ class SOAPHeaderItem < XSD::NSDBase public - attr_accessor :content + attr_accessor :element attr_accessor :mustunderstand attr_accessor :encodingstyle - def initialize(content, mustunderstand = true, encodingstyle = nil) - super(nil) - @content = content + def initialize(element, mustunderstand = true, encodingstyle = nil) + super() + @type = nil + @element = element @mustunderstand = mustunderstand - @encodingstyle = encodingstyle || LiteralNamespace + @encodingstyle = encodingstyle + element.parent = self if element end def encode(generator, ns, attrs = {}) attrs.each do |key, value| - @content.attr[key] = value + @element.extraattr[key] = value end - @content.attr[ns.name(EnvelopeNamespace, AttrMustUnderstand)] = + @element.extraattr[ns.name(AttrMustUnderstandName)] = (@mustunderstand ? '1' : '0') if @encodingstyle - @content.attr[ns.name(EnvelopeNamespace, AttrEncodingStyle)] = - @encodingstyle + @element.extraattr[ns.name(AttrEncodingStyleName)] = @encodingstyle end - @content.encodingstyle = @encodingstyle if !@content.encodingstyle - yield(@content, true) + @element.encodingstyle = @encodingstyle if !@element.encodingstyle + yield(@element, true) end end -class SOAPHeader < SOAPArray +class SOAPHeader < SOAPStruct include SOAPEnvelopeElement - def initialize() - super(nil, 1) # rank == 1 + def initialize + super(nil) @elename = EleHeaderName @encodingstyle = nil end @@ -183,9 +186,17 @@ class SOAPHeader < SOAPArray generator.encode_tag_end(name, true) end + def add(name, value) + mu = (value.extraattr[AttrMustUnderstandName] == '1') + encstyle = value.extraattr[AttrEncodingStyleName] + item = SOAPHeaderItem.new(value, mu, encstyle) + super(name, item) + end + def length @data.length end + alias size length end @@ -193,15 +204,30 @@ class SOAPEnvelope < XSD::NSDBase include SOAPEnvelopeElement include SOAPCompoundtype - attr_accessor :header - attr_accessor :body + attr_reader :header + attr_reader :body + attr_reader :external_content def initialize(header = nil, body = nil) - super(nil) + super() + @type = nil @elename = EleEnvelopeName @encodingstyle = nil @header = header @body = body + @external_content = {} + header.parent = self if header + body.parent = self if body + end + + def header=(header) + header.parent = self + @header = header + end + + def body=(body) + body.parent = self + @body = body end def encode(generator, ns, attrs = {}) @@ -215,6 +241,10 @@ class SOAPEnvelope < XSD::NSDBase generator.encode_tag_end(name, true) end + + def to_ary + [header, body] + end end diff --git a/lib/soap/encodingstyle/handler.rb b/lib/soap/encodingstyle/handler.rb index 8ea23ef146..7bf65a2fd5 100644 --- a/lib/soap/encodingstyle/handler.rb +++ b/lib/soap/encodingstyle/handler.rb @@ -44,8 +44,8 @@ class Handler attr_reader :charset attr_accessor :generate_explicit_type - def decode_typemap=(complextypes) - @decode_typemap = complextypes + def decode_typemap=(definedtypes) + @decode_typemap = definedtypes end def initialize(charset) diff --git a/lib/soap/encodingstyle/literalHandler.rb b/lib/soap/encodingstyle/literalHandler.rb index 995e1a5361..72a10b2daa 100644 --- a/lib/soap/encodingstyle/literalHandler.rb +++ b/lib/soap/encodingstyle/literalHandler.rb @@ -1,5 +1,5 @@ # SOAP4R - XML Literal EncodingStyle handler library -# Copyright (C) 2001, 2003 NAKAMURA, Hiroshi . +# Copyright (C) 2001, 2003, 2004 NAKAMURA, Hiroshi . # This program is copyrighted free software by NAKAMURA, Hiroshi. You can # redistribute it and/or modify it under the same terms of Ruby's license; @@ -41,14 +41,18 @@ class LiteralHandler < Handler generator.encode_rawstring(data.to_s) when XSD::XSDString generator.encode_tag(name, attrs) - generator.encode_string(@charset ? XSD::Charset.encoding_to_xml(data.to_s, @charset) : data.to_s) + str = data.to_s + str = XSD::Charset.encoding_to_xml(str, @charset) if @charset + generator.encode_string(str) when XSD::XSDAnySimpleType generator.encode_tag(name, attrs) generator.encode_string(data.to_s) when SOAPStruct generator.encode_tag(name, attrs) data.each do |key, value| - value.elename.namespace = data.elename.namespace if !value.elename.namespace + if !value.elename.namespace + value.elename.namespace = data.elename.namespace + end yield(value, true) end when SOAPArray @@ -61,8 +65,6 @@ class LiteralHandler < Handler generator.encode_tag(name, attrs.update(data.extraattr)) generator.encode_rawstring(data.text) if data.text data.each do |key, value| - value.elename.namespace = data.elename.namespace if !value.elename.namespace - #yield(value, data.qualified) yield(value, qualified) end else @@ -76,7 +78,8 @@ class LiteralHandler < Handler else data.elename.name end - generator.encode_tag_end(name) + cr = data.is_a?(SOAPElement) && !data.text + generator.encode_tag_end(name, cr) end @@ -92,15 +95,17 @@ class LiteralHandler < Handler end class SOAPUnknown < SOAPTemporalObject - def initialize(handler, elename) + def initialize(handler, elename, extraattr) super() @handler = handler @elename = elename + @extraattr = extraattr end - def as_struct - o = SOAPStruct.decode(@elename, XSD::AnyTypeName) + def as_element + o = SOAPElement.decode(@elename) o.parent = @parent + o.extraattr.update(@extraattr) @handler.decode_parent(@parent, o) o end @@ -108,6 +113,7 @@ class LiteralHandler < Handler def as_string o = SOAPString.decode(@elename) o.parent = @parent + o.extraattr.update(@extraattr) @handler.decode_parent(@parent, o) o end @@ -115,6 +121,7 @@ class LiteralHandler < Handler def as_nil o = SOAPNil.decode(@elename) o.parent = @parent + o.extraattr.update(@extraattr) @handler.decode_parent(@parent, o) o end @@ -123,7 +130,7 @@ class LiteralHandler < Handler def decode_tag(ns, elename, attrs, parent) # ToDo: check if @textbuf is empty... @textbuf = '' - o = SOAPUnknown.new(self, elename) + o = SOAPUnknown.new(self, elename, decode_attrs(ns, attrs)) o.parent = parent o end @@ -132,7 +139,7 @@ class LiteralHandler < Handler o = node.node if o.is_a?(SOAPUnknown) newnode = if /\A\s*\z/ =~ @textbuf - o.as_struct + o.as_element else o.as_string end @@ -149,6 +156,15 @@ class LiteralHandler < Handler @textbuf << text end + def decode_attrs(ns, attrs) + extraattr = {} + attrs.each do |key, value| + qname = ns.parse(key) + extraattr[qname] = value + end + extraattr + end + def decode_prologue end @@ -158,13 +174,18 @@ class LiteralHandler < Handler def decode_parent(parent, node) case parent.node when SOAPUnknown - newparent = parent.node.as_struct + newparent = parent.node.as_element node.parent = newparent parent.replace_node(newparent) decode_parent(parent, node) + when SOAPElement + parent.node.add(node) + node.parent = parent.node + when SOAPStruct - parent.node.add(node.name, node) + parent.node.add(node.elename.name, node) + node.parent = parent.node when SOAPArray if node.position @@ -173,13 +194,14 @@ class LiteralHandler < Handler else parent.node.add(node) end + node.parent = parent.node when SOAPBasetype raise EncodingStyleError.new("SOAP base type must not have a child.") else # SOAPUnknown does not have parent. - # raise EncodingStyleError.new("Illegal parent: #{ parent }.") + raise EncodingStyleError.new("Illegal parent: #{ parent }.") end end diff --git a/lib/soap/encodingstyle/soapHandler.rb b/lib/soap/encodingstyle/soapHandler.rb index 9aa732535e..114060bd02 100644 --- a/lib/soap/encodingstyle/soapHandler.rb +++ b/lib/soap/encodingstyle/soapHandler.rb @@ -33,7 +33,7 @@ class SOAPHandler < Handler attrs = encode_attrs(generator, ns, data, parent) if parent && parent.is_a?(SOAPArray) && parent.position - attrs[ns.name(AttrPositionName)] = '[' << parent.position.join(',') << ']' + attrs[ns.name(AttrPositionName)] = "[#{ parent.position.join(',') }]" end name = nil @@ -46,14 +46,19 @@ class SOAPHandler < Handler case data when SOAPReference - attrs['href'] = '#' << data.refid + attrs['href'] = data.refidstr + generator.encode_tag(name, attrs) + when SOAPExternalReference + data.referred + attrs['href'] = data.refidstr generator.encode_tag(name, attrs) when SOAPRawString generator.encode_tag(name, attrs) generator.encode_rawstring(data.to_s) when XSD::XSDString generator.encode_tag(name, attrs) - generator.encode_string(@charset ? XSD::Charset.encoding_to_xml(data.to_s, @charset) : data.to_s) + generator.encode_string(@charset ? + XSD::Charset.encoding_to_xml(data.to_s, @charset) : data.to_s) when XSD::XSDAnySimpleType generator.encode_tag(name, attrs) generator.encode_string(data.to_s) @@ -202,16 +207,12 @@ class SOAPHandler < Handler node.replace_node(newnode) o = node.node end - if o.is_a?(SOAPCompoundtype) - o.definedtype = nil - end - decode_textbuf(o) - @textbuf = '' + # unlink definedtype + o.definedtype = nil end def decode_text(ns, text) - # @textbuf is set at decode_tag_end. @textbuf << text end @@ -235,11 +236,9 @@ class SOAPHandler < Handler end parent.replace_node(newparent) decode_parent(parent, node) - when SOAPStruct parent.node.add(node.elename.name, node) node.parent = parent.node - when SOAPArray if node.position parent.node[*(decode_arypos(node.position))] = node @@ -248,10 +247,8 @@ class SOAPHandler < Handler parent.node.add(node) end node.parent = parent.node - when SOAPBasetype raise EncodingStyleError.new("SOAP base type must not have a child.") - else raise EncodingStyleError.new("Illegal parent: #{ parent.node }.") end @@ -269,7 +266,7 @@ private def create_arytype(ns, data) XSD::QName.new(data.arytype.namespace, - content_typename(data.arytype.name) << '[' << data.size.join(',') << ']') + content_typename(data.arytype.name) + "[#{ data.size.join(',') }]") end def encode_attrs(generator, ns, data, parent) @@ -320,10 +317,9 @@ private def encode_attr_value(generator, ns, qname, value) if value.is_a?(SOAPType) - refid = SOAPReference.create_refid(value) - value.id = refid + ref = SOAPReference.new(value) generator.add_reftarget(qname.name, value) - '#' + refid + ref.refidstr else value.to_s end @@ -349,8 +345,7 @@ private typename = ns.parse(typestr) typedef = @decode_typemap[typename] if typedef - return decode_defined_compoundtype(elename, typename, typedef, - arytypestr) + return decode_definedtype(elename, typename, typedef, arytypestr) end end return decode_tag_by_type(ns, elename, typestr, parent, arytypestr, @@ -372,21 +367,42 @@ private definedtype_name = parenttype.child_type(elename) if definedtype_name and (klass = TypeMap[definedtype_name]) - return klass.decode(elename) + return decode_basetype(klass, elename) elsif definedtype_name == XSD::AnyTypeName return decode_tag_by_type(ns, elename, typestr, parent, arytypestr, extraattr) end - typedef = definedtype_name ? @decode_typemap[definedtype_name] : - parenttype.child_defined_complextype(elename) - decode_defined_compoundtype(elename, definedtype_name, typedef, arytypestr) + if definedtype_name + typedef = @decode_typemap[definedtype_name] + else + typedef = parenttype.child_defined_complextype(elename) + end + decode_definedtype(elename, definedtype_name, typedef, arytypestr) end - def decode_defined_compoundtype(elename, typename, typedef, arytypestr) + def decode_definedtype(elename, typename, typedef, arytypestr) unless typedef raise EncodingStyleError.new("Unknown type '#{ typename }'.") end + if typedef.is_a?(::WSDL::XMLSchema::SimpleType) + decode_defined_simpletype(elename, typename, typedef, arytypestr) + else + decode_defined_complextype(elename, typename, typedef, arytypestr) + end + end + + def decode_basetype(klass, elename) + klass.decode(elename) + end + + def decode_defined_simpletype(elename, typename, typedef, arytypestr) + o = decode_basetype(TypeMap[typedef.base], elename) + o.definedtype = typedef + o + end + + def decode_defined_complextype(elename, typename, typedef, arytypestr) case typedef.compoundtype when :TYPE_STRUCT o = SOAPStruct.decode(elename, typename) @@ -406,7 +422,7 @@ private o.definedtype = typedef return o end - return nil + nil end def decode_tag_by_type(ns, elename, typestr, parent, arytypestr, extraattr) @@ -431,7 +447,7 @@ private end if (klass = TypeMap[type]) - node = klass.decode(elename) + node = decode_basetype(klass, elename) node.extraattr.update(extraattr) return node end @@ -446,10 +462,12 @@ private node.set_encoded(@textbuf) when XSD::XSDString if @charset - node.set(XSD::Charset.encoding_from_xml(@textbuf, @charset)) - else - node.set(@textbuf) + @textbuf = XSD::Charset.encoding_from_xml(@textbuf, @charset) + end + if node.definedtype + node.definedtype.check_lexical_format(@textbuf) end + node.set(@textbuf) when SOAPNil # Nothing to do. when SOAPBasetype @@ -457,6 +475,7 @@ private else # Nothing to do... end + @textbuf = '' end NilLiteralMap = { @@ -526,7 +545,7 @@ private def decode_attr_value(ns, qname, value) if /\A#/ =~ value - o = SOAPReference.new(value) + o = SOAPReference.decode(nil, value) @refpool << o o else @@ -544,16 +563,18 @@ private while !@refpool.empty? && count > 0 @refpool = @refpool.find_all { |ref| o = @idpool.find { |item| - '#' + item.id == ref.refid + item.id == ref.refid } - unless o - raise EncodingStyleError.new("Unresolved reference: #{ ref.refid }.") - end if o.is_a?(SOAPReference) - true - else + true # link of link. + elsif o ref.__setobj__(o) false + elsif o = ref.rootnode.external_content[ref.refid] + ref.__setobj__(o) + false + else + raise EncodingStyleError.new("Unresolved reference: #{ ref.refid }.") end } count -= 1 diff --git a/lib/soap/generator.rb b/lib/soap/generator.rb index dd868fb9db..edd90492c6 100644 --- a/lib/soap/generator.rb +++ b/lib/soap/generator.rb @@ -68,9 +68,8 @@ public if @reftarget && !obj.precedents.empty? add_reftarget(obj.elename.name, obj) - ref = SOAPReference.new + ref = SOAPReference.new(obj) ref.elename.name = obj.elename.name - ref.__setobj__(obj) obj.precedents.clear # Avoid cyclic delay. obj.encodingstyle = parent.encodingstyle # SOAPReference is encoded here. @@ -91,9 +90,9 @@ public raise FormatEncodeError.new("Element name not defined: #{ obj }.") end - handler.encode_data(self, ns, qualified, obj, parent) do |child, child_q| + handler.encode_data(self, ns, qualified, obj, parent) do |child, nextq| indent_backup, @indent = @indent, @indent + ' ' - encode_data(ns.clone_ns, child_q, child, obj) + encode_data(ns.clone_ns, nextq, child, obj) @indent = indent_backup end handler.encode_data_end(self, ns, qualified, obj, parent) @@ -110,9 +109,9 @@ public attrs = {} if obj.is_a?(SOAPBody) @reftarget = obj - obj.encode(self, ns, attrs) do |child, child_q| + obj.encode(self, ns, attrs) do |child, nextq| indent_backup, @indent = @indent, @indent + ' ' - encode_data(ns.clone_ns, child_q, child, obj) + encode_data(ns.clone_ns, nextq, child, obj) @indent = indent_backup end @reftarget = nil @@ -125,9 +124,9 @@ public SOAPGenerator.assign_ns(attrs, ns, XSD::Namespace, XSDNamespaceTag) end end - obj.encode(self, ns, attrs) do |child, child_q| + obj.encode(self, ns, attrs) do |child, nextq| indent_backup, @indent = @indent, @indent + ' ' - encode_data(ns.clone_ns, child_q, child, obj) + encode_data(ns.clone_ns, nextq, child, obj) @indent = indent_backup end end diff --git a/lib/soap/mapping/factory.rb b/lib/soap/mapping/factory.rb index fe6a6de7ae..6b9ac1eeaa 100644 --- a/lib/soap/mapping/factory.rb +++ b/lib/soap/mapping/factory.rb @@ -70,6 +70,7 @@ class Factory end def setiv2soap(node, obj, map) + # should we sort instance_variables? obj.instance_variables.each do |var| name = var.sub(/^@/, '') node.add(Mapping.name2elename(name), diff --git a/lib/soap/mapping/mapping.rb b/lib/soap/mapping/mapping.rb index 4b68b811fc..db7ea607fd 100644 --- a/lib/soap/mapping/mapping.rb +++ b/lib/soap/mapping/mapping.rb @@ -68,24 +68,26 @@ module Mapping md_ary end - def self.fault2exception(e, registry = nil) + def self.fault2exception(fault, registry = nil) registry ||= Mapping::DefaultRegistry - detail = if e.detail - soap2obj(e.detail, registry) || "" + detail = if fault.detail + soap2obj(fault.detail, registry) || "" else "" end if detail.is_a?(Mapping::SOAPException) begin - remote_backtrace = detail.to_e.backtrace - raise detail.to_e - rescue Exception => e2 - e2.set_backtrace(remote_backtrace + e2.backtrace) + e = detail.to_e + remote_backtrace = e.backtrace + e.set_backtrace(nil) + raise e # ruby sets current caller as local backtrace of e => e2. + rescue Exception => e + e.set_backtrace(remote_backtrace + e.backtrace[1..-1]) raise end else - e.detail = detail - e.set_backtrace( + fault.detail = detail + fault.set_backtrace( if detail.is_a?(Array) detail else @@ -98,9 +100,7 @@ module Mapping def self._obj2soap(obj, registry, type = nil) if referent = Thread.current[:SOAPMarshalDataKey][obj.__id__] - soap_obj = SOAPReference.new - soap_obj.__setobj__(referent) - soap_obj + SOAPReference.new(referent) else registry.obj2soap(obj.class, obj, type) end diff --git a/lib/soap/mapping/registry.rb b/lib/soap/mapping/registry.rb index 8142047724..1317d40cd6 100644 --- a/lib/soap/mapping/registry.rb +++ b/lib/soap/mapping/registry.rb @@ -44,14 +44,15 @@ class SOAPException; include Marshallable if @cause.is_a?(::Exception) @cause.extend(::SOAP::Mapping::MappedException) return @cause + elsif @cause.respond_to?(:message) and @cause.respond_to?(:backtrace) + e = RuntimeError.new(@cause.message) + e.set_backtrace(@cause.backtrace) + return e end klass = Mapping.class_from_name( Mapping.elename2name(@excn_type_name.to_s)) - if klass.nil? - raise RuntimeError.new(@cause.message) - end - unless klass <= ::Exception - raise NameError.new + if klass.nil? or not klass <= ::Exception + return RuntimeError.new(@cause.inspect) end obj = klass.new(@cause.message) obj.extend(::SOAP::Mapping::MappedException) @@ -62,50 +63,78 @@ end # For anyType object: SOAP::Mapping::Object not ::Object class Object; include Marshallable - def set_property(name, value) - var_name = name - begin - instance_eval <<-EOS - def #{ var_name } - @#{ var_name } - end + def initialize + @__members = [] + @__value_type = {} + end - def #{ var_name }=(value) - @#{ var_name } = value - end - EOS - self.send(var_name + '=', value) - rescue SyntaxError - var_name = safe_name(var_name) - retry + def [](name) + if @__members.include?(name) + self.__send__(name) + else + self.__send__(Object.safe_name(name)) end + end + + def []=(name, value) + if @__members.include?(name) + self.__send__(name + '=', value) + else + self.__send__(Object.safe_name(name) + '=', value) + end + end + def __set_property(name, value) + var_name = name + unless @__members.include?(name) + var_name = __define_attr_accessor(var_name) + end + __set_property_value(var_name, value) var_name end - def members - instance_variables.collect { |str| str[1..-1] } + def __members + @__members end - def [](name) - if self.respond_to?(name) - self.send(name) +private + + def __set_property_value(name, value) + org = self.__send__(name) + case @__value_type[name] + when :single + self.__send__(name + '=', [org, value]) + @__value_type[name] = :multi + when :multi + org << value else - self.send(safe_name(name)) + self.__send__(name + '=', value) + @__value_type[name] = :single end + value end - def []=(name, value) - if self.respond_to?(name) - self.send(name + '=', value) - else - self.send(safe_name(name) + '=', value) + def __define_attr_accessor(name) + var_name = name + begin + instance_eval <<-EOS + def #{ var_name } + @#{ var_name } + end + + def #{ var_name }=(value) + @#{ var_name } = value + end + EOS + rescue SyntaxError + var_name = Object.safe_name(var_name) + retry end + @__members << var_name + var_name end -private - - def safe_name(name) + def Object.safe_name(name) require 'md5' "var_" << MD5.new(name).hexdigest end @@ -309,7 +338,7 @@ class Registry def add(obj_class, soap_class, factory, info = nil) @map.add(obj_class, soap_class, factory, info) end - alias :set :add + alias set add # This mapping registry ignores type hint. def obj2soap(klass, obj, type_qname = nil) diff --git a/lib/soap/mapping/rubytypeFactory.rb b/lib/soap/mapping/rubytypeFactory.rb index f79bc78cc7..a46d93275f 100644 --- a/lib/soap/mapping/rubytypeFactory.rb +++ b/lib/soap/mapping/rubytypeFactory.rb @@ -38,7 +38,7 @@ class RubytypeFactory < Factory def obj2soap(soap_class, obj, info, map) param = nil case obj - when String + when ::String unless @allow_original_mapping return nil end @@ -47,7 +47,7 @@ class RubytypeFactory < Factory param.extraattr[RubyTypeName] = obj.class.name end addiv2soapattr(param, obj, map) - when Time + when ::Time unless @allow_original_mapping return nil end @@ -56,7 +56,7 @@ class RubytypeFactory < Factory param.extraattr[RubyTypeName] = obj.class.name end addiv2soapattr(param, obj, map) - when Array + when ::Array unless @allow_original_mapping return nil end @@ -65,19 +65,19 @@ class RubytypeFactory < Factory param.extraattr[RubyTypeName] = obj.class.name end addiv2soapattr(param, obj, map) - when NilClass + when ::NilClass unless @allow_original_mapping return nil end param = @basetype_factory.obj2soap(SOAPNil, obj, info, map) addiv2soapattr(param, obj, map) - when FalseClass, TrueClass + when ::FalseClass, ::TrueClass unless @allow_original_mapping return nil end param = @basetype_factory.obj2soap(SOAPBoolean, obj, info, map) addiv2soapattr(param, obj, map) - when Integer + when ::Integer unless @allow_original_mapping return nil end @@ -85,7 +85,7 @@ class RubytypeFactory < Factory param ||= @basetype_factory.obj2soap(SOAPInteger, obj, info, map) param ||= @basetype_factory.obj2soap(SOAPDecimal, obj, info, map) addiv2soapattr(param, obj, map) - when Float + when ::Float unless @allow_original_mapping return nil end @@ -94,7 +94,7 @@ class RubytypeFactory < Factory param.extraattr[RubyTypeName] = obj.class.name end addiv2soapattr(param, obj, map) - when Hash + when ::Hash unless @allow_original_mapping return nil end @@ -114,7 +114,7 @@ class RubytypeFactory < Factory end param.add('default', Mapping._obj2soap(obj.default, map)) addiv2soapattr(param, obj, map) - when Regexp + when ::Regexp unless @allow_original_mapping return nil end @@ -150,7 +150,7 @@ class RubytypeFactory < Factory end param.add('options', SOAPInt.new(options)) addiv2soapattr(param, obj, map) - when Range + when ::Range unless @allow_original_mapping return nil end @@ -163,29 +163,29 @@ class RubytypeFactory < Factory param.add('end', Mapping._obj2soap(obj.end, map)) param.add('exclude_end', SOAP::SOAPBoolean.new(obj.exclude_end?)) addiv2soapattr(param, obj, map) - when Class + when ::Class unless @allow_original_mapping return nil end if obj.to_s[0] == ?# - raise TypeError.new("Can't dump anonymous class #{ obj }.") + raise TypeError.new("can't dump anonymous class #{ obj }") end param = SOAPStruct.new(TYPE_CLASS) mark_marshalled_obj(obj, param) param.add('name', SOAPString.new(obj.name)) addiv2soapattr(param, obj, map) - when Module + when ::Module unless @allow_original_mapping return nil end if obj.to_s[0] == ?# - raise TypeError.new("Can't dump anonymous module #{ obj }.") + raise TypeError.new("can't dump anonymous module #{ obj }") end param = SOAPStruct.new(TYPE_MODULE) mark_marshalled_obj(obj, param) param.add('name', SOAPString.new(obj.name)) addiv2soapattr(param, obj, map) - when Symbol + when ::Symbol unless @allow_original_mapping return nil end @@ -193,28 +193,37 @@ class RubytypeFactory < Factory mark_marshalled_obj(obj, param) param.add('id', SOAPString.new(obj.id2name)) addiv2soapattr(param, obj, map) - when Struct + when ::Struct unless @allow_original_mapping - return nil - end - param = SOAPStruct.new(TYPE_STRUCT) - mark_marshalled_obj(obj, param) - param.add('type', ele_type = SOAPString.new(obj.class.to_s)) - ele_member = SOAPStruct.new - obj.members.each do |member| - ele_member.add(Mapping.name2elename(member), - Mapping._obj2soap(obj[member], map)) + # treat it as an user defined class. [ruby-talk:104980] + #param = unknownobj2soap(soap_class, obj, info, map) + param = SOAPStruct.new(XSD::AnyTypeName) + mark_marshalled_obj(obj, param) + obj.members.each do |member| + param.add(Mapping.name2elename(member), + Mapping._obj2soap(obj[member], map)) + end + else + param = SOAPStruct.new(TYPE_STRUCT) + mark_marshalled_obj(obj, param) + param.add('type', ele_type = SOAPString.new(obj.class.to_s)) + ele_member = SOAPStruct.new + obj.members.each do |member| + ele_member.add(Mapping.name2elename(member), + Mapping._obj2soap(obj[member], map)) + end + param.add('member', ele_member) + addiv2soapattr(param, obj, map) end - param.add('member', ele_member) - addiv2soapattr(param, obj, map) - when IO, Binding, Continuation, Data, Dir, File::Stat, MatchData, Method, - Proc, Thread, ThreadGroup # from 1.8: Process::Status, UnboundMethod + when ::IO, ::Binding, ::Continuation, ::Data, ::Dir, ::File::Stat, + ::MatchData, Method, ::Proc, ::Thread, ::ThreadGroup + # from 1.8: Process::Status, UnboundMethod return nil when ::SOAP::Mapping::Object param = SOAPStruct.new(XSD::AnyTypeName) mark_marshalled_obj(obj, param) addiv2soapattr(param, obj, map) - when Exception + when ::Exception typestr = Mapping.name2elename(obj.class.to_s) param = SOAPStruct.new(XSD::QName.new(RubyTypeNamespace, typestr)) mark_marshalled_obj(obj, param) @@ -249,7 +258,7 @@ private def unknownobj2soap(soap_class, obj, info, map) if obj.class.name.empty? - raise TypeError.new("Can't dump anonymous class #{ obj }.") + raise TypeError.new("can't dump anonymous class #{ obj }") end singleton_class = class << obj; self; end if !singleton_methods_true(obj).empty? or @@ -369,7 +378,7 @@ private obj = klass.new mark_unmarshalled_obj(node, obj) node.each do |name, value| - obj.set_property(name, Mapping._soap2obj(value, map)) + obj.__set_property(name, Mapping._soap2obj(value, map)) end return true, obj else diff --git a/lib/soap/mapping/wsdlRegistry.rb b/lib/soap/mapping/wsdlRegistry.rb index 66d16c6f90..64f49f2265 100644 --- a/lib/soap/mapping/wsdlRegistry.rb +++ b/lib/soap/mapping/wsdlRegistry.rb @@ -18,10 +18,10 @@ module Mapping class WSDLRegistry include TraverseSupport - attr_reader :complextypes + attr_reader :definedtypes - def initialize(complextypes, config = {}) - @complextypes = complextypes + def initialize(definedtypes, config = {}) + @definedtypes = definedtypes @config = config @excn_handler_obj2soap = nil # For mapping AnyType element. @@ -37,27 +37,20 @@ class WSDLRegistry soap_obj = SOAPNil.new elsif obj.is_a?(XSD::NSDBase) soap_obj = soap2soap(obj, type_qname) - elsif (type = @complextypes[type_qname]) - case type.compoundtype - when :TYPE_STRUCT - soap_obj = struct2soap(obj, type_qname, type) - when :TYPE_ARRAY - soap_obj = array2soap(obj, type_qname, type) - end + elsif type = @definedtypes[type_qname] + soap_obj = obj2type(obj, type) elsif (type = TypeMap[type_qname]) soap_obj = base2soap(obj, type) elsif type_qname == XSD::AnyTypeName soap_obj = @rubytype_factory.obj2soap(nil, obj, nil, nil) end return soap_obj if soap_obj - if @excn_handler_obj2soap soap_obj = @excn_handler_obj2soap.call(obj) { |yield_obj| Mapping._obj2soap(yield_obj, self) } end return soap_obj if soap_obj - raise MappingError.new("Cannot map #{ klass.name } to SOAP/OM.") end @@ -74,12 +67,12 @@ private def soap2soap(obj, type_qname) if obj.is_a?(SOAPBasetype) obj - elsif obj.is_a?(SOAPStruct) && (type = @complextypes[type_qname]) + elsif obj.is_a?(SOAPStruct) && (type = @definedtypes[type_qname]) soap_obj = obj mark_marshalled_obj(obj, soap_obj) elements2soap(obj, soap_obj, type.content.elements) soap_obj - elsif obj.is_a?(SOAPArray) && (type = @complextypes[type_qname]) + elsif obj.is_a?(SOAPArray) && (type = @definedtypes[type_qname]) soap_obj = obj contenttype = type.child_type mark_marshalled_obj(obj, soap_obj) @@ -92,6 +85,33 @@ private end end + def obj2type(obj, type) + if type.is_a?(::WSDL::XMLSchema::SimpleType) + simple2soap(obj, type) + else + complex2soap(obj, type) + end + end + + def simple2soap(obj, type) + o = base2soap(obj, TypeMap[type.base]) + if type.restriction.enumeration.empty? + STDERR.puts("#{type.name}: simpleType which is not enum type not supported.") + return o + end + type.check_lexical_format(obj) + o + end + + def complex2soap(obj, type) + case type.compoundtype + when :TYPE_STRUCT + struct2soap(obj, type.name, type) + when :TYPE_ARRAY + array2soap(obj, type.name, type) + end + end + def base2soap(obj, type) soap_obj = nil if type <= XSD::XSDString diff --git a/lib/soap/marshal.rb b/lib/soap/marshal.rb index 910ab24527..7202a6aba8 100644 --- a/lib/soap/marshal.rb +++ b/lib/soap/marshal.rb @@ -37,15 +37,16 @@ module Marshal soap_obj = Mapping.obj2soap(obj, mapping_registry) body = SOAPBody.new body.add(elename, soap_obj) - SOAP::Processor.marshal(nil, body, {}, io) + env = SOAPEnvelope.new(nil, body) + SOAP::Processor.marshal(env, {}, io) end def unmarshal(stream, mapping_registry = MarshalMappingRegistry) - header, body = SOAP::Processor.unmarshal(stream) - if body.nil? + env = SOAP::Processor.unmarshal(stream) + if env.nil? raise ArgumentError.new("Illegal SOAP marshal format.") end - Mapping.soap2obj(body.root_node, mapping_registry) + Mapping.soap2obj(env.body.root_node, mapping_registry) end end end diff --git a/lib/soap/netHttpClient.rb b/lib/soap/netHttpClient.rb index 4505de815e..1e9d71c5a3 100644 --- a/lib/soap/netHttpClient.rb +++ b/lib/soap/netHttpClient.rb @@ -34,6 +34,10 @@ class NetHttpClient @session_manager = SessionManager.new @no_proxy = nil end + + def test_loopback_response + raise NotImplementedError.new("not supported for now") + end def proxy=(proxy_str) if proxy_str.nil? @@ -54,7 +58,11 @@ class NetHttpClient end def set_cookie_store(filename) - # ignored. + raise NotImplementedError.new + end + + def save_cookie_store(filename) + raise NotImplementedError.new end def reset(url) @@ -70,8 +78,8 @@ class NetHttpClient extra = header.dup extra['User-Agent'] = @agent if @agent res = start(url) { |http| - http.post(url.request_uri, req_body, extra) - } + http.post(url.request_uri, req_body, extra) + } Response.new(res) end diff --git a/lib/soap/parser.rb b/lib/soap/parser.rb index 1395be55ec..14704a6d9b 100644 --- a/lib/soap/parser.rb +++ b/lib/soap/parser.rb @@ -65,6 +65,7 @@ public attr_accessor :allow_unqualified_element def initialize(opt = {}) + @opt = opt @parser = XSD::XMLParser.create_parser(self, opt) @parsestack = nil @lastnode = nil @@ -116,7 +117,13 @@ public encodingstyle = find_encodingstyle(ns, attrs) # Children's encodingstyle is derived from its parent. - encodingstyle ||= parent_encodingstyle || @default_encodingstyle + if encodingstyle.nil? + if parent.node.is_a?(SOAPHeader) + encodingstyle = LiteralNamespace + else + encodingstyle = parent_encodingstyle || @default_encodingstyle + end + end node = decode_tag(ns, name, attrs, parent, encodingstyle) @@ -201,6 +208,11 @@ private o = nil if ele.name == EleEnvelope o = SOAPEnvelope.new + if ext = @opt[:external_content] + ext.each do |k, v| + o.external_content[k] = v + end + end elsif ele.name == EleHeader unless parent.node.is_a?(SOAPEnvelope) raise FormatDecodeError.new("Header should be a child of Envelope.") @@ -220,7 +232,6 @@ private o = SOAPFault.new parent.node.fault = o end - o.parent = parent if o o end diff --git a/lib/soap/processor.rb b/lib/soap/processor.rb index 9cf00e8340..3c6dbedf2f 100644 --- a/lib/soap/processor.rb +++ b/lib/soap/processor.rb @@ -25,20 +25,18 @@ module Processor class << self public - def marshal(header, body, opt = {}, io = nil) - env = SOAPEnvelope.new(header, body) + def marshal(env, opt = {}, io = nil) generator = create_generator(opt) - generator.generate(env, io) + marshalled_str = generator.generate(env, io) + unless env.external_content.empty? + opt[:external_content] = env.external_content + end + marshalled_str end def unmarshal(stream, opt = {}) parser = create_parser(opt) - env = parser.parse(stream) - if env - return env.header, env.body - else - return nil, nil - end + parser.parse(stream) end def default_parser_option=(rhs) diff --git a/lib/soap/property.rb b/lib/soap/property.rb index 079c294a77..113cc64f3c 100644 --- a/lib/soap/property.rb +++ b/lib/soap/property.rb @@ -34,22 +34,24 @@ module SOAP class Property include Enumerable - def self.load(stream) - new.load(stream) + module Util + def const_from_name(fqname) + fqname.split("::").inject(Kernel) { |klass, name| klass.const_get(name) } + end + module_function :const_from_name + + def require_from_name(fqname) + require File.join(fqname.split("::").collect { |ele| ele.downcase }) + end + module_function :require_from_name end - def self.open(filename) - File.open(filename) { |f| load(f) } + def self.load(stream) + new.load(stream) end - # find property from $:. def self.loadproperty(propname) - $:.each do |path| - if File.file?(file = File.join(path, propname)) - return open(file) - end - end - nil + new.loadproperty(propname) end def initialize @@ -87,6 +89,17 @@ class Property self end + # find property from $:. + def loadproperty(propname) + return loadpropertyfile(propname) if File.file?(propname) + $:.each do |path| + if File.file?(file = File.join(path, propname)) + return loadpropertyfile(file) + end + end + nil + end + # name: a Symbol, String or an Array def [](name) referent(name_to_a(name)) @@ -95,10 +108,10 @@ class Property # name: a Symbol, String or an Array # value: an Object def []=(name, value) - hooks = assign(name_to_a(name), value) - normalized_name = normalize_name(name) + name_pair = name_to_a(name).freeze + hooks = assign(name_pair, value) hooks.each do |hook| - hook.call(normalized_name, value) + hook.call(name_pair, value) end value end @@ -109,13 +122,15 @@ class Property self[generate_new_key] = value end - # name: a Symbol, String or an Array. nil means hook to the root + # name: a Symbol, String or an Array; nil means hook to the root + # cascade: true/false; for cascading hook of sub key # hook: block which will be called with 2 args, name and value - def add_hook(name = nil, &hook) - if name.nil? - assign_self_hook(&hook) + def add_hook(name = nil, cascade = false, &hook) + if name == nil or name == true or name == false + cascade = name + assign_self_hook(cascade, &hook) else - assign_hook(name_to_a(name), &hook) + assign_hook(name_to_a(name), cascade, &hook) end end @@ -192,14 +207,18 @@ protected @store[key] = value end - def local_hook(key) - @self_hook + (@hook[key] || NO_HOOK) + def local_hook(key, direct) + hooks = [] + (@self_hook + (@hook[key] || NO_HOOK)).each do |hook, cascade| + hooks << hook if direct or cascade + end + hooks end - def local_assign_hook(key, &hook) + def local_assign_hook(key, cascade, &hook) check_lock(key) @store[key] ||= nil - (@hook[key] ||= []) << hook + (@hook[key] ||= []) << [hook, cascade] end private @@ -217,23 +236,23 @@ private hook = NO_HOOK ary[0..-2].each do |name| key = to_key(name) - hook += ref.local_hook(key) + hook += ref.local_hook(key, false) ref = ref.deref_key(key) end last_key = to_key(ary.last) ref.local_assign(last_key, value) - hook + ref.local_hook(last_key) + hook + ref.local_hook(last_key, true) end - def assign_hook(ary, &hook) + def assign_hook(ary, cascade, &hook) ary[0..-2].inject(self) { |ref, name| ref.deref_key(to_key(name)) - }.local_assign_hook(to_key(ary.last), &hook) + }.local_assign_hook(to_key(ary.last), cascade, &hook) end - def assign_self_hook(&hook) + def assign_self_hook(cascade, &hook) check_lock(nil) - @self_hook << hook + @self_hook << [hook, cascade] end def each_key @@ -267,10 +286,6 @@ private end end - def normalize_name(name) - name_to_a(name).collect { |key| to_key(key) }.join('.') - end - def to_key(name) name.to_s.downcase end @@ -286,6 +301,13 @@ private def key_max (@store.keys.max { |l, r| l.to_s.to_i <=> r.to_s.to_i }).to_s.to_i end + + def loadpropertyfile(file) + puts "find property at #{file}" if $DEBUG + File.open(file) do |f| + load(f) + end + end end diff --git a/lib/soap/rpc/cgistub.rb b/lib/soap/rpc/cgistub.rb index 2377f343b5..55437bac59 100644 --- a/lib/soap/rpc/cgistub.rb +++ b/lib/soap/rpc/cgistub.rb @@ -1,5 +1,5 @@ # SOAP4R - CGI stub library -# Copyright (C) 2001, 2003 NAKAMURA, Hiroshi . +# Copyright (C) 2001, 2003, 2004 NAKAMURA, Hiroshi . # This program is copyrighted free software by NAKAMURA, Hiroshi. You can # redistribute it and/or modify it under the same terms of Ruby's license; @@ -40,7 +40,6 @@ class CGIStub < Logger::Application @method = ENV['REQUEST_METHOD'] @size = ENV['CONTENT_LENGTH'].to_i || 0 @contenttype = ENV['CONTENT_TYPE'] - @charset = nil @soapaction = ENV['HTTP_SOAPAction'] @source = stream @body = nil @@ -48,7 +47,6 @@ class CGIStub < Logger::Application def init validate - @charset = StreamHandler.parse_media_type(@contenttype) @body = @source.read(@size) self end @@ -61,8 +59,8 @@ class CGIStub < Logger::Application @soapaction end - def charset - @charset + def contenttype + @contenttype end def to_s @@ -96,15 +94,21 @@ class CGIStub < Logger::Application on_init end - def add_servant(obj, namespace = @default_namespace, soapaction = nil) + def add_rpc_servant(obj, namespace = @default_namespace, soapaction = nil) RPC.defined_methods(obj).each do |name| qname = XSD::QName.new(namespace, name) param_size = obj.method(name).arity.abs - params = (1..param_size).collect { |i| "p#{ i }" } + params = (1..param_size).collect { |i| "p#{i}" } param_def = SOAP::RPC::SOAPMethod.create_param_def(params) @router.add_method(obj, qname, soapaction, name, param_def) end end + alias add_servant add_rpc_servant + + def add_rpc_headerhandler(obj) + @router.headerhandler << obj + end + alias add_headerhandler add_rpc_headerhandler def on_init # Override this method in derived class to call 'add_method' to add methods. @@ -142,8 +146,8 @@ class CGIStub < Logger::Application @router.add_method(receiver, qname, nil, name, param_def) end - def route(request_string, charset) - @router.route(request_string, charset) + def route(conn_data) + @router.route(conn_data) end def create_fault_response(e) @@ -157,32 +161,30 @@ private httpversion = WEBrick::HTTPVersion.new('1.0') @response = WEBrick::HTTPResponse.new({:HTTPVersion => httpversion}) + conn_data = nil begin log(INFO) { "Received a request from '#{ @remote_user }@#{ @remote_host }'." } # SOAP request parsing. @request = SOAPRequest.new.init @response['Status'] = 200 - req_charset = @request.charset - req_string = @request.dump - log(DEBUG) { "XML Request: #{req_string}" } - res_string, is_fault = route(req_string, req_charset) - log(DEBUG) { "XML Response: #{res_string}" } - - @response['Cache-Control'] = 'private' - if req_charset - @response['content-type'] = "#{@mediatype}; charset=\"#{req_charset}\"" - else - @response['content-type'] = @mediatype - end - if is_fault + conn_data = ::SOAP::StreamHandler::ConnectionData.new + conn_data.receive_string = @request.dump + conn_data.receive_contenttype = @request.contenttype + log(DEBUG) { "XML Request: #{conn_data.receive_string}" } + conn_data = route(conn_data) + log(DEBUG) { "XML Response: #{conn_data.send_string}" } + if conn_data.is_fault @response['Status'] = 500 end - @response.body = res_string + @response['Cache-Control'] = 'private' + @response.body = conn_data.send_string + @response['content-type'] = conn_data.send_contenttype rescue Exception - res_string = create_fault_response($!) + conn_data = create_fault_response($!) @response['Cache-Control'] = 'private' - @response['content-type'] = @mediatype @response['Status'] = 500 + @response.body = conn_data.send_string + @response['content-type'] = conn_data.send_contenttype || @mediatype ensure buf = '' @response.send_response(buf) diff --git a/lib/soap/rpc/driver.rb b/lib/soap/rpc/driver.rb index dd433ca33f..0e59dde9be 100644 --- a/lib/soap/rpc/driver.rb +++ b/lib/soap/rpc/driver.rb @@ -1,5 +1,5 @@ # SOAP4R - SOAP RPC driver -# Copyright (C) 2000, 2001, 2003 NAKAMURA, Hiroshi . +# Copyright (C) 2000, 2001, 2003, 2004 NAKAMURA, Hiroshi . # This program is copyrighted free software by NAKAMURA, Hiroshi. You can # redistribute it and/or modify it under the same terms of Ruby's license; @@ -13,6 +13,7 @@ require 'soap/rpc/proxy' require 'soap/rpc/element' require 'soap/streamHandler' require 'soap/property' +require 'soap/header/handlerset' module SOAP @@ -41,6 +42,8 @@ class Driver end __attr_proxy :options + __attr_proxy :headerhandler + __attr_proxy :test_loopback_response __attr_proxy :endpoint_url, true __attr_proxy :mapping_registry, true __attr_proxy :soapaction, true @@ -84,6 +87,12 @@ class Driver @proxy = @servant.proxy end + def loadproperty(propertyname) + unless options.loadproperty(propertyname) + raise LoadError.new("No such property to load -- #{propertyname}") + end + end + def inspect "#<#{self.class}:#{@servant.streamhandler.inspect}>" end @@ -130,6 +139,7 @@ private class Servant__ attr_reader :options attr_reader :streamhandler + attr_reader :headerhandler attr_reader :proxy def initialize(host, endpoint_url, namespace) @@ -141,6 +151,7 @@ private @options = setup_options @streamhandler = HTTPPostStreamHandler.new(endpoint_url, @options["protocol.http"] ||= ::SOAP::Property.new) + @headerhandler = Header::HandlerSet.new @proxy = Proxy.new(@streamhandler, @soapaction) @proxy.allow_unqualified_element = true end @@ -178,27 +189,37 @@ private @proxy.default_encodingstyle = encodingstyle end + def test_loopback_response + @streamhandler.test_loopback_response + end + def invoke(headers, body) set_wiredump_file_base(body.elename.name) - @proxy.invoke(headers, body) + env = @proxy.invoke(headers, body) + if env.nil? + return nil, nil + else + return env.header, env.body + end end def call(name, *params) set_wiredump_file_base(name) # Convert parameters: params array => SOAPArray => members array params = Mapping.obj2soap(params, @mapping_registry).to_a - header, body = @proxy.call(nil, name, *params) - raise EmptyResponseError.new("Empty response.") unless body + env = @proxy.call(call_headers, name, *params) + raise EmptyResponseError.new("Empty response.") unless env + receive_headers(env.header) begin - @proxy.check_fault(body) + @proxy.check_fault(env.body) rescue SOAP::FaultError => e Mapping.fault2exception(e) end - ret = body.response ? - Mapping.soap2obj(body.response, @mapping_registry) : nil - if body.outparams - outparams = body.outparams.collect { |outparam| + ret = env.body.response ? + Mapping.soap2obj(env.body.response, @mapping_registry) : nil + if env.body.outparams + outparams = env.body.outparams.collect { |outparam| Mapping.soap2obj(outparam) } return [ret].concat(outparams) @@ -227,10 +248,28 @@ private @servant.call(#{ name.dump }#{ callparam }) end EOS + @host.method(name) end private + def call_headers + headers = @headerhandler.on_outbound + if headers.empty? + nil + else + h = ::SOAP::SOAPHeader.new + headers.each do |header| + h.add(header.elename.name, header) + end + h + end + end + + def receive_headers(headers) + @headerhandler.on_inbound(headers) if headers + end + def set_wiredump_file_base(name) if @wiredump_file_base @streamhandler.wiredump_file_base = @wiredump_file_base + "_#{ name }" diff --git a/lib/soap/rpc/element.rb b/lib/soap/rpc/element.rb index 395823ab00..8a2f319293 100644 --- a/lib/soap/rpc/element.rb +++ b/lib/soap/rpc/element.rb @@ -43,7 +43,7 @@ class SOAPBody < SOAPStruct end def void? - root_node.nil? # || root_node.is_a?(SOAPNil) + root_node.nil? end def fault @@ -113,6 +113,7 @@ class SOAPMethod < SOAPStruct params.each do |param, data| @inparam[param] = data data.elename.name = param + data.parent = self end end @@ -226,6 +227,8 @@ class SOAPMethodResponse < SOAPMethod def retval=(retval) @retval = retval @retval.elename = @retval.elename.dup_name(@retval_name || 'return') + retval.parent = self + retval end def each diff --git a/lib/soap/rpc/proxy.rb b/lib/soap/rpc/proxy.rb index 5825a27138..355bf2e81a 100644 --- a/lib/soap/rpc/proxy.rb +++ b/lib/soap/rpc/proxy.rb @@ -1,5 +1,5 @@ # SOAP4R - RPC Proxy library. -# Copyright (C) 2000, 2003 NAKAMURA, Hiroshi . +# Copyright (C) 2000, 2003, 2004 NAKAMURA, Hiroshi . # This program is copyrighted free software by NAKAMURA, Hiroshi. You can # redistribute it and/or modify it under the same terms of Ruby's license; @@ -12,6 +12,7 @@ require 'soap/mapping' require 'soap/rpc/rpc' require 'soap/rpc/element' require 'soap/streamHandler' +require 'soap/mimemessage' module SOAP @@ -79,7 +80,6 @@ public raise SOAP::RPC::MethodDefinitionError.new( "Method: #{ name } not defined.") end - Request.new(method, values) end @@ -91,21 +91,30 @@ public req_body = SOAPBody.new(req_body) end opt = create_options - send_string = Processor.marshal(req_header, req_body, opt) - data = @streamhandler.send(send_string, soapaction) - if data.receive_string.empty? + opt[:external_content] = nil + req_env = SOAPEnvelope.new(req_header, req_body) + send_string = Processor.marshal(req_env, opt) + conn_data = StreamHandler::ConnectionData.new(send_string) + if ext = opt[:external_content] + mime = MIMEMessage.new + ext.each do |k, v| + mime.add_attachment(v.data) + end + mime.add_part(conn_data.send_string + "\r\n") + mime.close + conn_data.send_string = mime.content_str + conn_data.send_contenttype = mime.headers['content-type'].str + end + conn_data = @streamhandler.send(conn_data, soapaction) + if conn_data.receive_string.empty? return nil, nil end - opt = create_options - opt[:charset] = @mandatorycharset || - StreamHandler.parse_media_type(data.receive_contenttype) - res_header, res_body = Processor.unmarshal(data.receive_string, opt) - return res_header, res_body + unmarshal(conn_data, opt) end - def call(headers, name, *values) + def call(req_header, name, *values) req = create_request(name, *values) - return invoke(headers, req.method, req.method.soapaction || @soapaction) + invoke(req_header, req.method, req.method.soapaction || @soapaction) end def check_fault(body) @@ -116,6 +125,29 @@ public private + def unmarshal(conn_data, opt) + contenttype = conn_data.receive_contenttype + if /#{MIMEMessage::MultipartContentType}/i =~ contenttype + opt[:external_content] = {} + mime = MIMEMessage.parse("Content-Type: " + contenttype, + conn_data.receive_string) + mime.parts.each do |part| + value = Attachment.new(part.content) + value.contentid = part.contentid + obj = SOAPAttachment.new(value) + opt[:external_content][value.contentid] = obj if value.contentid + end + opt[:charset] = @mandatorycharset || + StreamHandler.parse_media_type(mime.root.headers['content-type'].str) + env = Processor.unmarshal(mime.root.content, opt) + else + opt[:charset] = @mandatorycharset || + ::SOAP::StreamHandler.parse_media_type(contenttype) + env = Processor.unmarshal(conn_data.receive_string, opt) + end + env + end + def create_header(headers) header = SOAPHeader.new() headers.each do |content, mustunderstand, encodingstyle| diff --git a/lib/soap/rpc/router.rb b/lib/soap/rpc/router.rb index 527ec05768..9d8d1c8da6 100644 --- a/lib/soap/rpc/router.rb +++ b/lib/soap/rpc/router.rb @@ -11,6 +11,9 @@ require 'soap/processor' require 'soap/mapping' require 'soap/rpc/rpc' require 'soap/rpc/element' +require 'soap/streamHandler' +require 'soap/mimemessage' +require 'soap/header/handlerset' module SOAP @@ -24,6 +27,7 @@ class Router attr_accessor :allow_unqualified_element attr_accessor :default_encodingstyle attr_accessor :mapping_registry + attr_reader :headerhandler def initialize(actor) @actor = actor @@ -33,6 +37,7 @@ class Router @allow_unqualified_element = false @default_encodingstyle = nil @mapping_registry = nil + @headerhandler = Header::HandlerSet.new end def add_method(receiver, qname, soapaction, name, param_def) @@ -42,47 +47,112 @@ class Router @method[fqname] = RPC::SOAPMethodRequest.new(qname, param_def, soapaction) end - def add_header_handler - raise NotImplementedError.new - end - - # Routing... - def route(soap_string, charset = nil) - opt = options - opt[:charset] = charset - is_fault = false + def route(conn_data) + soap_response = nil begin - header, body = Processor.unmarshal(soap_string, opt) - # So far, header is omitted... - soap_request = body.request + env = unmarshal(conn_data) + if env.nil? + raise ArgumentError.new("Illegal SOAP marshal format.") + end + receive_headers(env.header) + soap_request = env.body.request unless soap_request.is_a?(SOAPStruct) raise RPCRoutingError.new("Not an RPC style.") end soap_response = dispatch(soap_request) rescue Exception soap_response = fault($!) - is_fault = true + conn_data.is_fault = true end - header = SOAPHeader.new + opt = options + opt[:external_content] = nil + header = call_headers body = SOAPBody.new(soap_response) - response_string = Processor.marshal(header, body, opt) - - return response_string, is_fault + env = SOAPEnvelope.new(header, body) + response_string = Processor.marshal(env, opt) + conn_data.send_string = response_string + if ext = opt[:external_content] + mime = MIMEMessage.new + ext.each do |k, v| + mime.add_attachment(v.data) + end + mime.add_part(conn_data.send_string + "\r\n") + mime.close + conn_data.send_string = mime.content_str + conn_data.send_contenttype = mime.headers['content-type'].str + end + conn_data end # Create fault response string. def create_fault_response(e, charset = nil) header = SOAPHeader.new - soap_response = fault(e) - body = SOAPBody.new(soap_response) + body = SOAPBody.new(fault(e)) + env = SOAPEnvelope.new(header, body) opt = options + opt[:external_content] = nil opt[:charset] = charset - Processor.marshal(header, body, opt) + response_string = Processor.marshal(env, opt) + conn_data = StreamHandler::ConnectionData.new(response_string) + conn_data.is_fault = true + if ext = opt[:external_content] + mime = MIMEMessage.new + ext.each do |k, v| + mime.add_attachment(v.data) + end + mime.add_part(conn_data.send_string + "\r\n") + mime.close + conn_data.send_string = mime.content_str + conn_data.send_contenttype = mime.headers['content-type'].str + end + conn_data end private + def call_headers + headers = @headerhandler.on_outbound + if headers.empty? + nil + else + h = ::SOAP::SOAPHeader.new + headers.each do |header| + h.add(header.elename.name, header) + end + h + end + end + + def receive_headers(headers) + @headerhandler.on_inbound(headers) if headers + end + + def unmarshal(conn_data) + opt = options + contenttype = conn_data.receive_contenttype + if /#{MIMEMessage::MultipartContentType}/i =~ contenttype + opt[:external_content] = {} + mime = MIMEMessage.parse("Content-Type: " + contenttype, + conn_data.receive_string) + mime.parts.each do |part| + value = Attachment.new(part.content) + value.contentid = part.contentid + obj = SOAPAttachment.new(value) + opt[:external_content][value.contentid] = obj if value.contentid + end + opt[:charset] = + StreamHandler.parse_media_type(mime.root.headers['content-type'].str) + env = Processor.unmarshal(mime.root.content, opt) + else + opt[:charset] = ::SOAP::StreamHandler.parse_media_type(contenttype) + env = Processor.unmarshal(conn_data.receive_string, opt) + end + charset = opt[:charset] + conn_data.send_contenttype = "text/xml; charset=\"#{charset}\"" + env + end + # Create new response. def create_response(qname, result) name = fqname(qname) diff --git a/lib/soap/rpc/soaplet.rb b/lib/soap/rpc/soaplet.rb index ec172fd85e..0c1427acf5 100644 --- a/lib/soap/rpc/soaplet.rb +++ b/lib/soap/rpc/soaplet.rb @@ -1,5 +1,5 @@ # SOAP4R - SOAP handler servlet for WEBrick -# Copyright (C) 2001, 2002, 2003 NAKAMURA, Hiroshi . +# Copyright (C) 2001, 2002, 2003, 2004 NAKAMURA, Hiroshi . # This program is copyrighted free software by NAKAMURA, Hiroshi. You can # redistribute it and/or modify it under the same terms of Ruby's license; @@ -22,20 +22,28 @@ public def initialize @router_map = {} @app_scope_router = ::SOAP::RPC::Router.new(self.class.name) + @headerhandlerfactory = [] + @app_scope_headerhandler = nil end - # Add servant klass whose object has request scope. A servant object is - # instantiated for each request. + # Add servant factory whose object has request scope. A servant object is + # instanciated for each request. # - # Bare in mind that servant klasses are distinguished by HTTP SOAPAction + # Bear in mind that servant factories are distinguished by HTTP SOAPAction # header in request. Client which calls request-scoped servant must have a - # SOAPAction header which is a namespace of the servant klass. + # SOAPAction header which is a namespace of the servant factory. # I mean, use Driver#add_method_with_soapaction instead of Driver#add_method # at client side. # - def add_rpc_request_servant(klass, namespace, mapping_registry = nil) - router = RequestRouter.new(klass, namespace, mapping_registry) - add_router(namespace, router) + # A factory must respond to :create. + # + def add_rpc_request_servant(factory, namespace, mapping_registry = nil) + unless factory.respond_to?(:create) + raise TypeError.new("factory must respond to 'create'") + end + router = setup_request_router(namespace) + router.factory = factory + router.mapping_registry = mapping_registry end # Add servant object which has application scope. @@ -46,6 +54,17 @@ public end alias add_servant add_rpc_servant + def add_rpc_request_headerhandler(factory) + unless factory.respond_to?(:create) + raise TypeError.new("factory must respond to 'create'") + end + @headerhandlerfactory << factory + end + + def add_rpc_headerhandler(obj) + @app_scope_headerhandler = obj + end + alias add_headerhandler add_rpc_headerhandler ### ## Servlet interfaces for WEBrick. @@ -67,42 +86,43 @@ public def do_POST(req, res) namespace = parse_soapaction(req.meta_vars['HTTP_SOAPACTION']) router = lookup_router(namespace) - - is_fault = false - - charset = ::SOAP::StreamHandler.parse_media_type(req['content-type']) - begin - response_stream, is_fault = router.route(req.body, charset) - rescue Exception => e - response_stream = router.create_fault_response(e) - is_fault = true + with_headerhandler(router) do |router| + begin + conn_data = ::SOAP::StreamHandler::ConnectionData.new + conn_data.receive_string = req.body + conn_data.receive_contenttype = req['content-type'] + conn_data = router.route(conn_data) + if conn_data.is_fault + res.status = WEBrick::HTTPStatus::RC_INTERNAL_SERVER_ERROR + end + res.body = conn_data.send_string + res['content-type'] = conn_data.send_contenttype + rescue Exception => e + conn_data = router.create_fault_response(e) + res.status = WEBrick::HTTPStatus::RC_INTERNAL_SERVER_ERROR + res.body = conn_data.send_string + res['content-type'] = conn_data.send_contenttype || "text/xml" + end end - res.body = response_stream - res['content-type'] = "text/xml; charset=\"#{charset}\"" - if response_stream.is_a?(IO) + if res.body.is_a?(IO) res.chunked = true end - - if is_fault - res.status = WEBrick::HTTPStatus::RC_INTERNAL_SERVER_ERROR - end end private class RequestRouter < ::SOAP::RPC::Router - def initialize(klass, namespace, mapping_registry = nil) + attr_accessor :factory + + def initialize(namespace = nil) super(namespace) - if mapping_registry - self.mapping_registry = mapping_registry - end - @klass = klass @namespace = namespace + @factory = nil end def route(soap_string) - obj = @klass.new + obj = @factory.create namespace = self.actor router = ::SOAP::RPC::Router.new(@namespace) SOAPlet.add_servant_to_router(router, obj, namespace) @@ -110,6 +130,12 @@ private end end + def setup_request_router(namespace) + router = @router_map[namespace] || RequestRouter.new(namespace) + add_router(namespace, router) + router + end + def add_router(namespace, router) @router_map[namespace] = router end @@ -132,11 +158,29 @@ private end end + def with_headerhandler(router) + if @app_scope_headerhandler and + !router.headerhandler.include?(@app_scope_headerhandler) + router.headerhandler.add(@app_scope_headerhandler) + end + handlers = @headerhandlerfactory.collect { |f| f.create } + begin + handlers.each { |h| router.headerhandler.add(h) } + yield(router) + ensure + handlers.each { |h| router.headerhandler.delete(h) } + end + end + class << self public def add_servant_to_router(router, obj, namespace) ::SOAP::RPC.defined_methods(obj).each do |name| - add_servant_method_to_router(router, obj, namespace, name) + begin + add_servant_method_to_router(router, obj, namespace, name) + rescue SOAP::RPC::MethodDefinitionError => e + p e if $DEBUG + end end end @@ -145,7 +189,7 @@ private soapaction = nil method = obj.method(name) param_def = ::SOAP::RPC::SOAPMethod.create_param_def( - (1..method.arity.abs).collect { |i| "p#{ i }" }) + (1..method.arity.abs).collect { |i| "p#{ i }" }) router.add_method(obj, qname, soapaction, name, param_def) end end diff --git a/lib/soap/rpc/standaloneServer.rb b/lib/soap/rpc/standaloneServer.rb index 42a566e088..080343ba33 100644 --- a/lib/soap/rpc/standaloneServer.rb +++ b/lib/soap/rpc/standaloneServer.rb @@ -6,111 +6,35 @@ # either the dual license version in 2003, or any later version. -require 'logger' -require 'soap/rpc/soaplet' -require 'soap/streamHandler' - -# require 'webrick' -require 'webrick/compat.rb' -require 'webrick/version.rb' -require 'webrick/config.rb' -require 'webrick/log.rb' -require 'webrick/server.rb' -require 'webrick/utils.rb' -require 'webrick/accesslog' -# require 'webrick/htmlutils.rb' -require 'webrick/httputils.rb' -# require 'webrick/cookie.rb' -require 'webrick/httpversion.rb' -require 'webrick/httpstatus.rb' -require 'webrick/httprequest.rb' -require 'webrick/httpresponse.rb' -require 'webrick/httpserver.rb' -# require 'webrick/httpservlet.rb' -# require 'webrick/httpauth.rb' +require 'soap/rpc/httpserver' module SOAP module RPC -class StandaloneServer < Logger::Application - attr_reader :server - - def initialize(app_name, namespace, host = "0.0.0.0", port = 8080) - super(app_name) - self.level = Logger::Severity::INFO - @namespace = namespace +class StandaloneServer < HTTPServer + def initialize(appname, default_namespace, host = "0.0.0.0", port = 8080) + @appname = appname + @default_namespace = default_namespace @host = host @port = port - @server = nil - @soaplet = ::SOAP::RPC::SOAPlet.new - on_init - end - - def on_init - # define extra methods in derived class. - end - - def status - if @server - @server.status - else - nil - end - end - - def shutdown - @server.shutdown - end - - def add_rpc_request_servant(klass, namespace = @namespace, mapping_registry = nil) - @soaplet.add_rpc_request_servant(klass, namespace, mapping_registry) + super(create_config) end - def add_rpc_servant(obj, namespace = @namespace) - @soaplet.add_rpc_servant(obj, namespace) - end alias add_servant add_rpc_servant - - def mapping_registry - @soaplet.app_scope_router.mapping_registry - end - - def mapping_registry=(mapping_registry) - @soaplet.app_scope_router.mapping_registry = mapping_registry - end - - def add_method(obj, name, *param) - add_method_as(obj, name, name, *param) - end - - def add_method_as(obj, name, name_as, *param) - qname = XSD::QName.new(@namespace, name_as) - soapaction = nil - method = obj.method(name) - param_def = if param.size == 1 and param[0].is_a?(Array) - param[0] - elsif param.empty? - ::SOAP::RPC::SOAPMethod.create_param_def( - (1..method.arity.abs).collect { |i| "p#{ i }" }) - else - SOAP::RPC::SOAPMethod.create_param_def(param) - end - @soaplet.app_scope_router.add_method(obj, qname, soapaction, name, param_def) - end + alias add_headerhandler add_rpc_headerhandler private - def run - @server = WEBrick::HTTPServer.new( + def create_config + { :BindAddress => @host, - :Logger => @log, + :Port => @port, :AccessLog => [], - :Port => @port - ) - @server.mount('/', @soaplet) - @server.start + :SOAPDefaultNamespace => @default_namespace, + :SOAPHTTPServerApplicationName => @appname, + } end end diff --git a/lib/soap/soap.rb b/lib/soap/soap.rb index d00d89b05b..02b26e4246 100644 --- a/lib/soap/soap.rb +++ b/lib/soap/soap.rb @@ -1,5 +1,5 @@ # soap/soap.rb: SOAP4R - Base definitions. -# Copyright (C) 2000, 2001, 2002, 2003 NAKAMURA, Hiroshi . +# Copyright (C) 2000-2004 NAKAMURA, Hiroshi . # This program is copyrighted free software by NAKAMURA, Hiroshi. You can # redistribute it and/or modify it under the same terms of Ruby's license; @@ -48,6 +48,7 @@ EleFaultStringName = XSD::QName.new(nil, EleFaultString) EleFaultActorName = XSD::QName.new(nil, EleFaultActor) EleFaultCodeName = XSD::QName.new(nil, EleFaultCode) EleFaultDetailName = XSD::QName.new(nil, EleFaultDetail) +AttrMustUnderstandName = XSD::QName.new(EnvelopeNamespace, AttrMustUnderstand) AttrEncodingStyleName = XSD::QName.new(EnvelopeNamespace, AttrEncodingStyle) AttrRootName = XSD::QName.new(EncodingNamespace, AttrRoot) AttrArrayTypeName = XSD::QName.new(EncodingNamespace, AttrArrayType) @@ -75,6 +76,8 @@ class ArrayStoreError < Error; end class RPCRoutingError < Error; end +class UnhandledMustUnderstandHeaderError < Error; end + class FaultError < Error attr_reader :faultcode attr_reader :faultstring diff --git a/lib/soap/streamHandler.rb b/lib/soap/streamHandler.rb index d6b9c3bdca..efadf21e07 100644 --- a/lib/soap/streamHandler.rb +++ b/lib/soap/streamHandler.rb @@ -33,21 +33,14 @@ class StreamHandler attr_accessor :send_contenttype attr_accessor :receive_string attr_accessor :receive_contenttype + attr_accessor :is_fault - def initialize - @send_string = nil + def initialize(send_string = nil) + @send_string = send_string @send_contenttype = nil @receive_string = nil @receive_contenttype = nil - @bag = {} - end - - def [](idx) - @bag[idx] - end - - def []=(idx, value) - @bag[idx] = value + @is_fault = false end end @@ -59,7 +52,7 @@ class StreamHandler def self.parse_media_type(str) if /^#{ MediaType }(?:\s*;\s*charset=([^"]+|"[^"]+"))?$/i !~ str - raise StreamError.new("Illegal media type."); + return nil end charset = $1 charset.gsub!(/"/, '') if charset @@ -90,18 +83,24 @@ public @options = options set_options @client.debug_dev = @wiredump_dev + @cookie_store = nil + end + + def test_loopback_response + @client.test_loopback_response end def inspect "#<#{self.class}:#{endpoint_url}>" end - def send(soap_string, soapaction = nil, charset = @charset) - send_post(soap_string, soapaction, charset) + def send(conn_data, soapaction = nil, charset = @charset) + send_post(conn_data, soapaction, charset) end def reset @client.reset(@endpoint_url) + @client.save_cookie_store if @cookie_store end private @@ -125,10 +124,6 @@ private @options.add_hook("cookie_store_file") do |key, value| set_cookie_store_file(value) end - set_ssl_config(@options["ssl_config"]) - @options.add_hook("ssl_config") do |key, value| - set_ssl_config(@options["ssl_config"]) - end @charset = @options["charset"] || XSD::Charset.charset_label($KCODE) @options.add_hook("charset") do |key, value| @charset = value @@ -138,12 +133,18 @@ private @wiredump_dev = value @client.debug_dev = @wiredump_dev end + ssl_config = @options["ssl_config"] ||= ::SOAP::Property.new + set_ssl_config(ssl_config) + ssl_config.add_hook(true) do |key, value| + set_ssl_config(ssl_config) + end basic_auth = @options["basic_auth"] ||= ::SOAP::Property.new set_basic_auth(basic_auth) basic_auth.add_hook do |key, value| set_basic_auth(basic_auth) end @options.lock(true) + ssl_config.unlock basic_auth.unlock end @@ -154,34 +155,82 @@ private end def set_cookie_store_file(value) - return unless value - raise NotImplementedError.new + @cookie_store = value + @client.set_cookie_store(@cookie_store) if @cookie_store + end + + def set_ssl_config(ssl_config) + ssl_config.each do |key, value| + cfg = @client.ssl_config + case key + when 'client_cert' + cfg.client_cert = cert_from_file(value) + when 'client_key' + cfg.client_key = key_from_file(value) + when 'client_ca' + cfg.client_ca = value + when 'ca_path' + cfg.set_trust_ca(value) + when 'ca_file' + cfg.set_trust_ca(value) + when 'crl' + cfg.set_crl(value) + when 'verify_mode' + cfg.verify_mode = ssl_config_int(value) + when 'verify_depth' + cfg.verify_depth = ssl_config_int(value) + when 'options' + cfg.options = value + when 'ciphers' + cfg.ciphers = value + when 'verify_callback' + cfg.verify_callback = value + when 'cert_store' + cfg.cert_store = value + else + raise ArgumentError.new("unknown ssl_config property #{key}") + end + end + end + + def ssl_config_int(value) + if value.nil? or value.empty? + nil + else + begin + Integer(value) + rescue ArgumentError + ::SOAP::Property::Util.const_from_name(value) + end + end end - def set_ssl_config(value) - return unless value - raise NotImplementedError.new + def cert_from_file(filename) + OpenSSL::X509::Certificate.new(File.open(filename) { |f| f.read }) end - def send_post(soap_string, soapaction, charset) - data = ConnectionData.new - data.send_string = soap_string - data.send_contenttype = StreamHandler.create_media_type(charset) + def key_from_file(filename) + OpenSSL::PKey::RSA.new(File.open(filename) { |f| f.read }) + end + + def send_post(conn_data, soapaction, charset) + conn_data.send_contenttype ||= StreamHandler.create_media_type(charset) if @wiredump_file_base filename = @wiredump_file_base + '_request.xml' f = File.open(filename, "w") - f << soap_string + f << conn_data.send_string f.close end extra = {} - extra['Content-Type'] = data.send_contenttype + extra['Content-Type'] = conn_data.send_contenttype extra['SOAPAction'] = "\"#{ soapaction }\"" + send_string = conn_data.send_string @wiredump_dev << "Wire dump:\n\n" if @wiredump_dev begin - res = @client.post(@endpoint_url, soap_string, extra) + res = @client.post(@endpoint_url, send_string, extra) rescue @client.reset(@endpoint_url) raise @@ -206,10 +255,9 @@ private raise HTTPStreamError.new("#{ res.status }: #{ res.reason }") end - data.receive_string = receive_string - data.receive_contenttype = res.contenttype - - return data + conn_data.receive_string = receive_string + conn_data.receive_contenttype = res.contenttype + conn_data end CRLF = "\r\n" diff --git a/lib/soap/wsdlDriver.rb b/lib/soap/wsdlDriver.rb index d1a1a6cf29..af868ea886 100644 --- a/lib/soap/wsdlDriver.rb +++ b/lib/soap/wsdlDriver.rb @@ -12,11 +12,13 @@ require 'xsd/qname' require 'soap/element' require 'soap/baseData' require 'soap/streamHandler' +require 'soap/mimemessage' require 'soap/mapping' require 'soap/mapping/wsdlRegistry' require 'soap/rpc/rpc' require 'soap/rpc/element' require 'soap/processor' +require 'soap/header/handlerset' require 'logger' @@ -91,6 +93,8 @@ class WSDLDriver end __attr_proxy :options + __attr_proxy :headerhandler + __attr_proxy :test_loopback_response __attr_proxy :endpoint_url, true __attr_proxy :mapping_registry, true # for RPC unmarshal __attr_proxy :wsdl_mapping_registry, true # for RPC marshal @@ -151,6 +155,7 @@ class WSDLDriver attr_reader :options attr_reader :streamhandler + attr_reader :headerhandler attr_reader :port attr_accessor :mapping_registry @@ -175,7 +180,7 @@ class WSDLDriver @mandatorycharset = nil @wsdl_elements = @wsdl.collect_elements - @wsdl_types = @wsdl.collect_complextypes + @wsdl_types = @wsdl.collect_complextypes + @wsdl.collect_simpletypes @rpc_decode_typemap = @wsdl_types + @wsdl.soap_rpc_complextypes(port.find_binding) @wsdl_mapping_registry = Mapping::WSDLRegistry.new(@rpc_decode_typemap) @@ -183,6 +188,7 @@ class WSDLDriver endpoint_url = @port.soap_address.location @streamhandler = HTTPPostStreamHandler.new(endpoint_url, @options["protocol.http"] ||= Property.new) + @headerhandler = Header::HandlerSet.new # Convert a map which key is QName, to a Hash which key is String. @operations = {} @port.inputoperation_map.each do |op_name, op_info| @@ -200,14 +206,19 @@ class WSDLDriver @streamhandler.reset end + def test_loopback_response + @streamhandler.test_loopback_response + end + def rpc_send(method_name, *params) log(INFO) { "call: calling method '#{ method_name }'." } log(DEBUG) { "call: parameters '#{ params.inspect }'." } op_info = @operations[method_name] method = create_method_struct(op_info, params) - req_header = nil + req_header = call_headers req_body = SOAPBody.new(method) + req_env = SOAPEnvelope.new(req_header, req_body) if @wiredump_file_base @streamhandler.wiredump_file_base = @@ -217,19 +228,20 @@ class WSDLDriver begin opt = create_options opt[:decode_typemap] = @rpc_decode_typemap - res_header, res_body = invoke(req_header, req_body, op_info, opt) - if res_body.fault - raise SOAP::FaultError.new(res_body.fault) + res_env = invoke(req_env, op_info, opt) + receive_headers(res_env.header) + if res_env.body.fault + raise ::SOAP::FaultError.new(res_env.body.fault) end - rescue SOAP::FaultError => e + rescue ::SOAP::FaultError => e Mapping.fault2exception(e) end - ret = res_body.response ? - Mapping.soap2obj(res_body.response, @mapping_registry) : nil + ret = res_env.body.response ? + Mapping.soap2obj(res_env.body.response, @mapping_registry) : nil - if res_body.outparams - outparams = res_body.outparams.collect { |outparam| + if res_env.body.outparams + outparams = res_env.body.outparams.collect { |outparam| Mapping.soap2obj(outparam) } return [ret].concat(outparams) @@ -245,18 +257,36 @@ class WSDLDriver op_info = @operations[name] req_header = header_from_obj(header_obj, op_info) req_body = body_from_obj(body_obj, op_info) + req_env = SOAPEnvelope.new(req_header, req_body) opt = create_options - res_header, res_body = invoke(req_header, req_body, op_info, opt) - if res_body.fault - raise SOAP::FaultError.new(res_body.fault) + res_env = invoke(req_env, op_info, opt) + if res_env.body.fault + raise ::SOAP::FaultError.new(res_env.body.fault) end - res_body_obj = res_body.response ? - Mapping.soap2obj(res_body.response, @mapping_registry) : nil - return res_header, res_body_obj + res_body_obj = res_env.body.response ? + Mapping.soap2obj(res_env.body.response, @mapping_registry) : nil + return res_env.header, res_body_obj end private + def call_headers + headers = @headerhandler.on_outbound + if headers.empty? + nil + else + h = ::SOAP::SOAPHeader.new + headers.each do |header| + h.add(header.elename.name, header) + end + h + end + end + + def receive_headers(headers) + @headerhandler.on_inbound(headers) if headers + end + def create_method_struct(op_info, params) parts_names = op_info.bodyparts.collect { |part| part.name } obj = create_method_obj(parts_names, params) @@ -283,18 +313,50 @@ class WSDLDriver o end - def invoke(req_header, req_body, op_info, opt) - send_string = Processor.marshal(req_header, req_body, opt) + def invoke(req_env, op_info, opt) + opt[:external_content] = nil + send_string = Processor.marshal(req_env, opt) log(DEBUG) { "invoke: sending string #{ send_string }" } - data = @streamhandler.send(send_string, op_info.soapaction) - log(DEBUG) { "invoke: received string #{ data.receive_string }" } - if data.receive_string.empty? + conn_data = StreamHandler::ConnectionData.new(send_string) + if ext = opt[:external_content] + mime = MIMEMessage.new + ext.each do |k, v| + mime.add_attachment(v.data) + end + mime.add_part(conn_data.send_string + "\r\n") + mime.close + conn_data.send_string = mime.content_str + conn_data.send_contenttype = mime.headers['content-type'].str + end + conn_data = @streamhandler.send(conn_data, op_info.soapaction) + log(DEBUG) { "invoke: received string #{ conn_data.receive_string }" } + if conn_data.receive_string.empty? return nil, nil end - opt[:charset] = @mandatorycharset || - StreamHandler.parse_media_type(data.receive_contenttype) - res_header, res_body = Processor.unmarshal(data.receive_string, opt) - return res_header, res_body + unmarshal(conn_data, opt) + end + + def unmarshal(conn_data, opt) + contenttype = conn_data.receive_contenttype + if /#{MIMEMessage::MultipartContentType}/i =~ contenttype + opt[:external_content] = {} + mime = MIMEMessage.parse("Content-Type: " + contenttype, + conn_data.receive_string) + mime.parts.each do |part| + value = Attachment.new(part.content) + value.contentid = part.contentid + obj = SOAPAttachment.new(value) + opt[:external_content][value.contentid] = obj if value.contentid + end + opt[:charset] = @mandatorycharset || + StreamHandler.parse_media_type(mime.root.headers['content-type'].str) + env = Processor.unmarshal(mime.root.content, opt) + else + opt[:charset] = @mandatorycharset || + ::SOAP::StreamHandler.parse_media_type(contenttype) + env = Processor.unmarshal(conn_data.receive_string, opt) + end + env end def header_from_obj(obj, op_info) @@ -314,9 +376,9 @@ class WSDLDriver else header = SOAPHeader.new() op_info.headerparts.each do |part| - child = obj[part.elename.name] + child = Mapper.find_attribute(obj, part.name) ele = headeritem_from_obj(child, part.element || part.eletype) - header.add(ele) + header.add(part.name, ele) end header end @@ -348,7 +410,7 @@ class WSDLDriver else body = SOAPBody.new op_info.bodyparts.each do |part| - child = obj[part.elename.name] + child = Mapper.find_attribute(obj, part.name) ele = bodyitem_from_obj(child, part.element || part.type) body.add(ele.elename.name, ele) end @@ -426,6 +488,7 @@ class WSDLDriver opt end + class MappingError < StandardError; end class Mapper def initialize(elements, types) @elements = elements @@ -438,7 +501,7 @@ class WSDLDriver elsif type = @types[name] obj2type(obj, type) else - raise RuntimeError.new("Cannot find name #{name} in schema.") + raise MappingError.new("Cannot find name #{name} in schema.") end end @@ -446,6 +509,16 @@ class WSDLDriver raise NotImplementedError.new end + def Mapper.find_attribute(obj, attr_name) + if obj.respond_to?(attr_name) + obj.__send__(attr_name) + elsif obj.is_a?(Hash) + obj[attr_name] || obj[attr_name.intern] + else + obj.instance_eval("@#{ attr_name }") + end + end + private def _obj2ele(obj, ele) @@ -456,25 +529,47 @@ class WSDLDriver elsif type = TypeMap[ele.type] o = base2soap(obj, type) else - raise RuntimeError.new("Cannot find type #{ele.type}.") + raise MappingError.new("Cannot find type #{ele.type}.") end o.elename = ele.name elsif ele.local_complextype o = SOAPElement.new(ele.name) - ele.local_complextype.each_element do |child_name, child_ele| - o.add(_obj2ele(find_attribute(obj, child_name.name), child_ele)) + ele.local_complextype.each_element do |child_ele| + o.add(_obj2ele(Mapper.find_attribute(obj, child_ele.name.name), + child_ele)) end else - raise RuntimeError.new("Illegal schema?") + raise MappingError.new("Illegal schema?") end o end def obj2type(obj, type) - o = SOAPElement.new(type.name) - type.each_element do |child_name, child_ele| - o.add(_obj2ele(find_attribute(obj, child_name.name), child_ele)) - end + if type.is_a?(::WSDL::XMLSchema::SimpleType) + simple2soap(obj, type) + else + complex2soap(obj, type) + end + end + + def simple2soap(obj, type) + o = base2soap(obj, TypeMap[type.base]) + if type.restriction.enumeration.empty? + STDERR.puts("#{type.name}: simpleType which is not enum type not supported.") + return o + end + if type.restriction.enumeration.include?(o) + raise MappingError.new("#{o} is not allowed for #{type.name}") + end + o + end + + def complex2soap(obj, type) + o = SOAPElement.new(type.name) + type.each_element do |child_ele| + o.add(_obj2ele(Mapper.find_attribute(obj, child_ele.name.name), + child_ele)) + end o end @@ -486,22 +581,13 @@ class WSDLDriver soap_obj = nil if type <= XSD::XSDString soap_obj = type.new(XSD::Charset.is_ces(obj, $KCODE) ? - XSD::Charset.encoding_conv(obj, $KCODE, XSD::Charset.encoding) : obj) + XSD::Charset.encoding_conv(obj, $KCODE, XSD::Charset.encoding) : + obj) else soap_obj = type.new(obj) end soap_obj end - - def find_attribute(obj, attr_name) - if obj.respond_to?(attr_name) - obj.__send__(attr_name) - elsif obj.is_a?(Hash) - obj[attr_name] || obj[attr_name.intern] - else - obj.instance_eval("@#{ attr_name }") - end - end end end end diff --git a/lib/wsdl/data.rb b/lib/wsdl/data.rb index 8a14dd14d7..45eaad8526 100644 --- a/lib/wsdl/data.rb +++ b/lib/wsdl/data.rb @@ -6,6 +6,7 @@ # either the dual license version in 2003, or any later version. +require 'xsd/qname' require 'wsdl/documentation' require 'wsdl/definitions' require 'wsdl/types' diff --git a/lib/wsdl/definitions.rb b/lib/wsdl/definitions.rb index 561a335744..c530220fde 100644 --- a/lib/wsdl/definitions.rb +++ b/lib/wsdl/definitions.rb @@ -43,8 +43,7 @@ class Definitions < Info end def inspect - name = @name || '(unnamed)' - "#<#{self.class}:#{name}>" + sprintf("#<%s:0x%x %s>", self.class.name, __id__, @name || '(unnamed)') end def targetnamespace=(targetnamespace) @@ -58,7 +57,7 @@ class Definitions < Info result = XSD::NamedElements.new if @types @types.schemas.each do |schema| - result.concat(schema.elements) + result.concat(schema.collect_elements) end end @imports.each do |import| @@ -71,7 +70,7 @@ class Definitions < Info result = @anontypes.dup if @types @types.schemas.each do |schema| - result.concat(schema.complextypes) + result.concat(schema.collect_complextypes) end end @imports.each do |import| @@ -80,6 +79,20 @@ class Definitions < Info result end + def collect_simpletypes + result = XSD::NamedElements.new + if @types + @types.schemas.each do |schema| + result.concat(schema.collect_simpletypes) + end + end + @imports.each do |import| + result.concat(import.content.collect_simpletypes) + end + result + end + + # ToDo: simpletype must be accepted... def add_type(complextype) @anontypes << complextype end diff --git a/lib/wsdl/operation.rb b/lib/wsdl/operation.rb index 228dc85b05..be28446d34 100644 --- a/lib/wsdl/operation.rb +++ b/lib/wsdl/operation.rb @@ -119,7 +119,7 @@ private return parts.dup end if parts.length != result.length - raise RuntimeError.new("Incomplete parameter order list.") + raise RuntimeError.new("Incomplete prarmeterOrder list.") end result end diff --git a/lib/wsdl/parser.rb b/lib/wsdl/parser.rb index 7e7a4d8bce..6387911f79 100644 --- a/lib/wsdl/parser.rb +++ b/lib/wsdl/parser.rb @@ -119,7 +119,8 @@ private STDERR.puts("Unknown element #{ element }.") o = Documentation.new # which accepts any element. end - o.parent = parent + # node could be a pseudo element. pseudo element has its own parent. + o.parent = parent if o.parent.nil? end attrs.each do |key, value| attr = unless /:/ =~ key diff --git a/lib/wsdl/soap/definitions.rb b/lib/wsdl/soap/definitions.rb index 7a62242204..2f6e7e19f0 100644 --- a/lib/wsdl/soap/definitions.rb +++ b/lib/wsdl/soap/definitions.rb @@ -75,8 +75,36 @@ class Definitions < Info types + self.class.soap_rpc_complextypes end + def collect_faulttypes + result = [] + collect_fault_messages.each do |message| + parts = message(message).parts + if parts.size != 1 + raise RuntimeError.new("Expecting fault message to have only 1 part.") + end + if result.index(parts[0].type).nil? + result << parts[0].type + end + end + result + end + private + def collect_fault_messages + result = [] + porttypes.each do |porttype| + porttype.operations.each do |operation| + operation.fault.each do |fault| + if result.index(fault.message).nil? + result << fault.message + end + end + end + end + result + end + def rpc_operation_complextypes(binding) types = XSD::NamedElements.new binding.operations.each do |op_bind| diff --git a/lib/wsdl/xmlSchema/complexContent.rb b/lib/wsdl/xmlSchema/complexContent.rb index 22f6851864..66ad9e251d 100644 --- a/lib/wsdl/xmlSchema/complexContent.rb +++ b/lib/wsdl/xmlSchema/complexContent.rb @@ -28,6 +28,10 @@ class ComplexContent < Info @attributes = XSD::NamedElements.new end + def targetnamespace + parent.targetnamespace + end + def parse_element(element) case element when RestrictionName, ExtensionName diff --git a/lib/wsdl/xmlSchema/complexType.rb b/lib/wsdl/xmlSchema/complexType.rb index e889482d09..056a806dc5 100644 --- a/lib/wsdl/xmlSchema/complexType.rb +++ b/lib/wsdl/xmlSchema/complexType.rb @@ -8,6 +8,7 @@ require 'wsdl/info' require 'wsdl/xmlSchema/content' +require 'wsdl/xmlSchema/element' require 'xsd/namedelements' @@ -36,11 +37,16 @@ class ComplexType < Info def targetnamespace parent.targetnamespace end - + + AnyAsElement = Element.new(XSD::QName.new(nil, 'any'), XSD::AnyTypeName) def each_element if @content @content.elements.each do |element| - yield(element.name, element) + if element.is_a?(Any) + yield(AnyAsElement) + else + yield(element) + end end end end @@ -48,7 +54,11 @@ class ComplexType < Info def find_element(name) if @content @content.elements.each do |element| - return element if name == element.name + if element.is_a?(Any) + return AnyAsElement if name == AnyAsElement.name + else + return element if name == element.name + end end end nil @@ -57,7 +67,11 @@ class ComplexType < Info def find_element_by_name(name) if @content @content.elements.each do |element| - return element if name == element.name.name + if element.is_a?(Any) + return AnyAsElement if name == AnyAsElement.name.name + else + return element if name == element.name.name + end end end nil diff --git a/lib/wsdl/xmlSchema/data.rb b/lib/wsdl/xmlSchema/data.rb index 2fa8ad6a91..1283ac2a1d 100644 --- a/lib/wsdl/xmlSchema/data.rb +++ b/lib/wsdl/xmlSchema/data.rb @@ -6,8 +6,11 @@ # either the dual license version in 2003, or any later version. +require 'xsd/datatypes' require 'wsdl/xmlSchema/schema' require 'wsdl/xmlSchema/import' +require 'wsdl/xmlSchema/simpleType' +require 'wsdl/xmlSchema/simpleRestriction' require 'wsdl/xmlSchema/complexType' require 'wsdl/xmlSchema/complexContent' require 'wsdl/xmlSchema/any' @@ -17,7 +20,7 @@ require 'wsdl/xmlSchema/choice' require 'wsdl/xmlSchema/sequence' require 'wsdl/xmlSchema/attribute' require 'wsdl/xmlSchema/unique' - +require 'wsdl/xmlSchema/enumeration' module WSDL module XMLSchema @@ -30,6 +33,7 @@ ChoiceName = XSD::QName.new(XSD::Namespace, 'choice') ComplexContentName = XSD::QName.new(XSD::Namespace, 'complexContent') ComplexTypeName = XSD::QName.new(XSD::Namespace, 'complexType') ElementName = XSD::QName.new(XSD::Namespace, 'element') +EnumerationName = XSD::QName.new(XSD::Namespace, 'enumeration') ExtensionName = XSD::QName.new(XSD::Namespace, 'extension') ImportName = XSD::QName.new(XSD::Namespace, 'import') RestrictionName = XSD::QName.new(XSD::Namespace, 'restriction') @@ -57,6 +61,7 @@ SchemaLocationAttrName = XSD::QName.new(nil, 'schemaLocation') TargetNamespaceAttrName = XSD::QName.new(nil, 'targetNamespace') TypeAttrName = XSD::QName.new(nil, 'type') UseAttrName = XSD::QName.new(nil, 'use') +ValueAttrName = XSD::QName.new(nil, 'value') end diff --git a/lib/wsdl/xmlSchema/parser.rb b/lib/wsdl/xmlSchema/parser.rb index 688af27c8c..5401c5f729 100644 --- a/lib/wsdl/xmlSchema/parser.rb +++ b/lib/wsdl/xmlSchema/parser.rb @@ -116,7 +116,8 @@ private unless o raise UnknownElementError.new("Unknown element #{ element }.") end - o.parent = parent + # node could be a pseudo element. pseudo element has its own parent. + o.parent = parent if o.parent.nil? end attrs.each do |key, value| attr = unless /:/ =~ key diff --git a/lib/wsdl/xmlSchema/schema.rb b/lib/wsdl/xmlSchema/schema.rb index b2a195d41f..b530a92556 100644 --- a/lib/wsdl/xmlSchema/schema.rb +++ b/lib/wsdl/xmlSchema/schema.rb @@ -17,6 +17,7 @@ module XMLSchema class Schema < Info attr_reader :targetnamespace # required attr_reader :complextypes + attr_reader :simpletypes attr_reader :elements attr_reader :attributes attr_reader :imports @@ -27,6 +28,7 @@ class Schema < Info super @targetnamespace = nil @complextypes = XSD::NamedElements.new + @simpletypes = XSD::NamedElements.new @elements = XSD::NamedElements.new @attributes = XSD::NamedElements.new @imports = [] @@ -44,8 +46,9 @@ class Schema < Info @complextypes << o o when SimpleTypeName - STDERR.puts("Restriction of basetype with simpleType definition is ignored for now.") - nil + o = SimpleType.new + @simpletypes << o + o when ElementName o = Element.new @elements << o @@ -83,6 +86,12 @@ class Schema < Info result end + def collect_simpletypes + result = XSD::NamedElements.new + result.concat(@simpletypes) + result + end + def self.parse_element(element) if element == SchemaName Schema.new diff --git a/lib/xsd/datatypes.rb b/lib/xsd/datatypes.rb index 7223632b04..7173f52d65 100644 --- a/lib/xsd/datatypes.rb +++ b/lib/xsd/datatypes.rb @@ -103,6 +103,12 @@ class XSDAnySimpleType < NSDBase set(value) if value end + # true or raise + def check_lexical_format(value) + screen_data(value) + true + end + # set accepts a string which follows lexical space (ex. String: "+123"), or # an object which follows canonical space (ex. Integer: 123). def set(value) @@ -111,7 +117,7 @@ class XSDAnySimpleType < NSDBase @data = nil else @is_nil = false - _set(value) + _set(screen_data(value)) end end @@ -126,6 +132,11 @@ class XSDAnySimpleType < NSDBase private + # raises ValueSpaceError if check failed + def screen_data(value) + value + end + def _set(value) @data = value end @@ -144,12 +155,6 @@ class XSDNil < XSDAnySimpleType @type = Type set(value) end - -private - - def _set(value) - @data = value - end end @@ -167,11 +172,11 @@ class XSDString < XSDAnySimpleType private - def _set(value) + def screen_data(value) unless XSD::Charset.is_ces(value, XSD::Charset.encoding) raise ValueSpaceError.new("#{ type }: cannot accept '#{ value }'.") end - @data = value + value end end @@ -186,18 +191,18 @@ class XSDBoolean < XSDAnySimpleType private - def _set(value) + def screen_data(value) if value.is_a?(String) str = value.strip if str == 'true' || str == '1' - @data = true + true elsif str == 'false' || str == '0' - @data = false + false else raise ValueSpaceError.new("#{ type }: cannot accept '#{ str }'.") end else - @data = value ? true : false + value ? true : false end end end @@ -220,38 +225,39 @@ class XSDDecimal < XSDAnySimpleType private - def _set(d) + def screen_data(d) if d.is_a?(String) # Integer("00012") => 10 in Ruby. d.sub!(/^([+\-]?)0*(?=\d)/, "\\1") end - set_str(d) + screen_data_str(d) end - def set_str(str) + def screen_data_str(str) /^([+\-]?)(\d*)(?:\.(\d*)?)?$/ =~ str.to_s.strip unless Regexp.last_match raise ValueSpaceError.new("#{ type }: cannot accept '#{ str }'.") end - - @sign = $1 || '+' + sign = $1 || '+' int_part = $2 frac_part = $3 - int_part = '0' if int_part.empty? frac_part = frac_part ? frac_part.sub(/0+$/, '') : '' - @point = - frac_part.size - @number = int_part + frac_part - + point = - frac_part.size + number = int_part + frac_part # normalize - if @sign == '+' - @sign = '' - elsif @sign == '-' - if @number == '0' - @sign = '' + if sign == '+' + sign = '' + elsif sign == '-' + if number == '0' + sign = '' end end + [sign, point, number] + end + def _set(pair) + @sign, @point, @number = pair @data = _to_s @data.freeze end @@ -272,7 +278,7 @@ module FloatConstants NEGATIVE_INF = -1.0/0.0 POSITIVE_ZERO = +1.0/POSITIVE_INF NEGATIVE_ZERO = -1.0/POSITIVE_INF - MIN_POSITIVE_SINGLE = 2 ** -149 + MIN_POSITIVE_SINGLE = 2.0 ** -149 end class XSDFloat < XSDAnySimpleType @@ -287,20 +293,18 @@ class XSDFloat < XSDAnySimpleType private - def _set(value) + def screen_data(value) # "NaN".to_f => 0 in some environment. libc? if value.is_a?(Float) - @data = narrow32bit(value) - return + return narrow32bit(value) end - str = value.to_s.strip if str == 'NaN' - @data = NaN + NaN elsif str == 'INF' - @data = POSITIVE_INF + POSITIVE_INF elsif str == '-INF' - @data = NEGATIVE_INF + NEGATIVE_INF else if /^[+\-\.\deE]+$/ !~ str raise ValueSpaceError.new("#{ type }: cannot accept '#{ str }'.") @@ -308,7 +312,7 @@ private # Float("-1.4E") might fail on some system. str << '0' if /e$/i =~ str begin - @data = narrow32bit(Float(str)) + return narrow32bit(Float(str)) rescue ArgumentError raise ValueSpaceError.new("#{ type }: cannot accept '#{ str }'.") end @@ -357,28 +361,26 @@ class XSDDouble < XSDAnySimpleType private - def _set(value) + def screen_data(value) # "NaN".to_f => 0 in some environment. libc? if value.is_a?(Float) - @data = value - return + return value end - str = value.to_s.strip if str == 'NaN' - @data = NaN + NaN elsif str == 'INF' - @data = POSITIVE_INF + POSITIVE_INF elsif str == '-INF' - @data = NEGATIVE_INF + NEGATIVE_INF else begin - @data = Float(str) + return Float(str) rescue ArgumentError # '1.4e' cannot be parsed on some architecture. if /e\z/i =~ str begin - @data = Float(str + '0') + return Float(str + '0') rescue ArgumentError raise ValueSpaceError.new("#{ type }: cannot accept '#{ str }'.") end @@ -429,24 +431,27 @@ class XSDDuration < XSDAnySimpleType private - def _set(value) + def screen_data(value) /^([+\-]?)P(?:(\d+)Y)?(?:(\d+)M)?(?:(\d+)D)?(T(?:(\d+)H)?(?:(\d+)M)?(?:(\d+(?:\.\d+)?)S)?)?$/ =~ value.to_s.strip unless Regexp.last_match raise ValueSpaceError.new("#{ type }: cannot accept '#{ value }'.") end - if ($5 and ((!$2 and !$3 and !$4) or (!$6 and !$7 and !$8))) # Should we allow 'PT5S' here? raise ValueSpaceError.new("#{ type }: cannot accept '#{ value }'.") end + sign = $1 + year = $2.to_i + month = $3.to_i + day = $4.to_i + hour = $6.to_i + min = $7.to_i + sec = $8 ? XSDDecimal.new($8) : 0 + [sign, year, month, day, hour, min, sec] + end - @sign = $1 - @year = $2.to_i - @month = $3.to_i - @day = $4.to_i - @hour = $6.to_i - @min = $7.to_i - @sec = $8 ? XSDDecimal.new($8) : 0 + def _set(ary) + @sign, @year, @month, @day, @hour, @min, @sec = ary @data = _to_s @data.freeze end @@ -524,18 +529,18 @@ module XSDDateTimeImpl end end - def _set(t) - set_datetime_init(t) + def screen_data(t) if (t.is_a?(Date)) - @data = t + t elsif (t.is_a?(Time)) sec, min, hour, mday, month, year = t.to_a[0..5] diffday = t.usec.to_r / 1000000 / SecInDay of = t.utc_offset.to_r / SecInDay - @data = DateTime.civil(year, month, mday, hour, min, sec, of) - @data += diffday + data = DateTime.civil(year, month, mday, hour, min, sec, of) + data += diffday + data else - set_str(t) + screen_data_str(t) end end @@ -557,11 +562,7 @@ class XSDDateTime < XSDAnySimpleType private - def set_datetime_init(t) - @secfrac = nil - end - - def set_str(t) + def screen_data_str(t) /^([+\-]?\d{4,})-(\d\d)-(\d\d)T(\d\d):(\d\d):(\d\d(?:\.(\d*))?)(Z|(?:[+\-]\d\d:\d\d)?)?$/ =~ t.to_s.strip unless Regexp.last_match raise ValueSpaceError.new("#{ type }: cannot accept '#{ t }'.") @@ -569,7 +570,6 @@ private if $1 == '0000' raise ValueSpaceError.new("#{ type }: cannot accept '#{ t }'.") end - year = $1.to_i if year < 0 year += 1 @@ -581,22 +581,18 @@ private sec = $6.to_i secfrac = $7 zonestr = $8 - - @data = DateTime.civil(year, mon, mday, hour, min, sec, tz2of(zonestr)) - @secfrac = secfrac - + data = DateTime.civil(year, mon, mday, hour, min, sec, tz2of(zonestr)) if secfrac diffday = secfrac.to_i.to_r / (10 ** secfrac.size) / SecInDay - # jd = @data.jd - # day_fraction = @data.day_fraction + diffday - # @data = DateTime.new0(DateTime.jd_to_rjd(jd, day_fraction, - # @data.offset), @data.offset) - # - # Thanks to Funaba-san, above code can be simply written as below. - @data += diffday + data += diffday # FYI: new0 and jd_to_rjd are not necessary to use if you don't have # exceptional reason. end + [data, secfrac] + end + + def _set(pair) + @data, @secfrac = pair end def _to_s @@ -607,7 +603,8 @@ private if @secfrac s << ".#{ @secfrac }" else - s << sprintf("%.16f", (@data.sec_fraction * SecInDay).to_f).sub(/^0/, '').sub(/0*$/, '') + s << sprintf("%.16f", + (@data.sec_fraction * SecInDay).to_f).sub(/^0/, '').sub(/0*$/, '') end end add_tz(s) @@ -627,29 +624,26 @@ class XSDTime < XSDAnySimpleType private - def set_datetime_init(t) - @secfrac = nil - end - - def set_str(t) + def screen_data_str(t) /^(\d\d):(\d\d):(\d\d(?:\.(\d*))?)(Z|(?:([+\-])(\d\d):(\d\d))?)?$/ =~ t.to_s.strip unless Regexp.last_match raise ValueSpaceError.new("#{ type }: cannot accept '#{ t }'.") end - hour = $1.to_i min = $2.to_i sec = $3.to_i secfrac = $4 zonestr = $5 - - @data = DateTime.civil(1, 1, 1, hour, min, sec, tz2of(zonestr)) - @secfrac = secfrac - + data = DateTime.civil(1, 1, 1, hour, min, sec, tz2of(zonestr)) if secfrac diffday = secfrac.to_i.to_r / (10 ** secfrac.size) / SecInDay - @data += diffday + data += diffday end + [data, secfrac] + end + + def _set(pair) + @data, @secfrac = pair end def _to_s @@ -658,7 +652,8 @@ private if @secfrac s << ".#{ @secfrac }" else - s << sprintf("%.16f", (@data.sec_fraction * SecInDay).to_f).sub(/^0/, '').sub(/0*$/, '') + s << sprintf("%.16f", + (@data.sec_fraction * SecInDay).to_f).sub(/^0/, '').sub(/0*$/, '') end end add_tz(s) @@ -677,15 +672,11 @@ class XSDDate < XSDAnySimpleType private - def set_datetime_init(t) - end - - def set_str(t) + def screen_data_str(t) /^([+\-]?\d{4,})-(\d\d)-(\d\d)(Z|(?:([+\-])(\d\d):(\d\d))?)?$/ =~ t.to_s.strip unless Regexp.last_match raise ValueSpaceError.new("#{ type }: cannot accept '#{ t }'.") end - year = $1.to_i if year < 0 year += 1 @@ -693,8 +684,7 @@ private mon = $2.to_i mday = $3.to_i zonestr = $4 - - @data = DateTime.civil(year, mon, mday, 0, 0, 0, tz2of(zonestr)) + DateTime.civil(year, mon, mday, 0, 0, 0, tz2of(zonestr)) end def _to_s @@ -716,23 +706,18 @@ class XSDGYearMonth < XSDAnySimpleType private - def set_datetime_init(t) - end - - def set_str(t) + def screen_data_str(t) /^([+\-]?\d{4,})-(\d\d)(Z|(?:([+\-])(\d\d):(\d\d))?)?$/ =~ t.to_s.strip unless Regexp.last_match raise ValueSpaceError.new("#{ type }: cannot accept '#{ t }'.") end - year = $1.to_i if year < 0 year += 1 end mon = $2.to_i zonestr = $3 - - @data = DateTime.civil(year, mon, 1, 0, 0, 0, tz2of(zonestr)) + DateTime.civil(year, mon, 1, 0, 0, 0, tz2of(zonestr)) end def _to_s @@ -754,22 +739,17 @@ class XSDGYear < XSDAnySimpleType private - def set_datetime_init(t) - end - - def set_str(t) + def screen_data_str(t) /^([+\-]?\d{4,})(Z|(?:([+\-])(\d\d):(\d\d))?)?$/ =~ t.to_s.strip unless Regexp.last_match raise ValueSpaceError.new("#{ type }: cannot accept '#{ t }'.") end - year = $1.to_i if year < 0 year += 1 end zonestr = $2 - - @data = DateTime.civil(year, 1, 1, 0, 0, 0, tz2of(zonestr)) + DateTime.civil(year, 1, 1, 0, 0, 0, tz2of(zonestr)) end def _to_s @@ -791,20 +771,15 @@ class XSDGMonthDay < XSDAnySimpleType private - def set_datetime_init(t) - end - - def set_str(t) + def screen_data_str(t) /^(\d\d)-(\d\d)(Z|(?:[+\-]\d\d:\d\d)?)?$/ =~ t.to_s.strip unless Regexp.last_match raise ValueSpaceError.new("#{ type }: cannot accept '#{ t }'.") end - mon = $1.to_i mday = $2.to_i zonestr = $3 - - @data = DateTime.civil(1, mon, mday, 0, 0, 0, tz2of(zonestr)) + DateTime.civil(1, mon, mday, 0, 0, 0, tz2of(zonestr)) end def _to_s @@ -825,19 +800,14 @@ class XSDGDay < XSDAnySimpleType private - def set_datetime_init(t) - end - - def set_str(t) + def screen_data_str(t) /^(\d\d)(Z|(?:[+\-]\d\d:\d\d)?)?$/ =~ t.to_s.strip unless Regexp.last_match raise ValueSpaceError.new("#{ type }: cannot accept '#{ t }'.") end - mday = $1.to_i zonestr = $2 - - @data = DateTime.civil(1, 1, mday, 0, 0, 0, tz2of(zonestr)) + DateTime.civil(1, 1, mday, 0, 0, 0, tz2of(zonestr)) end def _to_s @@ -858,19 +828,14 @@ class XSDGMonth < XSDAnySimpleType private - def set_datetime_init(t) - end - - def set_str(t) + def screen_data_str(t) /^(\d\d)(Z|(?:[+\-]\d\d:\d\d)?)?$/ =~ t.to_s.strip unless Regexp.last_match raise ValueSpaceError.new("#{ type }: cannot accept '#{ t }'.") end - mon = $1.to_i zonestr = $2 - - @data = DateTime.civil(1, mon, 1, 0, 0, 0, tz2of(zonestr)) + DateTime.civil(1, mon, 1, 0, 0, 0, tz2of(zonestr)) end def _to_s @@ -903,9 +868,8 @@ class XSDHexBinary < XSDAnySimpleType private - def _set(value) - @data = value.unpack("H*")[0] - @data.tr!('a-f', 'A-F') + def screen_data(value) + value.unpack("H*")[0].tr('a-f', 'A-F') end end @@ -933,8 +897,8 @@ class XSDBase64Binary < XSDAnySimpleType private - def _set(value) - @data = [value].pack("m").strip + def screen_data(value) + [value].pack("m").strip end end @@ -949,9 +913,9 @@ class XSDAnyURI < XSDAnySimpleType private - def _set(value) + def screen_data(value) begin - @data = URI.parse(value.to_s.strip) + URI.parse(value.to_s.strip) rescue URI::InvalidURIError raise ValueSpaceError.new("#{ type }: cannot accept '#{ value }'.") end @@ -969,14 +933,18 @@ class XSDQName < XSDAnySimpleType private - def _set(value) + def screen_data(value) /^(?:([^:]+):)?([^:]+)$/ =~ value.to_s.strip unless Regexp.last_match raise ValueSpaceError.new("#{ type }: cannot accept '#{ value }'.") end + prefix = $1 + localpart = $2 + [prefix, localpart] + end - @prefix = $1 - @localpart = $2 + def _set(pair) + @prefix, @localpart = pair @data = _to_s @data.freeze end @@ -1005,7 +973,7 @@ class XSDNormalizedString < XSDString private - def _set(value) + def screen_data(value) if /[\t\r\n]/ =~ value raise ValueSpaceError.new("#{ type }: cannot accept '#{ value }'.") end @@ -1024,12 +992,17 @@ class XSDInteger < XSDDecimal private - def set_str(str) + def screen_data_str(str) begin - @data = Integer(str) + data = Integer(str) rescue ArgumentError raise ValueSpaceError.new("#{ type }: cannot accept '#{ str }'.") end + data + end + + def _set(value) + @data = value end def _to_s() @@ -1048,15 +1021,20 @@ class XSDLong < XSDInteger private - def set_str(str) + def screen_data_str(str) begin - @data = Integer(str) + data = Integer(str) rescue ArgumentError raise ValueSpaceError.new("#{ type }: cannot accept '#{ str }'.") end - unless validate(@data) + unless validate(data) raise ValueSpaceError.new("#{ type }: cannot accept '#{ str }'.") end + data + end + + def _set(value) + @data = value end MaxInclusive = +9223372036854775807 @@ -1077,15 +1055,20 @@ class XSDInt < XSDLong private - def set_str(str) + def screen_data_str(str) begin - @data = Integer(str) + data = Integer(str) rescue ArgumentError raise ValueSpaceError.new("#{ type }: cannot accept '#{ str }'.") end - unless validate(@data) + unless validate(data) raise ValueSpaceError.new("#{ type }: cannot accept '#{ str }'.") end + data + end + + def _set(value) + @data = value end MaxInclusive = +2147483647 @@ -1106,15 +1089,20 @@ class XSDShort < XSDInt private - def set_str(str) + def screen_data_str(str) begin - @data = Integer(str) + data = Integer(str) rescue ArgumentError raise ValueSpaceError.new("#{ type }: cannot accept '#{ str }'.") end - unless validate(@data) + unless validate(data) raise ValueSpaceError.new("#{ type }: cannot accept '#{ str }'.") end + data + end + + def _set(value) + @data = value end MaxInclusive = +32767 diff --git a/lib/xsd/qname.rb b/lib/xsd/qname.rb index 9dce1340f8..7185fedf2d 100644 --- a/lib/xsd/qname.rb +++ b/lib/xsd/qname.rb @@ -1,5 +1,5 @@ # XSD4R - XML QName definition. -# Copyright (C) 2002, 2003 NAKAMURA, Hiroshi . +# Copyright (C) 2002, 2003, 2004 NAKAMURA, Hiroshi . # This program is copyrighted free software by NAKAMURA, Hiroshi. You can # redistribute it and/or modify it under the same terms of Ruby's license; @@ -19,7 +19,7 @@ class QName end def dup_name(name) - self.class.new(@namespace, name) + ::XSD::QName.new(@namespace, name) end def match(rhs) @@ -55,6 +55,11 @@ class QName "{#{ namespace }}#{ name }" end + def inspect + sprintf("#<%s:0x%x %s>", self.class.name, __id__, + "{#{ namespace }}#{ name }") + end + NormalizedNameRegexp = /^\{([^}]*)\}(.*)$/ def parse(str) NormalizedNameRegexp =~ str diff --git a/sample/soap/calc/httpd.rb b/sample/soap/calc/httpd.rb index ee8ab09f50..bebcff96c6 100644 --- a/sample/soap/calc/httpd.rb +++ b/sample/soap/calc/httpd.rb @@ -1,14 +1,19 @@ #!/usr/bin/env ruby require 'webrick' -require 'getopts' +require 'soap/property' -getopts "", 'r:', 'p:8808' +docroot = "." +port = 8808 +if opt = SOAP::Property.loadproperty("samplehttpd.conf") + docroot = opt["docroot"] + port = Integer(opt["port"]) +end s = WEBrick::HTTPServer.new( :BindAddress => "0.0.0.0", - :Port => $OPT_p.to_i, - :DocumentRoot => $OPT_r || ".", + :Port => port, + :DocumentRoot => docroot, :CGIPathEnv => ENV['PATH'] ) trap(:INT){ s.shutdown } diff --git a/sample/soap/exchange/httpd.rb b/sample/soap/exchange/httpd.rb index ee8ab09f50..bebcff96c6 100644 --- a/sample/soap/exchange/httpd.rb +++ b/sample/soap/exchange/httpd.rb @@ -1,14 +1,19 @@ #!/usr/bin/env ruby require 'webrick' -require 'getopts' +require 'soap/property' -getopts "", 'r:', 'p:8808' +docroot = "." +port = 8808 +if opt = SOAP::Property.loadproperty("samplehttpd.conf") + docroot = opt["docroot"] + port = Integer(opt["port"]) +end s = WEBrick::HTTPServer.new( :BindAddress => "0.0.0.0", - :Port => $OPT_p.to_i, - :DocumentRoot => $OPT_r || ".", + :Port => port, + :DocumentRoot => docroot, :CGIPathEnv => ENV['PATH'] ) trap(:INT){ s.shutdown } diff --git a/sample/soap/sampleStruct/httpd.rb b/sample/soap/sampleStruct/httpd.rb index ee8ab09f50..bebcff96c6 100644 --- a/sample/soap/sampleStruct/httpd.rb +++ b/sample/soap/sampleStruct/httpd.rb @@ -1,14 +1,19 @@ #!/usr/bin/env ruby require 'webrick' -require 'getopts' +require 'soap/property' -getopts "", 'r:', 'p:8808' +docroot = "." +port = 8808 +if opt = SOAP::Property.loadproperty("samplehttpd.conf") + docroot = opt["docroot"] + port = Integer(opt["port"]) +end s = WEBrick::HTTPServer.new( :BindAddress => "0.0.0.0", - :Port => $OPT_p.to_i, - :DocumentRoot => $OPT_r || ".", + :Port => port, + :DocumentRoot => docroot, :CGIPathEnv => ENV['PATH'] ) trap(:INT){ s.shutdown } diff --git a/sample/soap/sampleStruct/server.rb b/sample/soap/sampleStruct/server.rb index 3caa31a052..ea1a2ef1d4 100644 --- a/sample/soap/sampleStruct/server.rb +++ b/sample/soap/sampleStruct/server.rb @@ -12,5 +12,9 @@ class SampleStructServer < SOAP::RPC::StandaloneServer end if $0 == __FILE__ - status = SampleStructServer.new('SampleStructServer', SampleStructServiceNamespace, '0.0.0.0', 7000).start + server = SampleStructServer.new('SampleStructServer', SampleStructServiceNamespace, '0.0.0.0', 7000) + trap(:INT) do + server.shutdown + end + server.start end diff --git a/sample/wsdl/amazon/AmazonSearch.rb b/sample/wsdl/amazon/AmazonSearch.rb index 1027592d85..373c7da29d 100644 --- a/sample/wsdl/amazon/AmazonSearch.rb +++ b/sample/wsdl/amazon/AmazonSearch.rb @@ -1,6 +1,5 @@ # http://soap.amazon.com class ProductLineArray < Array - # Contents type should be dumped here... @@schema_type = "ProductLineArray" @@schema_ns = "http://soap.amazon.com" end @@ -13,22 +12,30 @@ class ProductLine def Mode @mode end - + def Mode=(value) @mode = value end + def RelevanceRank + @relevanceRank + end + + def RelevanceRank=(value) + @relevanceRank = value + end + def ProductInfo @productInfo end - + def ProductInfo=(value) @productInfo = value end - def initialize(mode = nil, - productInfo = nil) + def initialize(mode = nil, relevanceRank = nil, productInfo = nil) @mode = mode + @relevanceRank = relevanceRank @productInfo = productInfo end end @@ -41,7 +48,7 @@ class ProductInfo def TotalResults @totalResults end - + def TotalResults=(value) @totalResults = value end @@ -49,7 +56,7 @@ class ProductInfo def TotalPages @totalPages end - + def TotalPages=(value) @totalPages = value end @@ -57,7 +64,7 @@ class ProductInfo def ListName @listName end - + def ListName=(value) @listName = value end @@ -65,15 +72,12 @@ class ProductInfo def Details @details end - + def Details=(value) @details = value end - def initialize(totalResults = nil, - totalPages = nil, - listName = nil, - details = nil) + def initialize(totalResults = nil, totalPages = nil, listName = nil, details = nil) @totalResults = totalResults @totalPages = totalPages @listName = listName @@ -83,7 +87,6 @@ end # http://soap.amazon.com class DetailsArray < Array - # Contents type should be dumped here... @@schema_type = "DetailsArray" @@schema_ns = "http://soap.amazon.com" end @@ -96,7 +99,7 @@ class Details def Url @url end - + def Url=(value) @url = value end @@ -104,7 +107,7 @@ class Details def Asin @asin end - + def Asin=(value) @asin = value end @@ -112,7 +115,7 @@ class Details def ProductName @productName end - + def ProductName=(value) @productName = value end @@ -120,7 +123,7 @@ class Details def Catalog @catalog end - + def Catalog=(value) @catalog = value end @@ -128,7 +131,7 @@ class Details def KeyPhrases @keyPhrases end - + def KeyPhrases=(value) @keyPhrases = value end @@ -136,7 +139,7 @@ class Details def Artists @artists end - + def Artists=(value) @artists = value end @@ -144,7 +147,7 @@ class Details def Authors @authors end - + def Authors=(value) @authors = value end @@ -152,7 +155,7 @@ class Details def Mpn @mpn end - + def Mpn=(value) @mpn = value end @@ -160,7 +163,7 @@ class Details def Starring @starring end - + def Starring=(value) @starring = value end @@ -168,7 +171,7 @@ class Details def Directors @directors end - + def Directors=(value) @directors = value end @@ -176,7 +179,7 @@ class Details def TheatricalReleaseDate @theatricalReleaseDate end - + def TheatricalReleaseDate=(value) @theatricalReleaseDate = value end @@ -184,7 +187,7 @@ class Details def ReleaseDate @releaseDate end - + def ReleaseDate=(value) @releaseDate = value end @@ -192,7 +195,7 @@ class Details def Manufacturer @manufacturer end - + def Manufacturer=(value) @manufacturer = value end @@ -200,7 +203,7 @@ class Details def Distributor @distributor end - + def Distributor=(value) @distributor = value end @@ -208,7 +211,7 @@ class Details def ImageUrlSmall @imageUrlSmall end - + def ImageUrlSmall=(value) @imageUrlSmall = value end @@ -216,7 +219,7 @@ class Details def ImageUrlMedium @imageUrlMedium end - + def ImageUrlMedium=(value) @imageUrlMedium = value end @@ -224,7 +227,7 @@ class Details def ImageUrlLarge @imageUrlLarge end - + def ImageUrlLarge=(value) @imageUrlLarge = value end @@ -232,7 +235,7 @@ class Details def MerchantId @merchantId end - + def MerchantId=(value) @merchantId = value end @@ -240,7 +243,7 @@ class Details def MinPrice @minPrice end - + def MinPrice=(value) @minPrice = value end @@ -248,7 +251,7 @@ class Details def MaxPrice @maxPrice end - + def MaxPrice=(value) @maxPrice = value end @@ -256,7 +259,7 @@ class Details def MinSalePrice @minSalePrice end - + def MinSalePrice=(value) @minSalePrice = value end @@ -264,7 +267,7 @@ class Details def MaxSalePrice @maxSalePrice end - + def MaxSalePrice=(value) @maxSalePrice = value end @@ -272,7 +275,7 @@ class Details def MultiMerchant @multiMerchant end - + def MultiMerchant=(value) @multiMerchant = value end @@ -280,7 +283,7 @@ class Details def MerchantSku @merchantSku end - + def MerchantSku=(value) @merchantSku = value end @@ -288,7 +291,7 @@ class Details def ListPrice @listPrice end - + def ListPrice=(value) @listPrice = value end @@ -296,7 +299,7 @@ class Details def OurPrice @ourPrice end - + def OurPrice=(value) @ourPrice = value end @@ -304,7 +307,7 @@ class Details def UsedPrice @usedPrice end - + def UsedPrice=(value) @usedPrice = value end @@ -312,7 +315,7 @@ class Details def RefurbishedPrice @refurbishedPrice end - + def RefurbishedPrice=(value) @refurbishedPrice = value end @@ -320,7 +323,7 @@ class Details def CollectiblePrice @collectiblePrice end - + def CollectiblePrice=(value) @collectiblePrice = value end @@ -328,7 +331,7 @@ class Details def ThirdPartyNewPrice @thirdPartyNewPrice end - + def ThirdPartyNewPrice=(value) @thirdPartyNewPrice = value end @@ -336,7 +339,7 @@ class Details def NumberOfOfferings @numberOfOfferings end - + def NumberOfOfferings=(value) @numberOfOfferings = value end @@ -344,7 +347,7 @@ class Details def ThirdPartyNewCount @thirdPartyNewCount end - + def ThirdPartyNewCount=(value) @thirdPartyNewCount = value end @@ -352,7 +355,7 @@ class Details def UsedCount @usedCount end - + def UsedCount=(value) @usedCount = value end @@ -360,7 +363,7 @@ class Details def CollectibleCount @collectibleCount end - + def CollectibleCount=(value) @collectibleCount = value end @@ -368,7 +371,7 @@ class Details def RefurbishedCount @refurbishedCount end - + def RefurbishedCount=(value) @refurbishedCount = value end @@ -376,7 +379,7 @@ class Details def ThirdPartyProductInfo @thirdPartyProductInfo end - + def ThirdPartyProductInfo=(value) @thirdPartyProductInfo = value end @@ -384,7 +387,7 @@ class Details def SalesRank @salesRank end - + def SalesRank=(value) @salesRank = value end @@ -392,7 +395,7 @@ class Details def BrowseList @browseList end - + def BrowseList=(value) @browseList = value end @@ -400,7 +403,7 @@ class Details def Media @media end - + def Media=(value) @media = value end @@ -408,15 +411,63 @@ class Details def ReadingLevel @readingLevel end - + def ReadingLevel=(value) @readingLevel = value end + def NumberOfPages + @numberOfPages + end + + def NumberOfPages=(value) + @numberOfPages = value + end + + def NumberOfIssues + @numberOfIssues + end + + def NumberOfIssues=(value) + @numberOfIssues = value + end + + def IssuesPerYear + @issuesPerYear + end + + def IssuesPerYear=(value) + @issuesPerYear = value + end + + def SubscriptionLength + @subscriptionLength + end + + def SubscriptionLength=(value) + @subscriptionLength = value + end + + def DeweyNumber + @deweyNumber + end + + def DeweyNumber=(value) + @deweyNumber = value + end + + def RunningTime + @runningTime + end + + def RunningTime=(value) + @runningTime = value + end + def Publisher @publisher end - + def Publisher=(value) @publisher = value end @@ -424,7 +475,7 @@ class Details def NumMedia @numMedia end - + def NumMedia=(value) @numMedia = value end @@ -432,7 +483,7 @@ class Details def Isbn @isbn end - + def Isbn=(value) @isbn = value end @@ -440,7 +491,7 @@ class Details def Features @features end - + def Features=(value) @features = value end @@ -448,7 +499,7 @@ class Details def MpaaRating @mpaaRating end - + def MpaaRating=(value) @mpaaRating = value end @@ -456,7 +507,7 @@ class Details def EsrbRating @esrbRating end - + def EsrbRating=(value) @esrbRating = value end @@ -464,7 +515,7 @@ class Details def AgeGroup @ageGroup end - + def AgeGroup=(value) @ageGroup = value end @@ -472,7 +523,7 @@ class Details def Availability @availability end - + def Availability=(value) @availability = value end @@ -480,7 +531,7 @@ class Details def Upc @upc end - + def Upc=(value) @upc = value end @@ -488,7 +539,7 @@ class Details def Tracks @tracks end - + def Tracks=(value) @tracks = value end @@ -496,7 +547,7 @@ class Details def Accessories @accessories end - + def Accessories=(value) @accessories = value end @@ -504,7 +555,7 @@ class Details def Platforms @platforms end - + def Platforms=(value) @platforms = value end @@ -512,7 +563,7 @@ class Details def Encoding @encoding end - + def Encoding=(value) @encoding = value end @@ -520,7 +571,7 @@ class Details def ProductDescription @productDescription end - + def ProductDescription=(value) @productDescription = value end @@ -528,7 +579,7 @@ class Details def Reviews @reviews end - + def Reviews=(value) @reviews = value end @@ -536,7 +587,7 @@ class Details def SimilarProducts @similarProducts end - + def SimilarProducts=(value) @similarProducts = value end @@ -544,7 +595,7 @@ class Details def FeaturedProducts @featuredProducts end - + def FeaturedProducts=(value) @featuredProducts = value end @@ -552,7 +603,7 @@ class Details def Lists @lists end - + def Lists=(value) @lists = value end @@ -560,7 +611,7 @@ class Details def Status @status end - + def Status=(value) @status = value end @@ -568,71 +619,12 @@ class Details def Variations @variations end - + def Variations=(value) @variations = value end - def initialize(url = nil, - asin = nil, - productName = nil, - catalog = nil, - keyPhrases = nil, - artists = nil, - authors = nil, - mpn = nil, - starring = nil, - directors = nil, - theatricalReleaseDate = nil, - releaseDate = nil, - manufacturer = nil, - distributor = nil, - imageUrlSmall = nil, - imageUrlMedium = nil, - imageUrlLarge = nil, - merchantId = nil, - minPrice = nil, - maxPrice = nil, - minSalePrice = nil, - maxSalePrice = nil, - multiMerchant = nil, - merchantSku = nil, - listPrice = nil, - ourPrice = nil, - usedPrice = nil, - refurbishedPrice = nil, - collectiblePrice = nil, - thirdPartyNewPrice = nil, - numberOfOfferings = nil, - thirdPartyNewCount = nil, - usedCount = nil, - collectibleCount = nil, - refurbishedCount = nil, - thirdPartyProductInfo = nil, - salesRank = nil, - browseList = nil, - media = nil, - readingLevel = nil, - publisher = nil, - numMedia = nil, - isbn = nil, - features = nil, - mpaaRating = nil, - esrbRating = nil, - ageGroup = nil, - availability = nil, - upc = nil, - tracks = nil, - accessories = nil, - platforms = nil, - encoding = nil, - productDescription = nil, - reviews = nil, - similarProducts = nil, - featuredProducts = nil, - lists = nil, - status = nil, - variations = nil) + def initialize(url = nil, asin = nil, productName = nil, catalog = nil, keyPhrases = nil, artists = nil, authors = nil, mpn = nil, starring = nil, directors = nil, theatricalReleaseDate = nil, releaseDate = nil, manufacturer = nil, distributor = nil, imageUrlSmall = nil, imageUrlMedium = nil, imageUrlLarge = nil, merchantId = nil, minPrice = nil, maxPrice = nil, minSalePrice = nil, maxSalePrice = nil, multiMerchant = nil, merchantSku = nil, listPrice = nil, ourPrice = nil, usedPrice = nil, refurbishedPrice = nil, collectiblePrice = nil, thirdPartyNewPrice = nil, numberOfOfferings = nil, thirdPartyNewCount = nil, usedCount = nil, collectibleCount = nil, refurbishedCount = nil, thirdPartyProductInfo = nil, salesRank = nil, browseList = nil, media = nil, readingLevel = nil, numberOfPages = nil, numberOfIssues = nil, issuesPerYear = nil, subscriptionLength = nil, deweyNumber = nil, runningTime = nil, publisher = nil, numMedia = nil, isbn = nil, features = nil, mpaaRating = nil, esrbRating = nil, ageGroup = nil, availability = nil, upc = nil, tracks = nil, accessories = nil, platforms = nil, encoding = nil, productDescription = nil, reviews = nil, similarProducts = nil, featuredProducts = nil, lists = nil, status = nil, variations = nil) @url = url @asin = asin @productName = productName @@ -673,6 +665,12 @@ class Details @browseList = browseList @media = media @readingLevel = readingLevel + @numberOfPages = numberOfPages + @numberOfIssues = numberOfIssues + @issuesPerYear = issuesPerYear + @subscriptionLength = subscriptionLength + @deweyNumber = deweyNumber + @runningTime = runningTime @publisher = publisher @numMedia = numMedia @isbn = isbn @@ -698,7 +696,6 @@ end # http://soap.amazon.com class KeyPhraseArray < Array - # Contents type should be dumped here... @@schema_type = "KeyPhraseArray" @@schema_ns = "http://soap.amazon.com" end @@ -711,7 +708,7 @@ class KeyPhrase def KeyPhrase @keyPhrase end - + def KeyPhrase=(value) @keyPhrase = value end @@ -719,13 +716,12 @@ class KeyPhrase def Type @type end - + def Type=(value) @type = value end - def initialize(keyPhrase = nil, - type = nil) + def initialize(keyPhrase = nil, type = nil) @keyPhrase = keyPhrase @type = type end @@ -733,35 +729,30 @@ end # http://soap.amazon.com class ArtistArray < Array - # Contents type should be dumped here... @@schema_type = "ArtistArray" @@schema_ns = "http://soap.amazon.com" end # http://soap.amazon.com class AuthorArray < Array - # Contents type should be dumped here... @@schema_type = "AuthorArray" @@schema_ns = "http://soap.amazon.com" end # http://soap.amazon.com class StarringArray < Array - # Contents type should be dumped here... @@schema_type = "StarringArray" @@schema_ns = "http://soap.amazon.com" end # http://soap.amazon.com class DirectorArray < Array - # Contents type should be dumped here... @@schema_type = "DirectorArray" @@schema_ns = "http://soap.amazon.com" end # http://soap.amazon.com class BrowseNodeArray < Array - # Contents type should be dumped here... @@schema_type = "BrowseNodeArray" @@schema_ns = "http://soap.amazon.com" end @@ -774,7 +765,7 @@ class BrowseNode def BrowseId @browseId end - + def BrowseId=(value) @browseId = value end @@ -782,13 +773,12 @@ class BrowseNode def BrowseName @browseName end - + def BrowseName=(value) @browseName = value end - def initialize(browseId = nil, - browseName = nil) + def initialize(browseId = nil, browseName = nil) @browseId = browseId @browseName = browseName end @@ -796,14 +786,12 @@ end # http://soap.amazon.com class FeaturesArray < Array - # Contents type should be dumped here... @@schema_type = "FeaturesArray" @@schema_ns = "http://soap.amazon.com" end # http://soap.amazon.com class TrackArray < Array - # Contents type should be dumped here... @@schema_type = "TrackArray" @@schema_ns = "http://soap.amazon.com" end @@ -816,7 +804,7 @@ class Track def TrackName @trackName end - + def TrackName=(value) @trackName = value end @@ -824,13 +812,12 @@ class Track def ByArtist @byArtist end - + def ByArtist=(value) @byArtist = value end - def initialize(trackName = nil, - byArtist = nil) + def initialize(trackName = nil, byArtist = nil) @trackName = trackName @byArtist = byArtist end @@ -838,14 +825,12 @@ end # http://soap.amazon.com class AccessoryArray < Array - # Contents type should be dumped here... @@schema_type = "AccessoryArray" @@schema_ns = "http://soap.amazon.com" end # http://soap.amazon.com class PlatformArray < Array - # Contents type should be dumped here... @@schema_type = "PlatformArray" @@schema_ns = "http://soap.amazon.com" end @@ -858,7 +843,7 @@ class Reviews def AvgCustomerRating @avgCustomerRating end - + def AvgCustomerRating=(value) @avgCustomerRating = value end @@ -866,7 +851,7 @@ class Reviews def TotalCustomerReviews @totalCustomerReviews end - + def TotalCustomerReviews=(value) @totalCustomerReviews = value end @@ -874,14 +859,12 @@ class Reviews def CustomerReviews @customerReviews end - + def CustomerReviews=(value) @customerReviews = value end - def initialize(avgCustomerRating = nil, - totalCustomerReviews = nil, - customerReviews = nil) + def initialize(avgCustomerRating = nil, totalCustomerReviews = nil, customerReviews = nil) @avgCustomerRating = avgCustomerRating @totalCustomerReviews = totalCustomerReviews @customerReviews = customerReviews @@ -890,7 +873,6 @@ end # http://soap.amazon.com class CustomerReviewArray < Array - # Contents type should be dumped here... @@schema_type = "CustomerReviewArray" @@schema_ns = "http://soap.amazon.com" end @@ -903,15 +885,23 @@ class CustomerReview def Rating @rating end - + def Rating=(value) @rating = value end + def Date + @date + end + + def Date=(value) + @date = value + end + def Summary @summary end - + def Summary=(value) @summary = value end @@ -919,15 +909,14 @@ class CustomerReview def Comment @comment end - + def Comment=(value) @comment = value end - def initialize(rating = nil, - summary = nil, - comment = nil) + def initialize(rating = nil, date = nil, summary = nil, comment = nil) @rating = rating + @date = date @summary = summary @comment = comment end @@ -935,14 +924,12 @@ end # http://soap.amazon.com class SimilarProductsArray < Array - # Contents type should be dumped here... @@schema_type = "SimilarProductsArray" @@schema_ns = "http://soap.amazon.com" end # http://soap.amazon.com class FeaturedProductsArray < Array - # Contents type should be dumped here... @@schema_type = "FeaturedProductsArray" @@schema_ns = "http://soap.amazon.com" end @@ -955,7 +942,7 @@ class FeaturedProduct def Asin @asin end - + def Asin=(value) @asin = value end @@ -963,13 +950,12 @@ class FeaturedProduct def Comment @comment end - + def Comment=(value) @comment = value end - def initialize(asin = nil, - comment = nil) + def initialize(asin = nil, comment = nil) @asin = asin @comment = comment end @@ -977,14 +963,12 @@ end # http://soap.amazon.com class ListArray < Array - # Contents type should be dumped here... @@schema_type = "ListArray" @@schema_ns = "http://soap.amazon.com" end # http://soap.amazon.com class VariationArray < Array - # Contents type should be dumped here... @@schema_type = "VariationArray" @@schema_ns = "http://soap.amazon.com" end @@ -997,7 +981,7 @@ class Variation def Asin @asin end - + def Asin=(value) @asin = value end @@ -1005,7 +989,7 @@ class Variation def ClothingSize @clothingSize end - + def ClothingSize=(value) @clothingSize = value end @@ -1013,7 +997,7 @@ class Variation def ClothingColor @clothingColor end - + def ClothingColor=(value) @clothingColor = value end @@ -1021,7 +1005,7 @@ class Variation def Price @price end - + def Price=(value) @price = value end @@ -1029,7 +1013,7 @@ class Variation def SalePrice @salePrice end - + def SalePrice=(value) @salePrice = value end @@ -1037,7 +1021,7 @@ class Variation def Availability @availability end - + def Availability=(value) @availability = value end @@ -1045,7 +1029,7 @@ class Variation def MultiMerchant @multiMerchant end - + def MultiMerchant=(value) @multiMerchant = value end @@ -1053,19 +1037,12 @@ class Variation def MerchantSku @merchantSku end - + def MerchantSku=(value) @merchantSku = value end - def initialize(asin = nil, - clothingSize = nil, - clothingColor = nil, - price = nil, - salePrice = nil, - availability = nil, - multiMerchant = nil, - merchantSku = nil) + def initialize(asin = nil, clothingSize = nil, clothingColor = nil, price = nil, salePrice = nil, availability = nil, multiMerchant = nil, merchantSku = nil) @asin = asin @clothingSize = clothingSize @clothingColor = clothingColor @@ -1085,7 +1062,7 @@ class MarketplaceSearch def MarketplaceSearchDetails @marketplaceSearchDetails end - + def MarketplaceSearchDetails=(value) @marketplaceSearchDetails = value end @@ -1103,7 +1080,7 @@ class SellerProfile def SellerProfileDetails @sellerProfileDetails end - + def SellerProfileDetails=(value) @sellerProfileDetails = value end @@ -1121,7 +1098,7 @@ class SellerSearch def SellerSearchDetails @sellerSearchDetails end - + def SellerSearchDetails=(value) @sellerSearchDetails = value end @@ -1139,7 +1116,7 @@ class MarketplaceSearchDetails def NumberOfOpenListings @numberOfOpenListings end - + def NumberOfOpenListings=(value) @numberOfOpenListings = value end @@ -1147,13 +1124,12 @@ class MarketplaceSearchDetails def ListingProductInfo @listingProductInfo end - + def ListingProductInfo=(value) @listingProductInfo = value end - def initialize(numberOfOpenListings = nil, - listingProductInfo = nil) + def initialize(numberOfOpenListings = nil, listingProductInfo = nil) @numberOfOpenListings = numberOfOpenListings @listingProductInfo = listingProductInfo end @@ -1161,7 +1137,6 @@ end # http://soap.amazon.com class MarketplaceSearchDetailsArray < Array - # Contents type should be dumped here... @@schema_type = "MarketplaceSearchDetailsArray" @@schema_ns = "http://soap.amazon.com" end @@ -1174,7 +1149,7 @@ class SellerProfileDetails def SellerNickname @sellerNickname end - + def SellerNickname=(value) @sellerNickname = value end @@ -1182,7 +1157,7 @@ class SellerProfileDetails def OverallFeedbackRating @overallFeedbackRating end - + def OverallFeedbackRating=(value) @overallFeedbackRating = value end @@ -1190,7 +1165,7 @@ class SellerProfileDetails def NumberOfFeedback @numberOfFeedback end - + def NumberOfFeedback=(value) @numberOfFeedback = value end @@ -1198,7 +1173,7 @@ class SellerProfileDetails def NumberOfCanceledBids @numberOfCanceledBids end - + def NumberOfCanceledBids=(value) @numberOfCanceledBids = value end @@ -1206,7 +1181,7 @@ class SellerProfileDetails def NumberOfCanceledAuctions @numberOfCanceledAuctions end - + def NumberOfCanceledAuctions=(value) @numberOfCanceledAuctions = value end @@ -1214,7 +1189,7 @@ class SellerProfileDetails def StoreId @storeId end - + def StoreId=(value) @storeId = value end @@ -1222,7 +1197,7 @@ class SellerProfileDetails def StoreName @storeName end - + def StoreName=(value) @storeName = value end @@ -1230,19 +1205,12 @@ class SellerProfileDetails def SellerFeedback @sellerFeedback end - + def SellerFeedback=(value) @sellerFeedback = value end - def initialize(sellerNickname = nil, - overallFeedbackRating = nil, - numberOfFeedback = nil, - numberOfCanceledBids = nil, - numberOfCanceledAuctions = nil, - storeId = nil, - storeName = nil, - sellerFeedback = nil) + def initialize(sellerNickname = nil, overallFeedbackRating = nil, numberOfFeedback = nil, numberOfCanceledBids = nil, numberOfCanceledAuctions = nil, storeId = nil, storeName = nil, sellerFeedback = nil) @sellerNickname = sellerNickname @overallFeedbackRating = overallFeedbackRating @numberOfFeedback = numberOfFeedback @@ -1256,7 +1224,6 @@ end # http://soap.amazon.com class SellerProfileDetailsArray < Array - # Contents type should be dumped here... @@schema_type = "SellerProfileDetailsArray" @@schema_ns = "http://soap.amazon.com" end @@ -1269,7 +1236,7 @@ class SellerSearchDetails def SellerNickname @sellerNickname end - + def SellerNickname=(value) @sellerNickname = value end @@ -1277,7 +1244,7 @@ class SellerSearchDetails def StoreId @storeId end - + def StoreId=(value) @storeId = value end @@ -1285,7 +1252,7 @@ class SellerSearchDetails def StoreName @storeName end - + def StoreName=(value) @storeName = value end @@ -1293,7 +1260,7 @@ class SellerSearchDetails def NumberOfOpenListings @numberOfOpenListings end - + def NumberOfOpenListings=(value) @numberOfOpenListings = value end @@ -1301,16 +1268,12 @@ class SellerSearchDetails def ListingProductInfo @listingProductInfo end - + def ListingProductInfo=(value) @listingProductInfo = value end - def initialize(sellerNickname = nil, - storeId = nil, - storeName = nil, - numberOfOpenListings = nil, - listingProductInfo = nil) + def initialize(sellerNickname = nil, storeId = nil, storeName = nil, numberOfOpenListings = nil, listingProductInfo = nil) @sellerNickname = sellerNickname @storeId = storeId @storeName = storeName @@ -1321,7 +1284,6 @@ end # http://soap.amazon.com class SellerSearchDetailsArray < Array - # Contents type should be dumped here... @@schema_type = "SellerSearchDetailsArray" @@schema_ns = "http://soap.amazon.com" end @@ -1334,7 +1296,7 @@ class ListingProductInfo def ListingProductDetails @listingProductDetails end - + def ListingProductDetails=(value) @listingProductDetails = value end @@ -1346,7 +1308,6 @@ end # http://soap.amazon.com class ListingProductDetailsArray < Array - # Contents type should be dumped here... @@schema_type = "ListingProductDetailsArray" @@schema_ns = "http://soap.amazon.com" end @@ -1359,7 +1320,7 @@ class ListingProductDetails def ExchangeId @exchangeId end - + def ExchangeId=(value) @exchangeId = value end @@ -1367,7 +1328,7 @@ class ListingProductDetails def ListingId @listingId end - + def ListingId=(value) @listingId = value end @@ -1375,7 +1336,7 @@ class ListingProductDetails def ExchangeTitle @exchangeTitle end - + def ExchangeTitle=(value) @exchangeTitle = value end @@ -1383,7 +1344,7 @@ class ListingProductDetails def ExchangeDescription @exchangeDescription end - + def ExchangeDescription=(value) @exchangeDescription = value end @@ -1391,7 +1352,7 @@ class ListingProductDetails def ExchangePrice @exchangePrice end - + def ExchangePrice=(value) @exchangePrice = value end @@ -1399,7 +1360,7 @@ class ListingProductDetails def ExchangeAsin @exchangeAsin end - + def ExchangeAsin=(value) @exchangeAsin = value end @@ -1407,7 +1368,7 @@ class ListingProductDetails def ExchangeEndDate @exchangeEndDate end - + def ExchangeEndDate=(value) @exchangeEndDate = value end @@ -1415,7 +1376,7 @@ class ListingProductDetails def ExchangeTinyImage @exchangeTinyImage end - + def ExchangeTinyImage=(value) @exchangeTinyImage = value end @@ -1423,7 +1384,7 @@ class ListingProductDetails def ExchangeSellerId @exchangeSellerId end - + def ExchangeSellerId=(value) @exchangeSellerId = value end @@ -1431,7 +1392,7 @@ class ListingProductDetails def ExchangeSellerNickname @exchangeSellerNickname end - + def ExchangeSellerNickname=(value) @exchangeSellerNickname = value end @@ -1439,7 +1400,7 @@ class ListingProductDetails def ExchangeStartDate @exchangeStartDate end - + def ExchangeStartDate=(value) @exchangeStartDate = value end @@ -1447,7 +1408,7 @@ class ListingProductDetails def ExchangeStatus @exchangeStatus end - + def ExchangeStatus=(value) @exchangeStatus = value end @@ -1455,7 +1416,7 @@ class ListingProductDetails def ExchangeQuantity @exchangeQuantity end - + def ExchangeQuantity=(value) @exchangeQuantity = value end @@ -1463,7 +1424,7 @@ class ListingProductDetails def ExchangeQuantityAllocated @exchangeQuantityAllocated end - + def ExchangeQuantityAllocated=(value) @exchangeQuantityAllocated = value end @@ -1471,7 +1432,7 @@ class ListingProductDetails def ExchangeFeaturedCategory @exchangeFeaturedCategory end - + def ExchangeFeaturedCategory=(value) @exchangeFeaturedCategory = value end @@ -1479,7 +1440,7 @@ class ListingProductDetails def ExchangeCondition @exchangeCondition end - + def ExchangeCondition=(value) @exchangeCondition = value end @@ -1487,7 +1448,7 @@ class ListingProductDetails def ExchangeConditionType @exchangeConditionType end - + def ExchangeConditionType=(value) @exchangeConditionType = value end @@ -1495,7 +1456,7 @@ class ListingProductDetails def ExchangeAvailability @exchangeAvailability end - + def ExchangeAvailability=(value) @exchangeAvailability = value end @@ -1503,7 +1464,7 @@ class ListingProductDetails def ExchangeOfferingType @exchangeOfferingType end - + def ExchangeOfferingType=(value) @exchangeOfferingType = value end @@ -1511,7 +1472,7 @@ class ListingProductDetails def ExchangeSellerState @exchangeSellerState end - + def ExchangeSellerState=(value) @exchangeSellerState = value end @@ -1519,7 +1480,7 @@ class ListingProductDetails def ExchangeSellerCountry @exchangeSellerCountry end - + def ExchangeSellerCountry=(value) @exchangeSellerCountry = value end @@ -1527,33 +1488,12 @@ class ListingProductDetails def ExchangeSellerRating @exchangeSellerRating end - + def ExchangeSellerRating=(value) @exchangeSellerRating = value end - def initialize(exchangeId = nil, - listingId = nil, - exchangeTitle = nil, - exchangeDescription = nil, - exchangePrice = nil, - exchangeAsin = nil, - exchangeEndDate = nil, - exchangeTinyImage = nil, - exchangeSellerId = nil, - exchangeSellerNickname = nil, - exchangeStartDate = nil, - exchangeStatus = nil, - exchangeQuantity = nil, - exchangeQuantityAllocated = nil, - exchangeFeaturedCategory = nil, - exchangeCondition = nil, - exchangeConditionType = nil, - exchangeAvailability = nil, - exchangeOfferingType = nil, - exchangeSellerState = nil, - exchangeSellerCountry = nil, - exchangeSellerRating = nil) + def initialize(exchangeId = nil, listingId = nil, exchangeTitle = nil, exchangeDescription = nil, exchangePrice = nil, exchangeAsin = nil, exchangeEndDate = nil, exchangeTinyImage = nil, exchangeSellerId = nil, exchangeSellerNickname = nil, exchangeStartDate = nil, exchangeStatus = nil, exchangeQuantity = nil, exchangeQuantityAllocated = nil, exchangeFeaturedCategory = nil, exchangeCondition = nil, exchangeConditionType = nil, exchangeAvailability = nil, exchangeOfferingType = nil, exchangeSellerState = nil, exchangeSellerCountry = nil, exchangeSellerRating = nil) @exchangeId = exchangeId @listingId = listingId @exchangeTitle = exchangeTitle @@ -1587,7 +1527,7 @@ class SellerFeedback def Feedback @feedback end - + def Feedback=(value) @feedback = value end @@ -1599,7 +1539,6 @@ end # http://soap.amazon.com class FeedbackArray < Array - # Contents type should be dumped here... @@schema_type = "FeedbackArray" @@schema_ns = "http://soap.amazon.com" end @@ -1612,7 +1551,7 @@ class Feedback def FeedbackRating @feedbackRating end - + def FeedbackRating=(value) @feedbackRating = value end @@ -1620,7 +1559,7 @@ class Feedback def FeedbackComments @feedbackComments end - + def FeedbackComments=(value) @feedbackComments = value end @@ -1628,7 +1567,7 @@ class Feedback def FeedbackDate @feedbackDate end - + def FeedbackDate=(value) @feedbackDate = value end @@ -1636,15 +1575,12 @@ class Feedback def FeedbackRater @feedbackRater end - + def FeedbackRater=(value) @feedbackRater = value end - def initialize(feedbackRating = nil, - feedbackComments = nil, - feedbackDate = nil, - feedbackRater = nil) + def initialize(feedbackRating = nil, feedbackComments = nil, feedbackDate = nil, feedbackRater = nil) @feedbackRating = feedbackRating @feedbackComments = feedbackComments @feedbackDate = feedbackDate @@ -1660,7 +1596,7 @@ class ThirdPartyProductInfo def ThirdPartyProductDetails @thirdPartyProductDetails end - + def ThirdPartyProductDetails=(value) @thirdPartyProductDetails = value end @@ -1672,7 +1608,6 @@ end # http://soap.amazon.com class ThirdPartyProductDetailsArray < Array - # Contents type should be dumped here... @@schema_type = "ThirdPartyProductDetailsArray" @@schema_ns = "http://soap.amazon.com" end @@ -1685,7 +1620,7 @@ class ThirdPartyProductDetails def OfferingType @offeringType end - + def OfferingType=(value) @offeringType = value end @@ -1693,7 +1628,7 @@ class ThirdPartyProductDetails def SellerId @sellerId end - + def SellerId=(value) @sellerId = value end @@ -1701,7 +1636,7 @@ class ThirdPartyProductDetails def SellerNickname @sellerNickname end - + def SellerNickname=(value) @sellerNickname = value end @@ -1709,7 +1644,7 @@ class ThirdPartyProductDetails def ExchangeId @exchangeId end - + def ExchangeId=(value) @exchangeId = value end @@ -1717,7 +1652,7 @@ class ThirdPartyProductDetails def OfferingPrice @offeringPrice end - + def OfferingPrice=(value) @offeringPrice = value end @@ -1725,7 +1660,7 @@ class ThirdPartyProductDetails def Condition @condition end - + def Condition=(value) @condition = value end @@ -1733,7 +1668,7 @@ class ThirdPartyProductDetails def ConditionType @conditionType end - + def ConditionType=(value) @conditionType = value end @@ -1741,7 +1676,7 @@ class ThirdPartyProductDetails def ExchangeAvailability @exchangeAvailability end - + def ExchangeAvailability=(value) @exchangeAvailability = value end @@ -1749,7 +1684,7 @@ class ThirdPartyProductDetails def SellerCountry @sellerCountry end - + def SellerCountry=(value) @sellerCountry = value end @@ -1757,7 +1692,7 @@ class ThirdPartyProductDetails def SellerState @sellerState end - + def SellerState=(value) @sellerState = value end @@ -1765,7 +1700,7 @@ class ThirdPartyProductDetails def ShipComments @shipComments end - + def ShipComments=(value) @shipComments = value end @@ -1773,23 +1708,12 @@ class ThirdPartyProductDetails def SellerRating @sellerRating end - + def SellerRating=(value) @sellerRating = value end - def initialize(offeringType = nil, - sellerId = nil, - sellerNickname = nil, - exchangeId = nil, - offeringPrice = nil, - condition = nil, - conditionType = nil, - exchangeAvailability = nil, - sellerCountry = nil, - sellerState = nil, - shipComments = nil, - sellerRating = nil) + def initialize(offeringType = nil, sellerId = nil, sellerNickname = nil, exchangeId = nil, offeringPrice = nil, condition = nil, conditionType = nil, exchangeAvailability = nil, sellerCountry = nil, sellerState = nil, shipComments = nil, sellerRating = nil) @offeringType = offeringType @sellerId = sellerId @sellerNickname = sellerNickname @@ -1810,87 +1734,17 @@ class KeywordRequest @@schema_type = "KeywordRequest" @@schema_ns = "http://soap.amazon.com" - def keyword - @keyword - end - - def keyword=(value) - @keyword = value - end - - def page - @page - end - - def page=(value) - @page = value - end - - def mode - @mode - end - - def mode=(value) - @mode = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def sort - @sort - end - - def sort=(value) - @sort = value - end - - def locale - @locale - end - - def locale=(value) - @locale = value - end - - def price - @price - end - - def price=(value) - @price = value - end + attr_accessor :keyword + attr_accessor :page + attr_accessor :mode + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :sort + attr_accessor :locale + attr_accessor :price - def initialize(keyword = nil, - page = nil, - mode = nil, - tag = nil, - type = nil, - devtag = nil, - sort = nil, - locale = nil, - price = nil) + def initialize(keyword = nil, page = nil, mode = nil, tag = nil, type = nil, devtag = nil, sort = nil, locale = nil, price = nil) @keyword = keyword @page = page @mode = mode @@ -1908,87 +1762,17 @@ class TextStreamRequest @@schema_type = "TextStreamRequest" @@schema_ns = "http://soap.amazon.com" - def textStream - @textStream - end - - def textStream=(value) - @textStream = value - end - - def page - @page - end - - def page=(value) - @page = value - end - - def mode - @mode - end - - def mode=(value) - @mode = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def sort - @sort - end - - def sort=(value) - @sort = value - end - - def locale - @locale - end - - def locale=(value) - @locale = value - end - - def price - @price - end - - def price=(value) - @price = value - end + attr_accessor :textStream + attr_accessor :page + attr_accessor :mode + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :sort + attr_accessor :locale + attr_accessor :price - def initialize(textStream = nil, - page = nil, - mode = nil, - tag = nil, - type = nil, - devtag = nil, - sort = nil, - locale = nil, - price = nil) + def initialize(textStream = nil, page = nil, mode = nil, tag = nil, type = nil, devtag = nil, sort = nil, locale = nil, price = nil) @textStream = textStream @page = page @mode = mode @@ -2006,78 +1790,16 @@ class PowerRequest @@schema_type = "PowerRequest" @@schema_ns = "http://soap.amazon.com" - def power - @power - end - - def power=(value) - @power = value - end + attr_accessor :power + attr_accessor :page + attr_accessor :mode + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :sort + attr_accessor :locale - def page - @page - end - - def page=(value) - @page = value - end - - def mode - @mode - end - - def mode=(value) - @mode = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def sort - @sort - end - - def sort=(value) - @sort = value - end - - def locale - @locale - end - - def locale=(value) - @locale = value - end - - def initialize(power = nil, - page = nil, - mode = nil, - tag = nil, - type = nil, - devtag = nil, - sort = nil, - locale = nil) + def initialize(power = nil, page = nil, mode = nil, tag = nil, type = nil, devtag = nil, sort = nil, locale = nil) @power = power @page = page @mode = mode @@ -2094,96 +1816,18 @@ class BrowseNodeRequest @@schema_type = "BrowseNodeRequest" @@schema_ns = "http://soap.amazon.com" - def browse_node - @browse_node - end - - def browse_node=(value) - @browse_node = value - end - - def page - @page - end - - def page=(value) - @page = value - end - - def mode - @mode - end - - def mode=(value) - @mode = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def sort - @sort - end - - def sort=(value) - @sort = value - end - - def locale - @locale - end - - def locale=(value) - @locale = value - end - - def keywords - @keywords - end - - def keywords=(value) - @keywords = value - end - - def price - @price - end - - def price=(value) - @price = value - end + attr_accessor :browse_node + attr_accessor :page + attr_accessor :mode + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :sort + attr_accessor :locale + attr_accessor :keywords + attr_accessor :price - def initialize(browse_node = nil, - page = nil, - mode = nil, - tag = nil, - type = nil, - devtag = nil, - sort = nil, - locale = nil, - keywords = nil, - price = nil) + def initialize(browse_node = nil, page = nil, mode = nil, tag = nil, type = nil, devtag = nil, sort = nil, locale = nil, keywords = nil, price = nil) @browse_node = browse_node @page = page @mode = mode @@ -2202,78 +1846,16 @@ class AsinRequest @@schema_type = "AsinRequest" @@schema_ns = "http://soap.amazon.com" - def asin - @asin - end - - def asin=(value) - @asin = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def offer - @offer - end - - def offer=(value) - @offer = value - end - - def offerpage - @offerpage - end - - def offerpage=(value) - @offerpage = value - end - - def locale - @locale - end - - def locale=(value) - @locale = value - end - - def mode - @mode - end - - def mode=(value) - @mode = value - end + attr_accessor :asin + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :offer + attr_accessor :offerpage + attr_accessor :locale + attr_accessor :mode - def initialize(asin = nil, - tag = nil, - type = nil, - devtag = nil, - offer = nil, - offerpage = nil, - locale = nil, - mode = nil) + def initialize(asin = nil, tag = nil, type = nil, devtag = nil, offer = nil, offerpage = nil, locale = nil, mode = nil) @asin = asin @tag = tag @type = type @@ -2290,51 +1872,13 @@ class BlendedRequest @@schema_type = "BlendedRequest" @@schema_ns = "http://soap.amazon.com" - def blended - @blended - end - - def blended=(value) - @blended = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def locale - @locale - end - - def locale=(value) - @locale = value - end + attr_accessor :blended + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :locale - def initialize(blended = nil, - tag = nil, - type = nil, - devtag = nil, - locale = nil) + def initialize(blended = nil, tag = nil, type = nil, devtag = nil, locale = nil) @blended = blended @tag = tag @type = type @@ -2348,69 +1892,15 @@ class UpcRequest @@schema_type = "UpcRequest" @@schema_ns = "http://soap.amazon.com" - def upc - @upc - end - - def upc=(value) - @upc = value - end - - def mode - @mode - end - - def mode=(value) - @mode = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def sort - @sort - end - - def sort=(value) - @sort = value - end - - def locale - @locale - end - - def locale=(value) - @locale = value - end + attr_accessor :upc + attr_accessor :mode + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :sort + attr_accessor :locale - def initialize(upc = nil, - mode = nil, - tag = nil, - type = nil, - devtag = nil, - sort = nil, - locale = nil) + def initialize(upc = nil, mode = nil, tag = nil, type = nil, devtag = nil, sort = nil, locale = nil) @upc = upc @mode = mode @tag = tag @@ -2426,87 +1916,17 @@ class SkuRequest @@schema_type = "SkuRequest" @@schema_ns = "http://soap.amazon.com" - def sku - @sku - end - - def sku=(value) - @sku = value - end - - def mode - @mode - end - - def mode=(value) - @mode = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def merchant_id - @merchant_id - end - - def merchant_id=(value) - @merchant_id = value - end - - def keywords - @keywords - end - - def keywords=(value) - @keywords = value - end - - def sort - @sort - end - - def sort=(value) - @sort = value - end - - def locale - @locale - end - - def locale=(value) - @locale = value - end + attr_accessor :sku + attr_accessor :mode + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :merchant_id + attr_accessor :keywords + attr_accessor :sort + attr_accessor :locale - def initialize(sku = nil, - mode = nil, - tag = nil, - type = nil, - devtag = nil, - merchant_id = nil, - keywords = nil, - sort = nil, - locale = nil) + def initialize(sku = nil, mode = nil, tag = nil, type = nil, devtag = nil, merchant_id = nil, keywords = nil, sort = nil, locale = nil) @sku = sku @mode = mode @tag = tag @@ -2524,96 +1944,18 @@ class ArtistRequest @@schema_type = "ArtistRequest" @@schema_ns = "http://soap.amazon.com" - def artist - @artist - end - - def artist=(value) - @artist = value - end - - def page - @page - end - - def page=(value) - @page = value - end - - def mode - @mode - end - - def mode=(value) - @mode = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def sort - @sort - end - - def sort=(value) - @sort = value - end - - def locale - @locale - end - - def locale=(value) - @locale = value - end - - def keywords - @keywords - end - - def keywords=(value) - @keywords = value - end - - def price - @price - end - - def price=(value) - @price = value - end + attr_accessor :artist + attr_accessor :page + attr_accessor :mode + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :sort + attr_accessor :locale + attr_accessor :keywords + attr_accessor :price - def initialize(artist = nil, - page = nil, - mode = nil, - tag = nil, - type = nil, - devtag = nil, - sort = nil, - locale = nil, - keywords = nil, - price = nil) + def initialize(artist = nil, page = nil, mode = nil, tag = nil, type = nil, devtag = nil, sort = nil, locale = nil, keywords = nil, price = nil) @artist = artist @page = page @mode = mode @@ -2632,96 +1974,18 @@ class AuthorRequest @@schema_type = "AuthorRequest" @@schema_ns = "http://soap.amazon.com" - def author - @author - end - - def author=(value) - @author = value - end + attr_accessor :author + attr_accessor :page + attr_accessor :mode + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :sort + attr_accessor :locale + attr_accessor :keywords + attr_accessor :price - def page - @page - end - - def page=(value) - @page = value - end - - def mode - @mode - end - - def mode=(value) - @mode = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def sort - @sort - end - - def sort=(value) - @sort = value - end - - def locale - @locale - end - - def locale=(value) - @locale = value - end - - def keywords - @keywords - end - - def keywords=(value) - @keywords = value - end - - def price - @price - end - - def price=(value) - @price = value - end - - def initialize(author = nil, - page = nil, - mode = nil, - tag = nil, - type = nil, - devtag = nil, - sort = nil, - locale = nil, - keywords = nil, - price = nil) + def initialize(author = nil, page = nil, mode = nil, tag = nil, type = nil, devtag = nil, sort = nil, locale = nil, keywords = nil, price = nil) @author = author @page = page @mode = mode @@ -2740,96 +2004,18 @@ class ActorRequest @@schema_type = "ActorRequest" @@schema_ns = "http://soap.amazon.com" - def actor - @actor - end - - def actor=(value) - @actor = value - end + attr_accessor :actor + attr_accessor :page + attr_accessor :mode + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :sort + attr_accessor :locale + attr_accessor :keywords + attr_accessor :price - def page - @page - end - - def page=(value) - @page = value - end - - def mode - @mode - end - - def mode=(value) - @mode = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def sort - @sort - end - - def sort=(value) - @sort = value - end - - def locale - @locale - end - - def locale=(value) - @locale = value - end - - def keywords - @keywords - end - - def keywords=(value) - @keywords = value - end - - def price - @price - end - - def price=(value) - @price = value - end - - def initialize(actor = nil, - page = nil, - mode = nil, - tag = nil, - type = nil, - devtag = nil, - sort = nil, - locale = nil, - keywords = nil, - price = nil) + def initialize(actor = nil, page = nil, mode = nil, tag = nil, type = nil, devtag = nil, sort = nil, locale = nil, keywords = nil, price = nil) @actor = actor @page = page @mode = mode @@ -2848,96 +2034,18 @@ class DirectorRequest @@schema_type = "DirectorRequest" @@schema_ns = "http://soap.amazon.com" - def director - @director - end - - def director=(value) - @director = value - end - - def page - @page - end - - def page=(value) - @page = value - end - - def mode - @mode - end - - def mode=(value) - @mode = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def sort - @sort - end - - def sort=(value) - @sort = value - end - - def locale - @locale - end - - def locale=(value) - @locale = value - end - - def keywords - @keywords - end + attr_accessor :director + attr_accessor :page + attr_accessor :mode + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :sort + attr_accessor :locale + attr_accessor :keywords + attr_accessor :price - def keywords=(value) - @keywords = value - end - - def price - @price - end - - def price=(value) - @price = value - end - - def initialize(director = nil, - page = nil, - mode = nil, - tag = nil, - type = nil, - devtag = nil, - sort = nil, - locale = nil, - keywords = nil, - price = nil) + def initialize(director = nil, page = nil, mode = nil, tag = nil, type = nil, devtag = nil, sort = nil, locale = nil, keywords = nil, price = nil) @director = director @page = page @mode = mode @@ -2956,51 +2064,13 @@ class ExchangeRequest @@schema_type = "ExchangeRequest" @@schema_ns = "http://soap.amazon.com" - def exchange_id - @exchange_id - end - - def exchange_id=(value) - @exchange_id = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def locale - @locale - end + attr_accessor :exchange_id + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :locale - def locale=(value) - @locale = value - end - - def initialize(exchange_id = nil, - tag = nil, - type = nil, - devtag = nil, - locale = nil) + def initialize(exchange_id = nil, tag = nil, type = nil, devtag = nil, locale = nil) @exchange_id = exchange_id @tag = tag @type = type @@ -3014,96 +2084,18 @@ class ManufacturerRequest @@schema_type = "ManufacturerRequest" @@schema_ns = "http://soap.amazon.com" - def manufacturer - @manufacturer - end - - def manufacturer=(value) - @manufacturer = value - end - - def page - @page - end - - def page=(value) - @page = value - end + attr_accessor :manufacturer + attr_accessor :page + attr_accessor :mode + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :sort + attr_accessor :locale + attr_accessor :keywords + attr_accessor :price - def mode - @mode - end - - def mode=(value) - @mode = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def sort - @sort - end - - def sort=(value) - @sort = value - end - - def locale - @locale - end - - def locale=(value) - @locale = value - end - - def keywords - @keywords - end - - def keywords=(value) - @keywords = value - end - - def price - @price - end - - def price=(value) - @price = value - end - - def initialize(manufacturer = nil, - page = nil, - mode = nil, - tag = nil, - type = nil, - devtag = nil, - sort = nil, - locale = nil, - keywords = nil, - price = nil) + def initialize(manufacturer = nil, page = nil, mode = nil, tag = nil, type = nil, devtag = nil, sort = nil, locale = nil, keywords = nil, price = nil) @manufacturer = manufacturer @page = page @mode = mode @@ -3122,60 +2114,14 @@ class ListManiaRequest @@schema_type = "ListManiaRequest" @@schema_ns = "http://soap.amazon.com" - def lm_id - @lm_id - end - - def lm_id=(value) - @lm_id = value - end - - def page - @page - end + attr_accessor :lm_id + attr_accessor :page + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :locale - def page=(value) - @page = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def locale - @locale - end - - def locale=(value) - @locale = value - end - - def initialize(lm_id = nil, - page = nil, - tag = nil, - type = nil, - devtag = nil, - locale = nil) + def initialize(lm_id = nil, page = nil, tag = nil, type = nil, devtag = nil, locale = nil) @lm_id = lm_id @page = page @tag = tag @@ -3190,218 +2136,46 @@ class WishlistRequest @@schema_type = "WishlistRequest" @@schema_ns = "http://soap.amazon.com" - def wishlist_id - @wishlist_id - end - - def wishlist_id=(value) - @wishlist_id = value - end - - def page - @page - end - - def page=(value) - @page = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def locale - @locale - end - - def locale=(value) - @locale = value - end - - def initialize(wishlist_id = nil, - page = nil, - tag = nil, - type = nil, - devtag = nil, - locale = nil) - @wishlist_id = wishlist_id - @page = page - @tag = tag - @type = type - @devtag = devtag - @locale = locale - end -end - -# http://soap.amazon.com -class MarketplaceRequest - @@schema_type = "MarketplaceRequest" - @@schema_ns = "http://soap.amazon.com" - - def marketplace_search - @marketplace_search - end - - def marketplace_search=(value) - @marketplace_search = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def page - @page - end - - def page=(value) - @page = value - end - - def keyword - @keyword - end - - def keyword=(value) - @keyword = value - end - - def keyword_search - @keyword_search - end - - def keyword_search=(value) - @keyword_search = value - end - - def browse_id - @browse_id - end - - def browse_id=(value) - @browse_id = value - end - - def zipcode - @zipcode - end - - def zipcode=(value) - @zipcode = value - end - - def area_id - @area_id - end - - def area_id=(value) - @area_id = value - end - - def geo - @geo - end - - def geo=(value) - @geo = value - end - - def sort - @sort - end - - def sort=(value) - @sort = value - end - - def listing_id - @listing_id - end - - def listing_id=(value) - @listing_id = value - end - - def desc - @desc - end - - def desc=(value) - @desc = value - end - - def locale - @locale - end - - def locale=(value) - @locale = value - end + attr_accessor :wishlist_id + attr_accessor :page + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :locale - def index - @index + def initialize(wishlist_id = nil, page = nil, tag = nil, type = nil, devtag = nil, locale = nil) + @wishlist_id = wishlist_id + @page = page + @tag = tag + @type = type + @devtag = devtag + @locale = locale end +end - def index=(value) - @index = value - end +# http://soap.amazon.com +class MarketplaceRequest + @@schema_type = "MarketplaceRequest" + @@schema_ns = "http://soap.amazon.com" - def initialize(marketplace_search = nil, - tag = nil, - type = nil, - devtag = nil, - page = nil, - keyword = nil, - keyword_search = nil, - browse_id = nil, - zipcode = nil, - area_id = nil, - geo = nil, - sort = nil, - listing_id = nil, - desc = nil, - locale = nil, - index = nil) + attr_accessor :marketplace_search + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :page + attr_accessor :keyword + attr_accessor :keyword_search + attr_accessor :browse_id + attr_accessor :zipcode + attr_accessor :area_id + attr_accessor :geo + attr_accessor :sort + attr_accessor :listing_id + attr_accessor :desc + attr_accessor :locale + attr_accessor :index + + def initialize(marketplace_search = nil, tag = nil, type = nil, devtag = nil, page = nil, keyword = nil, keyword_search = nil, browse_id = nil, zipcode = nil, area_id = nil, geo = nil, sort = nil, listing_id = nil, desc = nil, locale = nil, index = nil) @marketplace_search = marketplace_search @tag = tag @type = type @@ -3426,69 +2200,15 @@ class SellerProfileRequest @@schema_type = "SellerProfileRequest" @@schema_ns = "http://soap.amazon.com" - def seller_id - @seller_id - end - - def seller_id=(value) - @seller_id = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def page - @page - end - - def page=(value) - @page = value - end - - def desc - @desc - end - - def desc=(value) - @desc = value - end - - def locale - @locale - end - - def locale=(value) - @locale = value - end + attr_accessor :seller_id + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :page + attr_accessor :desc + attr_accessor :locale - def initialize(seller_id = nil, - tag = nil, - type = nil, - devtag = nil, - page = nil, - desc = nil, - locale = nil) + def initialize(seller_id = nil, tag = nil, type = nil, devtag = nil, page = nil, desc = nil, locale = nil) @seller_id = seller_id @tag = tag @type = type @@ -3504,105 +2224,19 @@ class SellerRequest @@schema_type = "SellerRequest" @@schema_ns = "http://soap.amazon.com" - def seller_id - @seller_id - end - - def seller_id=(value) - @seller_id = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def offerstatus - @offerstatus - end - - def offerstatus=(value) - @offerstatus = value - end - - def page - @page - end - - def page=(value) - @page = value - end - - def seller_browse_id - @seller_browse_id - end - - def seller_browse_id=(value) - @seller_browse_id = value - end - - def keyword - @keyword - end - - def keyword=(value) - @keyword = value - end - - def desc - @desc - end - - def desc=(value) - @desc = value - end - - def locale - @locale - end - - def locale=(value) - @locale = value - end - - def index - @index - end - - def index=(value) - @index = value - end + attr_accessor :seller_id + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :offerstatus + attr_accessor :page + attr_accessor :seller_browse_id + attr_accessor :keyword + attr_accessor :desc + attr_accessor :locale + attr_accessor :index - def initialize(seller_id = nil, - tag = nil, - type = nil, - devtag = nil, - offerstatus = nil, - page = nil, - seller_browse_id = nil, - keyword = nil, - desc = nil, - locale = nil, - index = nil) + def initialize(seller_id = nil, tag = nil, type = nil, devtag = nil, offerstatus = nil, page = nil, seller_browse_id = nil, keyword = nil, desc = nil, locale = nil, index = nil) @seller_id = seller_id @tag = tag @type = type @@ -3622,51 +2256,13 @@ class SimilarityRequest @@schema_type = "SimilarityRequest" @@schema_ns = "http://soap.amazon.com" - def asin - @asin - end - - def asin=(value) - @asin = value - end - - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def type - @type - end - - def type=(value) - @type = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def locale - @locale - end - - def locale=(value) - @locale = value - end + attr_accessor :asin + attr_accessor :tag + attr_accessor :type + attr_accessor :devtag + attr_accessor :locale - def initialize(asin = nil, - tag = nil, - type = nil, - devtag = nil, - locale = nil) + def initialize(asin = nil, tag = nil, type = nil, devtag = nil, locale = nil) @asin = asin @tag = tag @type = type @@ -3677,14 +2273,12 @@ end # http://soap.amazon.com class ItemIdArray < Array - # Contents type should be dumped here... @@schema_type = "ItemIdArray" @@schema_ns = "http://soap.amazon.com" end # http://soap.amazon.com class ItemArray < Array - # Contents type should be dumped here... @@schema_type = "ItemArray" @@schema_ns = "http://soap.amazon.com" end @@ -3697,7 +2291,7 @@ class Item def ItemId @itemId end - + def ItemId=(value) @itemId = value end @@ -3705,7 +2299,7 @@ class Item def ProductName @productName end - + def ProductName=(value) @productName = value end @@ -3713,7 +2307,7 @@ class Item def Catalog @catalog end - + def Catalog=(value) @catalog = value end @@ -3721,7 +2315,7 @@ class Item def Asin @asin end - + def Asin=(value) @asin = value end @@ -3729,7 +2323,7 @@ class Item def ExchangeId @exchangeId end - + def ExchangeId=(value) @exchangeId = value end @@ -3737,7 +2331,7 @@ class Item def Quantity @quantity end - + def Quantity=(value) @quantity = value end @@ -3745,7 +2339,7 @@ class Item def ListPrice @listPrice end - + def ListPrice=(value) @listPrice = value end @@ -3753,7 +2347,7 @@ class Item def OurPrice @ourPrice end - + def OurPrice=(value) @ourPrice = value end @@ -3761,20 +2355,12 @@ class Item def MerchantSku @merchantSku end - + def MerchantSku=(value) @merchantSku = value end - def initialize(itemId = nil, - productName = nil, - catalog = nil, - asin = nil, - exchangeId = nil, - quantity = nil, - listPrice = nil, - ourPrice = nil, - merchantSku = nil) + def initialize(itemId = nil, productName = nil, catalog = nil, asin = nil, exchangeId = nil, quantity = nil, listPrice = nil, ourPrice = nil, merchantSku = nil) @itemId = itemId @productName = productName @catalog = catalog @@ -3789,7 +2375,6 @@ end # http://soap.amazon.com class ItemQuantityArray < Array - # Contents type should be dumped here... @@schema_type = "ItemQuantityArray" @@schema_ns = "http://soap.amazon.com" end @@ -3802,7 +2387,7 @@ class ItemQuantity def ItemId @itemId end - + def ItemId=(value) @itemId = value end @@ -3810,13 +2395,12 @@ class ItemQuantity def Quantity @quantity end - + def Quantity=(value) @quantity = value end - def initialize(itemId = nil, - quantity = nil) + def initialize(itemId = nil, quantity = nil) @itemId = itemId @quantity = quantity end @@ -3824,7 +2408,6 @@ end # http://soap.amazon.com class AddItemArray < Array - # Contents type should be dumped here... @@schema_type = "AddItemArray" @@schema_ns = "http://soap.amazon.com" end @@ -3837,7 +2420,7 @@ class AddItem def ParentAsin @parentAsin end - + def ParentAsin=(value) @parentAsin = value end @@ -3845,7 +2428,7 @@ class AddItem def Asin @asin end - + def Asin=(value) @asin = value end @@ -3853,7 +2436,7 @@ class AddItem def MerchantId @merchantId end - + def MerchantId=(value) @merchantId = value end @@ -3861,7 +2444,7 @@ class AddItem def ExchangeId @exchangeId end - + def ExchangeId=(value) @exchangeId = value end @@ -3869,16 +2452,12 @@ class AddItem def Quantity @quantity end - + def Quantity=(value) @quantity = value end - def initialize(parentAsin = nil, - asin = nil, - merchantId = nil, - exchangeId = nil, - quantity = nil) + def initialize(parentAsin = nil, asin = nil, merchantId = nil, exchangeId = nil, quantity = nil) @parentAsin = parentAsin @asin = asin @merchantId = merchantId @@ -3895,7 +2474,7 @@ class ShoppingCart def CartId @cartId end - + def CartId=(value) @cartId = value end @@ -3903,7 +2482,7 @@ class ShoppingCart def HMAC @hMAC end - + def HMAC=(value) @hMAC = value end @@ -3911,7 +2490,7 @@ class ShoppingCart def PurchaseUrl @purchaseUrl end - + def PurchaseUrl=(value) @purchaseUrl = value end @@ -3919,7 +2498,7 @@ class ShoppingCart def Items @items end - + def Items=(value) @items = value end @@ -3927,16 +2506,12 @@ class ShoppingCart def SimilarProducts @similarProducts end - + def SimilarProducts=(value) @similarProducts = value end - def initialize(cartId = nil, - hMAC = nil, - purchaseUrl = nil, - items = nil, - similarProducts = nil) + def initialize(cartId = nil, hMAC = nil, purchaseUrl = nil, items = nil, similarProducts = nil) @cartId = cartId @hMAC = hMAC @purchaseUrl = purchaseUrl @@ -3950,26 +2525,15 @@ class GetShoppingCartRequest @@schema_type = "GetShoppingCartRequest" @@schema_ns = "http://soap.amazon.com" - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end + attr_accessor :tag + attr_accessor :devtag + attr_accessor :locale + attr_accessor :sims def CartId @cartId end - + def CartId=(value) @cartId = value end @@ -3977,33 +2541,12 @@ class GetShoppingCartRequest def HMAC @hMAC end - + def HMAC=(value) @hMAC = value end - def locale - @locale - end - - def locale=(value) - @locale = value - end - - def sims - @sims - end - - def sims=(value) - @sims = value - end - - def initialize(tag = nil, - devtag = nil, - cartId = nil, - hMAC = nil, - locale = nil, - sims = nil) + def initialize(tag = nil, devtag = nil, cartId = nil, hMAC = nil, locale = nil, sims = nil) @tag = tag @devtag = devtag @cartId = cartId @@ -4018,26 +2561,14 @@ class ClearShoppingCartRequest @@schema_type = "ClearShoppingCartRequest" @@schema_ns = "http://soap.amazon.com" - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end + attr_accessor :tag + attr_accessor :devtag + attr_accessor :locale def CartId @cartId end - + def CartId=(value) @cartId = value end @@ -4045,24 +2576,12 @@ class ClearShoppingCartRequest def HMAC @hMAC end - + def HMAC=(value) @hMAC = value end - def locale - @locale - end - - def locale=(value) - @locale = value - end - - def initialize(tag = nil, - devtag = nil, - cartId = nil, - hMAC = nil, - locale = nil) + def initialize(tag = nil, devtag = nil, cartId = nil, hMAC = nil, locale = nil) @tag = tag @devtag = devtag @cartId = cartId @@ -4076,26 +2595,15 @@ class AddShoppingCartItemsRequest @@schema_type = "AddShoppingCartItemsRequest" @@schema_ns = "http://soap.amazon.com" - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end + attr_accessor :tag + attr_accessor :devtag + attr_accessor :locale + attr_accessor :sims def CartId @cartId end - + def CartId=(value) @cartId = value end @@ -4103,7 +2611,7 @@ class AddShoppingCartItemsRequest def HMAC @hMAC end - + def HMAC=(value) @hMAC = value end @@ -4111,34 +2619,12 @@ class AddShoppingCartItemsRequest def Items @items end - + def Items=(value) @items = value end - def locale - @locale - end - - def locale=(value) - @locale = value - end - - def sims - @sims - end - - def sims=(value) - @sims = value - end - - def initialize(tag = nil, - devtag = nil, - cartId = nil, - hMAC = nil, - items = nil, - locale = nil, - sims = nil) + def initialize(tag = nil, devtag = nil, cartId = nil, hMAC = nil, items = nil, locale = nil, sims = nil) @tag = tag @devtag = devtag @cartId = cartId @@ -4154,26 +2640,15 @@ class RemoveShoppingCartItemsRequest @@schema_type = "RemoveShoppingCartItemsRequest" @@schema_ns = "http://soap.amazon.com" - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end + attr_accessor :tag + attr_accessor :devtag + attr_accessor :locale + attr_accessor :sims def CartId @cartId end - + def CartId=(value) @cartId = value end @@ -4181,7 +2656,7 @@ class RemoveShoppingCartItemsRequest def HMAC @hMAC end - + def HMAC=(value) @hMAC = value end @@ -4189,34 +2664,12 @@ class RemoveShoppingCartItemsRequest def Items @items end - + def Items=(value) @items = value end - def locale - @locale - end - - def locale=(value) - @locale = value - end - - def sims - @sims - end - - def sims=(value) - @sims = value - end - - def initialize(tag = nil, - devtag = nil, - cartId = nil, - hMAC = nil, - items = nil, - locale = nil, - sims = nil) + def initialize(tag = nil, devtag = nil, cartId = nil, hMAC = nil, items = nil, locale = nil, sims = nil) @tag = tag @devtag = devtag @cartId = cartId @@ -4232,26 +2685,15 @@ class ModifyShoppingCartItemsRequest @@schema_type = "ModifyShoppingCartItemsRequest" @@schema_ns = "http://soap.amazon.com" - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end + attr_accessor :tag + attr_accessor :devtag + attr_accessor :locale + attr_accessor :sims def CartId @cartId end - + def CartId=(value) @cartId = value end @@ -4259,7 +2701,7 @@ class ModifyShoppingCartItemsRequest def HMAC @hMAC end - + def HMAC=(value) @hMAC = value end @@ -4267,34 +2709,12 @@ class ModifyShoppingCartItemsRequest def Items @items end - + def Items=(value) @items = value end - def locale - @locale - end - - def locale=(value) - @locale = value - end - - def sims - @sims - end - - def sims=(value) - @sims = value - end - - def initialize(tag = nil, - devtag = nil, - cartId = nil, - hMAC = nil, - items = nil, - locale = nil, - sims = nil) + def initialize(tag = nil, devtag = nil, cartId = nil, hMAC = nil, items = nil, locale = nil, sims = nil) @tag = tag @devtag = devtag @cartId = cartId @@ -4307,7 +2727,6 @@ end # http://soap.amazon.com class OrderIdArray < Array - # Contents type should be dumped here... @@schema_type = "OrderIdArray" @@schema_ns = "http://soap.amazon.com" end @@ -4320,7 +2739,7 @@ class Price def Amount @amount end - + def Amount=(value) @amount = value end @@ -4328,13 +2747,12 @@ class Price def CurrencyCode @currencyCode end - + def CurrencyCode=(value) @currencyCode = value end - def initialize(amount = nil, - currencyCode = nil) + def initialize(amount = nil, currencyCode = nil) @amount = amount @currencyCode = currencyCode end @@ -4348,7 +2766,7 @@ class Package def TrackingNumber @trackingNumber end - + def TrackingNumber=(value) @trackingNumber = value end @@ -4356,13 +2774,12 @@ class Package def CarrierName @carrierName end - + def CarrierName=(value) @carrierName = value end - def initialize(trackingNumber = nil, - carrierName = nil) + def initialize(trackingNumber = nil, carrierName = nil) @trackingNumber = trackingNumber @carrierName = carrierName end @@ -4370,7 +2787,6 @@ end # http://soap.amazon.com class PackageArray < Array - # Contents type should be dumped here... @@schema_type = "PackageArray" @@schema_ns = "http://soap.amazon.com" end @@ -4383,7 +2799,7 @@ class OrderItem def ItemNumber @itemNumber end - + def ItemNumber=(value) @itemNumber = value end @@ -4391,7 +2807,7 @@ class OrderItem def ASIN @aSIN end - + def ASIN=(value) @aSIN = value end @@ -4399,7 +2815,7 @@ class OrderItem def ExchangeId @exchangeId end - + def ExchangeId=(value) @exchangeId = value end @@ -4407,7 +2823,7 @@ class OrderItem def Quantity @quantity end - + def Quantity=(value) @quantity = value end @@ -4415,7 +2831,7 @@ class OrderItem def UnitPrice @unitPrice end - + def UnitPrice=(value) @unitPrice = value end @@ -4423,17 +2839,12 @@ class OrderItem def TotalPrice @totalPrice end - + def TotalPrice=(value) @totalPrice = value end - def initialize(itemNumber = nil, - aSIN = nil, - exchangeId = nil, - quantity = nil, - unitPrice = nil, - totalPrice = nil) + def initialize(itemNumber = nil, aSIN = nil, exchangeId = nil, quantity = nil, unitPrice = nil, totalPrice = nil) @itemNumber = itemNumber @aSIN = aSIN @exchangeId = exchangeId @@ -4445,7 +2856,6 @@ end # http://soap.amazon.com class OrderItemArray < Array - # Contents type should be dumped here... @@schema_type = "OrderItemArray" @@schema_ns = "http://soap.amazon.com" end @@ -4458,7 +2868,7 @@ class ShortSummary def OrderId @orderId end - + def OrderId=(value) @orderId = value end @@ -4466,7 +2876,7 @@ class ShortSummary def SellerId @sellerId end - + def SellerId=(value) @sellerId = value end @@ -4474,7 +2884,7 @@ class ShortSummary def Condition @condition end - + def Condition=(value) @condition = value end @@ -4482,7 +2892,7 @@ class ShortSummary def TransactionDate @transactionDate end - + def TransactionDate=(value) @transactionDate = value end @@ -4490,7 +2900,7 @@ class ShortSummary def TransactionDateEpoch @transactionDateEpoch end - + def TransactionDateEpoch=(value) @transactionDateEpoch = value end @@ -4498,7 +2908,7 @@ class ShortSummary def Total @total end - + def Total=(value) @total = value end @@ -4506,7 +2916,7 @@ class ShortSummary def Subtotal @subtotal end - + def Subtotal=(value) @subtotal = value end @@ -4514,7 +2924,7 @@ class ShortSummary def Shipping @shipping end - + def Shipping=(value) @shipping = value end @@ -4522,7 +2932,7 @@ class ShortSummary def Tax @tax end - + def Tax=(value) @tax = value end @@ -4530,7 +2940,7 @@ class ShortSummary def Promotion @promotion end - + def Promotion=(value) @promotion = value end @@ -4538,7 +2948,7 @@ class ShortSummary def StoreName @storeName end - + def StoreName=(value) @storeName = value end @@ -4546,7 +2956,7 @@ class ShortSummary def Packages @packages end - + def Packages=(value) @packages = value end @@ -4554,7 +2964,7 @@ class ShortSummary def OrderItems @orderItems end - + def OrderItems=(value) @orderItems = value end @@ -4562,7 +2972,7 @@ class ShortSummary def ErrorCode @errorCode end - + def ErrorCode=(value) @errorCode = value end @@ -4570,26 +2980,12 @@ class ShortSummary def ErrorString @errorString end - + def ErrorString=(value) @errorString = value end - def initialize(orderId = nil, - sellerId = nil, - condition = nil, - transactionDate = nil, - transactionDateEpoch = nil, - total = nil, - subtotal = nil, - shipping = nil, - tax = nil, - promotion = nil, - storeName = nil, - packages = nil, - orderItems = nil, - errorCode = nil, - errorString = nil) + def initialize(orderId = nil, sellerId = nil, condition = nil, transactionDate = nil, transactionDateEpoch = nil, total = nil, subtotal = nil, shipping = nil, tax = nil, promotion = nil, storeName = nil, packages = nil, orderItems = nil, errorCode = nil, errorString = nil) @orderId = orderId @sellerId = sellerId @condition = condition @@ -4610,7 +3006,6 @@ end # http://soap.amazon.com class ShortSummaryArray < Array - # Contents type should be dumped here... @@schema_type = "ShortSummaryArray" @@schema_ns = "http://soap.amazon.com" end @@ -4620,51 +3015,20 @@ class GetTransactionDetailsRequest @@schema_type = "GetTransactionDetailsRequest" @@schema_ns = "http://soap.amazon.com" - def tag - @tag - end - - def tag=(value) - @tag = value - end - - def devtag - @devtag - end - - def devtag=(value) - @devtag = value - end - - def key - @key - end - - def key=(value) - @key = value - end + attr_accessor :tag + attr_accessor :devtag + attr_accessor :key + attr_accessor :locale def OrderIds @orderIds end - + def OrderIds=(value) @orderIds = value end - def locale - @locale - end - - def locale=(value) - @locale = value - end - - def initialize(tag = nil, - devtag = nil, - key = nil, - orderIds = nil, - locale = nil) + def initialize(tag = nil, devtag = nil, key = nil, orderIds = nil, locale = nil) @tag = tag @devtag = devtag @key = key @@ -4681,7 +3045,7 @@ class GetTransactionDetailsResponse def ShortSummaries @shortSummaries end - + def ShortSummaries=(value) @shortSummaries = value end diff --git a/sample/wsdl/amazon/AmazonSearchDriver.rb b/sample/wsdl/amazon/AmazonSearchDriver.rb index 01915e2735..60af68887c 100644 --- a/sample/wsdl/amazon/AmazonSearchDriver.rb +++ b/sample/wsdl/amazon/AmazonSearchDriver.rb @@ -2,7 +2,8 @@ require 'AmazonSearch.rb' require 'soap/rpc/driver' -class AmazonSearchPort < SOAP::RPC::Driver +class AmazonSearchPort < ::SOAP::RPC::Driver + DefaultEndpointUrl = "http://soap.amazon.com/onca/soap3" MappingRegistry = ::SOAP::Mapping::Registry.new MappingRegistry.set( @@ -331,166 +332,190 @@ class AmazonSearchPort < SOAP::RPC::Driver ) Methods = [ - ["KeywordSearchRequest", "keywordSearchRequest", [ - ["in", "KeywordSearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "KeywordRequest"]], - ["retval", "return", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["TextStreamSearchRequest", "textStreamSearchRequest", [ - ["in", "TextStreamSearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "TextStreamRequest"]], - ["retval", "return", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["PowerSearchRequest", "powerSearchRequest", [ - ["in", "PowerSearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "PowerRequest"]], - ["retval", "return", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["BrowseNodeSearchRequest", "browseNodeSearchRequest", [ - ["in", "BrowseNodeSearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "BrowseNodeRequest"]], - ["retval", "return", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["AsinSearchRequest", "asinSearchRequest", [ - ["in", "AsinSearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "AsinRequest"]], - ["retval", "return", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["BlendedSearchRequest", "blendedSearchRequest", [ - ["in", "BlendedSearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "BlendedRequest"]], - ["retval", "return", - [::SOAP::SOAPArray, "http://soap.amazon.com", "ProductLine"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["UpcSearchRequest", "upcSearchRequest", [ - ["in", "UpcSearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "UpcRequest"]], - ["retval", "return", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["SkuSearchRequest", "skuSearchRequest", [ - ["in", "SkuSearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "SkuRequest"]], - ["retval", "return", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["AuthorSearchRequest", "authorSearchRequest", [ - ["in", "AuthorSearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "AuthorRequest"]], - ["retval", "return", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["ArtistSearchRequest", "artistSearchRequest", [ - ["in", "ArtistSearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ArtistRequest"]], - ["retval", "return", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["ActorSearchRequest", "actorSearchRequest", [ - ["in", "ActorSearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ActorRequest"]], - ["retval", "return", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["ManufacturerSearchRequest", "manufacturerSearchRequest", [ - ["in", "ManufacturerSearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ManufacturerRequest"]], - ["retval", "return", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["DirectorSearchRequest", "directorSearchRequest", [ - ["in", "DirectorSearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "DirectorRequest"]], - ["retval", "return", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["ListManiaSearchRequest", "listManiaSearchRequest", [ - ["in", "ListManiaSearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ListManiaRequest"]], - ["retval", "return", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["WishlistSearchRequest", "wishlistSearchRequest", [ - ["in", "WishlistSearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "WishlistRequest"]], - ["retval", "return", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["ExchangeSearchRequest", "exchangeSearchRequest", [ - ["in", "ExchangeSearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ExchangeRequest"]], - ["retval", "return", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ListingProductDetails"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["MarketplaceSearchRequest", "marketplaceSearchRequest", [ - ["in", "MarketplaceSearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "MarketplaceRequest"]], - ["retval", "return", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "MarketplaceSearch"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["SellerProfileSearchRequest", "sellerProfileSearchRequest", [ - ["in", "SellerProfileSearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "SellerProfileRequest"]], - ["retval", "return", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "SellerProfile"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["SellerSearchRequest", "sellerSearchRequest", [ - ["in", "SellerSearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "SellerRequest"]], - ["retval", "return", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "SellerSearch"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["SimilaritySearchRequest", "similaritySearchRequest", [ - ["in", "SimilaritySearchRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "SimilarityRequest"]], - ["retval", "return", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["GetShoppingCartRequest", "getShoppingCartRequest", [ - ["in", "GetShoppingCartRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "GetShoppingCartRequest"]], - ["retval", "ShoppingCart", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ShoppingCart"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["ClearShoppingCartRequest", "clearShoppingCartRequest", [ - ["in", "ClearShoppingCartRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ClearShoppingCartRequest"]], - ["retval", "ShoppingCart", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ShoppingCart"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["AddShoppingCartItemsRequest", "addShoppingCartItemsRequest", [ - ["in", "AddShoppingCartItemsRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "AddShoppingCartItemsRequest"]], - ["retval", "ShoppingCart", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ShoppingCart"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["RemoveShoppingCartItemsRequest", "removeShoppingCartItemsRequest", [ - ["in", "RemoveShoppingCartItemsRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "RemoveShoppingCartItemsRequest"]], - ["retval", "ShoppingCart", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ShoppingCart"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["ModifyShoppingCartItemsRequest", "modifyShoppingCartItemsRequest", [ - ["in", "ModifyShoppingCartItemsRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ModifyShoppingCartItemsRequest"]], - ["retval", "ShoppingCart", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "ShoppingCart"]]], - "http://soap.amazon.com", "http://soap.amazon.com"], - ["GetTransactionDetailsRequest", "getTransactionDetailsRequest", [ - ["in", "GetTransactionDetailsRequest", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "GetTransactionDetailsRequest"]], - ["retval", "GetTransactionDetailsResponse", - [::SOAP::SOAPStruct, "http://soap.amazon.com", "GetTransactionDetailsResponse"]]], - "http://soap.amazon.com", "http://soap.amazon.com"] + ["KeywordSearchRequest", "keywordSearchRequest", + [ + ["in", "KeywordSearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "KeywordRequest"]], + ["retval", "return", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["TextStreamSearchRequest", "textStreamSearchRequest", + [ + ["in", "TextStreamSearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "TextStreamRequest"]], + ["retval", "return", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["PowerSearchRequest", "powerSearchRequest", + [ + ["in", "PowerSearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "PowerRequest"]], + ["retval", "return", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["BrowseNodeSearchRequest", "browseNodeSearchRequest", + [ + ["in", "BrowseNodeSearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "BrowseNodeRequest"]], + ["retval", "return", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["AsinSearchRequest", "asinSearchRequest", + [ + ["in", "AsinSearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "AsinRequest"]], + ["retval", "return", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["BlendedSearchRequest", "blendedSearchRequest", + [ + ["in", "BlendedSearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "BlendedRequest"]], + ["retval", "return", [::SOAP::SOAPArray, "http://soap.amazon.com", "ProductLine"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["UpcSearchRequest", "upcSearchRequest", + [ + ["in", "UpcSearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "UpcRequest"]], + ["retval", "return", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["SkuSearchRequest", "skuSearchRequest", + [ + ["in", "SkuSearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "SkuRequest"]], + ["retval", "return", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["AuthorSearchRequest", "authorSearchRequest", + [ + ["in", "AuthorSearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "AuthorRequest"]], + ["retval", "return", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["ArtistSearchRequest", "artistSearchRequest", + [ + ["in", "ArtistSearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ArtistRequest"]], + ["retval", "return", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["ActorSearchRequest", "actorSearchRequest", + [ + ["in", "ActorSearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ActorRequest"]], + ["retval", "return", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["ManufacturerSearchRequest", "manufacturerSearchRequest", + [ + ["in", "ManufacturerSearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ManufacturerRequest"]], + ["retval", "return", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["DirectorSearchRequest", "directorSearchRequest", + [ + ["in", "DirectorSearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "DirectorRequest"]], + ["retval", "return", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["ListManiaSearchRequest", "listManiaSearchRequest", + [ + ["in", "ListManiaSearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ListManiaRequest"]], + ["retval", "return", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["WishlistSearchRequest", "wishlistSearchRequest", + [ + ["in", "WishlistSearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "WishlistRequest"]], + ["retval", "return", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["ExchangeSearchRequest", "exchangeSearchRequest", + [ + ["in", "ExchangeSearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ExchangeRequest"]], + ["retval", "return", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ListingProductDetails"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["MarketplaceSearchRequest", "marketplaceSearchRequest", + [ + ["in", "MarketplaceSearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "MarketplaceRequest"]], + ["retval", "return", [::SOAP::SOAPStruct, "http://soap.amazon.com", "MarketplaceSearch"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["SellerProfileSearchRequest", "sellerProfileSearchRequest", + [ + ["in", "SellerProfileSearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "SellerProfileRequest"]], + ["retval", "return", [::SOAP::SOAPStruct, "http://soap.amazon.com", "SellerProfile"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["SellerSearchRequest", "sellerSearchRequest", + [ + ["in", "SellerSearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "SellerRequest"]], + ["retval", "return", [::SOAP::SOAPStruct, "http://soap.amazon.com", "SellerSearch"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["SimilaritySearchRequest", "similaritySearchRequest", + [ + ["in", "SimilaritySearchRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "SimilarityRequest"]], + ["retval", "return", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ProductInfo"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["GetShoppingCartRequest", "getShoppingCartRequest", + [ + ["in", "GetShoppingCartRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "GetShoppingCartRequest"]], + ["retval", "ShoppingCart", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ShoppingCart"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["ClearShoppingCartRequest", "clearShoppingCartRequest", + [ + ["in", "ClearShoppingCartRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ClearShoppingCartRequest"]], + ["retval", "ShoppingCart", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ShoppingCart"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["AddShoppingCartItemsRequest", "addShoppingCartItemsRequest", + [ + ["in", "AddShoppingCartItemsRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "AddShoppingCartItemsRequest"]], + ["retval", "ShoppingCart", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ShoppingCart"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["RemoveShoppingCartItemsRequest", "removeShoppingCartItemsRequest", + [ + ["in", "RemoveShoppingCartItemsRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "RemoveShoppingCartItemsRequest"]], + ["retval", "ShoppingCart", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ShoppingCart"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["ModifyShoppingCartItemsRequest", "modifyShoppingCartItemsRequest", + [ + ["in", "ModifyShoppingCartItemsRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ModifyShoppingCartItemsRequest"]], + ["retval", "ShoppingCart", [::SOAP::SOAPStruct, "http://soap.amazon.com", "ShoppingCart"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ], + ["GetTransactionDetailsRequest", "getTransactionDetailsRequest", + [ + ["in", "GetTransactionDetailsRequest", [::SOAP::SOAPStruct, "http://soap.amazon.com", "GetTransactionDetailsRequest"]], + ["retval", "GetTransactionDetailsResponse", [::SOAP::SOAPStruct, "http://soap.amazon.com", "GetTransactionDetailsResponse"]] + ], + "http://soap.amazon.com", "http://soap.amazon.com" + ] ] - DefaultEndpointUrl = "http://soap.amazon.com/onca/soap3" - def initialize(endpoint_url = nil) endpoint_url ||= DefaultEndpointUrl super(endpoint_url, nil) @@ -498,7 +523,7 @@ class AmazonSearchPort < SOAP::RPC::Driver init_methods end -private +private def init_methods Methods.each do |name_as, name, params, soapaction, namespace| diff --git a/sample/wsdl/googleSearch/httpd.rb b/sample/wsdl/googleSearch/httpd.rb index ee8ab09f50..bebcff96c6 100644 --- a/sample/wsdl/googleSearch/httpd.rb +++ b/sample/wsdl/googleSearch/httpd.rb @@ -1,14 +1,19 @@ #!/usr/bin/env ruby require 'webrick' -require 'getopts' +require 'soap/property' -getopts "", 'r:', 'p:8808' +docroot = "." +port = 8808 +if opt = SOAP::Property.loadproperty("samplehttpd.conf") + docroot = opt["docroot"] + port = Integer(opt["port"]) +end s = WEBrick::HTTPServer.new( :BindAddress => "0.0.0.0", - :Port => $OPT_p.to_i, - :DocumentRoot => $OPT_r || ".", + :Port => port, + :DocumentRoot => docroot, :CGIPathEnv => ENV['PATH'] ) trap(:INT){ s.shutdown } diff --git a/test/soap/calc/test_calc.rb b/test/soap/calc/test_calc.rb index c917ddcf9e..4210c65772 100644 --- a/test/soap/calc/test_calc.rb +++ b/test/soap/calc/test_calc.rb @@ -1,10 +1,6 @@ require 'test/unit' require 'soap/rpc/driver' - -dir = File.dirname(__FILE__) -$:.push(dir) require 'server.rb' -$:.delete(dir) module SOAP diff --git a/test/soap/calc/test_calc2.rb b/test/soap/calc/test_calc2.rb index b7fee71526..d15cfe9600 100644 --- a/test/soap/calc/test_calc2.rb +++ b/test/soap/calc/test_calc2.rb @@ -1,10 +1,6 @@ require 'test/unit' require 'soap/rpc/driver' - -dir = File.dirname(__FILE__) -$:.push(dir) require 'server2.rb' -$:.delete(dir) module SOAP @@ -30,6 +26,7 @@ class TestCalc2 < Test::Unit::TestCase end @endpoint = "http://localhost:#{Port}/" @var = SOAP::RPC::Driver.new(@endpoint, 'http://tempuri.org/calcService') + @var.wiredump_dev = STDERR if $DEBUG @var.add_method('set', 'newValue') @var.add_method('get') @var.add_method_as('+', 'add', 'rhs') diff --git a/test/soap/calc/test_calc_cgi.rb b/test/soap/calc/test_calc_cgi.rb index 523379f302..d1655b0b01 100644 --- a/test/soap/calc/test_calc_cgi.rb +++ b/test/soap/calc/test_calc_cgi.rb @@ -44,6 +44,7 @@ class TestCalcCGI < Test::Unit::TestCase end @endpoint = "http://localhost:#{Port}/server.cgi" @calc = SOAP::RPC::Driver.new(@endpoint, 'http://tempuri.org/calcService') + @calc.wiredump_dev = STDERR if $DEBUG @calc.add_method('add', 'lhs', 'rhs') @calc.add_method('sub', 'lhs', 'rhs') @calc.add_method('multi', 'lhs', 'rhs') diff --git a/test/soap/helloworld/test_helloworld.rb b/test/soap/helloworld/test_helloworld.rb index 7261e42f19..cd78d9fa0b 100644 --- a/test/soap/helloworld/test_helloworld.rb +++ b/test/soap/helloworld/test_helloworld.rb @@ -1,10 +1,6 @@ require 'test/unit' require 'soap/rpc/driver' - -dir = File.dirname(__FILE__) -$:.push(dir) require 'hw_s.rb' -$:.delete(dir) module SOAP diff --git a/test/soap/test_basetype.rb b/test/soap/test_basetype.rb index 7a77946c2c..afd550f996 100644 --- a/test/soap/test_basetype.rb +++ b/test/soap/test_basetype.rb @@ -156,8 +156,8 @@ class TestSOAP < Test::Unit::TestCase targets = [ 3.14159265358979, 12.34e36, - 1.4e-45, - -1.4e-45, + 1.402e-45, + -1.402e-45, ] targets.each do |f| assert_equal(f, SOAP::SOAPFloat.new(f).data) @@ -166,8 +166,8 @@ class TestSOAP < Test::Unit::TestCase targets = [ "+3.141592654", "+1.234e+37", - "+1.4e-45", - "-1.4e-45", + "+1.402e-45", + "-1.402e-45", ] targets.each do |f| assert_equal(f, SOAP::SOAPFloat.new(f).to_s) @@ -178,13 +178,13 @@ class TestSOAP < Test::Unit::TestCase [-2, "-2"], # ditto [3.14159265358979, "+3.141592654"], [12.34e36, "+1.234e+37"], - [1.4e-45, "+1.4e-45"], - [-1.4e-45, "-1.4e-45"], - ["1.4e", "+1.4"], + [1.402e-45, "+1.402e-45"], + [-1.402e-45, "-1.402e-45"], + ["1.402e", "+1.402"], ["12.34E36", "+1.234e+37"], - ["1.4E-45", "+1.4e-45"], - ["-1.4E-45", "-1.4e-45"], - ["1.4E", "+1.4"], + ["1.402E-45", "+1.402e-45"], + ["-1.402E-45", "-1.402e-45"], + ["1.402E", "+1.402"], ] targets.each do |f, str| assert_equal(str, SOAP::SOAPFloat.new(f).to_s) @@ -221,8 +221,8 @@ class TestSOAP < Test::Unit::TestCase targets = [ 3.14159265358979, 12.34e36, - 1.4e-45, - -1.4e-45, + 1.402e-45, + -1.402e-45, ] targets.each do |f| assert_equal(f, SOAP::SOAPDouble.new(f).data) @@ -231,8 +231,8 @@ class TestSOAP < Test::Unit::TestCase targets = [ "+3.14159265358979", "+1.234e+37", - "+1.4e-45", - "-1.4e-45", + "+1.402e-45", + "-1.402e-45", ] targets.each do |f| assert_equal(f, SOAP::SOAPDouble.new(f).to_s) @@ -243,13 +243,13 @@ class TestSOAP < Test::Unit::TestCase [-2, "-2"], # ditto. [3.14159265358979, "+3.14159265358979"], [12.34e36, "+1.234e+37"], - [1.4e-45, "+1.4e-45"], - [-1.4e-45, "-1.4e-45"], - ["1.4e", "+1.4"], + [1.402e-45, "+1.402e-45"], + [-1.402e-45, "-1.402e-45"], + ["1.402e", "+1.402"], ["12.34E36", "+1.234e+37"], - ["1.4E-45", "+1.4e-45"], - ["-1.4E-45", "-1.4e-45"], - ["1.4E", "+1.4"], + ["1.402E-45", "+1.402e-45"], + ["-1.402E-45", "-1.402e-45"], + ["1.402E", "+1.402"], ] targets.each do |f, str| assert_equal(str, SOAP::SOAPDouble.new(f).to_s) diff --git a/test/soap/test_property.rb b/test/soap/test_property.rb index 82363a83db..1cc826695f 100644 --- a/test/soap/test_property.rb +++ b/test/soap/test_property.rb @@ -59,7 +59,7 @@ __EOP__ prop = Property.new hooked = false prop.add_hook("foo.bar.baz") do |name, value| - assert_equal("foo.bar.baz", name) + assert_equal(["foo", "bar", "baz"], name) assert_equal("123", value) hooked = true end @@ -126,11 +126,24 @@ __EOP__ end end + def test_hook_name + tag = Object.new + tested = false + @prop.add_hook("foo.bar") do |key, value| + assert_raise(TypeError) do + key << "baz" + end + tested = true + end + @prop["foo.bar"] = tag + assert(tested) + end + def test_value_hook tag = Object.new tested = false @prop.add_hook("FOO.BAR.BAZ") do |key, value| - assert_equal("foo.bar.baz", key) + assert_equal(["Foo", "baR", "baZ"], key) assert_equal(tag, value) tested = true end @@ -141,32 +154,65 @@ __EOP__ assert_equal(1, @prop["foo.bar"]) end - def test_key_hook + def test_key_hook_no_cascade tag = Object.new tested = 0 + @prop.add_hook do |key, value| + assert(false) + end + @prop.add_hook(false) do |key, value| + assert(false) + end @prop.add_hook("foo") do |key, value| - assert_equal("foo.bar.baz.qux", key) + assert(false) + end + @prop.add_hook("foo.bar", false) do |key, value| + assert(false) + end + @prop.add_hook("foo.bar.baz") do |key, value| + assert(false) + end + @prop.add_hook("foo.bar.baz.qux", false) do |key, value| + assert_equal(["foo", "bar", "baz", "qux"], key) assert_equal(tag, value) tested += 1 end - @prop.add_hook("foo.bar") do |key, value| - assert_equal("foo.bar.baz.qux", key) + @prop["foo.bar.baz.qux"] = tag + assert_equal(tag, @prop["foo.bar.baz.qux"]) + assert_equal(1, tested) + end + + def test_key_hook_cascade + tag = Object.new + tested = 0 + @prop.add_hook(true) do |key, value| + assert_equal(["foo", "bar", "baz", "qux"], key) assert_equal(tag, value) tested += 1 end - @prop.add_hook("foo.bar.baz") do |key, value| - assert_equal("foo.bar.baz.qux", key) + @prop.add_hook("foo", true) do |key, value| + assert_equal(["foo", "bar", "baz", "qux"], key) assert_equal(tag, value) tested += 1 end - @prop.add_hook("foo.bar.baz.qux") do |key, value| - assert_equal("foo.bar.baz.qux", key) + @prop.add_hook("foo.bar", true) do |key, value| + assert_equal(["foo", "bar", "baz", "qux"], key) + assert_equal(tag, value) + tested += 1 + end + @prop.add_hook("foo.bar.baz", true) do |key, value| + assert_equal(["foo", "bar", "baz", "qux"], key) + assert_equal(tag, value) + tested += 1 + end + @prop.add_hook("foo.bar.baz.qux", true) do |key, value| + assert_equal(["foo", "bar", "baz", "qux"], key) assert_equal(tag, value) tested += 1 end @prop["foo.bar.baz.qux"] = tag assert_equal(tag, @prop["foo.bar.baz.qux"]) - assert_equal(4, tested) + assert_equal(5, tested) end def test_keys @@ -310,7 +356,7 @@ __EOP__ def test_hook_then_lock tested = false @prop.add_hook("a.b.c") do |name, value| - assert_equal("a.b.c", name) + assert_equal(["a", "b", "c"], name) tested = true end @prop["a.b"].lock diff --git a/test/soap/test_streamhandler.rb b/test/soap/test_streamhandler.rb index d38b84ed97..e5b578d7a6 100644 --- a/test/soap/test_streamhandler.rb +++ b/test/soap/test_streamhandler.rb @@ -142,9 +142,16 @@ __EOX__ end def test_basic_auth - # soap4r + basic_auth is not officially supported in ruby/1.8.1 even though - # soap4r + basic_auth + http-access2 should run fine. - return + unless Object.const_defined?('HTTPAccess2') + STDERR.puts("basic_auth is not supported under soap4r + net/http for now.") + return + end + str = "" + @client.wiredump_dev = str + @client.options["protocol.http.basic_auth"] << [@url, "foo", "bar"] + assert_nil(@client.do_server_proc) + r, h = parse_req_header(str) + assert_equal("Basic Zm9vOmJhcg==", h["authorization"]) end def test_proxy diff --git a/test/wsdl/axisArray/test_axisarray.rb b/test/wsdl/axisArray/test_axisarray.rb index 9c7b42564c..9f220bb48a 100644 --- a/test/wsdl/axisArray/test_axisarray.rb +++ b/test/wsdl/axisArray/test_axisarray.rb @@ -3,6 +3,7 @@ require 'soap/processor' require 'soap/mapping' require 'soap/rpc/element' require 'wsdl/importer' +require 'itemList.rb' module WSDL @@ -10,10 +11,6 @@ module WSDL class TestAxisArray < Test::Unit::TestCase def setup - dir = File.dirname(File.expand_path(__FILE__)) - $:.push(dir) - require 'itemList.rb' - $:.delete(dir) @xml =<<__EOX__ diff --git a/test/wsdl/datetime/test_datetime.rb b/test/wsdl/datetime/test_datetime.rb index 405bd1209a..0f531ff18c 100644 --- a/test/wsdl/datetime/test_datetime.rb +++ b/test/wsdl/datetime/test_datetime.rb @@ -1,5 +1,6 @@ require 'test/unit' require 'soap/wsdlDriver' +require 'DatetimeService.rb' module WSDL @@ -17,9 +18,6 @@ class TestDatetime < Test::Unit::TestCase end def setup_server - $:.push(DIR) - require File.join(DIR, 'DatetimeService.rb') - $:.delete(DIR) @server = DatetimePortTypeApp.new('Datetime server', nil, '0.0.0.0', Port) @server.level = Logger::Severity::ERROR @t = Thread.new { diff --git a/test/wsdl/raa/test_raa.rb b/test/wsdl/raa/test_raa.rb index 5fddb6b22d..cf171b373f 100644 --- a/test/wsdl/raa/test_raa.rb +++ b/test/wsdl/raa/test_raa.rb @@ -1,5 +1,8 @@ require 'test/unit' require 'soap/wsdlDriver' +require 'RAA.rb' +require 'RAAServant.rb' +require 'RAAService.rb' module WSDL @@ -17,11 +20,6 @@ class TestRAA < Test::Unit::TestCase end def setup_server - $:.push(DIR) - require File.join(DIR, 'RAA.rb') - require File.join(DIR, 'RAAServant.rb') - require File.join(DIR, 'RAAService.rb') - $:.delete(DIR) @server = App.new('RAA server', nil, '0.0.0.0', Port) @server.level = Logger::Severity::ERROR @t = Thread.new { diff --git a/test/wsdl/test_emptycomplextype.rb b/test/wsdl/test_emptycomplextype.rb index 45136b417d..71d1b8641d 100644 --- a/test/wsdl/test_emptycomplextype.rb +++ b/test/wsdl/test_emptycomplextype.rb @@ -7,12 +7,12 @@ module WSDL class TestWSDL < Test::Unit::TestCase def setup - @file = File.join(File.dirname(__FILE__), 'emptycomplextype.wsdl') + @file = File.join(File.dirname(File.expand_path(__FILE__)), 'emptycomplextype.wsdl') end def test_wsdl @wsdl = WSDL::Parser.new.parse(File.open(@file) { |f| f.read }) - assert_equal("#", @wsdl.inspect) + assert(/\{urn:jp.gr.jin.rrr.example.emptycomplextype\}emptycomplextype/ =~ @wsdl.inspect) end end diff --git a/test/xsd/test_xmlschemaparser.rb b/test/xsd/test_xmlschemaparser.rb index ab9421c954..10dff43e61 100644 --- a/test/xsd/test_xmlschemaparser.rb +++ b/test/xsd/test_xmlschemaparser.rb @@ -7,7 +7,7 @@ module XSD class TestXMLSchemaParser < Test::Unit::TestCase def setup - @file = File.join(File.dirname(__FILE__), 'xmlschema.xml') + @file = File.join(File.dirname(File.expand_path(__FILE__)), 'xmlschema.xml') end def test_wsdl diff --git a/test/xsd/test_xsd.rb b/test/xsd/test_xsd.rb index db38aee7ca..ce1b263625 100644 --- a/test/xsd/test_xsd.rb +++ b/test/xsd/test_xsd.rb @@ -189,8 +189,8 @@ class TestXSD < Test::Unit::TestCase targets = [ 3.14159265358979, 12.34e36, - 1.4e-45, - -1.4e-45, + 1.402e-45, + -1.402e-45, ] targets.each do |f| assert_equal(f, XSD::XSDFloat.new(f).data) @@ -199,8 +199,8 @@ class TestXSD < Test::Unit::TestCase targets = [ "+3.141592654", "+1.234e+37", - "+1.4e-45", - "-1.4e-45", + "+1.402e-45", + "-1.402e-45", ] targets.each do |f| assert_equal(f, XSD::XSDFloat.new(f).to_s) @@ -211,13 +211,13 @@ class TestXSD < Test::Unit::TestCase [-2, "-2"], # ditto [3.14159265358979, "+3.141592654"], [12.34e36, "+1.234e+37"], - [1.4e-45, "+1.4e-45"], - [-1.4e-45, "-1.4e-45"], - ["1.4e", "+1.4"], + [1.402e-45, "+1.402e-45"], + [-1.402e-45, "-1.402e-45"], + ["1.402e", "+1.402"], ["12.34E36", "+1.234e+37"], - ["1.4E-45", "+1.4e-45"], - ["-1.4E-45", "-1.4e-45"], - ["1.4E", "+1.4"], + ["1.402E-45", "+1.402e-45"], + ["-1.402E-45", "-1.402e-45"], + ["1.402E", "+1.402"], ] targets.each do |f, str| assert_equal(str, XSD::XSDFloat.new(f).to_s) @@ -254,8 +254,8 @@ class TestXSD < Test::Unit::TestCase targets = [ 3.14159265358979, 12.34e36, - 1.4e-45, - -1.4e-45, + 1.402e-45, + -1.402e-45, ] targets.each do |f| assert_equal(f, XSD::XSDDouble.new(f).data) @@ -264,8 +264,8 @@ class TestXSD < Test::Unit::TestCase targets = [ "+3.14159265358979", "+1.234e+37", - "+1.4e-45", - "-1.4e-45", + "+1.402e-45", + "-1.402e-45", ] targets.each do |f| assert_equal(f, XSD::XSDDouble.new(f).to_s) @@ -276,13 +276,13 @@ class TestXSD < Test::Unit::TestCase [-2, "-2"], # ditto. [3.14159265358979, "+3.14159265358979"], [12.34e36, "+1.234e+37"], - [1.4e-45, "+1.4e-45"], - [-1.4e-45, "-1.4e-45"], - ["1.4e", "+1.4"], + [1.402e-45, "+1.402e-45"], + [-1.402e-45, "-1.402e-45"], + ["1.402e", "+1.402"], ["12.34E36", "+1.234e+37"], - ["1.4E-45", "+1.4e-45"], - ["-1.4E-45", "-1.4e-45"], - ["1.4E", "+1.4"], + ["1.402E-45", "+1.402e-45"], + ["-1.402E-45", "-1.402e-45"], + ["1.402E", "+1.402"], ] targets.each do |f, str| assert_equal(str, XSD::XSDDouble.new(f).to_s) diff --git a/version.h b/version.h index 989d63da24..e1f16d7ff3 100644 --- a/version.h +++ b/version.h @@ -1,14 +1,14 @@ #define RUBY_VERSION "1.8.2" -#define RUBY_RELEASE_DATE "2004-07-03" +#define RUBY_RELEASE_DATE "2004-07-04" #define RUBY_VERSION_CODE 182 -#define RUBY_RELEASE_CODE 20040703 +#define RUBY_RELEASE_CODE 20040704 #define RUBY_VERSION_MAJOR 1 #define RUBY_VERSION_MINOR 8 #define RUBY_VERSION_TEENY 2 #define RUBY_RELEASE_YEAR 2004 #define RUBY_RELEASE_MONTH 7 -#define RUBY_RELEASE_DAY 3 +#define RUBY_RELEASE_DAY 4 RUBY_EXTERN const char ruby_version[]; RUBY_EXTERN const char ruby_release_date[]; -- cgit v1.2.3