~eday/burrow/prototype-conversion

« back to all changes in this revision

Viewing changes to burrowd/backend/__init__.py

  • Committer: Eric Day
  • Date: 2011-03-17 23:42:41 UTC
  • Revision ID: eday@oddments.org-20110317234241-ult80xn9d1lon867
First chunk of code from prototype. Beyond the prototype, configuration, module loading, and log handling was added.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2011 OpenStack LLC.
 
2
#
 
3
# Licensed under the Apache License, Version 2.0 (the "License");
 
4
# you may not use this file except in compliance with the License.
 
5
# You may obtain a copy of the License at
 
6
#
 
7
#     http://www.apache.org/licenses/LICENSE-2.0
 
8
#
 
9
# Unless required by applicable law or agreed to in writing, software
 
10
# distributed under the License is distributed on an "AS IS" BASIS,
 
11
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 
12
# See the License for the specific language governing permissions and
 
13
# limitations under the License.
 
14
 
 
15
'''Backends for the burrow server.'''
 
16
 
 
17
import eventlet
 
18
 
 
19
import burrowd
 
20
 
 
21
 
 
22
class Backend(burrowd.Module):
 
23
    '''Interface that backend implementations must provide.'''
 
24
 
 
25
    def __init__(self, config):
 
26
        super(Backend, self).__init__(config)
 
27
        self.queues = {}
 
28
 
 
29
    def run(self, thread_pool):
 
30
        thread_pool.spawn_n(self._clean)
 
31
 
 
32
    def _clean(self):
 
33
        while True:
 
34
            self.clean()
 
35
            eventlet.sleep(1)
 
36
 
 
37
    def delete_accounts(self):
 
38
        pass
 
39
 
 
40
    def get_accounts(self):
 
41
        return []
 
42
 
 
43
    def delete_account(self, account):
 
44
        pass
 
45
 
 
46
    def get_queues(self, account):
 
47
        return []
 
48
 
 
49
    def queue_exists(self, account, queue):
 
50
        return False
 
51
 
 
52
    def delete_messages(self, account, queue, limit, marker, match_hidden):
 
53
        return []
 
54
 
 
55
    def get_messages(self, account, queue, limit, marker, match_hidden):
 
56
        return []
 
57
 
 
58
    def update_messages(self, account, queue, limit, marker, match_hidden, ttl,
 
59
                        hide):
 
60
        return []
 
61
 
 
62
    def delete_message(self, account, queue, message_id):
 
63
        return None
 
64
 
 
65
    def get_message(self, account, queue, message_id):
 
66
        return None
 
67
 
 
68
    def put_message(self, account, queue, message_id, ttl, hide, body):
 
69
        return True
 
70
 
 
71
    def update_message(self, account, queue, message_id, ttl, hide):
 
72
        return None
 
73
 
 
74
    def clean(self):
 
75
        '''This method should remove all messages with an expired
 
76
        TTL and make hidden messages that have an expired hide time
 
77
        visible again.'''
 
78
        pass
 
79
 
 
80
    def notify(self, account, queue):
 
81
        queue = '%s/%s' % (account, queue)
 
82
        if queue in self.queues:
 
83
            self.queues[queue].put(0)
 
84
 
 
85
    def wait(self, account, queue, seconds):
 
86
        queue = '%s/%s' % (account, queue)
 
87
        if queue not in self.queues:
 
88
            self.queues[queue] = eventlet.Queue()
 
89
        try:
 
90
            self.queues[queue].get(timeout=seconds)
 
91
        except Exception:
 
92
            pass
 
93
        if self.queues[queue].getting() == 0:
 
94
            del self.queues[queue]