diff options
| author | Marko Tibold | 2011-12-30 18:46:18 +0100 | 
|---|---|---|
| committer | Marko Tibold | 2011-12-30 18:46:18 +0100 | 
| commit | e82ab8ea31de5a89470dd039e426af0e16df54f8 (patch) | |
| tree | 0344084391d9df3feea02fa9a328747c1af2e5d5 /docs | |
| parent | 2394fc70d1c33def374014226e7648db12562af1 (diff) | |
| download | django-rest-framework-e82ab8ea31de5a89470dd039e426af0e16df54f8.tar.bz2 | |
Added a simple example of how to use urllib and urllib2 to interact
with an api.
Diffstat (limited to 'docs')
| -rw-r--r-- | docs/contents.rst | 3 | ||||
| -rw-r--r-- | docs/howto.rst | 8 | ||||
| -rw-r--r-- | docs/howto/usingurllib2.rst | 33 | ||||
| -rw-r--r-- | docs/index.rst | 11 | 
4 files changed, 44 insertions, 11 deletions
diff --git a/docs/contents.rst b/docs/contents.rst index 4dbe5baa..d8e6e742 100644 --- a/docs/contents.rst +++ b/docs/contents.rst @@ -3,7 +3,8 @@ Documentation  .. toctree::    :maxdepth: 2 - +   +  howto    library    examples diff --git a/docs/howto.rst b/docs/howto.rst new file mode 100644 index 00000000..8fdc0926 --- /dev/null +++ b/docs/howto.rst @@ -0,0 +1,8 @@ +How Tos, FAQs & Notes +===================== + +.. toctree:: +  :maxdepth: 1 +  :glob: + +  howto/* diff --git a/docs/howto/usingurllib2.rst b/docs/howto/usingurllib2.rst new file mode 100644 index 00000000..8b655d45 --- /dev/null +++ b/docs/howto/usingurllib2.rst @@ -0,0 +1,33 @@ +Using urllib2 +============= + +Python's standard library comes with some nice modules +you can use to test your api or even write a full client. + +Here's an example which does a 'GET' on the `model-resource` examle +in the sandbox.:: + +    import urllib2 +    >>> r = urllib2.urlopen('htpp://rest.ep.io/model-resource-example') +    # You can check if the response was ok: +    >>> r.getcode() +    200 +    # Or examin the resonse itself: +    >>> print r.read() +    [{"url": "http://rest.ep.io/model-resource-example/1/", "baz": "sdf", "foo": true, "bar": 123}] + +And here's an example which does a 'POST' to create a new instance:: + +    # First encode tha data we want to POST, we'll use urllib for encoding +    # and the time module to send the current time as as a string value for our POST +    >>> import urllib, time +    >>> d = urllib.urlencode((('bar', 123), ('baz', time.asctime()))) +    # Now use the Request class and specify the 'Content-type' +    >>> req = urllib2.Request('http://rest.ep.io/model-resource-example/', data=d, headers={'Content-Type':'application/x-www-form-urlencoded'}) +    >>> resp = urllib2.urlopen(req) +    >>> resp.getcode() +    201 +    >>> resp.read() +    '{"url": "http://rest.ep.io/model-resource-example/4/", "baz": "Fri Dec 30 18:22:52 2011", "foo": false, "bar": 123}' + +That should get you started to write a client for your own api. diff --git a/docs/index.rst b/docs/index.rst index bec9e67f..3311bfa9 100644 --- a/docs/index.rst +++ b/docs/index.rst @@ -92,16 +92,7 @@ The following example exposes your `MyModel` model through an api. It will provi          url(r'^(?P<pk>[^/]+)/$', InstanceModelView.as_view(resource=MyResource)),      ) -How Tos, FAQs & Notes ---------------------- - -.. toctree:: -  :maxdepth: 1 - -  howto/setup -  howto/usingcurl -  howto/alternativeframeworks -  howto/mixin +.. include:: howto.rst  .. include:: library.rst  | 
