2017 © Pedro Peláez
 

library xml-rpc

Lightweight XML-RPC library.

image

milo/xml-rpc

Lightweight XML-RPC library.

  • Saturday, September 23, 2017
  • by milonemilo
  • Repository
  • 1 Watchers
  • 7 Stars
  • 5,145 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 3 Forks
  • 0 Open issues
  • 5 Versions
  • 38 % Grown

The README.md

XML-RPC

This library helps to work with XML-RPC calls and responses. It requires only PHP DOM extension. It is based on word written specification on http://www.xmlrpc.com/., (*1)

PHP 7.1 or newer is required since v3.0 release. The v2.x releases supports PHP 5.4., (*2)

Simple XML-RPC client and server examples follow., (*3)

Client

require 'src/xml-rpc.php';

use Milo\XmlRpc;


# Converter between XML source and PHP classes
$converter = new XmlRpc\Converter;


# Method we are calling and its arguments
$call = new XmlRpc\MethodCall('math.power', [2, 3]);

# Perform request over HTTP
$context = stream_context_create([
    'http' => array(
        'method' => 'POST',
        'header' => 'Content-type: text/xml',
        'content' => $converter->toXml($call),
    ),
]);
$xml = file_get_contents('http://example.com', false, $context);


# XML response parsing
$response = $converter->fromXml($xml);
if (!$response instanceof XmlRpc\MethodResponse) {
    throw new Exception('Expected method response. Got ' . get_class($response));
}

# Returned value
var_dump($response->getReturnValue());

Server - manually

An example of echo server. It only returns array with method name and its arguments which we called., (*4)

require 'src/xml-rpc.php';

use Milo\XmlRpc;


# Converter between XML source and PHP classes
$converter = new XmlRpc\Converter;


# Incoming XML
$xml = file_get_contents('php://input');

try {
    $call = $converter->fromXml($xml);
    if (!$call instanceof XmlRpc\MethodCall) {
        throw new Exception('Expected method call. Got ' . get_class($call));
    }

    # Echo response
    $response = new XmlRpc\MethodResponse([
        'youCalled' => $call->getName(),
        'withParameters' => $call->getParameters(),
    ]);

} catch (XmlRpc\RuntimeException $e) {
    # Fault response on error
    $response = XmlRpc\MethodFaultResponse::fromException($e);
}

# Print XML on standard output
echo $converter->toXml($response);

Server - automatically

An example of methods handling more automatically than above., (*5)

require 'src/xml-rpc.php';

use Milo\XmlRpc;


# Incoming XML
$xml = file_get_contents('php://input');


# Method call handler server
$server = new XmlRpc\Server;
$server->registerHandler(
    'my.method', ['string', 'int', '2?' => 'bool|null'],
    function ($string, $int, $bool = null) {
        # Throw XmlRpc\FaultResponseException and client will get your error message and code.
        # Throw anything else and client will get fault response with code 500.
        return [...];
    }
);


# Handle XML directly. All exceptions are caught and converted to fault response. 
echo $server->handleXml($xml, $faultCode);  # $faultCode is filled by fault response code



# Or handle MethodCall object.
$converter = new XmlRpc\Converter;

# It may throw exception on invalid XML.
$call = $converter->fromXml($xml);

# All exceptions are caught and converted to fault response.
$response = $server->handle($call);

# Print XML on standard output
echo $converter->toXml($response);



# To log what's happening inside.
$server->addLogger(function (MethodCall $call = null, IMethodResponse $response = null, \Exception $e = null) {
    ...
});

Installation

By Composer composer require milo/xml-rpc or download manually and require 'src/xml-rpc.php';, (*6)

License

You may use all files under the terms of the New BSD Licence, or the GNU Public Licence (GPL) version 2 or 3, or the MIT Licence., (*7)

Tests

Tests are written for Nette Tester, the Composer is required to run them:, (*8)

# Download the Tester
composer update

# Run the tests
vendor/bin/tester tests

Build Status, (*9)

The Versions

23/09 2017

dev-master

9999999-dev

Lightweight XML-RPC library.

  Sources   Download

MIT GPL-3.0 BSD-3-Clause GPL-2.0

The Requires

  • ext-dom *
  • php >=5.4.0

 

The Development Requires

23/09 2017

v2.2.0

2.2.0.0

Lightweight XML-RPC library.

  Sources   Download

MIT GPL-3.0 BSD-3-Clause GPL-2.0

The Requires

  • php >=5.4.0
  • ext-dom *

 

The Development Requires

06/09 2017

v2.1.0

2.1.0.0

Lightweight XML-RPC library.

  Sources   Download

MIT GPL-3.0 BSD-3-Clause GPL-2.0

The Requires

  • php >=5.4.0
  • ext-dom *

 

The Development Requires

03/03 2016

v2.0.0

2.0.0.0

Lightweight XML-RPC library.

  Sources   Download

MIT GPL-3.0 BSD-3-Clause GPL-2.0

The Requires

  • php >=5.4.0
  • ext-dom *

 

The Development Requires

10/02 2016

v1.0.0

1.0.0.0

Lightweight XML-RPC library.

  Sources   Download

MIT GPL-3.0 BSD-3-Clause GPL-2.0

The Requires

  • php >=5.3.0
  • ext-dom *

 

The Development Requires