com.amazonaws.services.xray.model.SamplingRuleUpdate Maven / Gradle / Ivy
/*
* Copyright 2018-2023 Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
* the License. A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file 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 com.amazonaws.services.xray.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;
/**
*
* A document specifying changes to a sampling rule's configuration.
*
*
* @see AWS API
* Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class SamplingRuleUpdate implements Serializable, Cloneable, StructuredPojo {
/**
*
* The name of the sampling rule. Specify a rule by either name or ARN, but not both.
*
*/
private String ruleName;
/**
*
* The ARN of the sampling rule. Specify a rule by either name or ARN, but not both.
*
*/
private String ruleARN;
/**
*
* Matches the ARN of the Amazon Web Services resource on which the service runs.
*
*/
private String resourceARN;
/**
*
* The priority of the sampling rule.
*
*/
private Integer priority;
/**
*
* The percentage of matching requests to instrument, after the reservoir is exhausted.
*
*/
private Double fixedRate;
/**
*
* A fixed number of matching requests to instrument per second, prior to applying the fixed rate. The reservoir is
* not used directly by services, but applies to all services using the rule collectively.
*
*/
private Integer reservoirSize;
/**
*
* Matches the hostname from a request URL.
*
*/
private String host;
/**
*
* Matches the name
that the service uses to identify itself in segments.
*
*/
private String serviceName;
/**
*
* Matches the origin
that the service uses to identify its type in segments.
*
*/
private String serviceType;
/**
*
* Matches the HTTP method of a request.
*
*/
private String hTTPMethod;
/**
*
* Matches the path from a request URL.
*
*/
private String uRLPath;
/**
*
* Matches attributes derived from the request.
*
*/
private java.util.Map attributes;
/**
*
* The name of the sampling rule. Specify a rule by either name or ARN, but not both.
*
*
* @param ruleName
* The name of the sampling rule. Specify a rule by either name or ARN, but not both.
*/
public void setRuleName(String ruleName) {
this.ruleName = ruleName;
}
/**
*
* The name of the sampling rule. Specify a rule by either name or ARN, but not both.
*
*
* @return The name of the sampling rule. Specify a rule by either name or ARN, but not both.
*/
public String getRuleName() {
return this.ruleName;
}
/**
*
* The name of the sampling rule. Specify a rule by either name or ARN, but not both.
*
*
* @param ruleName
* The name of the sampling rule. Specify a rule by either name or ARN, but not both.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public SamplingRuleUpdate withRuleName(String ruleName) {
setRuleName(ruleName);
return this;
}
/**
*
* The ARN of the sampling rule. Specify a rule by either name or ARN, but not both.
*
*
* @param ruleARN
* The ARN of the sampling rule. Specify a rule by either name or ARN, but not both.
*/
public void setRuleARN(String ruleARN) {
this.ruleARN = ruleARN;
}
/**
*
* The ARN of the sampling rule. Specify a rule by either name or ARN, but not both.
*
*
* @return The ARN of the sampling rule. Specify a rule by either name or ARN, but not both.
*/
public String getRuleARN() {
return this.ruleARN;
}
/**
*
* The ARN of the sampling rule. Specify a rule by either name or ARN, but not both.
*
*
* @param ruleARN
* The ARN of the sampling rule. Specify a rule by either name or ARN, but not both.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public SamplingRuleUpdate withRuleARN(String ruleARN) {
setRuleARN(ruleARN);
return this;
}
/**
*
* Matches the ARN of the Amazon Web Services resource on which the service runs.
*
*
* @param resourceARN
* Matches the ARN of the Amazon Web Services resource on which the service runs.
*/
public void setResourceARN(String resourceARN) {
this.resourceARN = resourceARN;
}
/**
*
* Matches the ARN of the Amazon Web Services resource on which the service runs.
*
*
* @return Matches the ARN of the Amazon Web Services resource on which the service runs.
*/
public String getResourceARN() {
return this.resourceARN;
}
/**
*
* Matches the ARN of the Amazon Web Services resource on which the service runs.
*
*
* @param resourceARN
* Matches the ARN of the Amazon Web Services resource on which the service runs.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public SamplingRuleUpdate withResourceARN(String resourceARN) {
setResourceARN(resourceARN);
return this;
}
/**
*
* The priority of the sampling rule.
*
*
* @param priority
* The priority of the sampling rule.
*/
public void setPriority(Integer priority) {
this.priority = priority;
}
/**
*
* The priority of the sampling rule.
*
*
* @return The priority of the sampling rule.
*/
public Integer getPriority() {
return this.priority;
}
/**
*
* The priority of the sampling rule.
*
*
* @param priority
* The priority of the sampling rule.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public SamplingRuleUpdate withPriority(Integer priority) {
setPriority(priority);
return this;
}
/**
*
* The percentage of matching requests to instrument, after the reservoir is exhausted.
*
*
* @param fixedRate
* The percentage of matching requests to instrument, after the reservoir is exhausted.
*/
public void setFixedRate(Double fixedRate) {
this.fixedRate = fixedRate;
}
/**
*
* The percentage of matching requests to instrument, after the reservoir is exhausted.
*
*
* @return The percentage of matching requests to instrument, after the reservoir is exhausted.
*/
public Double getFixedRate() {
return this.fixedRate;
}
/**
*
* The percentage of matching requests to instrument, after the reservoir is exhausted.
*
*
* @param fixedRate
* The percentage of matching requests to instrument, after the reservoir is exhausted.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public SamplingRuleUpdate withFixedRate(Double fixedRate) {
setFixedRate(fixedRate);
return this;
}
/**
*
* A fixed number of matching requests to instrument per second, prior to applying the fixed rate. The reservoir is
* not used directly by services, but applies to all services using the rule collectively.
*
*
* @param reservoirSize
* A fixed number of matching requests to instrument per second, prior to applying the fixed rate. The
* reservoir is not used directly by services, but applies to all services using the rule collectively.
*/
public void setReservoirSize(Integer reservoirSize) {
this.reservoirSize = reservoirSize;
}
/**
*
* A fixed number of matching requests to instrument per second, prior to applying the fixed rate. The reservoir is
* not used directly by services, but applies to all services using the rule collectively.
*
*
* @return A fixed number of matching requests to instrument per second, prior to applying the fixed rate. The
* reservoir is not used directly by services, but applies to all services using the rule collectively.
*/
public Integer getReservoirSize() {
return this.reservoirSize;
}
/**
*
* A fixed number of matching requests to instrument per second, prior to applying the fixed rate. The reservoir is
* not used directly by services, but applies to all services using the rule collectively.
*
*
* @param reservoirSize
* A fixed number of matching requests to instrument per second, prior to applying the fixed rate. The
* reservoir is not used directly by services, but applies to all services using the rule collectively.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public SamplingRuleUpdate withReservoirSize(Integer reservoirSize) {
setReservoirSize(reservoirSize);
return this;
}
/**
*
* Matches the hostname from a request URL.
*
*
* @param host
* Matches the hostname from a request URL.
*/
public void setHost(String host) {
this.host = host;
}
/**
*
* Matches the hostname from a request URL.
*
*
* @return Matches the hostname from a request URL.
*/
public String getHost() {
return this.host;
}
/**
*
* Matches the hostname from a request URL.
*
*
* @param host
* Matches the hostname from a request URL.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public SamplingRuleUpdate withHost(String host) {
setHost(host);
return this;
}
/**
*
* Matches the name
that the service uses to identify itself in segments.
*
*
* @param serviceName
* Matches the name
that the service uses to identify itself in segments.
*/
public void setServiceName(String serviceName) {
this.serviceName = serviceName;
}
/**
*
* Matches the name
that the service uses to identify itself in segments.
*
*
* @return Matches the name
that the service uses to identify itself in segments.
*/
public String getServiceName() {
return this.serviceName;
}
/**
*
* Matches the name
that the service uses to identify itself in segments.
*
*
* @param serviceName
* Matches the name
that the service uses to identify itself in segments.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public SamplingRuleUpdate withServiceName(String serviceName) {
setServiceName(serviceName);
return this;
}
/**
*
* Matches the origin
that the service uses to identify its type in segments.
*
*
* @param serviceType
* Matches the origin
that the service uses to identify its type in segments.
*/
public void setServiceType(String serviceType) {
this.serviceType = serviceType;
}
/**
*
* Matches the origin
that the service uses to identify its type in segments.
*
*
* @return Matches the origin
that the service uses to identify its type in segments.
*/
public String getServiceType() {
return this.serviceType;
}
/**
*
* Matches the origin
that the service uses to identify its type in segments.
*
*
* @param serviceType
* Matches the origin
that the service uses to identify its type in segments.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public SamplingRuleUpdate withServiceType(String serviceType) {
setServiceType(serviceType);
return this;
}
/**
*
* Matches the HTTP method of a request.
*
*
* @param hTTPMethod
* Matches the HTTP method of a request.
*/
public void setHTTPMethod(String hTTPMethod) {
this.hTTPMethod = hTTPMethod;
}
/**
*
* Matches the HTTP method of a request.
*
*
* @return Matches the HTTP method of a request.
*/
public String getHTTPMethod() {
return this.hTTPMethod;
}
/**
*
* Matches the HTTP method of a request.
*
*
* @param hTTPMethod
* Matches the HTTP method of a request.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public SamplingRuleUpdate withHTTPMethod(String hTTPMethod) {
setHTTPMethod(hTTPMethod);
return this;
}
/**
*
* Matches the path from a request URL.
*
*
* @param uRLPath
* Matches the path from a request URL.
*/
public void setURLPath(String uRLPath) {
this.uRLPath = uRLPath;
}
/**
*
* Matches the path from a request URL.
*
*
* @return Matches the path from a request URL.
*/
public String getURLPath() {
return this.uRLPath;
}
/**
*
* Matches the path from a request URL.
*
*
* @param uRLPath
* Matches the path from a request URL.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public SamplingRuleUpdate withURLPath(String uRLPath) {
setURLPath(uRLPath);
return this;
}
/**
*
* Matches attributes derived from the request.
*
*
* @return Matches attributes derived from the request.
*/
public java.util.Map getAttributes() {
return attributes;
}
/**
*
* Matches attributes derived from the request.
*
*
* @param attributes
* Matches attributes derived from the request.
*/
public void setAttributes(java.util.Map attributes) {
this.attributes = attributes;
}
/**
*
* Matches attributes derived from the request.
*
*
* @param attributes
* Matches attributes derived from the request.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public SamplingRuleUpdate withAttributes(java.util.Map attributes) {
setAttributes(attributes);
return this;
}
/**
* Add a single Attributes entry
*
* @see SamplingRuleUpdate#withAttributes
* @returns a reference to this object so that method calls can be chained together.
*/
public SamplingRuleUpdate addAttributesEntry(String key, String value) {
if (null == this.attributes) {
this.attributes = new java.util.HashMap();
}
if (this.attributes.containsKey(key))
throw new IllegalArgumentException("Duplicated keys (" + key.toString() + ") are provided.");
this.attributes.put(key, value);
return this;
}
/**
* Removes all the entries added into Attributes.
*
* @return Returns a reference to this object so that method calls can be chained together.
*/
public SamplingRuleUpdate clearAttributesEntries() {
this.attributes = null;
return this;
}
/**
* Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be
* redacted from this string using a placeholder value.
*
* @return A string representation of this object.
*
* @see java.lang.Object#toString()
*/
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("{");
if (getRuleName() != null)
sb.append("RuleName: ").append(getRuleName()).append(",");
if (getRuleARN() != null)
sb.append("RuleARN: ").append(getRuleARN()).append(",");
if (getResourceARN() != null)
sb.append("ResourceARN: ").append(getResourceARN()).append(",");
if (getPriority() != null)
sb.append("Priority: ").append(getPriority()).append(",");
if (getFixedRate() != null)
sb.append("FixedRate: ").append(getFixedRate()).append(",");
if (getReservoirSize() != null)
sb.append("ReservoirSize: ").append(getReservoirSize()).append(",");
if (getHost() != null)
sb.append("Host: ").append(getHost()).append(",");
if (getServiceName() != null)
sb.append("ServiceName: ").append(getServiceName()).append(",");
if (getServiceType() != null)
sb.append("ServiceType: ").append(getServiceType()).append(",");
if (getHTTPMethod() != null)
sb.append("HTTPMethod: ").append(getHTTPMethod()).append(",");
if (getURLPath() != null)
sb.append("URLPath: ").append(getURLPath()).append(",");
if (getAttributes() != null)
sb.append("Attributes: ").append(getAttributes());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof SamplingRuleUpdate == false)
return false;
SamplingRuleUpdate other = (SamplingRuleUpdate) obj;
if (other.getRuleName() == null ^ this.getRuleName() == null)
return false;
if (other.getRuleName() != null && other.getRuleName().equals(this.getRuleName()) == false)
return false;
if (other.getRuleARN() == null ^ this.getRuleARN() == null)
return false;
if (other.getRuleARN() != null && other.getRuleARN().equals(this.getRuleARN()) == false)
return false;
if (other.getResourceARN() == null ^ this.getResourceARN() == null)
return false;
if (other.getResourceARN() != null && other.getResourceARN().equals(this.getResourceARN()) == false)
return false;
if (other.getPriority() == null ^ this.getPriority() == null)
return false;
if (other.getPriority() != null && other.getPriority().equals(this.getPriority()) == false)
return false;
if (other.getFixedRate() == null ^ this.getFixedRate() == null)
return false;
if (other.getFixedRate() != null && other.getFixedRate().equals(this.getFixedRate()) == false)
return false;
if (other.getReservoirSize() == null ^ this.getReservoirSize() == null)
return false;
if (other.getReservoirSize() != null && other.getReservoirSize().equals(this.getReservoirSize()) == false)
return false;
if (other.getHost() == null ^ this.getHost() == null)
return false;
if (other.getHost() != null && other.getHost().equals(this.getHost()) == false)
return false;
if (other.getServiceName() == null ^ this.getServiceName() == null)
return false;
if (other.getServiceName() != null && other.getServiceName().equals(this.getServiceName()) == false)
return false;
if (other.getServiceType() == null ^ this.getServiceType() == null)
return false;
if (other.getServiceType() != null && other.getServiceType().equals(this.getServiceType()) == false)
return false;
if (other.getHTTPMethod() == null ^ this.getHTTPMethod() == null)
return false;
if (other.getHTTPMethod() != null && other.getHTTPMethod().equals(this.getHTTPMethod()) == false)
return false;
if (other.getURLPath() == null ^ this.getURLPath() == null)
return false;
if (other.getURLPath() != null && other.getURLPath().equals(this.getURLPath()) == false)
return false;
if (other.getAttributes() == null ^ this.getAttributes() == null)
return false;
if (other.getAttributes() != null && other.getAttributes().equals(this.getAttributes()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getRuleName() == null) ? 0 : getRuleName().hashCode());
hashCode = prime * hashCode + ((getRuleARN() == null) ? 0 : getRuleARN().hashCode());
hashCode = prime * hashCode + ((getResourceARN() == null) ? 0 : getResourceARN().hashCode());
hashCode = prime * hashCode + ((getPriority() == null) ? 0 : getPriority().hashCode());
hashCode = prime * hashCode + ((getFixedRate() == null) ? 0 : getFixedRate().hashCode());
hashCode = prime * hashCode + ((getReservoirSize() == null) ? 0 : getReservoirSize().hashCode());
hashCode = prime * hashCode + ((getHost() == null) ? 0 : getHost().hashCode());
hashCode = prime * hashCode + ((getServiceName() == null) ? 0 : getServiceName().hashCode());
hashCode = prime * hashCode + ((getServiceType() == null) ? 0 : getServiceType().hashCode());
hashCode = prime * hashCode + ((getHTTPMethod() == null) ? 0 : getHTTPMethod().hashCode());
hashCode = prime * hashCode + ((getURLPath() == null) ? 0 : getURLPath().hashCode());
hashCode = prime * hashCode + ((getAttributes() == null) ? 0 : getAttributes().hashCode());
return hashCode;
}
@Override
public SamplingRuleUpdate clone() {
try {
return (SamplingRuleUpdate) super.clone();
} catch (CloneNotSupportedException e) {
throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e);
}
}
@com.amazonaws.annotation.SdkInternalApi
@Override
public void marshall(ProtocolMarshaller protocolMarshaller) {
com.amazonaws.services.xray.model.transform.SamplingRuleUpdateMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}