root / snf-cyclades-app / synnefo / logic / subnets.py @ 3f18f035
History | View | Annotate | Download (9.8 kB)
1 | 9eb0710b | Dionysis Grigoropoulos | # Copyright 2013 GRNET S.A. All rights reserved.
|
---|---|---|---|
2 | 9eb0710b | Dionysis Grigoropoulos | #
|
3 | 9eb0710b | Dionysis Grigoropoulos | # Redistribution and use in source and binary forms, with or
|
4 | 9eb0710b | Dionysis Grigoropoulos | # without modification, are permitted provided that the following
|
5 | 9eb0710b | Dionysis Grigoropoulos | # conditions are met:
|
6 | 9eb0710b | Dionysis Grigoropoulos | #
|
7 | 9eb0710b | Dionysis Grigoropoulos | # 1. Redistributions of source code must retain the above
|
8 | 9eb0710b | Dionysis Grigoropoulos | # copyright notice, this list of conditions and the following
|
9 | 9eb0710b | Dionysis Grigoropoulos | # disclaimer.
|
10 | 9eb0710b | Dionysis Grigoropoulos | #
|
11 | 9eb0710b | Dionysis Grigoropoulos | # 2. Redistributions in binary form must reproduce the above
|
12 | 9eb0710b | Dionysis Grigoropoulos | # copyright notice, this list of conditions and the following
|
13 | 9eb0710b | Dionysis Grigoropoulos | # disclaimer in the documentation and/or other materials
|
14 | 9eb0710b | Dionysis Grigoropoulos | # provided with the distribution.
|
15 | 9eb0710b | Dionysis Grigoropoulos | #
|
16 | 9eb0710b | Dionysis Grigoropoulos | # THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
|
17 | 9eb0710b | Dionysis Grigoropoulos | # OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
18 | 9eb0710b | Dionysis Grigoropoulos | # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
19 | 9eb0710b | Dionysis Grigoropoulos | # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
|
20 | 9eb0710b | Dionysis Grigoropoulos | # CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
21 | 9eb0710b | Dionysis Grigoropoulos | # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
22 | 9eb0710b | Dionysis Grigoropoulos | # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
|
23 | 9eb0710b | Dionysis Grigoropoulos | # USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
24 | 9eb0710b | Dionysis Grigoropoulos | # AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
25 | 9eb0710b | Dionysis Grigoropoulos | # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
26 | 9eb0710b | Dionysis Grigoropoulos | # ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
27 | 9eb0710b | Dionysis Grigoropoulos | # POSSIBILITY OF SUCH DAMAGE.
|
28 | 9eb0710b | Dionysis Grigoropoulos | #
|
29 | 9eb0710b | Dionysis Grigoropoulos | # The views and conclusions contained in the software and
|
30 | 9eb0710b | Dionysis Grigoropoulos | # documentation are those of the authors and should not be
|
31 | 9eb0710b | Dionysis Grigoropoulos | # interpreted as representing official policies, either expressed
|
32 | 9eb0710b | Dionysis Grigoropoulos | # or implied, of GRNET S.A.
|
33 | 9eb0710b | Dionysis Grigoropoulos | |
34 | f82dfec6 | Christos Stavrakakis | import ipaddr |
35 | 9eb0710b | Dionysis Grigoropoulos | from logging import getLogger |
36 | f82dfec6 | Christos Stavrakakis | from functools import wraps |
37 | f82dfec6 | Christos Stavrakakis | |
38 | f82dfec6 | Christos Stavrakakis | from django.conf import settings |
39 | f82dfec6 | Christos Stavrakakis | from django.db import transaction |
40 | 9eb0710b | Dionysis Grigoropoulos | from snf_django.lib import api |
41 | 9eb0710b | Dionysis Grigoropoulos | from snf_django.lib.api import faults |
42 | 9eb0710b | Dionysis Grigoropoulos | |
43 | 9eb0710b | Dionysis Grigoropoulos | from synnefo.db.models import Subnet, Network, IPPoolTable |
44 | 9eb0710b | Dionysis Grigoropoulos | |
45 | 9eb0710b | Dionysis Grigoropoulos | log = getLogger(__name__) |
46 | 9eb0710b | Dionysis Grigoropoulos | |
47 | 9eb0710b | Dionysis Grigoropoulos | |
48 | 9eb0710b | Dionysis Grigoropoulos | def subnet_command(action): |
49 | 9eb0710b | Dionysis Grigoropoulos | def decorator(func): |
50 | 9eb0710b | Dionysis Grigoropoulos | @wraps(func)
|
51 | 9eb0710b | Dionysis Grigoropoulos | @transaction.commit_on_success()
|
52 | 9eb0710b | Dionysis Grigoropoulos | def wrapper(subnet, *args, **kwargs): |
53 | 9eb0710b | Dionysis Grigoropoulos | return func(subnet, *args, **kwargs)
|
54 | 9eb0710b | Dionysis Grigoropoulos | return wrapper
|
55 | 9eb0710b | Dionysis Grigoropoulos | return decorator
|
56 | 9eb0710b | Dionysis Grigoropoulos | |
57 | 9eb0710b | Dionysis Grigoropoulos | |
58 | 9eb0710b | Dionysis Grigoropoulos | def list_subnets(user_id): |
59 | 9eb0710b | Dionysis Grigoropoulos | """List all subnets of a user"""
|
60 | 9eb0710b | Dionysis Grigoropoulos | log.debug('list_subnets')
|
61 | 9eb0710b | Dionysis Grigoropoulos | |
62 | 9eb0710b | Dionysis Grigoropoulos | user_subnets = Subnet.objects.filter(network__userid=user_id) |
63 | 5d83d2ff | Dionysis Grigoropoulos | return user_subnets
|
64 | 9eb0710b | Dionysis Grigoropoulos | |
65 | 9eb0710b | Dionysis Grigoropoulos | |
66 | 9eb0710b | Dionysis Grigoropoulos | @transaction.commit_on_success
|
67 | f82dfec6 | Christos Stavrakakis | def create_subnet(*args, **kwargs): |
68 | f82dfec6 | Christos Stavrakakis | return _create_subnet(*args, **kwargs)
|
69 | f82dfec6 | Christos Stavrakakis | |
70 | f82dfec6 | Christos Stavrakakis | |
71 | f82dfec6 | Christos Stavrakakis | def _create_subnet(network_id, user_id, cidr, name, ipversion=4, gateway=None, |
72 | b7311f3d | Dionysis Grigoropoulos | dhcp=True, slaac=True, dns_nameservers=None, |
73 | f82dfec6 | Christos Stavrakakis | allocation_pools=None, host_routes=None): |
74 | 316787ab | Dionysis Grigoropoulos | """Create a subnet
|
75 | f82dfec6 | Christos Stavrakakis |
|
76 | 9eb0710b | Dionysis Grigoropoulos | network_id and the desired cidr are mandatory, everything else is optional
|
77 | 316787ab | Dionysis Grigoropoulos |
|
78 | 9eb0710b | Dionysis Grigoropoulos | """
|
79 | 9eb0710b | Dionysis Grigoropoulos | try:
|
80 | 9eb0710b | Dionysis Grigoropoulos | network = Network.objects.get(id=network_id) |
81 | 9eb0710b | Dionysis Grigoropoulos | except Network.DoesNotExist:
|
82 | b7311f3d | Dionysis Grigoropoulos | raise api.faults.ItemNotFound("No network found with that id") |
83 | 9eb0710b | Dionysis Grigoropoulos | |
84 | 5d83d2ff | Dionysis Grigoropoulos | if user_id != network.userid:
|
85 | 5d83d2ff | Dionysis Grigoropoulos | raise api.faults.Unauthorized("Unauthorized operation") |
86 | 5d83d2ff | Dionysis Grigoropoulos | |
87 | 9eb0710b | Dionysis Grigoropoulos | if ipversion not in [4, 6]: |
88 | 9eb0710b | Dionysis Grigoropoulos | raise api.faults.BadRequest("Malformed IP version type") |
89 | 9eb0710b | Dionysis Grigoropoulos | |
90 | 99718617 | Dionysis Grigoropoulos | check_number_of_subnets(network, ipversion) |
91 | 99718617 | Dionysis Grigoropoulos | |
92 | 9eb0710b | Dionysis Grigoropoulos | # Returns the first available IP in the subnet
|
93 | 99718617 | Dionysis Grigoropoulos | try:
|
94 | f82dfec6 | Christos Stavrakakis | cidr_ip = ipaddr.IPNetwork(cidr) |
95 | 99718617 | Dionysis Grigoropoulos | except ValueError: |
96 | 99718617 | Dionysis Grigoropoulos | raise api.faults.BadRequest("Malformed CIDR") |
97 | 5d83d2ff | Dionysis Grigoropoulos | |
98 | 9eb0710b | Dionysis Grigoropoulos | if ipversion == 6: |
99 | f82dfec6 | Christos Stavrakakis | validate_subnet_params(None, None, cidr, gateway) |
100 | 9eb0710b | Dionysis Grigoropoulos | else:
|
101 | f82dfec6 | Christos Stavrakakis | validate_subnet_params(cidr, gateway) |
102 | 9eb0710b | Dionysis Grigoropoulos | |
103 | 9eb0710b | Dionysis Grigoropoulos | name = check_name_length(name) |
104 | 9eb0710b | Dionysis Grigoropoulos | sub = Subnet.objects.create(name=name, network=network, cidr=cidr, |
105 | 9eb0710b | Dionysis Grigoropoulos | ipversion=ipversion, gateway=gateway, |
106 | 5d83d2ff | Dionysis Grigoropoulos | dhcp=dhcp, host_routes=host_routes, |
107 | 5d83d2ff | Dionysis Grigoropoulos | dns_nameservers=dns_nameservers) |
108 | 9eb0710b | Dionysis Grigoropoulos | |
109 | b7311f3d | Dionysis Grigoropoulos | gateway_ip = ipaddr.IPAddress(gateway) if gateway else None |
110 | b7311f3d | Dionysis Grigoropoulos | |
111 | 9eb0710b | Dionysis Grigoropoulos | if allocation_pools is not None: |
112 | 9eb0710b | Dionysis Grigoropoulos | # If the user specified IP allocation pools, validate them and use them
|
113 | 9eb0710b | Dionysis Grigoropoulos | if ipversion == 6: |
114 | 9eb0710b | Dionysis Grigoropoulos | raise api.faults.Conflict("Can't allocate an IP Pool in IPv6") |
115 | 5d83d2ff | Dionysis Grigoropoulos | validate_subpools(allocation_pools, cidr_ip, gateway_ip) |
116 | 9eb0710b | Dionysis Grigoropoulos | if allocation_pools is None and ipversion == 4: |
117 | 9eb0710b | Dionysis Grigoropoulos | # Check if the gateway is the first IP of the subnet, in this case
|
118 | 9eb0710b | Dionysis Grigoropoulos | # create a single ip pool
|
119 | b7311f3d | Dionysis Grigoropoulos | if gateway_ip:
|
120 | b7311f3d | Dionysis Grigoropoulos | if int(gateway_ip) - int(cidr_ip) == 1: |
121 | b7311f3d | Dionysis Grigoropoulos | allocation_pools = [[gateway_ip + 1, cidr_ip.broadcast - 1]] |
122 | b7311f3d | Dionysis Grigoropoulos | else:
|
123 | b7311f3d | Dionysis Grigoropoulos | # If the gateway isn't the first available ip, create two
|
124 | b7311f3d | Dionysis Grigoropoulos | # different ip pools adjacent to said ip
|
125 | b7311f3d | Dionysis Grigoropoulos | allocation_pools = (([cidr_ip.network + 1, gateway_ip - 1]), |
126 | b7311f3d | Dionysis Grigoropoulos | ([gateway_ip + 1, cidr_ip.broadcast - 1])) |
127 | 9eb0710b | Dionysis Grigoropoulos | else:
|
128 | b7311f3d | Dionysis Grigoropoulos | allocation_pools = [[cidr_ip.network + 1, cidr_ip.broadcast - 1]] |
129 | 9eb0710b | Dionysis Grigoropoulos | |
130 | 5d83d2ff | Dionysis Grigoropoulos | if allocation_pools:
|
131 | 5d83d2ff | Dionysis Grigoropoulos | create_ip_pools(allocation_pools, cidr_ip, sub) |
132 | 9eb0710b | Dionysis Grigoropoulos | |
133 | 9eb0710b | Dionysis Grigoropoulos | return sub
|
134 | 9eb0710b | Dionysis Grigoropoulos | |
135 | 9eb0710b | Dionysis Grigoropoulos | |
136 | 9eb0710b | Dionysis Grigoropoulos | def get_subnet(sub_id): |
137 | 9eb0710b | Dionysis Grigoropoulos | """Show info of a specific subnet"""
|
138 | 9eb0710b | Dionysis Grigoropoulos | log.debug('get_subnet %s', sub_id)
|
139 | 9eb0710b | Dionysis Grigoropoulos | try:
|
140 | 9eb0710b | Dionysis Grigoropoulos | subnet = Subnet.objects.get(id=sub_id) |
141 | 9eb0710b | Dionysis Grigoropoulos | except Subnet.DoesNotExist:
|
142 | 9eb0710b | Dionysis Grigoropoulos | raise api.faults.ItemNotFound("Subnet not found") |
143 | 9eb0710b | Dionysis Grigoropoulos | |
144 | 5d83d2ff | Dionysis Grigoropoulos | return subnet
|
145 | 9eb0710b | Dionysis Grigoropoulos | |
146 | 9eb0710b | Dionysis Grigoropoulos | |
147 | 9eb0710b | Dionysis Grigoropoulos | def delete_subnet(): |
148 | 316787ab | Dionysis Grigoropoulos | """Delete a subnet, raises BadRequest
|
149 | 9eb0710b | Dionysis Grigoropoulos | A subnet is deleted ONLY when the network that it belongs to is deleted
|
150 | 316787ab | Dionysis Grigoropoulos |
|
151 | 9eb0710b | Dionysis Grigoropoulos | """
|
152 | 9eb0710b | Dionysis Grigoropoulos | raise api.faults.BadRequest("Deletion of a subnet is not supported") |
153 | 9eb0710b | Dionysis Grigoropoulos | |
154 | 9eb0710b | Dionysis Grigoropoulos | |
155 | 9eb0710b | Dionysis Grigoropoulos | @transaction.commit_on_success
|
156 | 8646e606 | Dionysis Grigoropoulos | def update_subnet(sub_id, name, user_id): |
157 | 316787ab | Dionysis Grigoropoulos | """Update the fields of a subnet
|
158 | 9eb0710b | Dionysis Grigoropoulos | Only the name can be updated
|
159 | 316787ab | Dionysis Grigoropoulos |
|
160 | 9eb0710b | Dionysis Grigoropoulos | """
|
161 | 5d83d2ff | Dionysis Grigoropoulos | log.info('Update subnet %s, name %s' % (sub_id, name))
|
162 | 9eb0710b | Dionysis Grigoropoulos | |
163 | 9eb0710b | Dionysis Grigoropoulos | try:
|
164 | 9eb0710b | Dionysis Grigoropoulos | subnet = Subnet.objects.get(id=sub_id) |
165 | 9eb0710b | Dionysis Grigoropoulos | except:
|
166 | 9eb0710b | Dionysis Grigoropoulos | raise api.faults.ItemNotFound("Subnet not found") |
167 | 9eb0710b | Dionysis Grigoropoulos | |
168 | 8646e606 | Dionysis Grigoropoulos | if user_id != subnet.network.userid:
|
169 | 8646e606 | Dionysis Grigoropoulos | raise api.faults.Unauthorized("Unauthorized operation") |
170 | 8646e606 | Dionysis Grigoropoulos | |
171 | 9eb0710b | Dionysis Grigoropoulos | check_name_length(name) |
172 | 9eb0710b | Dionysis Grigoropoulos | |
173 | 9eb0710b | Dionysis Grigoropoulos | subnet.name = name |
174 | 9eb0710b | Dionysis Grigoropoulos | subnet.save() |
175 | 9eb0710b | Dionysis Grigoropoulos | |
176 | 9eb0710b | Dionysis Grigoropoulos | return subnet
|
177 | 9eb0710b | Dionysis Grigoropoulos | |
178 | 9eb0710b | Dionysis Grigoropoulos | |
179 | 9eb0710b | Dionysis Grigoropoulos | #Utility functions
|
180 | 9eb0710b | Dionysis Grigoropoulos | def create_ip_pools(pools, cidr, subnet): |
181 | 9eb0710b | Dionysis Grigoropoulos | """Create IP Pools in the database"""
|
182 | f82dfec6 | Christos Stavrakakis | ip_pools = [] |
183 | 9eb0710b | Dionysis Grigoropoulos | for pool in pools: |
184 | 9eb0710b | Dionysis Grigoropoulos | size = int(pool[1]) - int(pool[0]) + 1 |
185 | 9eb0710b | Dionysis Grigoropoulos | base = str(cidr)
|
186 | 9eb0710b | Dionysis Grigoropoulos | offset = int(pool[0]) - int(cidr.network) |
187 | 9eb0710b | Dionysis Grigoropoulos | ip_pool = IPPoolTable.objects.create(size=size, offset=offset, |
188 | 9eb0710b | Dionysis Grigoropoulos | base=base, subnet=subnet) |
189 | f82dfec6 | Christos Stavrakakis | ip_pools.append(ip_pool) |
190 | f82dfec6 | Christos Stavrakakis | return ip_pools
|
191 | 9eb0710b | Dionysis Grigoropoulos | |
192 | 9eb0710b | Dionysis Grigoropoulos | |
193 | 9eb0710b | Dionysis Grigoropoulos | def check_number_of_subnets(network, version): |
194 | 9eb0710b | Dionysis Grigoropoulos | """Check if a user can add a subnet in a network"""
|
195 | 9eb0710b | Dionysis Grigoropoulos | if network.subnets.filter(ipversion=version):
|
196 | 9eb0710b | Dionysis Grigoropoulos | raise api.faults.BadRequest("Only one subnet of IPv4/IPv6 per " |
197 | 9eb0710b | Dionysis Grigoropoulos | "network is allowed")
|
198 | 9eb0710b | Dionysis Grigoropoulos | |
199 | 9eb0710b | Dionysis Grigoropoulos | |
200 | 9eb0710b | Dionysis Grigoropoulos | def check_name_length(name): |
201 | 9eb0710b | Dionysis Grigoropoulos | """Check if the length of a name is within acceptable value"""
|
202 | 9eb0710b | Dionysis Grigoropoulos | if len(str(name)) > Subnet.SUBNET_NAME_LENGTH: |
203 | 9eb0710b | Dionysis Grigoropoulos | raise api.faults.BadRequest("Subnet name too long") |
204 | 9eb0710b | Dionysis Grigoropoulos | return name
|
205 | 9eb0710b | Dionysis Grigoropoulos | |
206 | 9eb0710b | Dionysis Grigoropoulos | |
207 | 9eb0710b | Dionysis Grigoropoulos | def validate_subpools(pool_list, cidr, gateway): |
208 | 316787ab | Dionysis Grigoropoulos | """Validate IP Pools
|
209 | 316787ab | Dionysis Grigoropoulos |
|
210 | 9eb0710b | Dionysis Grigoropoulos | Validate the given IP pools are inside the cidr range
|
211 | 9eb0710b | Dionysis Grigoropoulos | Validate there are no overlaps in the given pools
|
212 | 9eb0710b | Dionysis Grigoropoulos | Finally, validate the gateway isn't in the given ip pools
|
213 | 9eb0710b | Dionysis Grigoropoulos | Input must be a list containing a sublist with start/end ranges as
|
214 | 9eb0710b | Dionysis Grigoropoulos | ipaddr.IPAddress items eg.,
|
215 | 9eb0710b | Dionysis Grigoropoulos | [[IPv4Address('192.168.42.11'), IPv4Address('192.168.42.15')],
|
216 | 9eb0710b | Dionysis Grigoropoulos | [IPv4Address('192.168.42.30'), IPv4Address('192.168.42.60')]]
|
217 | 316787ab | Dionysis Grigoropoulos |
|
218 | 9eb0710b | Dionysis Grigoropoulos | """
|
219 | 9eb0710b | Dionysis Grigoropoulos | if pool_list[0][0] <= cidr.network: |
220 | 9eb0710b | Dionysis Grigoropoulos | raise api.faults.Conflict("IP Pool out of bounds") |
221 | 9eb0710b | Dionysis Grigoropoulos | elif pool_list[-1][1] >= cidr.broadcast: |
222 | 9eb0710b | Dionysis Grigoropoulos | raise api.faults.Conflict("IP Pool out of bounds") |
223 | 9eb0710b | Dionysis Grigoropoulos | |
224 | 9eb0710b | Dionysis Grigoropoulos | for start, end in pool_list: |
225 | 9eb0710b | Dionysis Grigoropoulos | if start > end:
|
226 | 9eb0710b | Dionysis Grigoropoulos | raise api.faults.Conflict("Invalid IP pool range") |
227 | 9eb0710b | Dionysis Grigoropoulos | # Raise BadRequest if gateway is inside the pool range
|
228 | b7311f3d | Dionysis Grigoropoulos | if gateway:
|
229 | b7311f3d | Dionysis Grigoropoulos | if not (gateway < start or gateway > end): |
230 | b7311f3d | Dionysis Grigoropoulos | raise api.faults.Conflict("Gateway cannot be in pool range") |
231 | 9eb0710b | Dionysis Grigoropoulos | |
232 | 9eb0710b | Dionysis Grigoropoulos | # Check if there is a conflict between the IP Poll ranges
|
233 | 9eb0710b | Dionysis Grigoropoulos | end = cidr.network |
234 | 9eb0710b | Dionysis Grigoropoulos | for pool in pool_list: |
235 | 9eb0710b | Dionysis Grigoropoulos | if end >= pool[0]: |
236 | 9eb0710b | Dionysis Grigoropoulos | raise api.faults.Conflict("IP Pool range conflict") |
237 | 9eb0710b | Dionysis Grigoropoulos | end = pool[1]
|
238 | f82dfec6 | Christos Stavrakakis | |
239 | f82dfec6 | Christos Stavrakakis | |
240 | f82dfec6 | Christos Stavrakakis | def validate_subnet_params(subnet=None, gateway=None, subnet6=None, |
241 | f82dfec6 | Christos Stavrakakis | gateway6=None):
|
242 | f82dfec6 | Christos Stavrakakis | if subnet:
|
243 | f82dfec6 | Christos Stavrakakis | try:
|
244 | f82dfec6 | Christos Stavrakakis | # Use strict option to not all subnets with host bits set
|
245 | f82dfec6 | Christos Stavrakakis | network = ipaddr.IPv4Network(subnet, strict=True)
|
246 | f82dfec6 | Christos Stavrakakis | except ValueError: |
247 | f82dfec6 | Christos Stavrakakis | raise faults.BadRequest("Invalid network IPv4 subnet") |
248 | f82dfec6 | Christos Stavrakakis | |
249 | f82dfec6 | Christos Stavrakakis | # Check that network size is allowed!
|
250 | f82dfec6 | Christos Stavrakakis | prefixlen = network.prefixlen |
251 | f82dfec6 | Christos Stavrakakis | if prefixlen > 29 or prefixlen <= settings.MAX_CIDR_BLOCK: |
252 | f82dfec6 | Christos Stavrakakis | raise faults.OverLimit(
|
253 | f82dfec6 | Christos Stavrakakis | message="Unsupported network size",
|
254 | f82dfec6 | Christos Stavrakakis | details="Netmask must be in range: (%s, 29]" %
|
255 | f82dfec6 | Christos Stavrakakis | settings.MAX_CIDR_BLOCK) |
256 | f82dfec6 | Christos Stavrakakis | if gateway: # Check that gateway belongs to network |
257 | f82dfec6 | Christos Stavrakakis | try:
|
258 | f82dfec6 | Christos Stavrakakis | gateway = ipaddr.IPv4Address(gateway) |
259 | f82dfec6 | Christos Stavrakakis | except ValueError: |
260 | f82dfec6 | Christos Stavrakakis | raise faults.BadRequest("Invalid network IPv4 gateway") |
261 | f82dfec6 | Christos Stavrakakis | if not gateway in network: |
262 | f82dfec6 | Christos Stavrakakis | raise faults.BadRequest("Invalid network IPv4 gateway") |
263 | f82dfec6 | Christos Stavrakakis | |
264 | f82dfec6 | Christos Stavrakakis | if subnet6:
|
265 | f82dfec6 | Christos Stavrakakis | try:
|
266 | f82dfec6 | Christos Stavrakakis | # Use strict option to not all subnets with host bits set
|
267 | f82dfec6 | Christos Stavrakakis | network6 = ipaddr.IPv6Network(subnet6, strict=True)
|
268 | f82dfec6 | Christos Stavrakakis | except ValueError: |
269 | f82dfec6 | Christos Stavrakakis | raise faults.BadRequest("Invalid network IPv6 subnet") |
270 | f82dfec6 | Christos Stavrakakis | # Check that network6 is an /64 subnet, because this is imposed by
|
271 | f82dfec6 | Christos Stavrakakis | # 'mac2eui64' utiity.
|
272 | f82dfec6 | Christos Stavrakakis | if network6.prefixlen != 64: |
273 | f82dfec6 | Christos Stavrakakis | msg = ("Unsupported IPv6 subnet size. Network netmask must be"
|
274 | f82dfec6 | Christos Stavrakakis | " /64")
|
275 | f82dfec6 | Christos Stavrakakis | raise faults.BadRequest(msg)
|
276 | f82dfec6 | Christos Stavrakakis | if gateway6:
|
277 | f82dfec6 | Christos Stavrakakis | try:
|
278 | f82dfec6 | Christos Stavrakakis | gateway6 = ipaddr.IPv6Address(gateway6) |
279 | f82dfec6 | Christos Stavrakakis | except ValueError: |
280 | f82dfec6 | Christos Stavrakakis | raise faults.BadRequest("Invalid network IPv6 gateway") |
281 | f82dfec6 | Christos Stavrakakis | if not gateway6 in network6: |
282 | f82dfec6 | Christos Stavrakakis | raise faults.BadRequest("Invalid network IPv6 gateway") |