Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/**
* The MIT License (MIT)
*
* Copyright (c) 2011-2014, Yannis Gonianakis
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
package net.ripe.commons.ip;
import java.math.BigInteger;
import java.util.Collections;
import java.util.List;
public final class Ipv4Range extends AbstractIpRange {
private static final long serialVersionUID = 1L;
protected Ipv4Range(Ipv4 start, Ipv4 end) {
super(start, end);
}
@Override
protected Ipv4Range newInstance(BigInteger start, BigInteger end) {
return Ipv4Range.from(start).to(end);
}
@Override
protected Ipv4Range newInstance(Ipv4 start, Ipv4 end) {
return new Ipv4Range(start, end);
}
public static Ipv4RangeBuilder from(Ipv4 from) {
return new Ipv4RangeBuilder(from);
}
public static Ipv4RangeBuilder from(BigInteger from) {
return new Ipv4RangeBuilder(Ipv4.of(from));
}
public static Ipv4RangeBuilder from(Long from) {
return new Ipv4RangeBuilder(Ipv4.of(from));
}
public static Ipv4RangeBuilder from(String from) {
return new Ipv4RangeBuilder(Ipv4.parse(from));
}
/**
* Parses a String into an {@link Ipv4Range}.
*
* @param range a dash separated string of two IPv4 addresses e.g. "192.168.0.0-192.168.255.255"
* or a CIDR-notation string, e.g. "192.168.0.0/16"
* @return a new {@link Ipv4Range}
* @throws IllegalArgumentException if the string cannot be parsed
* @see #parseCidr(String)
*/
public static Ipv4Range parse(String range) {
int idx = range.indexOf(DASH);
if (idx != -1) {
Ipv4 start = Ipv4.parse(range.substring(0, idx));
Ipv4 end = Ipv4.parse(range.substring(idx + 1, range.length()));
return new Ipv4Range(start, end);
} else {
return parseCidr(range);
}
}
/**
* Parses a String of an IPv4 address and its subnet mask formatted as in a
* Classless Inter-Domain Routing (CIDR) notation.
*
* @param cidrString a CIDR-notation string, e.g. "192.168.0.0/16"
* @return a new {@link Ipv4Range}
* @throws IllegalArgumentException if the string cannot be parsed
* @see rfc4632
*/
public static Ipv4Range parseCidr(String cidrString) {
int idx = cidrString.indexOf(SLASH);
Validate.isTrue(idx != -1, "Argument [" + cidrString + "] is not a range or does not comply with the CIDR notation");
String address = cidrString.substring(0, idx);
String prefix = cidrString.substring(idx + 1, cidrString.length());
return Ipv4Range.from(address).andPrefixLength(prefix);
}
public static Ipv4Range parseDecimalNotation(String range) {
int idx = range.indexOf(DASH);
Validate.isTrue(idx != -1, "Argument [" + range + "] does not comply with the decimal range notation");
long start = Long.valueOf(range.substring(0, idx));
long end = Long.valueOf(range.substring(idx + 1, range.length()));
return Ipv4Range.from(start).to(end);
}
@Override
public Long size() {
return (end().value() - start().value()) + 1;
}
// TODO(yg): refactor and move to parent
public String toStringInSlashNotation() {
List prefixes = splitToPrefixes();
Collections.sort(prefixes, StartAndSizeComparator.get());
StringBuilder notation = new StringBuilder().append(start());
for (Ipv4Range range : prefixes) {
notation.append(SLASH).append(PrefixUtils.getPrefixLength(range));
notation.append(",");
}
String noted = notation.toString();
return noted.substring(0, noted.length() - 1);
}
public static class Ipv4RangeBuilder extends AbstractRangeBuilder {
private final Ipv4 from;
protected Ipv4RangeBuilder(Ipv4 from) {
this.from = from;
}
public Ipv4Range to(BigInteger end) {
return to(Ipv4.of(end));
}
public Ipv4Range to(Long end) {
return to(Ipv4.of(end));
}
public Ipv4Range to(String end) {
return to(Ipv4.parse(end));
}
public Ipv4Range andPrefixLength(String prefix) {
return andPrefixLength(Integer.parseInt(prefix));
}
public Ipv4Range andPrefixLength(int prefixLength) {
Validate.isTrue(from.lowerBoundForPrefix(prefixLength).equals(from),
from + "/" + prefixLength + " is not a legal IPv4 address prefix.");
return to(from.upperBoundForPrefix(prefixLength));
}
@Override
public Ipv4Range to(Ipv4 to) {
return new Ipv4Range(from, to);
}
}
}