inet.ipaddr.IPAddressSegmentSeries Maven / Gradle / Ivy
/*
* Copyright 2016-2018 Sean C Foley
*
* 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
* or at
* https://github.com/seancfoley/IPAddress/blob/master/LICENSE
*
* 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 inet.ipaddr;
import java.math.BigInteger;
import java.util.Comparator;
import java.util.Iterator;
import java.util.stream.Stream;
import inet.ipaddr.IPAddress.IPVersion;
import inet.ipaddr.IPAddressSection.IPStringBuilderOptions;
import inet.ipaddr.IPAddressSection.IPStringOptions;
import inet.ipaddr.format.IPAddressDivisionSeries;
import inet.ipaddr.format.util.AddressComponentRangeSpliterator;
import inet.ipaddr.format.util.AddressComponentSpliterator;
import inet.ipaddr.format.util.IPAddressPartStringCollection;
/**
* Represents a series of IP address segments.
*
* Provides methods relevant to IP addresses and IP address sections in addition to the more general methods pertaining to address and address sections in AddressSegmentSeries.
*
*
* @author sfoley
*
*/
public interface IPAddressSegmentSeries extends IPAddressDivisionSeries, AddressSegmentSeries {
/**
* Returns a comparator to sort series by prefix length.
*
* @return
*/
static Comparator super IPAddressSegmentSeries> getPrefixLenComparator() {
return IPAddressSection.mergeListComparator;
}
/**
* Returns the version of this segment series
*
* @return
*/
IPVersion getIPVersion();
/**
* Returns the equivalent address series with the smallest CIDR prefix possible (largest network),
* such that the range of values of this address includes the subnet prefix block for that prefix.
*
* @see #toPrefixBlock()
* @see #assignPrefixForSingleBlock()
* @return
*/
IPAddressSegmentSeries assignMinPrefixForBlock();
/**
* Returns the equivalent CIDR address series with a prefix length for which the subnet block for that prefix matches the range of values in this series.
* In short, the returned series is a single block of address segment series.
* Another way of looking at it: if the range matches the range associated with some prefix length, then it returns the address series with that prefix length.
*
* If no such prefix length exists, returns null.
*
* If this address represents just a single address, "this" is returned.
*
* The methods {@link #assignMinPrefixForBlock}, {@link #assignPrefixForSingleBlock} can be compared as follows.
* {@link #assignMinPrefixForBlock} finds the smallest prefix length possible for this subnet and returns that subnet.
* {@link #assignPrefixForSingleBlock} finds the smallest prefix length possible for this subnet that results in just a single prefix and returns that subnet.
*
* For example, given the address 1-2.2.3.* /16
* {@link #assignMinPrefixForBlock} returns 1-2.2.3.* /24 if the prefix configuration is the default or is not ALL_PREFIXES_ARE_SUBNETS, otherwise 1-2.2.*.* /16, in order to return the subnet with the smallest prefix length
* {@link #assignPrefixForSingleBlock} returns null because any prefix length will end up with at least two prefixes due to the first segment spanning two values: 1-2.
*
* For another example, for the address 1.2.*.* /16 or the address 1.2.*.* both methods return 1.2.*.* /16.
*
* @see #toPrefixBlock()
* @see #assignMinPrefixForBlock()
* @return
*/
IPAddressSegmentSeries assignPrefixForSingleBlock();
/**
* Returns the minimal-size prefix block that covers all the values in this series.
* The resulting block will have a larger series count than this, unless this series is already a prefix block.
*/
IPAddressSegmentSeries coverWithPrefixBlock();
/**
* Produces an array of prefix blocks that spans the same set of values.
*/
IPAddressSegmentSeries[] spanWithPrefixBlocks();
/**
* Produces an array of blocks that are sequential that cover the same set of values.
* This array can be shorter than that produced by {@link #spanWithPrefixBlocks()} and is never longer.
*/
IPAddressSegmentSeries[] spanWithSequentialBlocks();
/**
* If this series has a prefix length, returns the subnet block for that prefix. If this series has no prefix length, this series is returned.
*
* @return the subnet block for the prefix length
*/
@Override
IPAddressSegmentSeries toPrefixBlock();
/**
* Returns the segment series of the same length that spans all hosts.
* The network prefix length will be the one provided, and the network values will match the same of this series.
*
* @param networkPrefixLength
* @return
*/
IPAddressSegmentSeries toPrefixBlock(int networkPrefixLength) throws PrefixLenException;
/**
* Returns the host mask associated with the CIDR network prefix length of this series.
* If this series has no prefix length, then the whole series is considered a host and the all ones host mask is returned.
*
* @return
*/
IPAddressSegmentSeries getHostMask();
/**
* Returns the network mask associated with the CIDR network prefix length of this series.
* If this series has no prefix length, then the whole series is considered network and the all ones network mask is returned.
*
* @return
*/
IPAddressSegmentSeries getNetworkMask();
/**
* Returns the host section of the series. The returned section will have only as many segments as needed
* as determined by the existing CIDR network prefix length. If this series has no CIDR prefix length, the returned host section will
* be the full section associated with a prefix length of 0.
*
* @return
*/
IPAddressSection getHostSection();
/**
* Returns the host section of the address as indicated by the network prefix length provided. The returned section will have only as many segments as needed
* to hold the host as indicated by the provided network prefix length.
*
* @param networkPrefixLength
* @return
*/
IPAddressSection getHostSection(int networkPrefixLength);
/**
* Returns the network section of the series if the series has a CIDR network prefix length,
* otherwise it returns the entire series as a prefixed series with prefix matching the address bit length.
*
* @return
*/
IPAddressSection getNetworkSection();
/**
* Returns the network section of the series. The returned section will have only as many segments as needed as indicated by networkPrefixLength.
* It will have networkPrefixLength as its associated prefix length,
* unless this address already has a smaller prefix length, in which case the existing prefix length is retained.
*
* @param networkPrefixLength
* @return
*/
IPAddressSection getNetworkSection(int networkPrefixLength);
/**
* Returns the network section of the series. The returned section will have only as many segments as needed as indicated by networkPrefixLength.
* If withPrefixLength is true, it will have networkPrefixLength as its associated prefix length,
* unless this series already has a smaller prefix length, in which case the existing prefix length is retained.
*
* @param networkPrefixLength
* @param withPrefixLength whether the resulting section will have networkPrefixLength as the associated prefix length or not
* @return
*/
IPAddressSection getNetworkSection(int networkPrefixLength, boolean withPrefixLength);
/**
* This produces a string with no compressed segments and all segments of full length,
* which is 4 characters for IPv6 segments and 3 characters for IPv4 segments.
*/
String toFullString();
/**
* Returns a string with a CIDR prefix length if this section has a network prefix length.
* For IPv6, the host section will be compressed with ::, for IPv4 the host section will be zeros.
* @return
*/
String toPrefixLengthString();
/**
* Produces a consistent subnet string.
*
* In the case of IPv4, this means that wildcards are used instead of a network prefix.
* In the case of IPv6, a prefix will be used and the host section will be compressed with ::.
*/
String toSubnetString();
/**
* This produces a string similar to the normalized string and avoids the CIDR prefix.
* CIDR addresses will be shown with wildcards and ranges instead of using the CIDR prefix notation.
*/
String toNormalizedWildcardString();
/**
* This produces a string similar to the canonical string and avoids the CIDR prefix.
* Addresses with a network prefix length will be shown with wildcards and ranges instead of using the CIDR prefix length notation.
* IPv6 addresses will be compressed according to the canonical representation.
*/
String toCanonicalWildcardString();
/**
* This is similar to toNormalizedWildcardString, avoiding the CIDR prefix, but with compression as well.
*/
String toCompressedWildcardString();
/**
* This is the same as the string from toNormalizedWildcardString except that
* it uses {@link IPAddress#SEGMENT_SQL_WILDCARD} instead of {@link IPAddress#SEGMENT_WILDCARD} and also uses {@link IPAddress#SEGMENT_SQL_SINGLE_WILDCARD}
*/
String toSQLWildcardString();
/**
* Generates the reverse DNS lookup string
* For 8.255.4.4 it is 4.4.255.8.in-addr.arpa
* For 2001:db8::567:89ab it is b.a.9.8.7.6.5.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.8.b.d.0.1.0.0.2.ip6.arpa
*
*
* @throws IncompatibleAddressException if this address is a subnet
* @return
*/
String toReverseDNSLookupString();
/**
* Writes this IP address segment series as a single binary value with always the exact same number of characters
*
* If this section represents a range of values outside of the network prefix length, then this is printed as a range of two binary values.
*/
String toBinaryString() throws IncompatibleAddressException;
/**
* Writes this IP address segment series as a segments of binary values preceded by the "0b" prefix.
*/
String toSegmentedBinaryString();
/**
* Writes this IP address segment series as a single octal value with always the exact same number of characters, with or without a preceding 0 prefix.
*
* If this section represents a range of values outside of the network prefix length, then this is printed as a range of two hex values.
*/
String toOctalString(boolean with0Prefix) throws IncompatibleAddressException;
IPAddressPartStringCollection toStringCollection(IPStringBuilderOptions options);
/**
* Creates a customized string from this series.
*
* @param stringOptions
* @return
*/
String toNormalizedString(IPStringOptions stringOptions);
@Override
IPAddressNetwork,?,?,?,?> getNetwork();
@Override
IPAddressSection getSection();
@Override
IPAddressSection getSection(int index);
@Override
IPAddressSection getSection(int index, int endIndex);
@Override
IPAddressSegment getSegment(int index);
@Override
IPAddressSegment[] getSegments();
/**
* Gets the count of single value series that this series may represent, but excluding series whose host is zero.
* The host is determined by the CIDR prefix length, if there is one.
*
* If this address series has no range of values, then there is only one such address, or none if it has a zero host.
*
* If this has no CIDR network prefix length, then it is equivalent to {@link #getCount()}.
*
* @return
*/
BigInteger getNonZeroHostCount();
/**
* Similar to {@link #getLower()}, but will not return a series that has a prefix length and whose host value is zero.
* If this series has no prefix length, returns the same series as {@link #getLower()}.
*
* @return the lowest IP address series whose host is non-zero, or null if no such address section exists.
*/
IPAddressSegmentSeries getLowerNonZeroHost();
@Override
IPAddressSegmentSeries getLower();
@Override
IPAddressSegmentSeries getUpper();
@Override
Iterable extends IPAddressSegmentSeries> getIterable();
@Override
Iterator extends IPAddressSegmentSeries> iterator();
@Override
AddressComponentSpliterator extends IPAddressSegmentSeries> spliterator();
@Override
Stream extends IPAddressSegmentSeries> stream();
@Override
Iterator extends IPAddressSegmentSeries> prefixIterator();
@Override
AddressComponentSpliterator extends IPAddressSegmentSeries> prefixSpliterator();
@Override
Stream extends IPAddressSegmentSeries> prefixStream();
@Override
Iterator extends IPAddressSegmentSeries> prefixBlockIterator();
@Override
AddressComponentSpliterator extends IPAddressSegmentSeries> prefixBlockSpliterator();
@Override
Stream extends IPAddressSegmentSeries> prefixBlockStream();
/**
* Similar to the iterator, but series with a host of zero are skipped.
* @return
*/
Iterator extends IPAddressSegmentSeries> nonZeroHostIterator();
/**
* Iterates through series that can be obtained by iterating through all the upper segments up to the given segment count.
* Segments following remain the same in all iterated series.
*
* For instance, given the IPv4 subnet 1-2.3-4.5-6.7, given the count argument 2,
* it will iterate through 1.3.5-6.7, 1.4.5-6.7, 2.3.5-6.7, 2.4.5-6.7
*
* @param segmentCount
* @return
*/
Iterator extends IPAddressSegmentSeries> blockIterator(int segmentCount);
/**
* Partitions and traverses through the individual sequential blocks created from each of the individual values up to the given segment count.
*
* @return
*/
AddressComponentSpliterator extends IPAddressSegmentSeries> blockSpliterator(int segmentCount);
/**
* Returns a sequential stream of the individual blocks created from each of the individual values up to the given segment count.
* For a parallel stream, call {@link Stream#parallel()} on the returned stream.
*
* @return
*/
Stream extends IPAddressSegmentSeries> blockStream(int segmentCount);
/**
* Iterates through the sequential series that make up this series.
* Generally this means finding the count of segments for which the segments that follow are not full range, and then using {@link #blockIterator(int)} with that segment count.
*
* For instance, given the IPv4 subnet 1-2.3-4.5-6.7-8, it will iterate through 1.3.5.7-8, 1.3.6.7-8, 1.4.5.7-8, 1.4.6.7-8, 2.3.5.7-8, 2.3.6.7-8, 2.4.6.7-8, 2.4.6.7-8.
*
* Use {@link #getSequentialBlockCount()} to get the count of iterated elements.
*
* @return
*/
Iterator extends IPAddressSegmentSeries> sequentialBlockIterator();
/**
* Partitions and traverses through the individual sequential blocks.
*
* @return
*/
AddressComponentSpliterator extends IPAddressSegmentSeries> sequentialBlockSpliterator();
/**
* Returns a sequential stream of the individual sequential blocks. For a parallel stream, call {@link Stream#parallel()} on the returned stream.
*
* Use {@link #getSequentialBlockCount()} to get the count of streamed elements.
*
* @return
*/
Stream extends IPAddressSegmentSeries> sequentialBlockStream();
/**
* provides the count of elements from the {@link #sequentialBlockIterator()}, the minimal number of sequential sub-series that comprise this series
* @return
*/
BigInteger getSequentialBlockCount();
@Override
Iterator extends IPAddressSegment[]> segmentsIterator();
@Override
AddressComponentRangeSpliterator extends IPAddressSegmentSeries, ? extends IPAddressSegment[]> segmentsSpliterator();
@Override
Stream extends IPAddressSegment[]> segmentsStream();
/**
* Similar to the segments iterator, but series with a host of zero are skipped.
*
* @return
*/
Iterator extends IPAddressSegment[]> segmentsNonZeroHostIterator();
@Override
IPAddressSegmentSeries increment(long increment);
@Override
IPAddressSegmentSeries incrementBoundary(long increment);
/**
* Returns the segment series with a host of zero, the host being the bits following the prefix length.
* If the series has no prefix length, then it returns an all-zero series.
*
* The default behaviour is that the resultant series will have the same prefix length.
* The resultant series will not have a prefix length if {@link inet.ipaddr.AddressNetwork#getPrefixConfiguration()} is {@link inet.ipaddr.AddressNetwork.PrefixConfiguration#ALL_PREFIXED_ADDRESSES_ARE_SUBNETS}.
*
* For instance, you can get the network address for a subnet as follows:
*
* String addrStr = "1.2.3.4/16";
* IPAddress address = new IPAddressString(addrStr).getAddress();
* IPAddress networkAddress = address.toZeroHost(); //1.2.0.0
*
*
* @see #toZeroNetwork()
*
* @return
*/
IPAddressSegmentSeries toZeroHost();
/**
* Produces the series with host values of 0 for the given prefix length.
*
* If this series has the same prefix length, then the resulting series will too, otherwise the resulting series will have no prefix length.
*
* This is nearly equivalent to doing the mask (bitwise conjunction) of this address series with the network mask for the given prefix length,
* but without the possibility of IncompatibleAddressException that can occur when applying a mask to a range of values.
* Instead, in this case, if the resulting series has a range of values, then the resulting series range boundaries will have host values of 0, but not necessarily the intervening values.
*
* For instance, you can get the network address for a subnet of prefix length 16 as follows:
*
* String addrStr = "1.2.3.4";
* IPAddress address = new IPAddressString(addrStr).getAddress();
* IPAddress networkAddress = address.toZeroHost(16); //1.2.0.0
*
*
* @param prefixLength
* @return
*/
IPAddressSegmentSeries toZeroHost(int prefixLength);
/**
* Returns the segment series with a network of zero, the network being the bits within the prefix length.
* If the series has no prefix length, then it returns an all-zero series.
*
* The default behaviour is that the resultant series will have the same prefix length.
* The resultant series will not have a prefix length if {@link inet.ipaddr.AddressNetwork#getPrefixConfiguration()} is {@link inet.ipaddr.AddressNetwork.PrefixConfiguration#ALL_PREFIXED_ADDRESSES_ARE_SUBNETS}.
*
* @see #toZeroHost()
*
* @return
*/
IPAddressSegmentSeries toZeroNetwork();
/**
* Returns whether the series has a host of zero. If the series has no prefix length, or the prefix length matches the bit count, then returns false.
*
* Otherwise, it checks whether all bits past the prefix are zero.
*
* @return
*/
boolean includesZeroHost();
/**
* Returns whether all bits past the given prefix length are zero.
*
* @return
*/
boolean includesZeroHost(int prefixLength);
/**
* Produces the series with host values of all one bits for the given prefix length.
*
* If this series has the same prefix length, then the resulting series will too, otherwise the resulting series will have no prefix length.
*
* This is nearly equivalent to doing the bitwise or (bitwise disjunction) of this address series with the network mask for the given prefix length,
* but without the possibility of IncompatibleAddressException that can occur when applying a mask to a range of values.
* Instead, in this case, if the resulting series has a range of values, then the resulting series range boundaries will have host values of all ones, but not necessarily the intervening values.
*
* For instance, you can get the broadcast address for a subnet of prefix length 16 as follows:
*
* String addrStr = "1.2.3.4";
* IPAddress address = new IPAddressString(addrStr).getAddress();
* IPAddress broadcastAddress = address.toMaxHost(16); //1.2.255.255
*
*
* @param prefixLength
* @return
*/
IPAddressSegmentSeries toMaxHost(int prefixLength);
/**
* Returns the segment series with a host of all ones.
* If the series has no prefix length, then it returns an all-ones series.
*
* The resultant series will have the same prefix length if {@link inet.ipaddr.AddressNetwork#getPrefixConfiguration()} is not {@link inet.ipaddr.AddressNetwork.PrefixConfiguration#ALL_PREFIXED_ADDRESSES_ARE_SUBNETS},
* otherwise it will no longer have a prefix length.
*
* For instance, you can get the broadcast address for a subnet as follows:
*
* String addrStr = "1.2.3.4/16";
* IPAddress address = new IPAddressString(addrStr).getAddress();
* IPAddress broadcastAddress = address.toMaxHost(); //1.2.255.255
*
*
* @return
*/
IPAddressSegmentSeries toMaxHost();
/**
* Returns whether the series has a host of all ones. If the series has no prefix length, or the prefix length matches the bit count, then returns false.
*
* Otherwise, it checks whether all bits past the prefix are ones.
*
* @return
*/
boolean includesMaxHost();
/**
* Returns whether all bits past the given prefix length are all ones.
*
* @return
*/
boolean includesMaxHost(int prefixLength);
@Override
IPAddressSegmentSeries reverseSegments();
/**
* Returns a new series which has the bits reversed.
*
* If this has an associated prefix length, then the prefix length is dropped in the reversed series.
*
* If this represents a range of values that cannot be reversed,
* because reversing the range results in a set of addresses that cannot be described by a range, then this throws {@link IncompatibleAddressException}.
* In such cases you can call {@link #iterator()}, {@link #getLower()}, {@link #getUpper()} or some other method to transform the address
* into an address representing a single value before reversing.
*
* @param perByte if true, only the bits in each byte are reversed, if false, then all bits in the address are reversed
* @throws IncompatibleAddressException if this is a subnet that cannot be reversed
* @return
*/
@Override
IPAddressSegmentSeries reverseBits(boolean perByte);
@Override
IPAddressSegmentSeries reverseBytes();
@Override
IPAddressSegmentSeries reverseBytesPerSegment();
@Override @Deprecated
IPAddressSegmentSeries removePrefixLength();
@Override
IPAddressSegmentSeries withoutPrefixLength();
@Override @Deprecated
IPAddressSegmentSeries removePrefixLength(boolean zeroed);
@Override
IPAddressSegmentSeries adjustPrefixBySegment(boolean nextSegment);
@Override
IPAddressSegmentSeries adjustPrefixBySegment(boolean nextSegment, boolean zeroed);
@Override
IPAddressSegmentSeries adjustPrefixLength(int adjustment);
@Override
IPAddressSegmentSeries adjustPrefixLength(int adjustment, boolean zeroed);
@Override
IPAddressSegmentSeries setPrefixLength(int prefixLength);
@Override
IPAddressSegmentSeries setPrefixLength(int prefixLength, boolean zeroed);
@Override @Deprecated
IPAddressSegmentSeries applyPrefixLength(int networkPrefixLength);
}