Statistics
| Branch: | Tag: | Revision:

root / snf-cyclades-app / synnefo / logic / management / commands / subnet-create.py @ a6e6fe48

History | View | Annotate | Download (5.9 kB)

1
# Copyright 2013-2014 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 import common
38
from snf_django.management.utils import parse_bool
39
from synnefo.management import pprint
40
from synnefo.logic import subnets
41

    
42
HELP_MSG = """
43

44
Create a new subnet without authenticating the user. The limit of one
45
IPv4/IPv6 subnet per network still applies. Mandatory fields are CIDR and the
46
Network ID.
47
"""
48

    
49

    
50
class Command(BaseCommand):
51
    help = "Create a new Subnet." + HELP_MSG
52

    
53
    option_list = BaseCommand.option_list + (
54
        make_option("--network-id", dest="network_id",
55
                    help="Specify the Network to attach the subnet. To get the"
56
                         " networks of a user, use snf-manage network-list"),
57
        make_option("--cidr", dest="cidr",
58
                    help="The CIDR of the subnet, e.g., 192.168.42.0/24"),
59
        make_option("--allocation-pool", dest="allocation_pools",
60
                    action="append",
61
                    help="IP allocation pools to be used for assigning IPs to"
62
                    " VMs. Can be used multiple times. Syntax: \n"
63
                    "192.168.42.220,192.168.42.240. Starting IP must proceed "
64
                    "ending IP.20,192.168.42.240. Starting IP must proceed "
65
                    "ending IP. If no allocation pools are given, the whole "
66
                    "subnet range is used, excluding the gateway IP, the "
67
                    "broadcast address and the network address"),
68
        make_option("--name", dest="name",
69
                    help="An arbitrary string for naming the subnet."),
70
        make_option("--ip-version", dest="ipversion", choices=["4", "6"],
71
                    metavar="4|6",
72
                    help="IP version of the CIDR. The value must be in sync"
73
                    " with the CIDR. Default value: 4"),
74
        make_option("--gateway", dest="gateway",
75
                    help="An IP to use as a gateway for the subnet."
76
                    " The IP must be inside the CIDR range and cannot be the"
77
                    " subnet or broadcast IP. If no value is specified, a"
78
                    " gateway will not be set."),
79
        make_option("--dhcp", dest="dhcp", default="True",
80
                    choices=["True", "False"], metavar="True|False",
81
                    help="Value for DHCP/SLAAC. True by default."),
82
        make_option("--dns", dest="dns",
83
                    help="DNS nameservers to be used by the VMs in the subnet."
84
                    " For the time being, this option isn't supported."),
85
        make_option("--host-routes", dest="host_routes",
86
                    help="Host routes to be used for advanced routing"
87
                    "settings. For the time being, this option isn't"
88
                    " supported.")
89
    )
90

    
91
    @common.convert_api_faults
92
    def handle(self, *args, **options):
93
        if args:
94
            raise CommandError("Command doesn't accept any arguments")
95

    
96
        network_id = options["network_id"]
97
        cidr = options["cidr"]
98

    
99
        if not network_id:
100
            raise CommandError("network-id is mandatory")
101
        if not cidr:
102
            raise CommandError("cidr is mandatory")
103

    
104
        user_id = common.get_resource("network", network_id).userid
105
        name = options["name"] or ""
106
        allocation_pools = options["allocation_pools"]
107
        ipversion = options["ipversion"] or 4
108
        ipversion = int(ipversion)
109
        gateway = options["gateway"]
110
        dhcp = parse_bool(options["dhcp"])
111
        dns = options["dns"]
112
        host_routes = options["host_routes"]
113

    
114
        alloc = None
115
        if allocation_pools is not None:
116
            alloc = subnets.parse_allocation_pools(allocation_pools)
117
            alloc.sort()
118

    
119
        sub = subnets.create_subnet(name=name,
120
                                    network_id=network_id,
121
                                    cidr=cidr,
122
                                    allocation_pools=alloc,
123
                                    gateway=gateway,
124
                                    ipversion=ipversion,
125
                                    dhcp=dhcp,
126
                                    slaac=dhcp,
127
                                    dns_nameservers=dns,
128
                                    host_routes=host_routes,
129
                                    user_id=user_id)
130

    
131
        pprint.pprint_subnet_in_db(sub, stdout=self.stdout)
132
        self.stdout.write("\n\n")
133
        pprint.pprint_ippool(sub, stdout=self.stdout)