bugzilla-4intranet/Bugzilla/WebService
vfilippov 899f8ba426 Bug 70605
git-svn-id: svn://svn.office.custis.ru/3rdparty/bugzilla.org/trunk@1346 6955db30-a419-402b-8a0d-67ecbb4d7f56
2011-08-23 22:17:45 +00:00
..
Server Bug 84586 - Merge WebServices from Bugzilla 4.0.1 2011-08-19 15:59:19 +00:00
Bug.pm Bug 70605 2011-08-23 22:17:45 +00:00
Bugzilla.pm Bug 84586 - Merge WebServices from Bugzilla 4.0.1 2011-08-19 15:59:19 +00:00
Constants.pm Bug 40933 - Merge with Bugzilla 3.6.3 (released 2010-11-02) 2010-11-03 17:13:12 +00:00
Field.pm Bug 70168 2010-11-26 13:51:53 +00:00
Product.pm Bug 84586 - Merge WebServices from Bugzilla 4.0.1 2011-08-19 15:59:19 +00:00
README Bug 40933 - НЕ ДО КОНЦА оттестированная объединённая версия Bugzilla 3.6 - НИКУДА НЕ РАЗВОРАЧИВАТЬ! :) 2010-05-14 20:02:34 +00:00
Server.pm Bug 70605 2011-08-23 22:17:45 +00:00
User.pm Bug 84586 - Merge WebServices from Bugzilla 4.0.1 2011-08-19 15:59:19 +00:00
Util.pm Bug 84586 - Merge WebServices from Bugzilla 4.0.1 2011-08-19 15:59:19 +00:00

README

The class structure of these files is a little strange, and this README
explains it.

Our goal is to make JSON::RPC and XMLRPC::Lite both work with the same code.
(That is, we want to have one WebService API, and have two frontends for it.)

The problem is that these both pass different things for $self to WebService
methods.

When XMLRPC::Lite calls a method, $self is the name of the *class* the 
method is in. For example, if we call Bugzilla.version(), the first argument
is Bugzilla::WebService::Bugzilla. So in order to have $self
(our first argument) act correctly in XML-RPC, we make all WebService
classes use base qw(Bugzilla::WebService). 

When JSON::RPC calls a method, $self is the JSON-RPC *server object*. In other
words, it's an instance of Bugzilla::WebService::Server::JSONRPC. So we have
Bugzilla::WebService::Server::JSONRPC inherit from Bugzilla::WebService.