X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=cgi%2Fsoap.cgi;h=53f7368536f4327b4a71b60acd59a9ce811250d8;hb=64d0fa452631c6e228fad18f8ae469582e3734b3;hp=666a68cafa178855da90c96a50f93f6b19ea9ef6;hpb=41f4070218c0b11c803e7bfea1ba5801b40479b5;p=debbugs.git diff --git a/cgi/soap.cgi b/cgi/soap.cgi index 666a68c..53f7368 100755 --- a/cgi/soap.cgi +++ b/cgi/soap.cgi @@ -1,7 +1,12 @@ -#!/usr/bin/perl -wT +#!/usr/bin/perl -T + +use warnings; +use strict; #use SOAP::Transport::HTTP; +use Debbugs::SOAP::Server; + # Work around stupid soap bug on line 411 if (not exists $ENV{EXPECT}) { $ENV{EXPECT} = ''; @@ -13,5 +18,25 @@ my $soap = Debbugs::SOAP::Server #$soap->serializer()->soapversion(1.2); # soapy is stupid, and is using the 1999 schema; override it. *SOAP::XMLSchema1999::Serializer::as_base64Binary = \&SOAP::XMLSchema2001::Serializer::as_base64Binary; -$soap-> handle; +*SOAP::Serializer::as_anyURI = \&SOAP::XMLSchema2001::Serializer::as_string; +# do this twice to avoid the warning if the serializer doesn't get +# used +*SOAP::XMLSchema1999::Serializer::as_base64Binary = \&SOAP::XMLSchema2001::Serializer::as_base64Binary; +*SOAP::Serializer::as_anyURI = \&SOAP::XMLSchema2001::Serializer::as_string; +# to work around the serializer improperly using date/time stuff +# (Nothing in Debbugs should be looked at as if it were date/time) we +# kill off all of the date/time related bits in the serializer. +my $typelookup = $soap->serializer()->{_typelookup}; +for my $key (keys %{$typelookup}) { + delete $typelookup->{$key} if defined $key and $key =~ /Month|Day|Year|date|time|duration/i; +} +our $warnings = ''; +eval { + # Ignore stupid warning because elements (hashes) can't start with + # numbers + local $SIG{__WARN__} = sub {$warnings .= $_[0] unless $_[0] =~ /Cannot encode unnamed element/}; + $soap->handle; +}; +die $@ if $@; +warn $warnings if length $warnings;