Statistics
| Branch: | Tag: | Revision:

root / snf-cyclades-app / synnefo / api / management / commands / listnetworks.py @ 8fad925a

History | View | Annotate | Download (3.6 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

    
38
from synnefo.db.models import Network
39

    
40
from ._common import format_bool
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="List only deleted networks"),
57
        make_option('--public',
58
            action='store_true',
59
            dest='public',
60
            default=False,
61
            help="List only public networks"),
62
        )
63

    
64
    def handle(self, *args, **options):
65
        if args:
66
            raise CommandError("Command doesn't accept any arguments")
67

    
68
        networks = Network.objects.all()
69
        if options['deleted']:
70
            networks = networks.filter(state='DELETED')
71
        else:
72
            networks = networks.exclude(state='DELETED')
73

    
74
        if options['public']:
75
            networks = networks.filter(public=True)
76

    
77
        labels = ('id', 'name', 'owner', 'state', 'link', 'vms', 'public')
78
        columns = (3, 12, 20, 7, 14, 4, 6)
79

    
80
        if not options['csv']:
81
            line = ' '.join(l.rjust(w) for l, w in zip(labels, columns))
82
            self.stdout.write(line + '\n')
83
            sep = '-' * len(line)
84
            self.stdout.write(sep + '\n')
85

    
86
        for network in networks:
87
            fields = (str(network.id),
88
                      network.name,
89
                      network.userid or '',
90
                      network.state,
91
                      network.link.name,
92
                      str(network.machines.count()),
93
                      format_bool(network.public))
94

    
95
            if options['csv']:
96
                line = '|'.join(fields)
97
            else:
98
                line = ' '.join(f.rjust(w) for f, w in zip(fields, columns))
99

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