~unity-2d-team/unity-2d/Shell-MultiMonitor

« back to all changes in this revision

Viewing changes to grackle/client.py

  • Committer: Aaron Bentley
  • Date: 2012-01-11 11:18:15 UTC
  • mto: (6.1.30 trunk)
  • mto: This revision was merged to the branch mainline in revision 45.
  • Revision ID: aaron@canonical.com-20120111111815-0ecv9fihdao2u68o
Start working on GET.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
import httplib
 
2
import simplejson
 
3
from urlparse import urlunparse
 
4
from urllib import (
 
5
    quote,
 
6
    urlencode,
 
7
)
 
8
 
2
9
 
3
10
 
4
11
class GrackleClient:
6
13
    def __init__(self, host, port):
7
14
        self.host = host
8
15
        self.port = port
9
 
 
10
 
    def put_message(self, archive_name, permalink, file_obj):
11
 
        connection = httplib.HTTPConnection(self.host, self.port)
12
 
        connection.request('PUT', permalink, file_obj.read())
13
 
        response = connection.getresponse()
 
16
        self.netloc = '%s:%d' % (host, port)
 
17
 
 
18
    def archive_url(self, archive_name, query):
 
19
        path = '/%s' % quote(archive_name)
 
20
        query = urlencode(query)
 
21
        url = urlunparse(('http', self.netloc, path, '', '', ''))
 
22
 
 
23
    def _get_connection(self):
 
24
        print 'Connecting to %s' % self.port
 
25
        return httplib.HTTPConnection(self.host, self.port)
 
26
 
 
27
    def _verb_archive(self, verb, archive_name, query, body=None):
 
28
        url = self.archive_url(archive_name, query)
 
29
        connection = self._get_connection()
 
30
        connection.request(verb, url, body)
 
31
        return connection.getresponse()
 
32
 
 
33
    def put_message(self, archive_name, key, file_obj):
 
34
        response = self._verb_archive(
 
35
            'POST', archive_name, {'key': key}, file_obj.read())
14
36
        data = response.read()
15
37
        if response.status == httplib.BAD_REQUEST:
16
38
            raise Exception('wtf')
18
40
            return
19
41
        else:
20
42
            raise Exception('!!')
 
43
 
 
44
    def get_messages(self, archive_name, message_ids=None):
 
45
        parameters = {}
 
46
        if message_ids is not None:
 
47
            parameters[message_ids] = message_ids
 
48
        query = {'parameters': simplejson.dumps(parameters)}
 
49
        response = self._verb_archive('GET', archive_name, query)
 
50
        return {}