Skip to main content

Multiprotocol Web Services for TurboGears

Project description

TurboGears gives you a plain HTTP with JSON return values API for your application for free. This isn’t always what you want, though. Sometimes, you don’t want to expose all of the data to the web that you need to render your templates. Maybe you need to support a protocol that names the function it’s calling as part of what it POSTs such as SOAP or XML-RPC.

TGWebServices provides a super simple API for creating web services that are available via SOAP, HTTP->XML, and HTTP->JSON. The SOAP API generates WSDL automatically for your Python and even generates enough type information for statically typed languages (Java and C#, for example) to generate good client code on their end.

How easy is it?

class Multiplier(WebServicesRoot):

    @wsexpose(int)
    @wsvalidate(int, int)
    def multiply(self, num1, num2):
        return num1 * num2

With this at the root, SOAP clients can find the WSDL file at /soap/api.wsdl and POST SOAP requests to /soap/. HTTP requests to /multiply?num1=5&num2=20 will return an XML document with the result of 100. Add ?tg_format=json (or an HTTP Accept: text/javascript header) and you’ll get JSON back.

The great thing about this is that the code above looks like a ‘’’normal Python function’’’ and doesn’t know a thing about web services.

Features

  • Easiest way to expose a web services API

  • Supports SOAP, HTTP+XML, HTTP+JSON

  • Outputs wrapped document/literal SOAP, which is the most widely compatible format

  • Provides enough type information for statically typed languages to generate conveniently usable interfaces

  • Can output instances of your own classes

  • Works with TurboGears 1.0

  • MIT license allows for unrestricted use

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

TGWebServices-1.0.1.tar.gz (19.1 kB view details)

Uploaded Source

Built Distribution

TGWebServices-1.0.1-py2.4.egg (45.3 kB view details)

Uploaded Source

File details

Details for the file TGWebServices-1.0.1.tar.gz.

File metadata

File hashes

Hashes for TGWebServices-1.0.1.tar.gz
Algorithm Hash digest
SHA256 caf78427e99718f39d0f33ca45b59ee7cf61a33ac4bea6797c503d0a6b13df5c
MD5 784afc4194379683a1bcfe7fb70fad10
BLAKE2b-256 b8abf5fc36084c52195e09c76b3591b9222edd3f7c54f1be52bd1c48300bbd49

See more details on using hashes here.

File details

Details for the file TGWebServices-1.0.1-py2.4.egg.

File metadata

File hashes

Hashes for TGWebServices-1.0.1-py2.4.egg
Algorithm Hash digest
SHA256 449fa3cb93e5468f18769e4125e881416e5d5388f6f8e00963961890e40b61d0
MD5 4484a22372fd0b3b5e25fc3ddb8d8067
BLAKE2b-256 f1dcf992c0fb95c4a113e559d00f8f9e7d4f8c6236e989ca4c3bb1d1e79cba5f

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page