All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.groupbyinc.flux.next.common.network.NetworkAddress Maven / Gradle / Ivy

The newest version!
/*
 * Licensed to Elasticsearch under one or more contributor
 * license agreements. See the NOTICE file distributed with
 * this work for additional information regarding copyright
 * ownership. Elasticsearch licenses this file to you 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 org.elasticsearch.common.network;

import com.google.common.net.InetAddresses;

import org.elasticsearch.common.SuppressForbidden;

import java.net.Inet6Address;
import java.net.InetAddress;
import java.net.InetSocketAddress;
import java.util.Objects;

/** 
 * Utility functions for presentation of network addresses.
 * 

* Java's address formatting is particularly bad, every address * has an optional host if its resolved, so IPv4 addresses often * look like this (note the confusing leading slash): *

 *    {@code /127.0.0.1}
 * 
* IPv6 addresses are even worse, with no IPv6 address compression, * and often containing things like numeric scopeids, which are even * more confusing (e.g. not going to work in any user's browser, refer * to an interface on another machine, etc): *
 *    {@code /0:0:0:0:0:0:0:1%1}
 * 
* This class provides sane address formatting instead, e.g. * {@code 127.0.0.1} and {@code ::1} respectively. No methods do reverse * lookups. */ public final class NetworkAddress { /** No instantiation */ private NetworkAddress() {} /** * Formats a network address (with optional host) for display purposes. *

* If the host is already resolved (typically because, we looked up * a name to do that), then we include it, otherwise it is * omitted. See {@link #formatAddress(InetAddress)} if you only * want the address. *

* IPv6 addresses are compressed and without scope * identifiers. *

* Example output with already-resolved hostnames: *

    *
  • IPv4: {@code localhost/127.0.0.1}
  • *
  • IPv6: {@code localhost/::1}
  • *
*

* Example output with just an address: *

    *
  • IPv4: {@code 127.0.0.1}
  • *
  • IPv6: {@code ::1}
  • *
* @param address IPv4 or IPv6 address * @return formatted string * @see #formatAddress(InetAddress) */ public static String format(InetAddress address) { return format(address, -1, true); } /** * Formats a network address and port for display purposes. *

* If the host is already resolved (typically because, we looked up * a name to do that), then we include it, otherwise it is * omitted. See {@link #formatAddress(InetSocketAddress)} if you only * want the address. *

* This formats the address with {@link #format(InetAddress)} * and appends the port number. IPv6 addresses will be bracketed. *

* Example output with already-resolved hostnames: *

    *
  • IPv4: {@code localhost/127.0.0.1:9300}
  • *
  • IPv6: {@code localhost/[::1]:9300}
  • *
*

* Example output with just an address: *

    *
  • IPv4: {@code 127.0.0.1:9300}
  • *
  • IPv6: {@code [::1]:9300}
  • *
* @param address IPv4 or IPv6 address with port * @return formatted string * @see #formatAddress(InetSocketAddress) */ public static String format(InetSocketAddress address) { return format(address.getAddress(), address.getPort(), true); } /** * Formats a network address for display purposes. *

* This formats only the address, any hostname information, * if present, is ignored. IPv6 addresses are compressed * and without scope identifiers. *

* Example output with just an address: *

    *
  • IPv4: {@code 127.0.0.1}
  • *
  • IPv6: {@code ::1}
  • *
* @param address IPv4 or IPv6 address * @return formatted string */ public static String formatAddress(InetAddress address) { return format(address, -1, false); } /** * Formats a network address and port for display purposes. *

* This formats the address with {@link #formatAddress(InetAddress)} * and appends the port number. IPv6 addresses will be bracketed. * Any host information, if present is ignored. *

* Example output: *

    *
  • IPv4: {@code 127.0.0.1:9300}
  • *
  • IPv6: {@code [::1]:9300}
  • *
* @param address IPv4 or IPv6 address with port * @return formatted string */ public static String formatAddress(InetSocketAddress address) { return format(address.getAddress(), address.getPort(), false); } // note, we don't validate port, because we only allow InetSocketAddress @SuppressForbidden(reason = "we call toString to avoid a DNS lookup") static String format(InetAddress address, int port, boolean includeHost) { Objects.requireNonNull(address); StringBuilder builder = new StringBuilder(); if (includeHost) { // must use toString, to avoid DNS lookup. but the format is specified in the spec String toString = address.toString(); int separator = toString.indexOf('/'); if (separator > 0) { // append hostname, with the slash too builder.append(toString, 0, separator + 1); } } if (port != -1 && address instanceof Inet6Address) { builder.append(InetAddresses.toUriString(address)); } else { builder.append(InetAddresses.toAddrString(address)); } if (port != -1) { builder.append(':'); builder.append(port); } return builder.toString(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy