Statistics
| Branch: | Tag: | Revision:

root / snf-cyclades-app / synnefo / api / management / commands / network-list.py @ bad9404c

History | View | Annotate | Download (4.8 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 optparse import make_option
35

    
36
from django.core.management.base import BaseCommand, CommandError
37
from synnefo.management.common import format_bool, filter_results
38
from synnefo.db.models import Network
39

    
40
FIELDS = Network._meta.get_all_field_names()
41

    
42

    
43
class Command(BaseCommand):
44
    help = "List networks"
45

    
46
    option_list = BaseCommand.option_list + (
47
        make_option('-c',
48
            action='store_true',
49
            dest='csv',
50
            default=False,
51
            help="Use pipes to separate values"),
52
        make_option('--deleted',
53
            action='store_true',
54
            dest='deleted',
55
            default=False,
56
            help="Include deleted networks"),
57
        make_option('--public',
58
            action='store_true',
59
            dest='public',
60
            default=False,
61
            help="List only public networks"),
62
        make_option('--ipv6',
63
            action='store_true',
64
            dest='ipv6',
65
            default=False,
66
            help="Show IPv6 information of the network"),
67
        make_option('--filter-by',
68
            dest='filter_by',
69
            help="Filter results. Comma seperated list of key 'cond' val pairs"
70
                 " that displayed entries must satisfy. e.g."
71
                 " --filter-by \"name=Network-1,link!=prv0\"."
72
                 " Available keys are: %s" % ", ".join(FIELDS))
73

    
74
        )
75

    
76
    def handle(self, *args, **options):
77
        if args:
78
            raise CommandError("Command doesn't accept any arguments")
79

    
80
        if options['deleted']:
81
            networks = Network.objects.all()
82
        else:
83
            networks = Network.objects.filter(deleted=False)
84

    
85
        if options['public']:
86
            networks = networks.filter(public=True)
87

    
88
        filter_by = options['filter_by']
89
        if filter_by:
90
            networks = filter_results(networks, filter_by)
91

    
92
        labels = ['id', 'name', 'type', 'owner',
93
                  'mac_prefix', 'dhcp', 'state', 'link', 'vms', 'public']
94
        columns = [3, 16, 22, 30, 10, 6, 8, 12, 4, 6]
95

    
96
        if options['ipv6']:
97
            labels.extend(['IPv6 Subnet', 'IPv6 Gateway'])
98
            columns.extend([16, 16])
99
        else:
100
            labels.extend(['IPv4 Subnet', 'IPv4 Gateway'])
101
            columns.extend([14, 14])
102

    
103
        if not options['csv']:
104
            line = ' '.join(l.rjust(w) for l, w in zip(labels, columns))
105
            self.stdout.write(line + '\n')
106
            sep = '-' * len(line)
107
            self.stdout.write(sep + '\n')
108

    
109
        for network in networks.order_by("id"):
110
            fields = [str(network.id),
111
                      network.name,
112
                      network.type,
113
                      network.userid or '',
114
                      network.mac_prefix or '',
115
                      str(network.dhcp),
116
                      network.state,
117
                      network.link or '',
118
                      str(network.machines.count()),
119
                      format_bool(network.public)]
120

    
121
            if options['ipv6']:
122
                fields.extend([network.subnet6 or '', network.gateway6 or ''])
123
            else:
124
                fields.extend([network.subnet, network.gateway or ''])
125

    
126
            if options['csv']:
127
                line = '|'.join(fields)
128
            else:
129
                line = ' '.join(f.rjust(w) for f, w in zip(fields, columns))
130

    
131
            self.stdout.write(line.encode('utf8') + '\n')