xmlrpc server simplify.
Project description
xmlrpcutils
xmlrpc server simplify.
Install
pip install xmlrpcutils
TestServer
from xmlrpcutils.server import SimpleXmlRpcServer
from xmlrpcutils.service import ServiceBase
class SayHelloService(ServiceBase):
def hello(self, name):
return f"Hello {name}, how are you!"
class TestServer(SimpleXmlRpcServer):
def register_services(self):
super().register_services()
SayHelloService(namespace="debug").register_to(self.server)
app = TestServer()
app_ctrl = app.get_controller()
if __name__ == "__main__":
app_ctrl()
Start test server
python test_server.py start
Remote call with TestServer
In [9]: from xmlrpc.client import ServerProxy
In [10]: server = ServerProxy('http://127.0.0.1:8381')
In [11]: server.system.listMethods()
Out[11]:
['debug.counter',
'debug.echo',
'debug.false',
'debug.hello',
'debug.hostname',
'debug.null',
'debug.ping',
'debug.sleep',
'debug.sum',
'debug.timestamp',
'debug.true',
'debug.uname',
'debug.urandom',
'debug.uuid4',
'system.listMethods',
'system.methodHelp',
'system.methodSignature',
'system.multicall']
In [12]: server.debug.hello('zencore')
Out[12]: 'Hello zencore, how are you!'
Use apikey auth mechanism.
Add apikeys
in the server's config file
apikeys:
HyuTMsNzcSZYmwlVDdacERde9azdTKT8:
appid: test01
other-app-info: xxx
SEEpVkus5b86aHxS6UMSCFLxkIhYMMZF:
appid: test02
other-app-info: xxx
Add apikey
header at the client side
In [93]: from xmlrpc.client import ServerProxy
...: service = ServerProxy("http://127.0.0.1:8911", headers=[("apikey", "HyuTMsNzcSZYmwlVDdacERde9azdTKT8")])
...: result = service.debug.ping()
...: print(result)
pong
Enable server http-keepalive
keepalive:
enable: true
timeout: 5
max: 60
Http-keepalive is not enabled by default, add keepalive.enable=true to enable it.
Enable server response header
server-tokens: true
The response header Server is hide by default, add server-tokens=true to show it.
Enable methodSignature
def myfunc1(arg1:int, arg2:str, arg3:list) -> str:
pass
- Add returns and args typing to enable methodSignature.
def myfunc2(arg1, arg2, arg3):
"""
@methodSignature: ["str", "int", "str", "list"]
"""
pass
- Use doc string @methodSignature: to enable methodSignature.
def myfunc3(args, arg1, arg2, arg3):
pass
myfunc3._methodSignature = ["str", "int", "str", "list"]
- Use extra attr to enable methodSignature.
Releases
v0.1.1
- First release.
v0.1.2
- Fix license_files missing problem.
v0.1.3
- Fix DebugService init method problem, add super().init() calling.
v0.2.0
- Don't force to use gevent.
- Allow non-namespace services.
v0.3.1
- Remove all gevent things.
- Add apikey auth mechanism. Use headers parameter to provide apikey at then client side.
v0.3.2
- Fix get_ignore_methods name.
v0.4.0
- Add server-tokens option, allow user hide/show response header Server. Default to hide the Server header.
- Add keepalive options, allow user to enable http-keepalive function.
v0.4.2
- Doc update.
v0.4.3
- Doc fix.
- Add methodSignature support.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
xmlrpcutils-0.4.3.tar.gz
(9.2 kB
view hashes)
Built Distribution
Close
Hashes for xmlrpcutils-0.4.3-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 317bdee7c83dbb157c5b03c22e3123af3b9e982608630899c3661fbe34c4e702 |
|
MD5 | a26a9a42aa7503d5c5a77dc73ba6b185 |
|
BLAKE2b-256 | ee5d29b2bb0082099d1998767979d01dc5d624290793276fbe4f0a6ddef5cc70 |