Statistics
| Branch: | Tag: | Revision:

root / snf-cyclades-app / synnefo / api / management / commands / subnet-create.py @ 9835a70d

History | View | Annotate | Download (5.9 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 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
import ipaddr
43

    
44
HELP_MSG = """
45

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

    
51

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

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

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

    
98
        network_id = options["network_id"]
99
        cidr = options["cidr"]
100

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

    
106
        user_id = common.get_network(network_id).userid
107
        name = options["name"] or ""
108
        allocation_pools = options["allocation_pools"]
109
        ipversion = options["ipversion"] or 4
110
        ipversion = int(ipversion)
111
        gateway = options["gateway"]
112
        dhcp = parse_bool(options["dhcp"])
113
        dns = options["dns"]
114
        host_routes = options["host_routes"]
115

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

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

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