Statistics
| Branch: | Tag: | Revision:

root / snf-cyclades-app / synnefo / api / management / commands / server-list.py @ b84ed662

History | View | Annotate | Download (4.7 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_vm_state, get_backend
38

    
39
from synnefo.api.util import get_image
40
from synnefo.db.models import VirtualMachine
41

    
42

    
43
class Command(BaseCommand):
44
    help = "List servers"
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('--suspended',
53
            action='store_true',
54
            dest='suspended',
55
            default=False,
56
            help="List only suspended servers"),
57
        make_option('--build',
58
            action='store_true',
59
            dest='build',
60
            default=False,
61
            help="List only servers in the building state"),
62
        make_option('--deleted', action='store_true', dest='deleted',
63
                    default=False,
64
                    help="Include deletd servers"),
65
        make_option('--backend-id', dest='backend_id',
66
                    help="List only servers of the specified backend")
67
        )
68

    
69
    def handle(self, *args, **options):
70
        if args:
71
            raise CommandError("Command doesn't accept any arguments")
72

    
73
        if options['backend_id']:
74
            backend = get_backend(options['backend_id'])
75
            servers = backend.virtual_machines
76
        else:
77
            servers = VirtualMachine.objects
78

    
79
        if options['deleted']:
80
            servers = servers.all()
81
        else:
82
            servers = servers.filter(deleted=False)
83

    
84
        if options['suspended']:
85
            servers = servers.filter(suspended=True)
86

    
87
        if options['build']:
88
            servers = servers.filter(operstate='BUILD')
89

    
90
        labels = ('id', 'name', 'owner', 'flavor', 'image', 'state',
91
                  'backend')
92
        columns = (3, 12, 20, 11, 12, 9, 40)
93

    
94
        if not options['csv']:
95
            line = ' '.join(l.rjust(w) for l, w in zip(labels, columns))
96
            self.stdout.write(line + '\n')
97
            sep = '-' * len(line)
98
            self.stdout.write(sep + '\n')
99

    
100
        cache = ImageCache()
101

    
102
        for server in servers.order_by('id'):
103
            id = str(server.id)
104
            try:
105
                name = server.name.decode('utf8')
106
            except UnicodeEncodeError:
107
                name = server.name
108
            flavor = server.flavor.name
109
            try:
110
                image = cache.get_image(server.imageid, server.userid)['name']
111
            except:
112
                image = server.imageid
113

    
114
            state = format_vm_state(server)
115
            fields = (id, name, server.userid, flavor, image, state,
116
                      str(server.backend))
117

    
118
            if options['csv']:
119
                line = '|'.join(fields)
120
            else:
121
                line = ' '.join(f.rjust(w) for f, w in zip(fields, columns))
122

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

    
125

    
126
class ImageCache(object):
127
    def __init__(self):
128
        self.images = {}
129

    
130
    def get_image(self, imageid, userid):
131
        if not imageid in self.images:
132
            self.images[imageid] = get_image(imageid, userid)
133
        return self.images[imageid]