2007-08-15 11:28:01 -03:00
|
|
|
:mod:`xmlrpclib` --- XML-RPC client access
|
|
|
|
==========================================
|
|
|
|
|
|
|
|
.. module:: xmlrpclib
|
|
|
|
:synopsis: XML-RPC client access.
|
|
|
|
.. moduleauthor:: Fredrik Lundh <fredrik@pythonware.com>
|
|
|
|
.. sectionauthor:: Eric S. Raymond <esr@snark.thyrsus.com>
|
|
|
|
|
2008-05-26 07:47:43 -03:00
|
|
|
.. note::
|
|
|
|
The :mod:`xmlrpclib` module has been renamed to :mod:`xmlrpc.client` in
|
|
|
|
Python 3.0. The :term:`2to3` tool will automatically adapt imports when
|
|
|
|
converting your sources to 3.0.
|
|
|
|
|
2007-08-15 11:28:01 -03:00
|
|
|
|
2007-12-29 06:57:00 -04:00
|
|
|
.. XXX Not everything is documented yet. It might be good to describe
|
|
|
|
Marshaller, Unmarshaller, getparser, dumps, loads, and Transport.
|
2007-08-15 11:28:01 -03:00
|
|
|
|
|
|
|
.. versionadded:: 2.2
|
|
|
|
|
|
|
|
XML-RPC is a Remote Procedure Call method that uses XML passed via HTTP as a
|
|
|
|
transport. With it, a client can call methods with parameters on a remote
|
|
|
|
server (the server is named by a URI) and get back structured data. This module
|
|
|
|
supports writing XML-RPC client code; it handles all the details of translating
|
|
|
|
between conformable Python objects and XML on the wire.
|
|
|
|
|
|
|
|
|
|
|
|
.. class:: ServerProxy(uri[, transport[, encoding[, verbose[, allow_none[, use_datetime]]]]])
|
|
|
|
|
|
|
|
A :class:`ServerProxy` instance is an object that manages communication with a
|
|
|
|
remote XML-RPC server. The required first argument is a URI (Uniform Resource
|
|
|
|
Indicator), and will normally be the URL of the server. The optional second
|
|
|
|
argument is a transport factory instance; by default it is an internal
|
|
|
|
:class:`SafeTransport` instance for https: URLs and an internal HTTP
|
|
|
|
:class:`Transport` instance otherwise. The optional third argument is an
|
|
|
|
encoding, by default UTF-8. The optional fourth argument is a debugging flag.
|
|
|
|
If *allow_none* is true, the Python constant ``None`` will be translated into
|
|
|
|
XML; the default behaviour is for ``None`` to raise a :exc:`TypeError`. This is
|
|
|
|
a commonly-used extension to the XML-RPC specification, but isn't supported by
|
|
|
|
all clients and servers; see http://ontosys.com/xml-rpc/extensions.php for a
|
|
|
|
description. The *use_datetime* flag can be used to cause date/time values to
|
|
|
|
be presented as :class:`datetime.datetime` objects; this is false by default.
|
2008-02-23 12:23:05 -04:00
|
|
|
:class:`datetime.datetime` objects may be passed to calls.
|
2007-08-15 11:28:01 -03:00
|
|
|
|
|
|
|
Both the HTTP and HTTPS transports support the URL syntax extension for HTTP
|
|
|
|
Basic Authentication: ``http://user:pass@host:port/path``. The ``user:pass``
|
|
|
|
portion will be base64-encoded as an HTTP 'Authorization' header, and sent to
|
|
|
|
the remote server as part of the connection process when invoking an XML-RPC
|
|
|
|
method. You only need to use this if the remote server requires a Basic
|
|
|
|
Authentication user and password.
|
|
|
|
|
|
|
|
The returned instance is a proxy object with methods that can be used to invoke
|
|
|
|
corresponding RPC calls on the remote server. If the remote server supports the
|
|
|
|
introspection API, the proxy can also be used to query the remote server for the
|
|
|
|
methods it supports (service discovery) and fetch other server-associated
|
|
|
|
metadata.
|
|
|
|
|
|
|
|
:class:`ServerProxy` instance methods take Python basic types and objects as
|
|
|
|
arguments and return Python basic types and classes. Types that are conformable
|
|
|
|
(e.g. that can be marshalled through XML), include the following (and except
|
|
|
|
where noted, they are unmarshalled as the same Python type):
|
|
|
|
|
|
|
|
+---------------------------------+---------------------------------------------+
|
|
|
|
| Name | Meaning |
|
|
|
|
+=================================+=============================================+
|
|
|
|
| :const:`boolean` | The :const:`True` and :const:`False` |
|
|
|
|
| | constants |
|
|
|
|
+---------------------------------+---------------------------------------------+
|
|
|
|
| :const:`integers` | Pass in directly |
|
|
|
|
+---------------------------------+---------------------------------------------+
|
|
|
|
| :const:`floating-point numbers` | Pass in directly |
|
|
|
|
+---------------------------------+---------------------------------------------+
|
|
|
|
| :const:`strings` | Pass in directly |
|
|
|
|
+---------------------------------+---------------------------------------------+
|
|
|
|
| :const:`arrays` | Any Python sequence type containing |
|
|
|
|
| | conformable elements. Arrays are returned |
|
|
|
|
| | as lists |
|
|
|
|
+---------------------------------+---------------------------------------------+
|
|
|
|
| :const:`structures` | A Python dictionary. Keys must be strings, |
|
|
|
|
| | values may be any conformable type. Objects |
|
|
|
|
| | of user-defined classes can be passed in; |
|
|
|
|
| | only their *__dict__* attribute is |
|
|
|
|
| | transmitted. |
|
|
|
|
+---------------------------------+---------------------------------------------+
|
|
|
|
| :const:`dates` | in seconds since the epoch (pass in an |
|
|
|
|
| | instance of the :class:`DateTime` class) or |
|
2008-02-23 12:23:05 -04:00
|
|
|
| | a :class:`datetime.datetime` instance. |
|
2007-08-15 11:28:01 -03:00
|
|
|
+---------------------------------+---------------------------------------------+
|
|
|
|
| :const:`binary data` | pass in an instance of the :class:`Binary` |
|
|
|
|
| | wrapper class |
|
|
|
|
+---------------------------------+---------------------------------------------+
|
|
|
|
|
|
|
|
This is the full set of data types supported by XML-RPC. Method calls may also
|
|
|
|
raise a special :exc:`Fault` instance, used to signal XML-RPC server errors, or
|
|
|
|
:exc:`ProtocolError` used to signal an error in the HTTP/HTTPS transport layer.
|
|
|
|
Both :exc:`Fault` and :exc:`ProtocolError` derive from a base class called
|
|
|
|
:exc:`Error`. Note that even though starting with Python 2.2 you can subclass
|
|
|
|
builtin types, the xmlrpclib module currently does not marshal instances of such
|
|
|
|
subclasses.
|
|
|
|
|
|
|
|
When passing strings, characters special to XML such as ``<``, ``>``, and ``&``
|
|
|
|
will be automatically escaped. However, it's the caller's responsibility to
|
|
|
|
ensure that the string is free of characters that aren't allowed in XML, such as
|
|
|
|
the control characters with ASCII values between 0 and 31 (except, of course,
|
|
|
|
tab, newline and carriage return); failing to do this will result in an XML-RPC
|
|
|
|
request that isn't well-formed XML. If you have to pass arbitrary strings via
|
|
|
|
XML-RPC, use the :class:`Binary` wrapper class described below.
|
|
|
|
|
|
|
|
:class:`Server` is retained as an alias for :class:`ServerProxy` for backwards
|
|
|
|
compatibility. New code should use :class:`ServerProxy`.
|
|
|
|
|
|
|
|
.. versionchanged:: 2.5
|
|
|
|
The *use_datetime* flag was added.
|
|
|
|
|
|
|
|
.. versionchanged:: 2.6
|
2007-10-21 09:15:05 -03:00
|
|
|
Instances of :term:`new-style class`\es can be passed in if they have an
|
|
|
|
*__dict__* attribute and don't have a base class that is marshalled in a
|
|
|
|
special way.
|
2007-08-15 11:28:01 -03:00
|
|
|
|
|
|
|
|
|
|
|
.. seealso::
|
|
|
|
|
|
|
|
`XML-RPC HOWTO <http://www.tldp.org/HOWTO/XML-RPC-HOWTO/index.html>`_
|
2008-01-11 15:33:24 -04:00
|
|
|
A good description of XML-RPC operation and client software in several languages.
|
2007-08-15 11:28:01 -03:00
|
|
|
Contains pretty much everything an XML-RPC client developer needs to know.
|
|
|
|
|
2008-01-11 15:33:24 -04:00
|
|
|
`XML-RPC Introspection <http://xmlrpc-c.sourceforge.net/introspection.html>`_
|
|
|
|
Describes the XML-RPC protocol extension for introspection.
|
2007-08-15 11:28:01 -03:00
|
|
|
|
2008-04-22 19:45:09 -03:00
|
|
|
`XML-RPC Specification <http://www.xmlrpc.com/spec>`_
|
|
|
|
The official specification.
|
|
|
|
|
|
|
|
`Unofficial XML-RPC Errata <http://effbot.org/zone/xmlrpc-errata.htm>`_
|
|
|
|
Fredrik Lundh's "unofficial errata, intended to clarify certain
|
|
|
|
details in the XML-RPC specification, as well as hint at
|
|
|
|
'best practices' to use when designing your own XML-RPC
|
|
|
|
implementations."
|
2007-08-15 11:28:01 -03:00
|
|
|
|
|
|
|
.. _serverproxy-objects:
|
|
|
|
|
|
|
|
ServerProxy Objects
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
A :class:`ServerProxy` instance has a method corresponding to each remote
|
|
|
|
procedure call accepted by the XML-RPC server. Calling the method performs an
|
|
|
|
RPC, dispatched by both name and argument signature (e.g. the same method name
|
|
|
|
can be overloaded with multiple argument signatures). The RPC finishes by
|
|
|
|
returning a value, which may be either returned data in a conformant type or a
|
|
|
|
:class:`Fault` or :class:`ProtocolError` object indicating an error.
|
|
|
|
|
|
|
|
Servers that support the XML introspection API support some common methods
|
|
|
|
grouped under the reserved :attr:`system` member:
|
|
|
|
|
|
|
|
|
|
|
|
.. method:: ServerProxy.system.listMethods()
|
|
|
|
|
|
|
|
This method returns a list of strings, one for each (non-system) method
|
|
|
|
supported by the XML-RPC server.
|
|
|
|
|
|
|
|
|
|
|
|
.. method:: ServerProxy.system.methodSignature(name)
|
|
|
|
|
|
|
|
This method takes one parameter, the name of a method implemented by the XML-RPC
|
|
|
|
server.It returns an array of possible signatures for this method. A signature
|
|
|
|
is an array of types. The first of these types is the return type of the method,
|
|
|
|
the rest are parameters.
|
|
|
|
|
|
|
|
Because multiple signatures (ie. overloading) is permitted, this method returns
|
|
|
|
a list of signatures rather than a singleton.
|
|
|
|
|
|
|
|
Signatures themselves are restricted to the top level parameters expected by a
|
|
|
|
method. For instance if a method expects one array of structs as a parameter,
|
|
|
|
and it returns a string, its signature is simply "string, array". If it expects
|
|
|
|
three integers and returns a string, its signature is "string, int, int, int".
|
|
|
|
|
|
|
|
If no signature is defined for the method, a non-array value is returned. In
|
|
|
|
Python this means that the type of the returned value will be something other
|
|
|
|
that list.
|
|
|
|
|
|
|
|
|
|
|
|
.. method:: ServerProxy.system.methodHelp(name)
|
|
|
|
|
|
|
|
This method takes one parameter, the name of a method implemented by the XML-RPC
|
|
|
|
server. It returns a documentation string describing the use of that method. If
|
|
|
|
no such string is available, an empty string is returned. The documentation
|
|
|
|
string may contain HTML markup.
|
|
|
|
|
|
|
|
|
|
|
|
.. _boolean-objects:
|
|
|
|
|
|
|
|
Boolean Objects
|
|
|
|
---------------
|
|
|
|
|
|
|
|
This class may be initialized from any Python value; the instance returned
|
|
|
|
depends only on its truth value. It supports various Python operators through
|
|
|
|
:meth:`__cmp__`, :meth:`__repr__`, :meth:`__int__`, and :meth:`__nonzero__`
|
|
|
|
methods, all implemented in the obvious ways.
|
|
|
|
|
|
|
|
It also has the following method, supported mainly for internal use by the
|
|
|
|
unmarshalling code:
|
|
|
|
|
|
|
|
|
|
|
|
.. method:: Boolean.encode(out)
|
|
|
|
|
|
|
|
Write the XML-RPC encoding of this Boolean item to the out stream object.
|
|
|
|
|
2007-12-03 16:03:46 -04:00
|
|
|
A working example follows. The server code::
|
|
|
|
|
|
|
|
import xmlrpclib
|
|
|
|
from SimpleXMLRPCServer import SimpleXMLRPCServer
|
|
|
|
|
|
|
|
def is_even(n):
|
|
|
|
return n%2 == 0
|
|
|
|
|
|
|
|
server = SimpleXMLRPCServer(("localhost", 8000))
|
|
|
|
print "Listening on port 8000..."
|
|
|
|
server.register_function(is_even, "is_even")
|
|
|
|
server.serve_forever()
|
|
|
|
|
|
|
|
The client code for the preceding server::
|
|
|
|
|
|
|
|
import xmlrpclib
|
|
|
|
|
|
|
|
proxy = xmlrpclib.ServerProxy("http://localhost:8000/")
|
|
|
|
print "3 is even: %s" % str(proxy.is_even(3))
|
|
|
|
print "100 is even: %s" % str(proxy.is_even(100))
|
2007-08-15 11:28:01 -03:00
|
|
|
|
|
|
|
.. _datetime-objects:
|
|
|
|
|
|
|
|
DateTime Objects
|
|
|
|
----------------
|
|
|
|
|
2008-02-23 12:23:05 -04:00
|
|
|
This class may be initialized with seconds since the epoch, a time
|
|
|
|
tuple, an ISO 8601 time/date string, or a :class:`datetime.datetime`
|
|
|
|
instance. It has the following methods, supported mainly for internal
|
|
|
|
use by the marshalling/unmarshalling code:
|
2007-08-15 11:28:01 -03:00
|
|
|
|
|
|
|
|
|
|
|
.. method:: DateTime.decode(string)
|
|
|
|
|
|
|
|
Accept a string as the instance's new time value.
|
|
|
|
|
|
|
|
|
|
|
|
.. method:: DateTime.encode(out)
|
|
|
|
|
|
|
|
Write the XML-RPC encoding of this :class:`DateTime` item to the *out* stream
|
|
|
|
object.
|
|
|
|
|
|
|
|
It also supports certain of Python's built-in operators through :meth:`__cmp__`
|
|
|
|
and :meth:`__repr__` methods.
|
|
|
|
|
2007-12-03 16:03:46 -04:00
|
|
|
A working example follows. The server code::
|
|
|
|
|
|
|
|
import datetime
|
|
|
|
from SimpleXMLRPCServer import SimpleXMLRPCServer
|
|
|
|
import xmlrpclib
|
|
|
|
|
|
|
|
def today():
|
|
|
|
today = datetime.datetime.today()
|
|
|
|
return xmlrpclib.DateTime(today)
|
|
|
|
|
|
|
|
server = SimpleXMLRPCServer(("localhost", 8000))
|
|
|
|
print "Listening on port 8000..."
|
|
|
|
server.register_function(today, "today")
|
|
|
|
server.serve_forever()
|
|
|
|
|
|
|
|
The client code for the preceding server::
|
|
|
|
|
|
|
|
import xmlrpclib
|
|
|
|
import datetime
|
|
|
|
|
|
|
|
proxy = xmlrpclib.ServerProxy("http://localhost:8000/")
|
|
|
|
|
|
|
|
today = proxy.today()
|
|
|
|
# convert the ISO8601 string to a datetime object
|
|
|
|
converted = datetime.datetime.strptime(today.value, "%Y%m%dT%H:%M:%S")
|
|
|
|
print "Today: %s" % converted.strftime("%d.%m.%Y, %H:%M")
|
2007-08-15 11:28:01 -03:00
|
|
|
|
|
|
|
.. _binary-objects:
|
|
|
|
|
|
|
|
Binary Objects
|
|
|
|
--------------
|
|
|
|
|
|
|
|
This class may be initialized from string data (which may include NULs). The
|
|
|
|
primary access to the content of a :class:`Binary` object is provided by an
|
|
|
|
attribute:
|
|
|
|
|
|
|
|
|
|
|
|
.. attribute:: Binary.data
|
|
|
|
|
|
|
|
The binary data encapsulated by the :class:`Binary` instance. The data is
|
|
|
|
provided as an 8-bit string.
|
|
|
|
|
|
|
|
:class:`Binary` objects have the following methods, supported mainly for
|
|
|
|
internal use by the marshalling/unmarshalling code:
|
|
|
|
|
|
|
|
|
|
|
|
.. method:: Binary.decode(string)
|
|
|
|
|
|
|
|
Accept a base64 string and decode it as the instance's new data.
|
|
|
|
|
|
|
|
|
|
|
|
.. method:: Binary.encode(out)
|
|
|
|
|
|
|
|
Write the XML-RPC base 64 encoding of this binary item to the out stream object.
|
|
|
|
|
2008-04-22 19:45:09 -03:00
|
|
|
The encoded data will have newlines every 76 characters as per
|
|
|
|
`RFC 2045 section 6.8 <http://tools.ietf.org/html/rfc2045#section-6.8>`_,
|
|
|
|
which was the de facto standard base64 specification when the
|
|
|
|
XML-RPC spec was written.
|
|
|
|
|
2007-08-15 11:28:01 -03:00
|
|
|
It also supports certain of Python's built-in operators through a
|
|
|
|
:meth:`__cmp__` method.
|
|
|
|
|
2007-12-03 16:03:46 -04:00
|
|
|
Example usage of the binary objects. We're going to transfer an image over
|
|
|
|
XMLRPC::
|
|
|
|
|
|
|
|
from SimpleXMLRPCServer import SimpleXMLRPCServer
|
|
|
|
import xmlrpclib
|
|
|
|
|
|
|
|
def python_logo():
|
Merged revisions 68582,68718,68720-68721,68724-68727,68859,68973,69288-69289,69293,69295,69297-69301,69409,69414,69570,69573,69576,69728-69730,69769,69776,69803-69805,69840,69896 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r68582 | georg.brandl | 2009-01-13 23:14:01 +0100 (Di, 13 Jan 2009) | 2 lines
Use assertRaises.
........
r68718 | georg.brandl | 2009-01-18 11:42:35 +0100 (So, 18 Jan 2009) | 1 line
#4976: union() and intersection() take multiple args, but talk about "the other".
........
r68720 | georg.brandl | 2009-01-18 11:45:22 +0100 (So, 18 Jan 2009) | 1 line
#4974: fix redundant mention of lists and tuples.
........
r68721 | georg.brandl | 2009-01-18 11:48:16 +0100 (So, 18 Jan 2009) | 1 line
#4914: trunc is in math.
........
r68724 | georg.brandl | 2009-01-18 14:24:10 +0100 (So, 18 Jan 2009) | 1 line
#4979: correct result range for some random functions.
........
r68725 | georg.brandl | 2009-01-18 14:47:26 +0100 (So, 18 Jan 2009) | 1 line
#4857: fix augmented assignment target spec.
........
r68726 | georg.brandl | 2009-01-18 15:41:52 +0100 (So, 18 Jan 2009) | 1 line
#4923: clarify what was added.
........
r68727 | georg.brandl | 2009-01-18 19:25:30 +0100 (So, 18 Jan 2009) | 1 line
#4986: augassigns are not expressions.
........
r68859 | georg.brandl | 2009-01-22 19:29:28 +0100 (Do, 22 Jan 2009) | 2 lines
Clarify wording.
........
r68973 | georg.brandl | 2009-01-26 22:29:38 +0100 (Mo, 26 Jan 2009) | 2 lines
Copy over docs on advanced role features from Sphinx docs.
........
r69288 | georg.brandl | 2009-02-05 11:30:57 +0100 (Do, 05 Feb 2009) | 1 line
#5153: fix typo in example.
........
r69289 | georg.brandl | 2009-02-05 11:37:07 +0100 (Do, 05 Feb 2009) | 1 line
#5144: document that PySys_SetArgv prepends the script directory (or the empty string) to sys.path.
........
r69293 | georg.brandl | 2009-02-05 11:59:28 +0100 (Do, 05 Feb 2009) | 1 line
#5059: fix example.
........
r69295 | georg.brandl | 2009-02-05 12:23:47 +0100 (Do, 05 Feb 2009) | 1 line
PyErr_PrintEx is also in 2.x...
........
r69297 | georg.brandl | 2009-02-05 12:32:18 +0100 (Do, 05 Feb 2009) | 1 line
#5015: document PythonHome API functions.
........
r69298 | georg.brandl | 2009-02-05 12:33:21 +0100 (Do, 05 Feb 2009) | 1 line
#4827: fix callback example.
........
r69299 | georg.brandl | 2009-02-05 12:35:28 +0100 (Do, 05 Feb 2009) | 1 line
#4820: use correct module for ctypes.util.
........
r69300 | georg.brandl | 2009-02-05 12:38:23 +0100 (Do, 05 Feb 2009) | 1 line
#4563: disable alpha and roman lists, fixes wrong formatting of contributor list.
........
r69301 | georg.brandl | 2009-02-05 12:40:35 +0100 (Do, 05 Feb 2009) | 1 line
#5031: fix Thread.daemon property docs.
........
r69409 | georg.brandl | 2009-02-07 13:21:17 +0100 (Sa, 07 Feb 2009) | 1 line
#5174: fix wrong file closing in example.
........
r69414 | georg.brandl | 2009-02-07 19:49:54 +0100 (Sa, 07 Feb 2009) | 1 line
make "super only for new-style classes" a note.
........
r69570 | georg.brandl | 2009-02-13 11:40:14 +0100 (Fr, 13 Feb 2009) | 1 line
#4894: document "newurl" parameter to redirect_request().
........
r69573 | georg.brandl | 2009-02-13 11:44:17 +0100 (Fr, 13 Feb 2009) | 1 line
#3734: document complex coercing behavior better.
........
r69576 | georg.brandl | 2009-02-13 11:56:50 +0100 (Fr, 13 Feb 2009) | 1 line
#1661108: note that urlsafe encoded string can contain "=".
........
r69728 | georg.brandl | 2009-02-18 01:22:55 +0100 (Mi, 18 Feb 2009) | 2 lines
#5297: fix example.
........
r69729 | georg.brandl | 2009-02-18 01:25:13 +0100 (Mi, 18 Feb 2009) | 2 lines
#5296: sequence -> iterable.
........
r69730 | georg.brandl | 2009-02-18 01:31:36 +0100 (Mi, 18 Feb 2009) | 2 lines
#5268: mention VMSError.
........
r69769 | georg.brandl | 2009-02-19 09:30:06 +0100 (Do, 19 Feb 2009) | 1 line
#5310, #3558: fix operator precedence table.
........
r69776 | georg.brandl | 2009-02-19 17:34:51 +0100 (Do, 19 Feb 2009) | 2 lines
#5317: update IronPython URL.
........
r69803 | georg.brandl | 2009-02-20 08:48:21 +0100 (Fr, 20 Feb 2009) | 1 line
#5327: fix a broken link by joining it.
........
r69804 | georg.brandl | 2009-02-20 09:22:21 +0100 (Fr, 20 Feb 2009) | 1 line
At least separate imports from other statements.
........
r69805 | georg.brandl | 2009-02-20 09:45:47 +0100 (Fr, 20 Feb 2009) | 2 lines
Fix punctuation.
........
r69840 | georg.brandl | 2009-02-21 20:09:40 +0100 (Sa, 21 Feb 2009) | 1 line
#5338, #5339: two types in the API manual.
........
r69896 | georg.brandl | 2009-02-23 11:24:23 +0100 (Mo, 23 Feb 2009) | 1 line
#5348: format() converts all kinds of values.
........
2009-02-23 06:41:11 -04:00
|
|
|
with open("python_logo.jpg") as handle:
|
|
|
|
return xmlrpclib.Binary(handle.read())
|
2007-12-03 16:03:46 -04:00
|
|
|
|
|
|
|
server = SimpleXMLRPCServer(("localhost", 8000))
|
|
|
|
print "Listening on port 8000..."
|
|
|
|
server.register_function(python_logo, 'python_logo')
|
|
|
|
|
|
|
|
server.serve_forever()
|
|
|
|
|
|
|
|
The client gets the image and saves it to a file::
|
|
|
|
|
|
|
|
import xmlrpclib
|
|
|
|
|
|
|
|
proxy = xmlrpclib.ServerProxy("http://localhost:8000/")
|
Merged revisions 68582,68718,68720-68721,68724-68727,68859,68973,69288-69289,69293,69295,69297-69301,69409,69414,69570,69573,69576,69728-69730,69769,69776,69803-69805,69840,69896 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r68582 | georg.brandl | 2009-01-13 23:14:01 +0100 (Di, 13 Jan 2009) | 2 lines
Use assertRaises.
........
r68718 | georg.brandl | 2009-01-18 11:42:35 +0100 (So, 18 Jan 2009) | 1 line
#4976: union() and intersection() take multiple args, but talk about "the other".
........
r68720 | georg.brandl | 2009-01-18 11:45:22 +0100 (So, 18 Jan 2009) | 1 line
#4974: fix redundant mention of lists and tuples.
........
r68721 | georg.brandl | 2009-01-18 11:48:16 +0100 (So, 18 Jan 2009) | 1 line
#4914: trunc is in math.
........
r68724 | georg.brandl | 2009-01-18 14:24:10 +0100 (So, 18 Jan 2009) | 1 line
#4979: correct result range for some random functions.
........
r68725 | georg.brandl | 2009-01-18 14:47:26 +0100 (So, 18 Jan 2009) | 1 line
#4857: fix augmented assignment target spec.
........
r68726 | georg.brandl | 2009-01-18 15:41:52 +0100 (So, 18 Jan 2009) | 1 line
#4923: clarify what was added.
........
r68727 | georg.brandl | 2009-01-18 19:25:30 +0100 (So, 18 Jan 2009) | 1 line
#4986: augassigns are not expressions.
........
r68859 | georg.brandl | 2009-01-22 19:29:28 +0100 (Do, 22 Jan 2009) | 2 lines
Clarify wording.
........
r68973 | georg.brandl | 2009-01-26 22:29:38 +0100 (Mo, 26 Jan 2009) | 2 lines
Copy over docs on advanced role features from Sphinx docs.
........
r69288 | georg.brandl | 2009-02-05 11:30:57 +0100 (Do, 05 Feb 2009) | 1 line
#5153: fix typo in example.
........
r69289 | georg.brandl | 2009-02-05 11:37:07 +0100 (Do, 05 Feb 2009) | 1 line
#5144: document that PySys_SetArgv prepends the script directory (or the empty string) to sys.path.
........
r69293 | georg.brandl | 2009-02-05 11:59:28 +0100 (Do, 05 Feb 2009) | 1 line
#5059: fix example.
........
r69295 | georg.brandl | 2009-02-05 12:23:47 +0100 (Do, 05 Feb 2009) | 1 line
PyErr_PrintEx is also in 2.x...
........
r69297 | georg.brandl | 2009-02-05 12:32:18 +0100 (Do, 05 Feb 2009) | 1 line
#5015: document PythonHome API functions.
........
r69298 | georg.brandl | 2009-02-05 12:33:21 +0100 (Do, 05 Feb 2009) | 1 line
#4827: fix callback example.
........
r69299 | georg.brandl | 2009-02-05 12:35:28 +0100 (Do, 05 Feb 2009) | 1 line
#4820: use correct module for ctypes.util.
........
r69300 | georg.brandl | 2009-02-05 12:38:23 +0100 (Do, 05 Feb 2009) | 1 line
#4563: disable alpha and roman lists, fixes wrong formatting of contributor list.
........
r69301 | georg.brandl | 2009-02-05 12:40:35 +0100 (Do, 05 Feb 2009) | 1 line
#5031: fix Thread.daemon property docs.
........
r69409 | georg.brandl | 2009-02-07 13:21:17 +0100 (Sa, 07 Feb 2009) | 1 line
#5174: fix wrong file closing in example.
........
r69414 | georg.brandl | 2009-02-07 19:49:54 +0100 (Sa, 07 Feb 2009) | 1 line
make "super only for new-style classes" a note.
........
r69570 | georg.brandl | 2009-02-13 11:40:14 +0100 (Fr, 13 Feb 2009) | 1 line
#4894: document "newurl" parameter to redirect_request().
........
r69573 | georg.brandl | 2009-02-13 11:44:17 +0100 (Fr, 13 Feb 2009) | 1 line
#3734: document complex coercing behavior better.
........
r69576 | georg.brandl | 2009-02-13 11:56:50 +0100 (Fr, 13 Feb 2009) | 1 line
#1661108: note that urlsafe encoded string can contain "=".
........
r69728 | georg.brandl | 2009-02-18 01:22:55 +0100 (Mi, 18 Feb 2009) | 2 lines
#5297: fix example.
........
r69729 | georg.brandl | 2009-02-18 01:25:13 +0100 (Mi, 18 Feb 2009) | 2 lines
#5296: sequence -> iterable.
........
r69730 | georg.brandl | 2009-02-18 01:31:36 +0100 (Mi, 18 Feb 2009) | 2 lines
#5268: mention VMSError.
........
r69769 | georg.brandl | 2009-02-19 09:30:06 +0100 (Do, 19 Feb 2009) | 1 line
#5310, #3558: fix operator precedence table.
........
r69776 | georg.brandl | 2009-02-19 17:34:51 +0100 (Do, 19 Feb 2009) | 2 lines
#5317: update IronPython URL.
........
r69803 | georg.brandl | 2009-02-20 08:48:21 +0100 (Fr, 20 Feb 2009) | 1 line
#5327: fix a broken link by joining it.
........
r69804 | georg.brandl | 2009-02-20 09:22:21 +0100 (Fr, 20 Feb 2009) | 1 line
At least separate imports from other statements.
........
r69805 | georg.brandl | 2009-02-20 09:45:47 +0100 (Fr, 20 Feb 2009) | 2 lines
Fix punctuation.
........
r69840 | georg.brandl | 2009-02-21 20:09:40 +0100 (Sa, 21 Feb 2009) | 1 line
#5338, #5339: two types in the API manual.
........
r69896 | georg.brandl | 2009-02-23 11:24:23 +0100 (Mo, 23 Feb 2009) | 1 line
#5348: format() converts all kinds of values.
........
2009-02-23 06:41:11 -04:00
|
|
|
with open("fetched_python_logo.jpg", "w") as handle:
|
|
|
|
handle.write(proxy.python_logo().data)
|
2007-08-15 11:28:01 -03:00
|
|
|
|
|
|
|
.. _fault-objects:
|
|
|
|
|
|
|
|
Fault Objects
|
|
|
|
-------------
|
|
|
|
|
|
|
|
A :class:`Fault` object encapsulates the content of an XML-RPC fault tag. Fault
|
|
|
|
objects have the following members:
|
|
|
|
|
|
|
|
|
|
|
|
.. attribute:: Fault.faultCode
|
|
|
|
|
|
|
|
A string indicating the fault type.
|
|
|
|
|
|
|
|
|
|
|
|
.. attribute:: Fault.faultString
|
|
|
|
|
|
|
|
A string containing a diagnostic message associated with the fault.
|
|
|
|
|
2007-12-03 16:03:46 -04:00
|
|
|
In the following example we're going to intentionally cause a :exc:`Fault` by
|
|
|
|
returning a complex type object. The server code::
|
|
|
|
|
|
|
|
from SimpleXMLRPCServer import SimpleXMLRPCServer
|
|
|
|
|
|
|
|
# A marshalling error is going to occur because we're returning a
|
|
|
|
# complex number
|
|
|
|
def add(x,y):
|
|
|
|
return x+y+0j
|
|
|
|
|
|
|
|
server = SimpleXMLRPCServer(("localhost", 8000))
|
|
|
|
print "Listening on port 8000..."
|
|
|
|
server.register_function(add, 'add')
|
|
|
|
|
|
|
|
server.serve_forever()
|
|
|
|
|
|
|
|
The client code for the preceding server::
|
|
|
|
|
|
|
|
import xmlrpclib
|
|
|
|
|
|
|
|
proxy = xmlrpclib.ServerProxy("http://localhost:8000/")
|
|
|
|
try:
|
|
|
|
proxy.add(2, 5)
|
|
|
|
except xmlrpclib.Fault, err:
|
2008-07-12 17:16:19 -03:00
|
|
|
print "A fault occurred"
|
2007-12-03 16:03:46 -04:00
|
|
|
print "Fault code: %d" % err.faultCode
|
|
|
|
print "Fault string: %s" % err.faultString
|
|
|
|
|
|
|
|
|
2007-08-15 11:28:01 -03:00
|
|
|
|
|
|
|
.. _protocol-error-objects:
|
|
|
|
|
|
|
|
ProtocolError Objects
|
|
|
|
---------------------
|
|
|
|
|
|
|
|
A :class:`ProtocolError` object describes a protocol error in the underlying
|
|
|
|
transport layer (such as a 404 'not found' error if the server named by the URI
|
|
|
|
does not exist). It has the following members:
|
|
|
|
|
|
|
|
|
|
|
|
.. attribute:: ProtocolError.url
|
|
|
|
|
|
|
|
The URI or URL that triggered the error.
|
|
|
|
|
|
|
|
|
|
|
|
.. attribute:: ProtocolError.errcode
|
|
|
|
|
|
|
|
The error code.
|
|
|
|
|
|
|
|
|
|
|
|
.. attribute:: ProtocolError.errmsg
|
|
|
|
|
|
|
|
The error message or diagnostic string.
|
|
|
|
|
|
|
|
|
|
|
|
.. attribute:: ProtocolError.headers
|
|
|
|
|
|
|
|
A string containing the headers of the HTTP/HTTPS request that triggered the
|
|
|
|
error.
|
|
|
|
|
2007-12-03 16:03:46 -04:00
|
|
|
In the following example we're going to intentionally cause a :exc:`ProtocolError`
|
|
|
|
by providing an invalid URI::
|
|
|
|
|
|
|
|
import xmlrpclib
|
|
|
|
|
|
|
|
# create a ServerProxy with an invalid URI
|
|
|
|
proxy = xmlrpclib.ServerProxy("http://invalidaddress/")
|
|
|
|
|
|
|
|
try:
|
|
|
|
proxy.some_method()
|
|
|
|
except xmlrpclib.ProtocolError, err:
|
2008-07-12 17:16:19 -03:00
|
|
|
print "A protocol error occurred"
|
2007-12-03 16:03:46 -04:00
|
|
|
print "URL: %s" % err.url
|
|
|
|
print "HTTP/HTTPS headers: %s" % err.headers
|
|
|
|
print "Error code: %d" % err.errcode
|
|
|
|
print "Error message: %s" % err.errmsg
|
2007-08-15 11:28:01 -03:00
|
|
|
|
|
|
|
MultiCall Objects
|
|
|
|
-----------------
|
|
|
|
|
|
|
|
.. versionadded:: 2.4
|
|
|
|
|
|
|
|
In http://www.xmlrpc.com/discuss/msgReader%241208, an approach is presented to
|
|
|
|
encapsulate multiple calls to a remote server into a single request.
|
|
|
|
|
|
|
|
|
|
|
|
.. class:: MultiCall(server)
|
|
|
|
|
|
|
|
Create an object used to boxcar method calls. *server* is the eventual target of
|
|
|
|
the call. Calls can be made to the result object, but they will immediately
|
|
|
|
return ``None``, and only store the call name and parameters in the
|
|
|
|
:class:`MultiCall` object. Calling the object itself causes all stored calls to
|
|
|
|
be transmitted as a single ``system.multicall`` request. The result of this call
|
2007-10-21 07:52:38 -03:00
|
|
|
is a :term:`generator`; iterating over this generator yields the individual
|
|
|
|
results.
|
2007-08-15 11:28:01 -03:00
|
|
|
|
2007-12-03 16:03:46 -04:00
|
|
|
A usage example of this class follows. The server code ::
|
|
|
|
|
|
|
|
from SimpleXMLRPCServer import SimpleXMLRPCServer
|
|
|
|
|
|
|
|
def add(x,y):
|
|
|
|
return x+y
|
2007-08-15 11:28:01 -03:00
|
|
|
|
2007-12-03 16:03:46 -04:00
|
|
|
def subtract(x, y):
|
|
|
|
return x-y
|
|
|
|
|
|
|
|
def multiply(x, y):
|
|
|
|
return x*y
|
|
|
|
|
|
|
|
def divide(x, y):
|
|
|
|
return x/y
|
|
|
|
|
|
|
|
# A simple server with simple arithmetic functions
|
|
|
|
server = SimpleXMLRPCServer(("localhost", 8000))
|
|
|
|
print "Listening on port 8000..."
|
|
|
|
server.register_multicall_functions()
|
|
|
|
server.register_function(add, 'add')
|
|
|
|
server.register_function(subtract, 'subtract')
|
|
|
|
server.register_function(multiply, 'multiply')
|
|
|
|
server.register_function(divide, 'divide')
|
|
|
|
server.serve_forever()
|
|
|
|
|
|
|
|
The client code for the preceding server::
|
|
|
|
|
|
|
|
import xmlrpclib
|
|
|
|
|
|
|
|
proxy = xmlrpclib.ServerProxy("http://localhost:8000/")
|
|
|
|
multicall = xmlrpclib.MultiCall(proxy)
|
|
|
|
multicall.add(7,3)
|
|
|
|
multicall.subtract(7,3)
|
|
|
|
multicall.multiply(7,3)
|
|
|
|
multicall.divide(7,3)
|
|
|
|
result = multicall()
|
|
|
|
|
|
|
|
print "7+3=%d, 7-3=%d, 7*3=%d, 7/3=%d" % tuple(result)
|
2007-08-15 11:28:01 -03:00
|
|
|
|
|
|
|
|
|
|
|
Convenience Functions
|
|
|
|
---------------------
|
|
|
|
|
|
|
|
|
|
|
|
.. function:: boolean(value)
|
|
|
|
|
|
|
|
Convert any Python value to one of the XML-RPC Boolean constants, ``True`` or
|
|
|
|
``False``.
|
|
|
|
|
|
|
|
|
|
|
|
.. function:: dumps(params[, methodname[, methodresponse[, encoding[, allow_none]]]])
|
|
|
|
|
|
|
|
Convert *params* into an XML-RPC request. or into a response if *methodresponse*
|
|
|
|
is true. *params* can be either a tuple of arguments or an instance of the
|
|
|
|
:exc:`Fault` exception class. If *methodresponse* is true, only a single value
|
|
|
|
can be returned, meaning that *params* must be of length 1. *encoding*, if
|
|
|
|
supplied, is the encoding to use in the generated XML; the default is UTF-8.
|
|
|
|
Python's :const:`None` value cannot be used in standard XML-RPC; to allow using
|
|
|
|
it via an extension, provide a true value for *allow_none*.
|
|
|
|
|
|
|
|
|
|
|
|
.. function:: loads(data[, use_datetime])
|
|
|
|
|
|
|
|
Convert an XML-RPC request or response into Python objects, a ``(params,
|
|
|
|
methodname)``. *params* is a tuple of argument; *methodname* is a string, or
|
|
|
|
``None`` if no method name is present in the packet. If the XML-RPC packet
|
|
|
|
represents a fault condition, this function will raise a :exc:`Fault` exception.
|
|
|
|
The *use_datetime* flag can be used to cause date/time values to be presented as
|
2008-02-23 12:23:05 -04:00
|
|
|
:class:`datetime.datetime` objects; this is false by default.
|
2007-08-15 11:28:01 -03:00
|
|
|
|
|
|
|
.. versionchanged:: 2.5
|
|
|
|
The *use_datetime* flag was added.
|
|
|
|
|
|
|
|
|
|
|
|
.. _xmlrpc-client-example:
|
|
|
|
|
|
|
|
Example of Client Usage
|
|
|
|
-----------------------
|
|
|
|
|
|
|
|
::
|
|
|
|
|
|
|
|
# simple test program (from the XML-RPC specification)
|
|
|
|
from xmlrpclib import ServerProxy, Error
|
|
|
|
|
|
|
|
# server = ServerProxy("http://localhost:8000") # local server
|
|
|
|
server = ServerProxy("http://betty.userland.com")
|
|
|
|
|
|
|
|
print server
|
|
|
|
|
|
|
|
try:
|
|
|
|
print server.examples.getStateName(41)
|
|
|
|
except Error, v:
|
|
|
|
print "ERROR", v
|
|
|
|
|
|
|
|
To access an XML-RPC server through a proxy, you need to define a custom
|
2007-12-29 06:57:00 -04:00
|
|
|
transport. The following example shows how:
|
2007-08-15 11:28:01 -03:00
|
|
|
|
2007-12-29 06:57:00 -04:00
|
|
|
.. Example taken from http://lowlife.jp/nobonobo/wiki/xmlrpcwithproxy.html
|
2007-08-15 11:28:01 -03:00
|
|
|
|
|
|
|
::
|
|
|
|
|
|
|
|
import xmlrpclib, httplib
|
|
|
|
|
|
|
|
class ProxiedTransport(xmlrpclib.Transport):
|
|
|
|
def set_proxy(self, proxy):
|
|
|
|
self.proxy = proxy
|
|
|
|
def make_connection(self, host):
|
|
|
|
self.realhost = host
|
Merged revisions 68133-68134,68141-68142,68145-68146,68148-68149,68159-68162,68166,68171-68174,68179,68195-68196,68210,68214-68215,68217-68222 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r68133 | antoine.pitrou | 2009-01-01 16:38:03 +0100 (Thu, 01 Jan 2009) | 1 line
fill in actual issue number in tests
........
r68134 | hirokazu.yamamoto | 2009-01-01 16:45:39 +0100 (Thu, 01 Jan 2009) | 2 lines
Issue #4797: IOError.filename was not set when _fileio.FileIO failed to open
file with `str' filename on Windows.
........
r68141 | benjamin.peterson | 2009-01-01 17:43:12 +0100 (Thu, 01 Jan 2009) | 1 line
fix highlighting
........
r68142 | benjamin.peterson | 2009-01-01 18:29:49 +0100 (Thu, 01 Jan 2009) | 2 lines
welcome to 2009, Python!
........
r68145 | amaury.forgeotdarc | 2009-01-02 01:03:54 +0100 (Fri, 02 Jan 2009) | 5 lines
#4801 _collections module fails to build on cygwin.
_PyObject_GC_TRACK is the macro version of PyObject_GC_Track,
and according to documentation it should not be used for extension modules.
........
r68146 | ronald.oussoren | 2009-01-02 11:44:46 +0100 (Fri, 02 Jan 2009) | 2 lines
Fix for issue4472: "configure --enable-shared doesn't work on OSX"
........
r68148 | ronald.oussoren | 2009-01-02 11:48:31 +0100 (Fri, 02 Jan 2009) | 2 lines
Forgot to add a NEWS item in my previous checkin
........
r68149 | ronald.oussoren | 2009-01-02 11:50:48 +0100 (Fri, 02 Jan 2009) | 2 lines
Fix for issue4780
........
r68159 | ronald.oussoren | 2009-01-02 15:48:17 +0100 (Fri, 02 Jan 2009) | 2 lines
Fix for issue 1627952
........
r68160 | ronald.oussoren | 2009-01-02 15:52:09 +0100 (Fri, 02 Jan 2009) | 2 lines
Fix for issue r1737832
........
r68161 | ronald.oussoren | 2009-01-02 16:00:05 +0100 (Fri, 02 Jan 2009) | 3 lines
Fix for issue 1149804
........
r68162 | ronald.oussoren | 2009-01-02 16:06:00 +0100 (Fri, 02 Jan 2009) | 3 lines
Fix for issue 4472 is incompatible with Cygwin, this patch
should fix that.
........
r68166 | benjamin.peterson | 2009-01-02 19:26:23 +0100 (Fri, 02 Jan 2009) | 1 line
document PyMemberDef
........
r68171 | georg.brandl | 2009-01-02 21:25:14 +0100 (Fri, 02 Jan 2009) | 3 lines
#4811: fix markup glitches (mostly remains of the conversion),
found by Gabriel Genellina.
........
r68172 | martin.v.loewis | 2009-01-02 21:32:55 +0100 (Fri, 02 Jan 2009) | 2 lines
Issue #4075: Use OutputDebugStringW in Py_FatalError.
........
r68173 | martin.v.loewis | 2009-01-02 21:40:14 +0100 (Fri, 02 Jan 2009) | 2 lines
Issue #4051: Prevent conflict of UNICODE macros in cPickle.
........
r68174 | benjamin.peterson | 2009-01-02 21:47:27 +0100 (Fri, 02 Jan 2009) | 1 line
fix compilation on non-Windows platforms
........
r68179 | raymond.hettinger | 2009-01-02 22:26:45 +0100 (Fri, 02 Jan 2009) | 1 line
Issue #4615. Document how to use itertools for de-duping.
........
r68195 | georg.brandl | 2009-01-03 14:45:15 +0100 (Sat, 03 Jan 2009) | 2 lines
Remove useless string literal.
........
r68196 | georg.brandl | 2009-01-03 15:29:53 +0100 (Sat, 03 Jan 2009) | 2 lines
Fix indentation.
........
r68210 | georg.brandl | 2009-01-03 20:10:12 +0100 (Sat, 03 Jan 2009) | 2 lines
Set eol-style correctly for mp_distributing.py.
........
r68214 | georg.brandl | 2009-01-03 20:44:48 +0100 (Sat, 03 Jan 2009) | 2 lines
Make indentation consistent.
........
r68215 | georg.brandl | 2009-01-03 21:15:14 +0100 (Sat, 03 Jan 2009) | 2 lines
Fix role name.
........
r68217 | georg.brandl | 2009-01-03 21:30:15 +0100 (Sat, 03 Jan 2009) | 2 lines
Add rstlint, a little tool to find subtle markup problems and inconsistencies in the Doc sources.
........
r68218 | georg.brandl | 2009-01-03 21:38:59 +0100 (Sat, 03 Jan 2009) | 2 lines
Recognize usage of the default role.
........
r68219 | georg.brandl | 2009-01-03 21:47:01 +0100 (Sat, 03 Jan 2009) | 2 lines
Fix uses of the default role.
........
r68220 | georg.brandl | 2009-01-03 21:55:06 +0100 (Sat, 03 Jan 2009) | 2 lines
Remove trailing whitespace.
........
r68221 | georg.brandl | 2009-01-03 22:04:55 +0100 (Sat, 03 Jan 2009) | 2 lines
Remove tabs from the documentation.
........
r68222 | georg.brandl | 2009-01-03 22:11:58 +0100 (Sat, 03 Jan 2009) | 2 lines
Disable the line length checker by default.
........
2009-01-03 17:55:17 -04:00
|
|
|
h = httplib.HTTP(self.proxy)
|
|
|
|
return h
|
2007-08-15 11:28:01 -03:00
|
|
|
def send_request(self, connection, handler, request_body):
|
|
|
|
connection.putrequest("POST", 'http://%s%s' % (self.realhost, handler))
|
|
|
|
def send_host(self, connection, host):
|
|
|
|
connection.putheader('Host', self.realhost)
|
|
|
|
|
|
|
|
p = ProxiedTransport()
|
|
|
|
p.set_proxy('proxy-server:8080')
|
|
|
|
server = xmlrpclib.Server('http://time.xmlrpc.com/RPC2', transport=p)
|
|
|
|
print server.currentTime.getCurrentTime()
|
|
|
|
|
2007-12-03 16:03:46 -04:00
|
|
|
|
|
|
|
Example of Client and Server Usage
|
|
|
|
----------------------------------
|
|
|
|
|
|
|
|
See :ref:`simplexmlrpcserver-example`.
|
|
|
|
|
|
|
|
|