com.oracle.bmc.apmtraces.model.Span Maven / Gradle / Ivy
/**
* Copyright (c) 2016, 2023, Oracle and/or its affiliates. All rights reserved.
* This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license.
*/
package com.oracle.bmc.apmtraces.model;
/**
* Definition of a span object.
*
*
* Note: Objects should always be created or deserialized using the {@link Builder}. This model distinguishes fields
* that are {@code null} because they are unset from fields that are explicitly set to {@code null}. This is done in
* the setter methods of the {@link Builder}, which maintain a set of all explicitly set fields called
* {@link #__explicitlySet__}. The {@link #hashCode()} and {@link #equals(Object)} methods are implemented to take
* {@link #__explicitlySet__} into account. The constructor, on the other hand, does not set {@link #__explicitlySet__}
* (since the constructor cannot distinguish explicit {@code null} from unset {@code null}).
**/
@javax.annotation.Generated(value = "OracleSDKGenerator", comments = "API Version: 20200630")
@com.fasterxml.jackson.databind.annotation.JsonDeserialize(builder = Span.Builder.class)
@com.fasterxml.jackson.annotation.JsonFilter(com.oracle.bmc.http.internal.ExplicitlySetFilter.NAME)
public final class Span extends com.oracle.bmc.http.internal.ExplicitlySetBmcModel {
@Deprecated
@java.beans.ConstructorProperties({
"key",
"parentSpanKey",
"traceKey",
"timeStarted",
"timeEnded",
"durationInMs",
"operationName",
"serviceName",
"kind",
"tags",
"logs",
"isError"
})
public Span(
String key,
String parentSpanKey,
String traceKey,
java.util.Date timeStarted,
java.util.Date timeEnded,
Long durationInMs,
String operationName,
String serviceName,
String kind,
java.util.List tags,
java.util.List logs,
Boolean isError) {
super();
this.key = key;
this.parentSpanKey = parentSpanKey;
this.traceKey = traceKey;
this.timeStarted = timeStarted;
this.timeEnded = timeEnded;
this.durationInMs = durationInMs;
this.operationName = operationName;
this.serviceName = serviceName;
this.kind = kind;
this.tags = tags;
this.logs = logs;
this.isError = isError;
}
@com.fasterxml.jackson.databind.annotation.JsonPOJOBuilder(withPrefix = "")
public static class Builder {
/**
* Unique identifier (spanId) for the span. Note that this field is
* defined as spanKey in the API and it maps to the spanId in the trace data
* in Application Performance Monitoring.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("key")
private String key;
/**
* Unique identifier (spanId) for the span. Note that this field is
* defined as spanKey in the API and it maps to the spanId in the trace data
* in Application Performance Monitoring.
*
* @param key the value to set
* @return this builder
**/
public Builder key(String key) {
this.key = key;
this.__explicitlySet__.add("key");
return this;
}
/**
* Unique parent identifier for the span if one exists. For root spans this will be null.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("parentSpanKey")
private String parentSpanKey;
/**
* Unique parent identifier for the span if one exists. For root spans this will be null.
*
* @param parentSpanKey the value to set
* @return this builder
**/
public Builder parentSpanKey(String parentSpanKey) {
this.parentSpanKey = parentSpanKey;
this.__explicitlySet__.add("parentSpanKey");
return this;
}
/**
* Unique identifier for the trace.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("traceKey")
private String traceKey;
/**
* Unique identifier for the trace.
*
* @param traceKey the value to set
* @return this builder
**/
public Builder traceKey(String traceKey) {
this.traceKey = traceKey;
this.__explicitlySet__.add("traceKey");
return this;
}
/**
* Span start time. Timestamp when the span was started.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("timeStarted")
private java.util.Date timeStarted;
/**
* Span start time. Timestamp when the span was started.
*
* @param timeStarted the value to set
* @return this builder
**/
public Builder timeStarted(java.util.Date timeStarted) {
this.timeStarted = timeStarted;
this.__explicitlySet__.add("timeStarted");
return this;
}
/**
* Span end time. Timestamp when the span was completed.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("timeEnded")
private java.util.Date timeEnded;
/**
* Span end time. Timestamp when the span was completed.
*
* @param timeEnded the value to set
* @return this builder
**/
public Builder timeEnded(java.util.Date timeEnded) {
this.timeEnded = timeEnded;
this.__explicitlySet__.add("timeEnded");
return this;
}
/**
* Total span duration in milliseconds.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("durationInMs")
private Long durationInMs;
/**
* Total span duration in milliseconds.
*
* @param durationInMs the value to set
* @return this builder
**/
public Builder durationInMs(Long durationInMs) {
this.durationInMs = durationInMs;
this.__explicitlySet__.add("durationInMs");
return this;
}
/**
* Span name associated with the trace. This is usually the method or URI of the request.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("operationName")
private String operationName;
/**
* Span name associated with the trace. This is usually the method or URI of the request.
*
* @param operationName the value to set
* @return this builder
**/
public Builder operationName(String operationName) {
this.operationName = operationName;
this.__explicitlySet__.add("operationName");
return this;
}
/**
* Service name associated with the span.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("serviceName")
private String serviceName;
/**
* Service name associated with the span.
*
* @param serviceName the value to set
* @return this builder
**/
public Builder serviceName(String serviceName) {
this.serviceName = serviceName;
this.__explicitlySet__.add("serviceName");
return this;
}
/**
* Kind associated with the span.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("kind")
private String kind;
/**
* Kind associated with the span.
*
* @param kind the value to set
* @return this builder
**/
public Builder kind(String kind) {
this.kind = kind;
this.__explicitlySet__.add("kind");
return this;
}
/**
* List of tags associated with the span.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("tags")
private java.util.List tags;
/**
* List of tags associated with the span.
*
* @param tags the value to set
* @return this builder
**/
public Builder tags(java.util.List tags) {
this.tags = tags;
this.__explicitlySet__.add("tags");
return this;
}
/**
* List of logs associated with the span.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("logs")
private java.util.List logs;
/**
* List of logs associated with the span.
*
* @param logs the value to set
* @return this builder
**/
public Builder logs(java.util.List logs) {
this.logs = logs;
this.__explicitlySet__.add("logs");
return this;
}
/**
* Indicates if the span has an error.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("isError")
private Boolean isError;
/**
* Indicates if the span has an error.
*
* @param isError the value to set
* @return this builder
**/
public Builder isError(Boolean isError) {
this.isError = isError;
this.__explicitlySet__.add("isError");
return this;
}
@com.fasterxml.jackson.annotation.JsonIgnore
private final java.util.Set __explicitlySet__ = new java.util.HashSet();
public Span build() {
Span model =
new Span(
this.key,
this.parentSpanKey,
this.traceKey,
this.timeStarted,
this.timeEnded,
this.durationInMs,
this.operationName,
this.serviceName,
this.kind,
this.tags,
this.logs,
this.isError);
for (String explicitlySetProperty : this.__explicitlySet__) {
model.markPropertyAsExplicitlySet(explicitlySetProperty);
}
return model;
}
@com.fasterxml.jackson.annotation.JsonIgnore
public Builder copy(Span model) {
if (model.wasPropertyExplicitlySet("key")) {
this.key(model.getKey());
}
if (model.wasPropertyExplicitlySet("parentSpanKey")) {
this.parentSpanKey(model.getParentSpanKey());
}
if (model.wasPropertyExplicitlySet("traceKey")) {
this.traceKey(model.getTraceKey());
}
if (model.wasPropertyExplicitlySet("timeStarted")) {
this.timeStarted(model.getTimeStarted());
}
if (model.wasPropertyExplicitlySet("timeEnded")) {
this.timeEnded(model.getTimeEnded());
}
if (model.wasPropertyExplicitlySet("durationInMs")) {
this.durationInMs(model.getDurationInMs());
}
if (model.wasPropertyExplicitlySet("operationName")) {
this.operationName(model.getOperationName());
}
if (model.wasPropertyExplicitlySet("serviceName")) {
this.serviceName(model.getServiceName());
}
if (model.wasPropertyExplicitlySet("kind")) {
this.kind(model.getKind());
}
if (model.wasPropertyExplicitlySet("tags")) {
this.tags(model.getTags());
}
if (model.wasPropertyExplicitlySet("logs")) {
this.logs(model.getLogs());
}
if (model.wasPropertyExplicitlySet("isError")) {
this.isError(model.getIsError());
}
return this;
}
}
/**
* Create a new builder.
*/
public static Builder builder() {
return new Builder();
}
public Builder toBuilder() {
return new Builder().copy(this);
}
/**
* Unique identifier (spanId) for the span. Note that this field is
* defined as spanKey in the API and it maps to the spanId in the trace data
* in Application Performance Monitoring.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("key")
private final String key;
/**
* Unique identifier (spanId) for the span. Note that this field is
* defined as spanKey in the API and it maps to the spanId in the trace data
* in Application Performance Monitoring.
*
* @return the value
**/
public String getKey() {
return key;
}
/**
* Unique parent identifier for the span if one exists. For root spans this will be null.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("parentSpanKey")
private final String parentSpanKey;
/**
* Unique parent identifier for the span if one exists. For root spans this will be null.
*
* @return the value
**/
public String getParentSpanKey() {
return parentSpanKey;
}
/**
* Unique identifier for the trace.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("traceKey")
private final String traceKey;
/**
* Unique identifier for the trace.
*
* @return the value
**/
public String getTraceKey() {
return traceKey;
}
/**
* Span start time. Timestamp when the span was started.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("timeStarted")
private final java.util.Date timeStarted;
/**
* Span start time. Timestamp when the span was started.
*
* @return the value
**/
public java.util.Date getTimeStarted() {
return timeStarted;
}
/**
* Span end time. Timestamp when the span was completed.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("timeEnded")
private final java.util.Date timeEnded;
/**
* Span end time. Timestamp when the span was completed.
*
* @return the value
**/
public java.util.Date getTimeEnded() {
return timeEnded;
}
/**
* Total span duration in milliseconds.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("durationInMs")
private final Long durationInMs;
/**
* Total span duration in milliseconds.
*
* @return the value
**/
public Long getDurationInMs() {
return durationInMs;
}
/**
* Span name associated with the trace. This is usually the method or URI of the request.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("operationName")
private final String operationName;
/**
* Span name associated with the trace. This is usually the method or URI of the request.
*
* @return the value
**/
public String getOperationName() {
return operationName;
}
/**
* Service name associated with the span.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("serviceName")
private final String serviceName;
/**
* Service name associated with the span.
*
* @return the value
**/
public String getServiceName() {
return serviceName;
}
/**
* Kind associated with the span.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("kind")
private final String kind;
/**
* Kind associated with the span.
*
* @return the value
**/
public String getKind() {
return kind;
}
/**
* List of tags associated with the span.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("tags")
private final java.util.List tags;
/**
* List of tags associated with the span.
*
* @return the value
**/
public java.util.List getTags() {
return tags;
}
/**
* List of logs associated with the span.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("logs")
private final java.util.List logs;
/**
* List of logs associated with the span.
*
* @return the value
**/
public java.util.List getLogs() {
return logs;
}
/**
* Indicates if the span has an error.
*
**/
@com.fasterxml.jackson.annotation.JsonProperty("isError")
private final Boolean isError;
/**
* Indicates if the span has an error.
*
* @return the value
**/
public Boolean getIsError() {
return isError;
}
@Override
public String toString() {
return this.toString(true);
}
/**
* Return a string representation of the object.
* @param includeByteArrayContents true to include the full contents of byte arrays
* @return string representation
*/
public String toString(boolean includeByteArrayContents) {
java.lang.StringBuilder sb = new java.lang.StringBuilder();
sb.append("Span(");
sb.append("super=").append(super.toString());
sb.append("key=").append(String.valueOf(this.key));
sb.append(", parentSpanKey=").append(String.valueOf(this.parentSpanKey));
sb.append(", traceKey=").append(String.valueOf(this.traceKey));
sb.append(", timeStarted=").append(String.valueOf(this.timeStarted));
sb.append(", timeEnded=").append(String.valueOf(this.timeEnded));
sb.append(", durationInMs=").append(String.valueOf(this.durationInMs));
sb.append(", operationName=").append(String.valueOf(this.operationName));
sb.append(", serviceName=").append(String.valueOf(this.serviceName));
sb.append(", kind=").append(String.valueOf(this.kind));
sb.append(", tags=").append(String.valueOf(this.tags));
sb.append(", logs=").append(String.valueOf(this.logs));
sb.append(", isError=").append(String.valueOf(this.isError));
sb.append(")");
return sb.toString();
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (!(o instanceof Span)) {
return false;
}
Span other = (Span) o;
return java.util.Objects.equals(this.key, other.key)
&& java.util.Objects.equals(this.parentSpanKey, other.parentSpanKey)
&& java.util.Objects.equals(this.traceKey, other.traceKey)
&& java.util.Objects.equals(this.timeStarted, other.timeStarted)
&& java.util.Objects.equals(this.timeEnded, other.timeEnded)
&& java.util.Objects.equals(this.durationInMs, other.durationInMs)
&& java.util.Objects.equals(this.operationName, other.operationName)
&& java.util.Objects.equals(this.serviceName, other.serviceName)
&& java.util.Objects.equals(this.kind, other.kind)
&& java.util.Objects.equals(this.tags, other.tags)
&& java.util.Objects.equals(this.logs, other.logs)
&& java.util.Objects.equals(this.isError, other.isError)
&& super.equals(other);
}
@Override
public int hashCode() {
final int PRIME = 59;
int result = 1;
result = (result * PRIME) + (this.key == null ? 43 : this.key.hashCode());
result =
(result * PRIME)
+ (this.parentSpanKey == null ? 43 : this.parentSpanKey.hashCode());
result = (result * PRIME) + (this.traceKey == null ? 43 : this.traceKey.hashCode());
result = (result * PRIME) + (this.timeStarted == null ? 43 : this.timeStarted.hashCode());
result = (result * PRIME) + (this.timeEnded == null ? 43 : this.timeEnded.hashCode());
result = (result * PRIME) + (this.durationInMs == null ? 43 : this.durationInMs.hashCode());
result =
(result * PRIME)
+ (this.operationName == null ? 43 : this.operationName.hashCode());
result = (result * PRIME) + (this.serviceName == null ? 43 : this.serviceName.hashCode());
result = (result * PRIME) + (this.kind == null ? 43 : this.kind.hashCode());
result = (result * PRIME) + (this.tags == null ? 43 : this.tags.hashCode());
result = (result * PRIME) + (this.logs == null ? 43 : this.logs.hashCode());
result = (result * PRIME) + (this.isError == null ? 43 : this.isError.hashCode());
result = (result * PRIME) + super.hashCode();
return result;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy