Statistics
| Branch: | Tag: | Revision:

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

History | View | Annotate | Download (3.4 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
class Command(BaseCommand):
43
    args = "<pool ID>"
44
    help = "Show a pool"
45
    output_transaction = True
46
    option_list = BaseCommand.option_list + (
47
        make_option('--type', dest='type',
48
                    choices=POOL_CHOICES,
49
                    help="Type of pool"
50
                    ),
51
    )
52

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

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

    
59
        pool_table = pool_table_from_type(type_)
60

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

    
67
        pool = pool_row.pool
68

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

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

    
82
        step = type_=='bridge' and 64 or 80
83
        print_map('Pool', pool.to_map(), step, self.stdout)
84
        print_map('Reserved', bitarray_to_map(pool.reserved), step, self.stdout)
85

    
86

    
87
def print_map(name, pool_map, step, out):
88
    sep = '*' * 80
89
    out.write(sep + "\n")
90
    out.write("%s: \n" % name)
91
    out.write(sep + "\n")
92
    i = 0
93
    for p in pool_map_chunks(pool_map, step):
94
        out.write(("%d " % i).rjust(4))
95
        out.write(("|" + p + " |%d\n") % ( i + step - 1))
96
        i += step