Statistics
| Branch: | Tag: | Revision:

root / snf-cyclades-app / synnefo / logic / management / commands / queue-inspect.py @ b6426ead

History | View | Annotate | Download (3.5 kB)

1
# Copyright 2011-2012 GRNET S.A. All rights reserved.
2
#
3
# Redistribution and use in source and binary forms, with or without
4
# modification, are permitted provided that the following conditions
5
# are met:
6
#
7
#   1. Redistributions of source code must retain the above copyright
8
#      notice, this list of conditions and the following disclaimer.
9
#
10
#  2. Redistributions in binary form must reproduce the above copyright
11
#     notice, this list of conditions and the following disclaimer in the
12
#     documentation and/or other materials provided with the distribution.
13
#
14
# THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
15
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17
# ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
18
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20
# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23
# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24
# SUCH DAMAGE.
25
#
26
# The views and conclusions contained in the software and documentation are
27
# those of the authors and should not be interpreted as representing official
28
# policies, either expressed or implied, of GRNET S.A.
29
#
30

    
31
import pprint
32

    
33
from optparse import make_option
34
from django.core.management.base import CommandError
35

    
36
from synnefo.lib.amqp import AMQPClient
37
from snf_django.management.commands import SynnefoCommand
38

    
39

    
40
class Command(SynnefoCommand):
41
    args = "<queue name>"
42
    help = "Inspect the messages of a queue. Close all other clients in "\
43
           "order to be able to inspect unacknowledged messages."
44

    
45
    option_list = SynnefoCommand.option_list + (
46
        make_option('--no-requeue', action='store_false', dest='requeue',
47
                    default=True, help="Do not requeue the messages"),
48
        make_option('-i', '--interactive', action='store_true', default=False,
49
                    dest='interactive', help="Interactive mode")
50
    )
51

    
52
    def handle(self, *args, **options):
53
        if len(args) != 1:
54
            raise CommandError("Please provide a queue")
55

    
56
        queue = args[0]
57
        interactive = options['interactive']
58
        requeue = options['requeue']
59

    
60
        client = AMQPClient()
61
        client.connect()
62

    
63
        pp = pprint.PrettyPrinter(indent=4, width=4, stream=self.stdout)
64

    
65
        more_msgs = True
66
        counter = 0
67
        sep = '-' * 80
68
        while more_msgs:
69
            msg = client.basic_get(queue=queue)
70
            if msg:
71
                counter += 1
72
                self.stderr.write(sep)
73
                self.stderr.write('Message %d:' % counter)
74
                self.stderr.write(sep)
75
                pp.pprint(msg)
76
                if not requeue or interactive:
77
                    if interactive and not get_user_confirmation():
78
                        continue
79
                    # Acknowledging the message will remove it from the queue
80
                    client.basic_ack(msg)
81
            else:
82
                more_msgs = False
83

    
84

    
85
def get_user_confirmation():
86
    ans = raw_input("Do you want to delete this message (N/y):")
87

    
88
    if not ans:
89
        return False
90
    if ans not in ['Y', 'y']:
91
        return False
92
    return True