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

  • Can also accept instances of your classes as input

  • 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.2.2.tar.gz (21.0 kB view details)

Uploaded Source

Built Distribution

TGWebServices-1.2.2-py2.5.egg (55.4 kB view details)

Uploaded Source

File details

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

File metadata

File hashes

Hashes for TGWebServices-1.2.2.tar.gz
Algorithm Hash digest
SHA256 5ee7323212b738802e8b1e07e9b9bf934ac9048ad734c05513224a3e8f89ad7a
MD5 9e92db6bff99e961218aba6de94dff87
BLAKE2b-256 dac613648967de393268a4e221ef79f88956c2368643dc7882b0de3f2f08bea4

See more details on using hashes here.

File details

Details for the file TGWebServices-1.2.2-py2.5.egg.

File metadata

File hashes

Hashes for TGWebServices-1.2.2-py2.5.egg
Algorithm Hash digest
SHA256 0b7412a1d72c48922e0970f7836d094a04fb17ad8a6fdd443a6fda74c8d3aede
MD5 7dd50c66d4ed15cd8f8b20af413bec1a
BLAKE2b-256 b42b78b628b2b673c137217bed564c2a33e0fbc12696a595fb356304ed9c602c

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