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.1.1.tar.gz (21.4 kB view details)

Uploaded Source

Built Distribution

TGWebServices-1.1.1-py2.4.egg (54.2 kB view details)

Uploaded Source

File details

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

File metadata

File hashes

Hashes for TGWebServices-1.1.1.tar.gz
Algorithm Hash digest
SHA256 638123f41e57cc977ec2c2b6836917e21b54a5be8cb68d1686bdbf9e972ab4ed
MD5 a746b07350f00ebc3f6848e9bf54672a
BLAKE2b-256 6847cf80e6c8c5d4c01b970e17f10382c913eea8222dde89e87aa4beca9da0a4

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for TGWebServices-1.1.1-py2.4.egg
Algorithm Hash digest
SHA256 35982dba0641e12bdaba49a83c5ba34843223b15c46002a8dc8ad54b8ad82423
MD5 e47b9d5c0e7603ff9756fad93ee4ed9e
BLAKE2b-256 4a72ec3d094fa29aefc0de7dff31a4303190792f5fb3f0e956341ca54149bad5

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