com.twitter.zipkin.gen.Endpoint Maven / Gradle / Ivy
package com.twitter.zipkin.gen;
import com.github.kristofa.brave.internal.Nullable;
import java.io.Serializable;
import java.util.Arrays;
import static com.github.kristofa.brave.internal.Util.checkNotNull;
import static zipkin.internal.Util.checkArgument;
import static com.github.kristofa.brave.internal.Util.equal;
/**
* Indicates the network context of a service recording an annotation with two
* exceptions.
*
* When a BinaryAnnotation, and key is CLIENT_ADDR or SERVER_ADDR,
* the endpoint indicates the source or destination of an RPC. This exception
* allows zipkin to display network context of uninstrumented services, or
* clients such as web browsers.
*/
public class Endpoint implements Serializable {
/**
* @deprecated as leads to null pointer exceptions on port. Use {@link #builder()} instead.
*/
@Deprecated
public static Endpoint create(String serviceName, int ipv4, int port) {
return new Endpoint(serviceName, ipv4, null, port == 0 ? null : (short) (port & 0xffff));
}
public static Endpoint create(String serviceName, int ipv4) {
return new Endpoint(serviceName, ipv4, null, null);
}
static final long serialVersionUID = 1L;
/**
* IPv4 host address packed into 4 bytes or zero if unknown.
*
* Ex for the IP 1.2.3.4, it would be {@code (1 << 24) | (2 << 16) | (3 << 8) | 4}
*
* @see java.net.Inet4Address#getAddress()
*/
public final int ipv4;
/**
* IPv6 host address packed into 16 bytes or null if unknown.
*
* @see java.net.Inet6Address#getAddress()
* @since 3.12
*/
@Nullable
public final byte[] ipv6;
/**
* Port of the IP's socket or null, if not known.
*
*
Note: this is to be treated as an unsigned integer, so watch for negatives.
*
* @see java.net.InetSocketAddress#getPort()
*/
@Nullable
public final Short port;
/**
* Service name in lowercase, such as "memcache" or "zipkin-web"
*
* Conventionally, when the service name isn't known, service_name = "unknown".
*/
public final String service_name; // required
Endpoint(String service_name, int ipv4, byte[] ipv6, Short port) {
this.ipv4 = ipv4;
this.ipv6 = ipv6;
this.port = port;
if (service_name != null) {
service_name = service_name.toLowerCase();
} else {
service_name = "";
}
this.service_name = service_name;
}
public Endpoint.Builder toBuilder() {
return new Endpoint.Builder(this);
}
public static Endpoint.Builder builder() {
return new Endpoint.Builder();
}
public static final class Builder {
private String serviceName;
private Integer ipv4;
private byte[] ipv6;
private Short port;
Builder() {
}
Builder(Endpoint source) {
this.serviceName = source.service_name;
this.ipv4 = source.ipv4;
this.ipv6 = source.ipv6;
this.port = source.port;
}
/** @see Endpoint#service_name */
public Endpoint.Builder serviceName(String serviceName) {
this.serviceName = serviceName;
return this;
}
/** @see Endpoint#ipv4 */
public Endpoint.Builder ipv4(int ipv4) {
this.ipv4 = ipv4;
return this;
}
/** @see Endpoint#ipv6 */
public Endpoint.Builder ipv6(byte[] ipv6) {
if (ipv6 != null) {
checkArgument(ipv6.length == 16, "ipv6 addresses are 16 bytes: " + ipv6.length);
this.ipv6 = ipv6;
}
return this;
}
/**
* Use this to set the port to an externally defined value.
*
*
Don't pass {@link Endpoint#port} to this method, as it may result in a
* NullPointerException. Instead, use {@link Endpoint#toBuilder()} or {@link
* #port(Short)}.
*
* @param port port associated with the endpoint. zero coerces to null (unknown)
* @see Endpoint#port
*/
public Endpoint.Builder port(int port) {
checkArgument(port >= 0 && port <= 0xffff, "invalid port %s", port);
this.port = port == 0 ? null : (short) (port & 0xffff);
return this;
}
/** @see Endpoint#port */
public Endpoint.Builder port(Short port) {
if (port == null || port != 0) {
this.port = port;
}
return this;
}
public Endpoint build() {
checkNotNull(serviceName, "serviceName");
return new Endpoint(serviceName, ipv4 == null ? 0 : ipv4, ipv6, port);
}
}
@Override
public boolean equals(Object o) {
if (o == this) {
return true;
}
if (o instanceof Endpoint) {
Endpoint that = (Endpoint) o;
return equal(this.service_name, that.service_name)
&& (this.ipv4 == that.ipv4)
&& (Arrays.equals(this.ipv6, that.ipv6))
&& equal(this.port, that.port);
}
return false;
}
@Override
public int hashCode() {
int h = 1;
h *= 1000003;
h ^= service_name.hashCode();
h *= 1000003;
h ^= ipv4;
h *= 1000003;
h ^= Arrays.hashCode(ipv6);
h *= 1000003;
h ^= (port == null) ? 0 : port.hashCode();
return h;
}
}