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

com.amazonaws.services.xray.model.SamplingRule Maven / Gradle / Ivy

Go to download

The AWS Java SDK for AWS X-Ray module holds the client classes that are used for communicating with AWS X-Ray Service

There is a newer version: 1.12.780
Show newest version
/*
 * 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 sampling rule that services use to decide whether to instrument a request. Rule fields can match properties of the * service, or properties of a request. The service can ignore rules that don't match its properties. *

* * @see AWS API * Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class SamplingRule 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 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 hostname from a request URL. *

*/ private String host; /** *

* Matches the HTTP method of a request. *

*/ private String hTTPMethod; /** *

* Matches the path from a request URL. *

*/ private String uRLPath; /** *

* The version of the sampling rule format (1). *

*/ private Integer version; /** *

* 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 SamplingRule 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 SamplingRule 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 SamplingRule 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 SamplingRule 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 SamplingRule 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 SamplingRule withReservoirSize(Integer reservoirSize) { setReservoirSize(reservoirSize); 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 SamplingRule 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 SamplingRule withServiceType(String serviceType) { setServiceType(serviceType); 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 SamplingRule withHost(String host) { setHost(host); 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 SamplingRule 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 SamplingRule withURLPath(String uRLPath) { setURLPath(uRLPath); return this; } /** *

* The version of the sampling rule format (1). *

* * @param version * The version of the sampling rule format (1). */ public void setVersion(Integer version) { this.version = version; } /** *

* The version of the sampling rule format (1). *

* * @return The version of the sampling rule format (1). */ public Integer getVersion() { return this.version; } /** *

* The version of the sampling rule format (1). *

* * @param version * The version of the sampling rule format (1). * @return Returns a reference to this object so that method calls can be chained together. */ public SamplingRule withVersion(Integer version) { setVersion(version); 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 SamplingRule withAttributes(java.util.Map attributes) { setAttributes(attributes); return this; } /** * Add a single Attributes entry * * @see SamplingRule#withAttributes * @returns a reference to this object so that method calls can be chained together. */ public SamplingRule 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 SamplingRule 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 (getServiceName() != null) sb.append("ServiceName: ").append(getServiceName()).append(","); if (getServiceType() != null) sb.append("ServiceType: ").append(getServiceType()).append(","); if (getHost() != null) sb.append("Host: ").append(getHost()).append(","); if (getHTTPMethod() != null) sb.append("HTTPMethod: ").append(getHTTPMethod()).append(","); if (getURLPath() != null) sb.append("URLPath: ").append(getURLPath()).append(","); if (getVersion() != null) sb.append("Version: ").append(getVersion()).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 SamplingRule == false) return false; SamplingRule other = (SamplingRule) 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.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.getHost() == null ^ this.getHost() == null) return false; if (other.getHost() != null && other.getHost().equals(this.getHost()) == 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.getVersion() == null ^ this.getVersion() == null) return false; if (other.getVersion() != null && other.getVersion().equals(this.getVersion()) == 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 + ((getServiceName() == null) ? 0 : getServiceName().hashCode()); hashCode = prime * hashCode + ((getServiceType() == null) ? 0 : getServiceType().hashCode()); hashCode = prime * hashCode + ((getHost() == null) ? 0 : getHost().hashCode()); hashCode = prime * hashCode + ((getHTTPMethod() == null) ? 0 : getHTTPMethod().hashCode()); hashCode = prime * hashCode + ((getURLPath() == null) ? 0 : getURLPath().hashCode()); hashCode = prime * hashCode + ((getVersion() == null) ? 0 : getVersion().hashCode()); hashCode = prime * hashCode + ((getAttributes() == null) ? 0 : getAttributes().hashCode()); return hashCode; } @Override public SamplingRule clone() { try { return (SamplingRule) 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.SamplingRuleMarshaller.getInstance().marshall(this, protocolMarshaller); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy