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

io.vertx.core.net.SocketAddress Maven / Gradle / Ivy

/*
 * Copyright (c) 2011-2019 Contributors to the Eclipse Foundation
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License 2.0 which is available at
 * http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0
 * which is available at https://www.apache.org/licenses/LICENSE-2.0.
 *
 * SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
 */

package io.vertx.core.net;

import io.vertx.codegen.annotations.CacheReturn;
import io.vertx.codegen.annotations.DataObject;
import io.vertx.codegen.annotations.GenIgnore;
import io.vertx.core.impl.Arguments;
import io.vertx.core.json.JsonObject;
import io.vertx.core.net.impl.SocketAddressImpl;

import java.net.InetSocketAddress;

/**
 * The address of a socket, an inet socket address or a domain socket address.
 * 

* Use {@link #inetSocketAddress(int, String)} to create an inet socket address and {@link #domainSocketAddress(String)} * to create a domain socket address * * @author Tim Fox */ @DataObject public interface SocketAddress extends Address { static SocketAddress fromJson(JsonObject json) { Integer port = json.getInteger("port"); String host = json.getString("host"); if (host != null && port != null) { if (port >= 0) { return inetSocketAddress(port, host); } else { return sharedRandomPort(-port, host); } } String path = json.getString("path"); if (path != null) { return domainSocketAddress(path); } return null; } /** * Create an inet socket address that binds to a shared random port identified by {@code id}. *
* The {@code host} string can be a host name or a host address. *
* No name resolution will be attempted. * * @param id the shared random port id * @param host the host * @return the created socket address */ static SocketAddress sharedRandomPort(int id, String host) { if (id < 1) { throw new IllegalArgumentException("Shared random port ID " + id + " must be > 0"); } return new SocketAddressImpl(-id, host); } /** * Create an inet socket address, {@code host} must be non {@code null} and {@code port} must be between {@code 0} * and {@code 65536}. *
* The {@code host} string can be a host name or a host address. *
* No name resolution will be attempted. * * @param port the port * @param host the host * @return the created socket address */ static SocketAddress inetSocketAddress(int port, String host) { Arguments.requireInRange(port, 0, 65535, "port p must be in range 0 <= p <= 65535"); return new SocketAddressImpl(port, host); } /** * Create a domain socket address from a {@code path}. * * @param path the address path * @return the created socket address */ static SocketAddress domainSocketAddress(String path) { return new SocketAddressImpl(path); } /** * Create a inet socket address from a Java {@link InetSocketAddress}. *
* No name resolution will be attempted. * * @param address the address * @return the created socket address */ @GenIgnore(GenIgnore.PERMITTED_TYPE) static SocketAddress inetSocketAddress(InetSocketAddress address) { return new SocketAddressImpl(address); } /** * Returns the host name when available or the IP address in string representation. *
* Domain socket address returns {@code null}. * * @return the host address */ @CacheReturn String host(); /** * Returns the host name when available or {@code null} *
* Domain socket address returns {@code null}. * * @return the host name */ @CacheReturn String hostName(); /** * Returns the host IP address when available or {@code null} as a String. *
* Domain socket address returns {@code null}. * * @return the host address */ @CacheReturn String hostAddress(); /** * @return the address port or {@code -1} for a domain socket */ @CacheReturn int port(); /** * @return the domain socket path or {@code null} for inet socket address, empty path represents unnamed domain socket addresses. */ @CacheReturn String path(); /** * @return {@code true} for an inet socket address */ @CacheReturn boolean isInetSocket(); /** * @return {@code true} for an domain socket address */ @CacheReturn boolean isDomainSocket(); default JsonObject toJson() { if (isInetSocket()) { return new JsonObject().put("host", host()).put("port", port()); } else if (isDomainSocket()) { return new JsonObject().put("path", path()); } else { throw new IllegalStateException(); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy