blob: 0a8398ab7d8afed1e7ce0570fa432a0d9f82d3a1 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
|
/*
* Copyright (c) 2016 Cisco and/or its affiliates.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at:
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.fd.hc2vpp.common.translate.util;
import java.util.Objects;
import javax.annotation.Nonnull;
import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.Ipv4AddressNoZone;
import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.Ipv4Prefix;
/**
* IPv4 address range representation.
*/
public final class Ipv4AddressRange {
private final Ipv4AddressNoZone start;
private final Ipv4AddressNoZone end;
private Ipv4AddressRange(
@Nonnull final Ipv4AddressNoZone start,
@Nonnull final Ipv4AddressNoZone end) {
this.start = start;
this.end = end;
}
public Ipv4AddressNoZone getStart() {
return start;
}
public Ipv4AddressNoZone getEnd() {
return end;
}
@Override
public boolean equals(final Object other) {
if (this == other) {
return true;
}
if (other == null || getClass() != other.getClass()) {
return false;
}
final Ipv4AddressRange that = (Ipv4AddressRange) other;
return Objects.equals(start, that.start)
&& Objects.equals(end, that.end);
}
@Override
public int hashCode() {
return Objects.hash(start, end);
}
@Override
public String toString() {
return "Ipv4AddressRange{"
+ "start=" + start
+ ", end=" + end
+ '}';
}
/**
* Create address range from prefix.
*/
public static Ipv4AddressRange fromPrefix(@Nonnull final Ipv4Prefix prefix) {
final String addressString = prefix.getValue().split("/")[0];
byte prefixLength = Ipv4Translator.INSTANCE.extractPrefix(prefix);
if (prefixLength == 32) {
// 32 Prefix can be handled instantly
return new Ipv4AddressRange(new Ipv4AddressNoZone(addressString), new Ipv4AddressNoZone(addressString));
}
final byte[] prefixAddrBytes = Ipv4Translator.INSTANCE.ipv4AddressNoZoneToArray(addressString);
final byte[] prefixAddrBytes0 = new byte[prefixAddrBytes.length];
final byte[] prefixAddrBytesF = new byte[prefixAddrBytes.length];
byte index = 0;
while (prefixLength >= 8) {
prefixAddrBytes0[index] = prefixAddrBytes[index];
prefixAddrBytesF[index] = prefixAddrBytes[index];
index++;
prefixLength -= 8;
}
// Take care of the rest
if (prefixLength != 0) {
final int mask0 = (byte) ((1 << prefixLength) - 1) << (8 - prefixLength);
prefixAddrBytes0[index] = (byte) (prefixAddrBytes[index] & mask0);
final int maskF = (byte) ((1 << (8 - prefixLength)) - 1);
prefixAddrBytesF[index] = (byte) (prefixAddrBytes[index] | maskF);
index++;
}
for (int i = index; i < 4; i++) {
prefixAddrBytes0[i] = 0;
prefixAddrBytesF[i] = (byte) 255;
}
return new Ipv4AddressRange(
Ipv4Translator.INSTANCE.arrayToIpv4AddressNoZone(prefixAddrBytes0),
Ipv4Translator.INSTANCE.arrayToIpv4AddressNoZone(prefixAddrBytesF));
}
}
|