1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- #!/usr/bin/env 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;
- use lib qw(. lib);
- use Bugzilla;
- use Bugzilla::Constants;
- use Bugzilla::Error;
- use Bugzilla::Hook;
- use Bugzilla::WebService::Constants;
- # 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);
- local $SOAP::Constants::FAULT_SERVER;
- $SOAP::Constants::FAULT_SERVER = ERROR_UNKNOWN_FATAL;
- # The line above is used, this one is ignored, but SOAP::Lite
- # might start using this constant (the correct one) for XML-RPC someday.
- local $XMLRPC::Constants::FAULT_SERVER;
- $XMLRPC::Constants::FAULT_SERVER = ERROR_UNKNOWN_FATAL;
- my %hook_dispatch;
- Bugzilla::Hook::process('webservice', { dispatch => \%hook_dispatch });
- local @INC = (bz_locations()->{extensionsdir}, @INC);
- 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....
- my $response = Bugzilla::WebService::XMLRPC::Transport::HTTP::CGI
- ->dispatch_with($dispatch)
- ->on_action(sub { Bugzilla::WebService::handle_login($dispatch, @_) } )
- ->handle;
|