Statistics
| Branch: | Tag: | Revision:

root / snf-cyclades-app / synnefo / api / management / commands / flavor-list.py @ 9621c777

History | View | Annotate | Download (3.5 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
                                       pprint_table)
39

    
40
from synnefo.db.models import Flavor
41

    
42
FIELDS = Flavor._meta.get_all_field_names()
43

    
44

    
45
class Command(BaseCommand):
46
    help = "List flavors"
47

    
48
    option_list = BaseCommand.option_list + (
49
        make_option(
50
            '-c',
51
            action='store_true',
52
            dest='csv',
53
            default=False,
54
            help="Use pipes to separate values"),
55
        make_option(
56
            '--deleted',
57
            action='store_true',
58
            dest='deleted',
59
            default=False,
60
            help="Include deleted flavors"),
61
        make_option(
62
            '--filter-by',
63
            dest='filter_by',
64
            help="Filter results. Comma seperated list of key=val pairs"
65
                 " that displayed entries must satisfy. e.g."
66
                 " --filter-by \"cpu=1,ram!=1024\"."
67
                 "Available keys are: %s" % ", ".join(FIELDS))
68
    )
69

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

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

    
79
        filter_by = options['filter_by']
80
        if filter_by:
81
            flavors = filter_results(flavors, filter_by)
82

    
83
        headers = ('id', 'name', 'cpus', 'ram', 'disk', 'template', 'deleted')
84
        table = []
85
        for flavor in flavors.order_by('id'):
86
            id = str(flavor.id)
87
            cpu = str(flavor.cpu)
88
            ram = str(flavor.ram)
89
            disk = str(flavor.disk)
90
            deleted = format_bool(flavor.deleted)
91
            fields = (id, flavor.name, cpu, ram, disk, flavor.disk_template,
92
                      deleted)
93

    
94
            table.append(fields)
95

    
96
        separator = " | " if options['csv'] else None
97
        pprint_table(self.stdout, table, headers, separator)