Statistics
| Branch: | Tag: | Revision:

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

History | View | Annotate | Download (3.5 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 util import pool_table_from_type, pool_map_chunks
38
from synnefo.db.pools import bitarray_to_map
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 = 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
        print_map('Pool', pool.to_map(), step, self.stdout)
85
        print_map('Reserved', bitarray_to_map(pool.reserved[:pool_row.size]),
86
                  step, self.stdout)
87

    
88

    
89
def print_map(name, pool_map, step, out):
90
    sep = '*' * 80
91
    out.write(sep + "\n")
92
    out.write("%s: \n" % name)
93
    out.write(sep + "\n")
94
    count = 0
95
    for chunk in pool_map_chunks(pool_map, step):
96
        chunk_len = len(chunk)
97
        out.write(("%s " % count).rjust(4))
98
        out.write((chunk + " %d\n") % (count + chunk_len - 1))
99
        count += chunk_len