Statistics
| Branch: | Tag: | Revision:

root / snf-astakos-app / astakos / im / management / commands / resource-import.py @ 415c4a56

History | View | Annotate | Download (4.5 kB)

1
# Copyright 2013 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 django.db.utils import IntegrityError
38
from django.utils import simplejson as json
39

    
40
from snf_django.lib.db.transaction import commit_on_success_strict
41
from astakos.im.resources import add_resource
42
from astakos.im.models import Service
43

    
44

    
45
class Command(BaseCommand):
46
    args = "<service> <resource> <desc> <unit>"
47
    help = "Import resources"
48

    
49
    option_list = BaseCommand.option_list + (
50
        make_option('--json',
51
                    dest='json',
52
                    metavar='<json.file>',
53
                    help="Load resource info from a json file"),
54
        make_option('--service',
55
                    dest='service_id',
56
                    metavar='<service_id>',
57
                    help=("Automatically load resource info for a given "
58
                          "service")),
59
        make_option('--conf',
60
                    dest='conf',
61
                    metavar='<conf.json>',
62
                    help="Limit configuration file"),
63
    )
64

    
65
    def handle(self, *args, **options):
66

    
67
        config = {}
68
        conf_file = options['conf']
69
        if conf_file is not None:
70
            with open(conf_file) as file_data:
71
                config = json.load(file_data)
72

    
73

    
74
        json_file = options['json']
75
        service_id = options['service_id']
76
        if bool(json_file) == bool(service_id):
77
            m = "Please provide either --service or --json option."
78
            raise CommandError(m)
79

    
80
        if service_id:
81
            raise NotImplementedError()
82

    
83
        if json_file:
84
            with open(json_file) as file_data:
85
                m = ('Input should be a JSON dict containing "service" '
86
                     'and "resource" keys.')
87
                try:
88
                    data = json.load(file_data)
89
                except json.JSONDecodeError:
90
                    raise CommandError(m)
91
                if not isinstance(data, dict):
92
                    raise CommandError(m)
93
                else:
94
                    try:
95
                        service = data['service']
96
                        resources = data['resources']
97
                    except KeyError:
98
                        raise CommandError(m)
99

    
100
        self.add_resources(service, resources)
101

    
102

    
103
    @commit_on_success_strict()
104
    def add_resources(self, service, resources):
105

    
106
        try:
107
            s = Service.objects.get(name=service)
108
        except Service.DoesNotExist:
109
            raise CommandError("Service '%s' is not registered." % (service))
110

    
111
        for resource in resources:
112
            if not isinstance(resource, dict):
113
                raise CommandError("Malformed resource dict.")
114
            exists = add_resource(s, resource)
115
            name = resource['name']
116
            if exists:
117
                m = "Resource '%s' updated in database.\n" % (name)
118
            else:
119
                m = ("Resource '%s' created in database with default "
120
                     "quota limit 0.\n" % (name))
121
            self.stdout.write(m)