commit 754e8a1977aeb60c52388e0a24b081be5c8f72f1 Author: Petr Písař <ppisar@xxxxxxxxxx> Date: Mon May 6 14:38:32 2013 +0200 Fix sending a large object ...715-Accept-more-digit-number-in-_traverse.patch | 71 ++++++++++++++++++++ perl-SOAP-Lite.spec | 12 +++- 2 files changed, 80 insertions(+), 3 deletions(-) --- diff --git a/SOAP-Lite-0.715-Accept-more-digit-number-in-_traverse.patch b/SOAP-Lite-0.715-Accept-more-digit-number-in-_traverse.patch new file mode 100644 index 0000000..9d453b4 --- /dev/null +++ b/SOAP-Lite-0.715-Accept-more-digit-number-in-_traverse.patch @@ -0,0 +1,71 @@ +From fc370b31446533cc74a03f2af3949370a07e9980 Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Petr=20P=C3=ADsa=C5=99?= <ppisar@xxxxxxxxxx> +Date: Mon, 6 May 2013 14:22:16 +0200 +Subject: [PATCH] Accept more-digit number in _traverse() + +When sending a large object (many levels deep) through SOAP::Lite, +you got an error: Incorrect parameter at +/usr/lib/perl5/site_perl/5.8.8/SOAP/Lite.pm line 1993. + +This fixes wrong check for a number. + +Thanks to aharper[...]ecstuning.com and TONVOON[...]cpan.org. + +<https://rt.cpan.org/Public/Bug/Display.html?id=78692> +--- + lib/SOAP/Lite.pm | 2 +- + t/02-payload.t | 11 ++++++++++- + 2 files changed, 11 insertions(+), 2 deletions(-) + +diff --git a/lib/SOAP/Lite.pm b/lib/SOAP/Lite.pm +index 691e675..a37b27a 100644 +--- a/lib/SOAP/Lite.pm ++++ b/lib/SOAP/Lite.pm +@@ -1990,7 +1990,7 @@ sub match { + sub _traverse { + my ($self, $pointer, $itself, $path, @path) = @_; + +- die "Incorrect parameter" unless $itself =~/^\d$/; ++ die "Incorrect parameter" unless $itself =~/^\d+$/; + + if ($path && substr($path, 0, 1) eq '{') { + $path = join '/', $path, shift @path while @path && $path !~ /}/; +diff --git a/t/02-payload.t b/t/02-payload.t +index 6501ac1..1ab5171 100644 +--- a/t/02-payload.t ++++ b/t/02-payload.t +@@ -10,7 +10,7 @@ BEGIN { + use strict; + use Test; + +-BEGIN { plan tests => 131 } ++BEGIN { plan tests => 133 } + + use SOAP::Lite; + $SIG{__WARN__} = sub { ; }; # turn off deprecation warnings +@@ -97,6 +97,12 @@ my($a, $s, $r, $serialized, $deserialized); + <item2 xsi:type="xsd:int">60</item2> + <item2 xsi:type="xsd:int">100</item2> + <item3 xsi:type="xsd:int">200</item3> ++<item3 xsi:type="xsd:int">200</item3> ++<item4 xsi:type="xsd:int">200</item4> ++<item4 xsi:type="xsd:int">200</item4> ++<item5 xsi:type="xsd:int">400</item5> ++<item5 xsi:type="xsd:int">450</item5> ++<item6 xsi:type="xsd:int">600</item6> + </nums> + </m:doublerResponse> + </soap:Body> +@@ -108,6 +114,9 @@ my($a, $s, $r, $serialized, $deserialized); + ok($deserialized->valueof("$result/[1]") == 20); + ok($deserialized->valueof("$result/[3]") == 60); + ok($deserialized->valueof("$result/[5]") == 200); ++ ok($deserialized->valueof("$result/[9]") == 400); ++ # Test more than 9 items to check depth is okay - RT78692 ++ ok($deserialized->valueof("$result/[11]") == 600); + + # match should return true/false in boolean context (and object ref otherwise) + ok($deserialized->match('aaa') ? 0 : 1); +-- +1.8.1.4 + diff --git a/perl-SOAP-Lite.spec b/perl-SOAP-Lite.spec index b03f298..f96220a 100644 --- a/perl-SOAP-Lite.spec +++ b/perl-SOAP-Lite.spec @@ -1,14 +1,17 @@ Name: perl-SOAP-Lite Version: 0.715 -Release: 1%{?dist} +Release: 2%{?dist} Summary: Client and server side SOAP implementation License: GPL+ or Artistic Group: Development/Libraries URL: http://search.cpan.org/dist/SOAP-Lite/ Source0: http://search.cpan.org/CPAN/authors/id/M/MK/MKUTTER/SOAP-Lite-%{version}.tar.gz +# bug #960011, CPAN RT#78692 +Patch0: SOAP-Lite-0.715-Accept-more-digit-number-in-_traverse.patch BuildArch: noarch # Core package +BuildRequires: perl BuildRequires: perl(Class::Inspector) BuildRequires: perl(constant) BuildRequires: perl(MIME::Base64) @@ -65,6 +68,7 @@ client and server side. %prep %setup -q -n SOAP-Lite-%{version} +%patch0 -p1 find examples -type f -exec chmod ugo-x {} \; %build @@ -72,9 +76,8 @@ perl Makefile.PL --noprompt INSTALLDIRS=vendor make %{?_smp_mflags} %install -make pure_install PERL_INSTALL_ROOT=%{buildroot} +make pure_install DESTDIR=%{buildroot} find %{buildroot} -type f -name .packlist -exec rm -f {} ';' -find %{buildroot} -type d -depth -exec rmdir {} 2>/dev/null ';' chmod -R u+w %{buildroot}/* %check @@ -92,6 +95,9 @@ make test %{_mandir}/man1/* %changelog +* Mon May 06 2013 Petr Pisar <ppisar@xxxxxxxxxx> - 0.715-2 +- Fix sending a large object (bug #960011) + * Thu Jul 19 2012 Petr Šabata <contyk@xxxxxxxxxx> - 0.715-1 - 0.715 bump - Drop command macros -- Fedora Extras Perl SIG http://www.fedoraproject.org/wiki/Extras/SIGs/Perl perl-devel mailing list perl-devel@xxxxxxxxxxxxxxxxxxxxxxx https://admin.fedoraproject.org/mailman/listinfo/perl-devel