Statistics
| Branch: | Tag: | Revision:

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

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

    
38
from synnefo.api.util import get_image
39
from synnefo.db.models import VirtualMachine, Backend
40
from ._common import format_vm_state
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
            try:
75
                servers = Backend.objects.get(id=options['backend_id'])\
76
                                         .virtual_machines
77
            except Backend.DoesNotExist:
78
                raise CommandError("Backend not found in DB")
79
        else:
80
            servers = VirtualMachine.objects
81

    
82
        if options['deleted']:
83
            servers = servers.all()
84
        else:
85
            servers = servers.filter(deleted=False)
86

    
87
        if options['suspended']:
88
            servers = servers.filter(suspended=True)
89

    
90
        if options['build']:
91
            servers = servers.filter(operstate='BUILD')
92

    
93
        labels = ('id', 'name', 'owner', 'flavor', 'image', 'state',
94
                  'backend')
95
        columns = (3, 12, 20, 11, 12, 9, 40)
96

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

    
103
        cache = ImageCache()
104

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

    
117
            state = format_vm_state(server)
118
            fields = (id, name, server.userid, flavor, image, state,
119
                      str(server.backend))
120

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

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

    
128

    
129
class ImageCache(object):
130
    def __init__(self):
131
        self.images = {}
132

    
133
    def get_image(self, imageid, userid):
134
        if not imageid in self.images:
135
            self.images[imageid] = get_image(imageid, userid)
136
        return self.images[imageid]