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

com.amazonaws.services.sns.model.AddPermissionRequest Maven / Gradle / Ivy

/*
 * Copyright 2010-2011 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 com.amazonaws.AmazonWebServiceRequest;

/**
 * Container for the parameters to the {@link com.amazonaws.services.sns.AmazonSNS#addPermission(AddPermissionRequest) AddPermission operation}.
 * 

* The AddPermission action adds a statement to a topic's access control * policy, granting access for the specified AWS accounts to the * specified actions. *

* * @see com.amazonaws.services.sns.AmazonSNS#addPermission(AddPermissionRequest) */ public class AddPermissionRequest extends AmazonWebServiceRequest { /** * The ARN of the topic whose access control policy you wish to modify. */ private String topicArn; /** * A unique identifier for the new policy statement. */ private String label; /** * The AWS account IDs of the users (principals) who will be given access * to the specified actions. The users must have AWS accounts, but do not * need to be signed up for this service. */ private java.util.List aWSAccountIds; /** * The action you want to allow for the specified principal(s). */ private java.util.List actionNames; /** * Default constructor for a new AddPermissionRequest object. Callers should use the * setter or fluent setter (with...) methods to initialize this object after creating it. */ public AddPermissionRequest() {} /** * Constructs a new AddPermissionRequest object. * Callers should use the setter or fluent setter (with...) methods to * initialize any additional object members. * * @param topicArn The ARN of the topic whose access control policy you * wish to modify. * @param label A unique identifier for the new policy statement. * @param aWSAccountIds The AWS account IDs of the users (principals) who * will be given access to the specified actions. The users must have AWS * accounts, but do not need to be signed up for this service. * @param actionNames The action you want to allow for the specified * principal(s). */ public AddPermissionRequest(String topicArn, String label, java.util.List aWSAccountIds, java.util.List actionNames) { this.topicArn = topicArn; this.label = label; this.aWSAccountIds = aWSAccountIds; this.actionNames = actionNames; } /** * The ARN of the topic whose access control policy you wish to modify. * * @return The ARN of the topic whose access control policy you wish to modify. */ public String getTopicArn() { return topicArn; } /** * The ARN of the topic whose access control policy you wish to modify. * * @param topicArn The ARN of the topic whose access control policy you wish to modify. */ public void setTopicArn(String topicArn) { this.topicArn = topicArn; } /** * The ARN of the topic whose access control policy you wish to modify. *

* Returns a reference to this object so that method calls can be chained together. * * @param topicArn The ARN of the topic whose access control policy you wish to modify. * * @return A reference to this updated object so that method calls can be chained * together. */ public AddPermissionRequest withTopicArn(String topicArn) { this.topicArn = topicArn; return this; } /** * A unique identifier for the new policy statement. * * @return A unique identifier for the new policy statement. */ public String getLabel() { return label; } /** * A unique identifier for the new policy statement. * * @param label A unique identifier for the new policy statement. */ public void setLabel(String label) { this.label = label; } /** * A unique identifier for the new policy statement. *

* Returns a reference to this object so that method calls can be chained together. * * @param label A unique identifier for the new policy statement. * * @return A reference to this updated object so that method calls can be chained * together. */ public AddPermissionRequest withLabel(String label) { this.label = label; return this; } /** * The AWS account IDs of the users (principals) who will be given access * to the specified actions. The users must have AWS accounts, but do not * need to be signed up for this service. * * @return The AWS account IDs of the users (principals) who will be given access * to the specified actions. The users must have AWS accounts, but do not * need to be signed up for this service. */ public java.util.List getAWSAccountIds() { if (aWSAccountIds == null) { aWSAccountIds = new java.util.ArrayList(); } return aWSAccountIds; } /** * The AWS account IDs of the users (principals) who will be given access * to the specified actions. The users must have AWS accounts, but do not * need to be signed up for this service. * * @param aWSAccountIds The AWS account IDs of the users (principals) who will be given access * to the specified actions. The users must have AWS accounts, but do not * need to be signed up for this service. */ public void setAWSAccountIds(java.util.Collection aWSAccountIds) { java.util.List aWSAccountIdsCopy = new java.util.ArrayList(); if (aWSAccountIds != null) { aWSAccountIdsCopy.addAll(aWSAccountIds); } this.aWSAccountIds = aWSAccountIdsCopy; } /** * The AWS account IDs of the users (principals) who will be given access * to the specified actions. The users must have AWS accounts, but do not * need to be signed up for this service. *

* Returns a reference to this object so that method calls can be chained together. * * @param aWSAccountIds The AWS account IDs of the users (principals) who will be given access * to the specified actions. The users must have AWS accounts, but do not * need to be signed up for this service. * * @return A reference to this updated object so that method calls can be chained * together. */ public AddPermissionRequest withAWSAccountIds(String... aWSAccountIds) { for (String value : aWSAccountIds) { getAWSAccountIds().add(value); } return this; } /** * The AWS account IDs of the users (principals) who will be given access * to the specified actions. The users must have AWS accounts, but do not * need to be signed up for this service. *

* Returns a reference to this object so that method calls can be chained together. * * @param aWSAccountIds The AWS account IDs of the users (principals) who will be given access * to the specified actions. The users must have AWS accounts, but do not * need to be signed up for this service. * * @return A reference to this updated object so that method calls can be chained * together. */ public AddPermissionRequest withAWSAccountIds(java.util.Collection aWSAccountIds) { java.util.List aWSAccountIdsCopy = new java.util.ArrayList(); if (aWSAccountIds != null) { aWSAccountIdsCopy.addAll(aWSAccountIds); } this.aWSAccountIds = aWSAccountIdsCopy; return this; } /** * The action you want to allow for the specified principal(s). * * @return The action you want to allow for the specified principal(s). */ public java.util.List getActionNames() { if (actionNames == null) { actionNames = new java.util.ArrayList(); } return actionNames; } /** * The action you want to allow for the specified principal(s). * * @param actionNames The action you want to allow for the specified principal(s). */ public void setActionNames(java.util.Collection actionNames) { java.util.List actionNamesCopy = new java.util.ArrayList(); if (actionNames != null) { actionNamesCopy.addAll(actionNames); } this.actionNames = actionNamesCopy; } /** * The action you want to allow for the specified principal(s). *

* Returns a reference to this object so that method calls can be chained together. * * @param actionNames The action you want to allow for the specified principal(s). * * @return A reference to this updated object so that method calls can be chained * together. */ public AddPermissionRequest withActionNames(String... actionNames) { for (String value : actionNames) { getActionNames().add(value); } return this; } /** * The action you want to allow for the specified principal(s). *

* Returns a reference to this object so that method calls can be chained together. * * @param actionNames The action you want to allow for the specified principal(s). * * @return A reference to this updated object so that method calls can be chained * together. */ public AddPermissionRequest withActionNames(java.util.Collection actionNames) { java.util.List actionNamesCopy = new java.util.ArrayList(); if (actionNames != null) { actionNamesCopy.addAll(actionNames); } this.actionNames = actionNamesCopy; return this; } /** * 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("{"); sb.append("TopicArn: " + topicArn + ", "); sb.append("Label: " + label + ", "); sb.append("AWSAccountIds: " + aWSAccountIds + ", "); sb.append("ActionNames: " + actionNames + ", "); sb.append("}"); return sb.toString(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy