Statistics
| Branch: | Tag: | Revision:

root / snf-cyclades-app / synnefo / logic / management / commands / pool-show.py @ e2b37fb9

History | View | Annotate | Download (3.2 kB)

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

    
34
from django.core.management.base import BaseCommand, CommandError
35
from optparse import make_option
36

    
37
from synnefo.db.pools import bitarray_to_map
38
from synnefo.management import pprint, common
39

    
40
POOL_CHOICES = ['bridge', 'mac-prefix']
41

    
42

    
43
class Command(BaseCommand):
44
    args = "<pool ID>"
45
    help = "Show a pool"
46
    output_transaction = True
47
    option_list = BaseCommand.option_list + (
48
        make_option('--type', dest='type',
49
                    choices=POOL_CHOICES,
50
                    help="Type of pool"
51
                    ),
52
    )
53

    
54
    def handle(self, *args, **options):
55
        type_ = options['type']
56

    
57
        if not type_:
58
            raise CommandError("Type of pool is mandatory")
59

    
60
        pool_table = common.pool_table_from_type(type_)
61

    
62
        try:
63
            pool_id = int(args[0])
64
            pool_row = pool_table.objects.get(id=pool_id)
65
        except (ValueError, pool_table.DoesNotExist):
66
            raise CommandError("Invalid pool ID")
67

    
68
        pool = pool_row.pool
69

    
70
        kv = {
71
            'id': pool_row.id,
72
            'offset': pool_row.offset,
73
            'base': pool_row.base,
74
            'size': pool_row.size,
75
            'available': pool.count_available(),
76
            'reserved': pool.count_reserved(),
77
        }
78

    
79
        for key, val in sorted(kv.items()):
80
            line = '%s: %s\n' % (key.rjust(16), val)
81
            self.stdout.write(line.encode('utf8'))
82

    
83
        step = (type_ == 'bridge') and 64 or 80
84
        pprint.pprint_pool('Available', pool.to_map(), step, self.stdout)
85
        pprint.pprint_pool('Reserved',
86
                           bitarray_to_map(pool.reserved[:pool_row.size]),
87
                           step, self.stdout)