You need to sign in or sign up before continuing.
xmlrpc.cgi 2 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
#!/usr/bin/perl -wT
# -*- Mode: perl; indent-tabs-mode: nil -*-
#
# The contents of this file are subject to the Mozilla Public
# License Version 1.1 (the "License"); you may not use this file
# except in compliance with the License. You may obtain a copy of
# the License at http://www.mozilla.org/MPL/
#
# Software distributed under the License is distributed on an "AS
# IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
# implied. See the License for the specific language governing
# rights and limitations under the License.
#
# The Original Code is the Bugzilla Bug Tracking System.
#
# Contributor(s): Marc Schumann <wurblzap@gmail.com>

use strict;
19
use lib qw(. lib);
20 21 22

use Bugzilla;
use Bugzilla::Constants;
23
use Bugzilla::Error;
24
use Bugzilla::Hook;
25 26 27 28 29 30 31 32 33

# Use an eval here so that runtests.pl accepts this script even if SOAP-Lite
# is not installed.
eval 'use XMLRPC::Transport::HTTP;
      use Bugzilla::WebService;';
$@ && ThrowCodeError('soap_not_installed');

Bugzilla->usage_mode(Bugzilla::Constants::USAGE_MODE_WEBSERVICE);

34 35 36 37
my %hook_dispatch;
Bugzilla::Hook::process('webservice', { dispatch => \%hook_dispatch });
local @INC = (bz_locations()->{extensionsdir}, @INC);

38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
my $dispatch = {
    'Bugzilla' => 'Bugzilla::WebService::Bugzilla',
    'Bug'      => 'Bugzilla::WebService::Bug',
    'User'     => 'Bugzilla::WebService::User',
    'Product'  => 'Bugzilla::WebService::Product',
    %hook_dispatch
};

# The on_action sub needs to be wrapped so that we can work out which
# class to use; when the XMLRPC module calls it theres no indication
# of which dispatch class will be handling it.
# Note that using this to get code thats called before the actual routine
# is a bit of a hack; its meant to be for modifying the SOAPAction
# headers, which XMLRPC doesn't use; it relies on the XMLRPC modules
# using SOAP::Lite internally....

54
my $response = Bugzilla::WebService::XMLRPC::Transport::HTTP::CGI
55
    ->dispatch_with($dispatch)
56
    ->on_action(sub { Bugzilla::WebService::handle_login($dispatch, @_) } )
57
    ->handle;