]> git.ipfire.org Git - thirdparty/bugzilla.git/commitdiff
Bug 724464 - JSON-RPC support shouldn't require SOAP::Lite
authorDave Lawrence <dlawrence@mozilla.com>
Wed, 15 Feb 2012 15:59:08 +0000 (10:59 -0500)
committerDave Lawrence <dlawrence@mozilla.com>
Wed, 15 Feb 2012 15:59:08 +0000 (10:59 -0500)
r/a=LpSolit

Bugzilla/WebService.pm
Bugzilla/WebService/Server/XMLRPC.pm

index fe9c3fe098e83bd55e9a30b741bbb32584ac367c..16670762661c2427a90c283e734a5b087b15f727 100644 (file)
@@ -21,8 +21,6 @@ package Bugzilla::WebService;
 use strict;
 use Bugzilla::WebService::Server;
 
-use XMLRPC::Lite;
-
 # Used by the JSON-RPC server to convert incoming date fields apprpriately.
 use constant DATE_FIELDS => {};
 # Used by the JSON-RPC server to convert incoming base64 fields appropriately.
@@ -40,24 +38,6 @@ sub login_exempt {
     return $class->LOGIN_EXEMPT->{$method};
 }
 
-sub type {
-    my ($self, $type, $value) = @_;
-    if ($type eq 'dateTime') {
-        $value = $self->datetime_format_outbound($value);
-    }
-    return XMLRPC::Data->type($type)->value($value);
-}
-
-# This is the XML-RPC implementation, see the README in Bugzilla/WebService/.
-# Our "base" implementation is in Bugzilla::WebService::Server.
-sub datetime_format_outbound {
-    my $self = shift;
-    my $value = Bugzilla::WebService::Server->datetime_format_outbound(@_);
-    # XML-RPC uses an ISO-8601 format that doesn't have any hyphens.
-    $value =~ s/-//g;
-    return $value;
-}
-
 1;
 
 __END__
index b74d0eebdb35b994a225a2ae22f4a7fc25e9905a..5c367799333957f16ac3ef21b2bdb81e758ad3e8 100644 (file)
@@ -31,6 +31,20 @@ if ($ENV{MOD_PERL}) {
 
 use Bugzilla::WebService::Constants;
 
+# Allow WebService methods to call XMLRPC::Lite's type method directly
+BEGIN {
+    *Bugzilla::WebService::type = sub {
+        my ($self, $type, $value) = @_;
+        if ($type eq 'dateTime') {
+            # This is the XML-RPC implementation,  see the README in Bugzilla/WebService/.
+            # Our "base" implementation is in Bugzilla::WebService::Server.
+            $value = Bugzilla::WebService::Server->datetime_format_outbound($value);
+            $value =~ s/-//g;
+        }
+        return XMLRPC::Data->type($type)->value($value);
+    };
+}
+
 sub initialize {
     my $self = shift;
     my %retval = $self->SUPER::initialize(@_);