com.amazonaws.services.sns.model.SubscribeRequest Maven / Gradle / Ivy
Show all versions of aws-java-sdk-sns Show documentation
/*
* Copyright 2013-2018 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.sns.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.AmazonWebServiceRequest;
/**
*
* Input for Subscribe action.
*
*
* @see AWS API
* Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class SubscribeRequest extends com.amazonaws.AmazonWebServiceRequest implements Serializable, Cloneable {
/**
*
* The ARN of the topic you want to subscribe to.
*
*/
private String topicArn;
/**
*
* The protocol you want to use. Supported protocols include:
*
*
* -
*
* http
– delivery of JSON-encoded message via HTTP POST
*
*
* -
*
* https
– delivery of JSON-encoded message via HTTPS POST
*
*
* -
*
* email
– delivery of message via SMTP
*
*
* -
*
* email-json
– delivery of JSON-encoded message via SMTP
*
*
* -
*
* sms
– delivery of message via SMS
*
*
* -
*
* sqs
– delivery of JSON-encoded message to an Amazon SQS queue
*
*
* -
*
* application
– delivery of JSON-encoded message to an EndpointArn for a mobile app and device.
*
*
* -
*
* lambda
– delivery of JSON-encoded message to an AWS Lambda function.
*
*
*
*/
private String protocol;
/**
*
* The endpoint that you want to receive notifications. Endpoints vary by protocol:
*
*
* -
*
* For the http
protocol, the endpoint is an URL beginning with "http://"
*
*
* -
*
* For the https
protocol, the endpoint is a URL beginning with "https://"
*
*
* -
*
* For the email
protocol, the endpoint is an email address
*
*
* -
*
* For the email-json
protocol, the endpoint is an email address
*
*
* -
*
* For the sms
protocol, the endpoint is a phone number of an SMS-enabled device
*
*
* -
*
* For the sqs
protocol, the endpoint is the ARN of an Amazon SQS queue
*
*
* -
*
* For the application
protocol, the endpoint is the EndpointArn of a mobile app and device.
*
*
* -
*
* For the lambda
protocol, the endpoint is the ARN of an AWS Lambda function.
*
*
*
*/
private String endpoint;
/**
*
* A map of attributes with their corresponding values.
*
*
* The following lists the names, descriptions, and values of the special request parameters that the
* SetTopicAttributes
action uses:
*
*
* -
*
* DeliveryPolicy
– The policy that defines how Amazon SNS retries failed deliveries to HTTP/S
* endpoints.
*
*
* -
*
* FilterPolicy
– The simple JSON object that lets your subscriber receive only a subset of messages,
* rather than receiving every message published to the topic.
*
*
* -
*
* RawMessageDelivery
– When set to true
, enables raw message delivery to Amazon SQS or
* HTTP/S endpoints. This eliminates the need for the endpoints to process JSON formatting, which is otherwise
* created for Amazon SNS metadata.
*
*
*
*/
private com.amazonaws.internal.SdkInternalMap attributes;
/**
*
* Sets whether the response from the Subscribe
request includes the subscription ARN, even if the
* subscription is not yet confirmed.
*
*
* If you set this parameter to false
, the response includes the ARN for confirmed subscriptions, but
* it includes an ARN value of "pending subscription" for subscriptions that are not yet confirmed. A subscription
* becomes confirmed when the subscriber calls the ConfirmSubscription
action with a confirmation
* token.
*
*
* If you set this parameter to true
, the response includes the ARN in all cases, even if the
* subscription is not yet confirmed.
*
*
* The default value is false
.
*
*/
private Boolean returnSubscriptionArn;
/**
* Default constructor for SubscribeRequest object. Callers should use the setter or fluent setter (with...) methods
* to initialize the object after creating it.
*/
public SubscribeRequest() {
}
/**
* Constructs a new SubscribeRequest object. Callers should use the setter or fluent setter (with...) methods to
* initialize any additional object members.
*
* @param topicArn
* The ARN of the topic you want to subscribe to.
* @param protocol
* The protocol you want to use. Supported protocols include:
*
* -
*
* http
– delivery of JSON-encoded message via HTTP POST
*
*
* -
*
* https
– delivery of JSON-encoded message via HTTPS POST
*
*
* -
*
* email
– delivery of message via SMTP
*
*
* -
*
* email-json
– delivery of JSON-encoded message via SMTP
*
*
* -
*
* sms
– delivery of message via SMS
*
*
* -
*
* sqs
– delivery of JSON-encoded message to an Amazon SQS queue
*
*
* -
*
* application
– delivery of JSON-encoded message to an EndpointArn for a mobile app and device.
*
*
* -
*
* lambda
– delivery of JSON-encoded message to an AWS Lambda function.
*
*
* @param endpoint
* The endpoint that you want to receive notifications. Endpoints vary by protocol:
*
* -
*
* For the http
protocol, the endpoint is an URL beginning with "http://"
*
*
* -
*
* For the https
protocol, the endpoint is a URL beginning with "https://"
*
*
* -
*
* For the email
protocol, the endpoint is an email address
*
*
* -
*
* For the email-json
protocol, the endpoint is an email address
*
*
* -
*
* For the sms
protocol, the endpoint is a phone number of an SMS-enabled device
*
*
* -
*
* For the sqs
protocol, the endpoint is the ARN of an Amazon SQS queue
*
*
* -
*
* For the application
protocol, the endpoint is the EndpointArn of a mobile app and device.
*
*
* -
*
* For the lambda
protocol, the endpoint is the ARN of an AWS Lambda function.
*
*
*/
public SubscribeRequest(String topicArn, String protocol, String endpoint) {
setTopicArn(topicArn);
setProtocol(protocol);
setEndpoint(endpoint);
}
/**
*
* The ARN of the topic you want to subscribe to.
*
*
* @param topicArn
* The ARN of the topic you want to subscribe to.
*/
public void setTopicArn(String topicArn) {
this.topicArn = topicArn;
}
/**
*
* The ARN of the topic you want to subscribe to.
*
*
* @return The ARN of the topic you want to subscribe to.
*/
public String getTopicArn() {
return this.topicArn;
}
/**
*
* The ARN of the topic you want to subscribe to.
*
*
* @param topicArn
* The ARN of the topic you want to subscribe to.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public SubscribeRequest withTopicArn(String topicArn) {
setTopicArn(topicArn);
return this;
}
/**
*
* The protocol you want to use. Supported protocols include:
*
*
* -
*
* http
– delivery of JSON-encoded message via HTTP POST
*
*
* -
*
* https
– delivery of JSON-encoded message via HTTPS POST
*
*
* -
*
* email
– delivery of message via SMTP
*
*
* -
*
* email-json
– delivery of JSON-encoded message via SMTP
*
*
* -
*
* sms
– delivery of message via SMS
*
*
* -
*
* sqs
– delivery of JSON-encoded message to an Amazon SQS queue
*
*
* -
*
* application
– delivery of JSON-encoded message to an EndpointArn for a mobile app and device.
*
*
* -
*
* lambda
– delivery of JSON-encoded message to an AWS Lambda function.
*
*
*
*
* @param protocol
* The protocol you want to use. Supported protocols include:
*
* -
*
* http
– delivery of JSON-encoded message via HTTP POST
*
*
* -
*
* https
– delivery of JSON-encoded message via HTTPS POST
*
*
* -
*
* email
– delivery of message via SMTP
*
*
* -
*
* email-json
– delivery of JSON-encoded message via SMTP
*
*
* -
*
* sms
– delivery of message via SMS
*
*
* -
*
* sqs
– delivery of JSON-encoded message to an Amazon SQS queue
*
*
* -
*
* application
– delivery of JSON-encoded message to an EndpointArn for a mobile app and device.
*
*
* -
*
* lambda
– delivery of JSON-encoded message to an AWS Lambda function.
*
*
*/
public void setProtocol(String protocol) {
this.protocol = protocol;
}
/**
*
* The protocol you want to use. Supported protocols include:
*
*
* -
*
* http
– delivery of JSON-encoded message via HTTP POST
*
*
* -
*
* https
– delivery of JSON-encoded message via HTTPS POST
*
*
* -
*
* email
– delivery of message via SMTP
*
*
* -
*
* email-json
– delivery of JSON-encoded message via SMTP
*
*
* -
*
* sms
– delivery of message via SMS
*
*
* -
*
* sqs
– delivery of JSON-encoded message to an Amazon SQS queue
*
*
* -
*
* application
– delivery of JSON-encoded message to an EndpointArn for a mobile app and device.
*
*
* -
*
* lambda
– delivery of JSON-encoded message to an AWS Lambda function.
*
*
*
*
* @return The protocol you want to use. Supported protocols include:
*
* -
*
* http
– delivery of JSON-encoded message via HTTP POST
*
*
* -
*
* https
– delivery of JSON-encoded message via HTTPS POST
*
*
* -
*
* email
– delivery of message via SMTP
*
*
* -
*
* email-json
– delivery of JSON-encoded message via SMTP
*
*
* -
*
* sms
– delivery of message via SMS
*
*
* -
*
* sqs
– delivery of JSON-encoded message to an Amazon SQS queue
*
*
* -
*
* application
– delivery of JSON-encoded message to an EndpointArn for a mobile app and
* device.
*
*
* -
*
* lambda
– delivery of JSON-encoded message to an AWS Lambda function.
*
*
*/
public String getProtocol() {
return this.protocol;
}
/**
*
* The protocol you want to use. Supported protocols include:
*
*
* -
*
* http
– delivery of JSON-encoded message via HTTP POST
*
*
* -
*
* https
– delivery of JSON-encoded message via HTTPS POST
*
*
* -
*
* email
– delivery of message via SMTP
*
*
* -
*
* email-json
– delivery of JSON-encoded message via SMTP
*
*
* -
*
* sms
– delivery of message via SMS
*
*
* -
*
* sqs
– delivery of JSON-encoded message to an Amazon SQS queue
*
*
* -
*
* application
– delivery of JSON-encoded message to an EndpointArn for a mobile app and device.
*
*
* -
*
* lambda
– delivery of JSON-encoded message to an AWS Lambda function.
*
*
*
*
* @param protocol
* The protocol you want to use. Supported protocols include:
*
* -
*
* http
– delivery of JSON-encoded message via HTTP POST
*
*
* -
*
* https
– delivery of JSON-encoded message via HTTPS POST
*
*
* -
*
* email
– delivery of message via SMTP
*
*
* -
*
* email-json
– delivery of JSON-encoded message via SMTP
*
*
* -
*
* sms
– delivery of message via SMS
*
*
* -
*
* sqs
– delivery of JSON-encoded message to an Amazon SQS queue
*
*
* -
*
* application
– delivery of JSON-encoded message to an EndpointArn for a mobile app and device.
*
*
* -
*
* lambda
– delivery of JSON-encoded message to an AWS Lambda function.
*
*
* @return Returns a reference to this object so that method calls can be chained together.
*/
public SubscribeRequest withProtocol(String protocol) {
setProtocol(protocol);
return this;
}
/**
*
* The endpoint that you want to receive notifications. Endpoints vary by protocol:
*
*
* -
*
* For the http
protocol, the endpoint is an URL beginning with "http://"
*
*
* -
*
* For the https
protocol, the endpoint is a URL beginning with "https://"
*
*
* -
*
* For the email
protocol, the endpoint is an email address
*
*
* -
*
* For the email-json
protocol, the endpoint is an email address
*
*
* -
*
* For the sms
protocol, the endpoint is a phone number of an SMS-enabled device
*
*
* -
*
* For the sqs
protocol, the endpoint is the ARN of an Amazon SQS queue
*
*
* -
*
* For the application
protocol, the endpoint is the EndpointArn of a mobile app and device.
*
*
* -
*
* For the lambda
protocol, the endpoint is the ARN of an AWS Lambda function.
*
*
*
*
* @param endpoint
* The endpoint that you want to receive notifications. Endpoints vary by protocol:
*
* -
*
* For the http
protocol, the endpoint is an URL beginning with "http://"
*
*
* -
*
* For the https
protocol, the endpoint is a URL beginning with "https://"
*
*
* -
*
* For the email
protocol, the endpoint is an email address
*
*
* -
*
* For the email-json
protocol, the endpoint is an email address
*
*
* -
*
* For the sms
protocol, the endpoint is a phone number of an SMS-enabled device
*
*
* -
*
* For the sqs
protocol, the endpoint is the ARN of an Amazon SQS queue
*
*
* -
*
* For the application
protocol, the endpoint is the EndpointArn of a mobile app and device.
*
*
* -
*
* For the lambda
protocol, the endpoint is the ARN of an AWS Lambda function.
*
*
*/
public void setEndpoint(String endpoint) {
this.endpoint = endpoint;
}
/**
*
* The endpoint that you want to receive notifications. Endpoints vary by protocol:
*
*
* -
*
* For the http
protocol, the endpoint is an URL beginning with "http://"
*
*
* -
*
* For the https
protocol, the endpoint is a URL beginning with "https://"
*
*
* -
*
* For the email
protocol, the endpoint is an email address
*
*
* -
*
* For the email-json
protocol, the endpoint is an email address
*
*
* -
*
* For the sms
protocol, the endpoint is a phone number of an SMS-enabled device
*
*
* -
*
* For the sqs
protocol, the endpoint is the ARN of an Amazon SQS queue
*
*
* -
*
* For the application
protocol, the endpoint is the EndpointArn of a mobile app and device.
*
*
* -
*
* For the lambda
protocol, the endpoint is the ARN of an AWS Lambda function.
*
*
*
*
* @return The endpoint that you want to receive notifications. Endpoints vary by protocol:
*
* -
*
* For the http
protocol, the endpoint is an URL beginning with "http://"
*
*
* -
*
* For the https
protocol, the endpoint is a URL beginning with "https://"
*
*
* -
*
* For the email
protocol, the endpoint is an email address
*
*
* -
*
* For the email-json
protocol, the endpoint is an email address
*
*
* -
*
* For the sms
protocol, the endpoint is a phone number of an SMS-enabled device
*
*
* -
*
* For the sqs
protocol, the endpoint is the ARN of an Amazon SQS queue
*
*
* -
*
* For the application
protocol, the endpoint is the EndpointArn of a mobile app and device.
*
*
* -
*
* For the lambda
protocol, the endpoint is the ARN of an AWS Lambda function.
*
*
*/
public String getEndpoint() {
return this.endpoint;
}
/**
*
* The endpoint that you want to receive notifications. Endpoints vary by protocol:
*
*
* -
*
* For the http
protocol, the endpoint is an URL beginning with "http://"
*
*
* -
*
* For the https
protocol, the endpoint is a URL beginning with "https://"
*
*
* -
*
* For the email
protocol, the endpoint is an email address
*
*
* -
*
* For the email-json
protocol, the endpoint is an email address
*
*
* -
*
* For the sms
protocol, the endpoint is a phone number of an SMS-enabled device
*
*
* -
*
* For the sqs
protocol, the endpoint is the ARN of an Amazon SQS queue
*
*
* -
*
* For the application
protocol, the endpoint is the EndpointArn of a mobile app and device.
*
*
* -
*
* For the lambda
protocol, the endpoint is the ARN of an AWS Lambda function.
*
*
*
*
* @param endpoint
* The endpoint that you want to receive notifications. Endpoints vary by protocol:
*
* -
*
* For the http
protocol, the endpoint is an URL beginning with "http://"
*
*
* -
*
* For the https
protocol, the endpoint is a URL beginning with "https://"
*
*
* -
*
* For the email
protocol, the endpoint is an email address
*
*
* -
*
* For the email-json
protocol, the endpoint is an email address
*
*
* -
*
* For the sms
protocol, the endpoint is a phone number of an SMS-enabled device
*
*
* -
*
* For the sqs
protocol, the endpoint is the ARN of an Amazon SQS queue
*
*
* -
*
* For the application
protocol, the endpoint is the EndpointArn of a mobile app and device.
*
*
* -
*
* For the lambda
protocol, the endpoint is the ARN of an AWS Lambda function.
*
*
* @return Returns a reference to this object so that method calls can be chained together.
*/
public SubscribeRequest withEndpoint(String endpoint) {
setEndpoint(endpoint);
return this;
}
/**
*
* A map of attributes with their corresponding values.
*
*
* The following lists the names, descriptions, and values of the special request parameters that the
* SetTopicAttributes
action uses:
*
*
* -
*
* DeliveryPolicy
– The policy that defines how Amazon SNS retries failed deliveries to HTTP/S
* endpoints.
*
*
* -
*
* FilterPolicy
– The simple JSON object that lets your subscriber receive only a subset of messages,
* rather than receiving every message published to the topic.
*
*
* -
*
* RawMessageDelivery
– When set to true
, enables raw message delivery to Amazon SQS or
* HTTP/S endpoints. This eliminates the need for the endpoints to process JSON formatting, which is otherwise
* created for Amazon SNS metadata.
*
*
*
*
* @return A map of attributes with their corresponding values.
*
* The following lists the names, descriptions, and values of the special request parameters that the
* SetTopicAttributes
action uses:
*
*
* -
*
* DeliveryPolicy
– The policy that defines how Amazon SNS retries failed deliveries to HTTP/S
* endpoints.
*
*
* -
*
* FilterPolicy
– The simple JSON object that lets your subscriber receive only a subset of
* messages, rather than receiving every message published to the topic.
*
*
* -
*
* RawMessageDelivery
– When set to true
, enables raw message delivery to Amazon
* SQS or HTTP/S endpoints. This eliminates the need for the endpoints to process JSON formatting, which is
* otherwise created for Amazon SNS metadata.
*
*
*/
public java.util.Map getAttributes() {
if (attributes == null) {
attributes = new com.amazonaws.internal.SdkInternalMap();
}
return attributes;
}
/**
*
* A map of attributes with their corresponding values.
*
*
* The following lists the names, descriptions, and values of the special request parameters that the
* SetTopicAttributes
action uses:
*
*
* -
*
* DeliveryPolicy
– The policy that defines how Amazon SNS retries failed deliveries to HTTP/S
* endpoints.
*
*
* -
*
* FilterPolicy
– The simple JSON object that lets your subscriber receive only a subset of messages,
* rather than receiving every message published to the topic.
*
*
* -
*
* RawMessageDelivery
– When set to true
, enables raw message delivery to Amazon SQS or
* HTTP/S endpoints. This eliminates the need for the endpoints to process JSON formatting, which is otherwise
* created for Amazon SNS metadata.
*
*
*
*
* @param attributes
* A map of attributes with their corresponding values.
*
* The following lists the names, descriptions, and values of the special request parameters that the
* SetTopicAttributes
action uses:
*
*
* -
*
* DeliveryPolicy
– The policy that defines how Amazon SNS retries failed deliveries to HTTP/S
* endpoints.
*
*
* -
*
* FilterPolicy
– The simple JSON object that lets your subscriber receive only a subset of
* messages, rather than receiving every message published to the topic.
*
*
* -
*
* RawMessageDelivery
– When set to true
, enables raw message delivery to Amazon
* SQS or HTTP/S endpoints. This eliminates the need for the endpoints to process JSON formatting, which is
* otherwise created for Amazon SNS metadata.
*
*
*/
public void setAttributes(java.util.Map attributes) {
this.attributes = attributes == null ? null : new com.amazonaws.internal.SdkInternalMap(attributes);
}
/**
*
* A map of attributes with their corresponding values.
*
*
* The following lists the names, descriptions, and values of the special request parameters that the
* SetTopicAttributes
action uses:
*
*
* -
*
* DeliveryPolicy
– The policy that defines how Amazon SNS retries failed deliveries to HTTP/S
* endpoints.
*
*
* -
*
* FilterPolicy
– The simple JSON object that lets your subscriber receive only a subset of messages,
* rather than receiving every message published to the topic.
*
*
* -
*
* RawMessageDelivery
– When set to true
, enables raw message delivery to Amazon SQS or
* HTTP/S endpoints. This eliminates the need for the endpoints to process JSON formatting, which is otherwise
* created for Amazon SNS metadata.
*
*
*
*
* @param attributes
* A map of attributes with their corresponding values.
*
* The following lists the names, descriptions, and values of the special request parameters that the
* SetTopicAttributes
action uses:
*
*
* -
*
* DeliveryPolicy
– The policy that defines how Amazon SNS retries failed deliveries to HTTP/S
* endpoints.
*
*
* -
*
* FilterPolicy
– The simple JSON object that lets your subscriber receive only a subset of
* messages, rather than receiving every message published to the topic.
*
*
* -
*
* RawMessageDelivery
– When set to true
, enables raw message delivery to Amazon
* SQS or HTTP/S endpoints. This eliminates the need for the endpoints to process JSON formatting, which is
* otherwise created for Amazon SNS metadata.
*
*
* @return Returns a reference to this object so that method calls can be chained together.
*/
public SubscribeRequest withAttributes(java.util.Map attributes) {
setAttributes(attributes);
return this;
}
public SubscribeRequest addAttributesEntry(String key, String value) {
if (null == this.attributes) {
this.attributes = new com.amazonaws.internal.SdkInternalMap();
}
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 SubscribeRequest clearAttributesEntries() {
this.attributes = null;
return this;
}
/**
*
* Sets whether the response from the Subscribe
request includes the subscription ARN, even if the
* subscription is not yet confirmed.
*
*
* If you set this parameter to false
, the response includes the ARN for confirmed subscriptions, but
* it includes an ARN value of "pending subscription" for subscriptions that are not yet confirmed. A subscription
* becomes confirmed when the subscriber calls the ConfirmSubscription
action with a confirmation
* token.
*
*
* If you set this parameter to true
, the response includes the ARN in all cases, even if the
* subscription is not yet confirmed.
*
*
* The default value is false
.
*
*
* @param returnSubscriptionArn
* Sets whether the response from the Subscribe
request includes the subscription ARN, even if
* the subscription is not yet confirmed.
*
* If you set this parameter to false
, the response includes the ARN for confirmed
* subscriptions, but it includes an ARN value of "pending subscription" for subscriptions that are not yet
* confirmed. A subscription becomes confirmed when the subscriber calls the ConfirmSubscription
* action with a confirmation token.
*
*
* If you set this parameter to true
, the response includes the ARN in all cases, even if the
* subscription is not yet confirmed.
*
*
* The default value is false
.
*/
public void setReturnSubscriptionArn(Boolean returnSubscriptionArn) {
this.returnSubscriptionArn = returnSubscriptionArn;
}
/**
*
* Sets whether the response from the Subscribe
request includes the subscription ARN, even if the
* subscription is not yet confirmed.
*
*
* If you set this parameter to false
, the response includes the ARN for confirmed subscriptions, but
* it includes an ARN value of "pending subscription" for subscriptions that are not yet confirmed. A subscription
* becomes confirmed when the subscriber calls the ConfirmSubscription
action with a confirmation
* token.
*
*
* If you set this parameter to true
, the response includes the ARN in all cases, even if the
* subscription is not yet confirmed.
*
*
* The default value is false
.
*
*
* @return Sets whether the response from the Subscribe
request includes the subscription ARN, even if
* the subscription is not yet confirmed.
*
* If you set this parameter to false
, the response includes the ARN for confirmed
* subscriptions, but it includes an ARN value of "pending subscription" for subscriptions that are not yet
* confirmed. A subscription becomes confirmed when the subscriber calls the
* ConfirmSubscription
action with a confirmation token.
*
*
* If you set this parameter to true
, the response includes the ARN in all cases, even if the
* subscription is not yet confirmed.
*
*
* The default value is false
.
*/
public Boolean getReturnSubscriptionArn() {
return this.returnSubscriptionArn;
}
/**
*
* Sets whether the response from the Subscribe
request includes the subscription ARN, even if the
* subscription is not yet confirmed.
*
*
* If you set this parameter to false
, the response includes the ARN for confirmed subscriptions, but
* it includes an ARN value of "pending subscription" for subscriptions that are not yet confirmed. A subscription
* becomes confirmed when the subscriber calls the ConfirmSubscription
action with a confirmation
* token.
*
*
* If you set this parameter to true
, the response includes the ARN in all cases, even if the
* subscription is not yet confirmed.
*
*
* The default value is false
.
*
*
* @param returnSubscriptionArn
* Sets whether the response from the Subscribe
request includes the subscription ARN, even if
* the subscription is not yet confirmed.
*
* If you set this parameter to false
, the response includes the ARN for confirmed
* subscriptions, but it includes an ARN value of "pending subscription" for subscriptions that are not yet
* confirmed. A subscription becomes confirmed when the subscriber calls the ConfirmSubscription
* action with a confirmation token.
*
*
* If you set this parameter to true
, the response includes the ARN in all cases, even if the
* subscription is not yet confirmed.
*
*
* The default value is false
.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public SubscribeRequest withReturnSubscriptionArn(Boolean returnSubscriptionArn) {
setReturnSubscriptionArn(returnSubscriptionArn);
return this;
}
/**
*
* Sets whether the response from the Subscribe
request includes the subscription ARN, even if the
* subscription is not yet confirmed.
*
*
* If you set this parameter to false
, the response includes the ARN for confirmed subscriptions, but
* it includes an ARN value of "pending subscription" for subscriptions that are not yet confirmed. A subscription
* becomes confirmed when the subscriber calls the ConfirmSubscription
action with a confirmation
* token.
*
*
* If you set this parameter to true
, the response includes the ARN in all cases, even if the
* subscription is not yet confirmed.
*
*
* The default value is false
.
*
*
* @return Sets whether the response from the Subscribe
request includes the subscription ARN, even if
* the subscription is not yet confirmed.
*
* If you set this parameter to false
, the response includes the ARN for confirmed
* subscriptions, but it includes an ARN value of "pending subscription" for subscriptions that are not yet
* confirmed. A subscription becomes confirmed when the subscriber calls the
* ConfirmSubscription
action with a confirmation token.
*
*
* If you set this parameter to true
, the response includes the ARN in all cases, even if the
* subscription is not yet confirmed.
*
*
* The default value is false
.
*/
public Boolean isReturnSubscriptionArn() {
return this.returnSubscriptionArn;
}
/**
* Returns a string representation of this object; useful for testing and debugging.
*
* @return A string representation of this object.
*
* @see java.lang.Object#toString()
*/
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("{");
if (getTopicArn() != null)
sb.append("TopicArn: ").append(getTopicArn()).append(",");
if (getProtocol() != null)
sb.append("Protocol: ").append(getProtocol()).append(",");
if (getEndpoint() != null)
sb.append("Endpoint: ").append(getEndpoint()).append(",");
if (getAttributes() != null)
sb.append("Attributes: ").append(getAttributes()).append(",");
if (getReturnSubscriptionArn() != null)
sb.append("ReturnSubscriptionArn: ").append(getReturnSubscriptionArn());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof SubscribeRequest == false)
return false;
SubscribeRequest other = (SubscribeRequest) obj;
if (other.getTopicArn() == null ^ this.getTopicArn() == null)
return false;
if (other.getTopicArn() != null && other.getTopicArn().equals(this.getTopicArn()) == false)
return false;
if (other.getProtocol() == null ^ this.getProtocol() == null)
return false;
if (other.getProtocol() != null && other.getProtocol().equals(this.getProtocol()) == false)
return false;
if (other.getEndpoint() == null ^ this.getEndpoint() == null)
return false;
if (other.getEndpoint() != null && other.getEndpoint().equals(this.getEndpoint()) == false)
return false;
if (other.getAttributes() == null ^ this.getAttributes() == null)
return false;
if (other.getAttributes() != null && other.getAttributes().equals(this.getAttributes()) == false)
return false;
if (other.getReturnSubscriptionArn() == null ^ this.getReturnSubscriptionArn() == null)
return false;
if (other.getReturnSubscriptionArn() != null && other.getReturnSubscriptionArn().equals(this.getReturnSubscriptionArn()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getTopicArn() == null) ? 0 : getTopicArn().hashCode());
hashCode = prime * hashCode + ((getProtocol() == null) ? 0 : getProtocol().hashCode());
hashCode = prime * hashCode + ((getEndpoint() == null) ? 0 : getEndpoint().hashCode());
hashCode = prime * hashCode + ((getAttributes() == null) ? 0 : getAttributes().hashCode());
hashCode = prime * hashCode + ((getReturnSubscriptionArn() == null) ? 0 : getReturnSubscriptionArn().hashCode());
return hashCode;
}
@Override
public SubscribeRequest clone() {
return (SubscribeRequest) super.clone();
}
}