47 lines
1.1 KiB
Python
47 lines
1.1 KiB
Python
"""
|
|
Example soap server using spyne.
|
|
|
|
Run with
|
|
|
|
uwsgi --http :8000 \
|
|
--wsgi-file soap_server.py \
|
|
--virtualenv ~/.pyenv/versions/3.5.2/envs/zeep \
|
|
-p 10
|
|
|
|
"""
|
|
import time
|
|
|
|
from spyne import Application, ServiceBase, Unicode, rpc
|
|
from spyne.protocol.soap import Soap11
|
|
from spyne.server.wsgi import WsgiApplication
|
|
|
|
|
|
class ExampleService(ServiceBase):
|
|
|
|
@rpc(Unicode, _returns=Unicode)
|
|
def slow_request(ctx, request_id):
|
|
time.sleep(1)
|
|
return u'Request: %s' % request_id
|
|
|
|
application = Application(
|
|
services=[ExampleService],
|
|
tns='http://tests.python-zeep.org/',
|
|
in_protocol=Soap11(validator='lxml'),
|
|
out_protocol=Soap11())
|
|
|
|
application = WsgiApplication(application)
|
|
|
|
if __name__ == '__main__':
|
|
import logging
|
|
|
|
from wsgiref.simple_server import make_server
|
|
|
|
logging.basicConfig(level=logging.DEBUG)
|
|
logging.getLogger('spyne.protocol.xml').setLevel(logging.DEBUG)
|
|
|
|
logging.info("listening to http://127.0.0.1:8000")
|
|
logging.info("wsdl is at: http://localhost:8000/?wsdl")
|
|
|
|
server = make_server('127.0.0.1', 8000, application)
|
|
server.serve_forever()
|