Statistics
| Branch: | Tag: | Revision:

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

History | View | Annotate | Download (4.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 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('--build',
53
            action='store_true',
54
            dest='build',
55
            default=False,
56
            help="List only servers in the building state"),
57
        make_option('--deleted', action='store_true', dest='deleted',
58
                    default=False,
59
                    help="Include deletd servers"),
60
        make_option('--backend-id', dest='backend_id',
61
                    help="List only servers of the specified backend")
62
        )
63

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

    
68
        if options['backend_id']:
69
            servers = \
70
            Backend.objects.get(id=options['backend_id']).virtual_machines
71
        else:
72
            servers = VirtualMachine.objects
73

    
74
        if options['deleted']:
75
            servers = servers.all()
76
        else:
77
            servers = servers.filter(deleted=False)
78

    
79
        if options['build']:
80
            servers = servers.filter(operstate='BUILD')
81

    
82
        labels = ('id', 'name', 'owner', 'flavor', 'image', 'state',
83
                  'backend')
84
        columns = (3, 12, 20, 11, 12, 9, 40)
85

    
86
        if not options['csv']:
87
            line = ' '.join(l.rjust(w) for l, w in zip(labels, columns))
88
            self.stdout.write(line + '\n')
89
            sep = '-' * len(line)
90
            self.stdout.write(sep + '\n')
91

    
92
        cache = ImageCache()
93

    
94
        for server in servers:
95
            id = str(server.id)
96
            try:
97
                name = server.name.decode('utf8')
98
            except UnicodeEncodeError:
99
                name = server.name
100
            flavor = server.flavor.name
101
            try:
102
                image = cache.get_image(server.imageid, server.userid)['name']
103
            except:
104
                image = server.imageid
105

    
106
            state = format_vm_state(server)
107
            fields = (id, name, server.userid, flavor, image, state,
108
                      str(server.backend))
109

    
110
            if options['csv']:
111
                line = '|'.join(fields)
112
            else:
113
                line = ' '.join(f.rjust(w) for f, w in zip(fields, columns))
114

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

    
117

    
118
class ImageCache(object):
119
    def __init__(self):
120
        self.images = {}
121

    
122
    def get_image(self, imageid, userid):
123
        if not imageid in self.images:
124
            self.images[imageid] = get_image(imageid, userid)
125
        return self.images[imageid]