/* * 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.ssoadmin.model; import java.io.Serializable; import javax.annotation.Generated; import com.amazonaws.AmazonWebServiceRequest; /** * * @see AWS API Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class AttachCustomerManagedPolicyReferenceToPermissionSetRequest extends com.amazonaws.AmazonWebServiceRequest implements Serializable, Cloneable { /** *
* The ARN of the IAM Identity Center instance under which the operation will be executed. *
*/ private String instanceArn; /** *
* The ARN of the PermissionSet
.
*
* Specifies the name and path of a customer managed policy. You must have an IAM policy that matches the name and * path in each AWS account where you want to deploy your permission set. *
*/ private CustomerManagedPolicyReference customerManagedPolicyReference; /** ** The ARN of the IAM Identity Center instance under which the operation will be executed. *
* * @param instanceArn * The ARN of the IAM Identity Center instance under which the operation will be executed. */ public void setInstanceArn(String instanceArn) { this.instanceArn = instanceArn; } /** ** The ARN of the IAM Identity Center instance under which the operation will be executed. *
* * @return The ARN of the IAM Identity Center instance under which the operation will be executed. */ public String getInstanceArn() { return this.instanceArn; } /** ** The ARN of the IAM Identity Center instance under which the operation will be executed. *
* * @param instanceArn * The ARN of the IAM Identity Center instance under which the operation will be executed. * @return Returns a reference to this object so that method calls can be chained together. */ public AttachCustomerManagedPolicyReferenceToPermissionSetRequest withInstanceArn(String instanceArn) { setInstanceArn(instanceArn); return this; } /** *
* The ARN of the PermissionSet
.
*
PermissionSet
.
*/
public void setPermissionSetArn(String permissionSetArn) {
this.permissionSetArn = permissionSetArn;
}
/**
*
* The ARN of the PermissionSet
.
*
PermissionSet
.
*/
public String getPermissionSetArn() {
return this.permissionSetArn;
}
/**
*
* The ARN of the PermissionSet
.
*
PermissionSet
.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AttachCustomerManagedPolicyReferenceToPermissionSetRequest withPermissionSetArn(String permissionSetArn) {
setPermissionSetArn(permissionSetArn);
return this;
}
/**
* * Specifies the name and path of a customer managed policy. You must have an IAM policy that matches the name and * path in each AWS account where you want to deploy your permission set. *
* * @param customerManagedPolicyReference * Specifies the name and path of a customer managed policy. You must have an IAM policy that matches the * name and path in each AWS account where you want to deploy your permission set. */ public void setCustomerManagedPolicyReference(CustomerManagedPolicyReference customerManagedPolicyReference) { this.customerManagedPolicyReference = customerManagedPolicyReference; } /** ** Specifies the name and path of a customer managed policy. You must have an IAM policy that matches the name and * path in each AWS account where you want to deploy your permission set. *
* * @return Specifies the name and path of a customer managed policy. You must have an IAM policy that matches the * name and path in each AWS account where you want to deploy your permission set. */ public CustomerManagedPolicyReference getCustomerManagedPolicyReference() { return this.customerManagedPolicyReference; } /** ** Specifies the name and path of a customer managed policy. You must have an IAM policy that matches the name and * path in each AWS account where you want to deploy your permission set. *
* * @param customerManagedPolicyReference * Specifies the name and path of a customer managed policy. You must have an IAM policy that matches the * name and path in each AWS account where you want to deploy your permission set. * @return Returns a reference to this object so that method calls can be chained together. */ public AttachCustomerManagedPolicyReferenceToPermissionSetRequest withCustomerManagedPolicyReference( CustomerManagedPolicyReference customerManagedPolicyReference) { setCustomerManagedPolicyReference(customerManagedPolicyReference); 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 (getInstanceArn() != null) sb.append("InstanceArn: ").append(getInstanceArn()).append(","); if (getPermissionSetArn() != null) sb.append("PermissionSetArn: ").append(getPermissionSetArn()).append(","); if (getCustomerManagedPolicyReference() != null) sb.append("CustomerManagedPolicyReference: ").append(getCustomerManagedPolicyReference()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof AttachCustomerManagedPolicyReferenceToPermissionSetRequest == false) return false; AttachCustomerManagedPolicyReferenceToPermissionSetRequest other = (AttachCustomerManagedPolicyReferenceToPermissionSetRequest) obj; if (other.getInstanceArn() == null ^ this.getInstanceArn() == null) return false; if (other.getInstanceArn() != null && other.getInstanceArn().equals(this.getInstanceArn()) == false) return false; if (other.getPermissionSetArn() == null ^ this.getPermissionSetArn() == null) return false; if (other.getPermissionSetArn() != null && other.getPermissionSetArn().equals(this.getPermissionSetArn()) == false) return false; if (other.getCustomerManagedPolicyReference() == null ^ this.getCustomerManagedPolicyReference() == null) return false; if (other.getCustomerManagedPolicyReference() != null && other.getCustomerManagedPolicyReference().equals(this.getCustomerManagedPolicyReference()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getInstanceArn() == null) ? 0 : getInstanceArn().hashCode()); hashCode = prime * hashCode + ((getPermissionSetArn() == null) ? 0 : getPermissionSetArn().hashCode()); hashCode = prime * hashCode + ((getCustomerManagedPolicyReference() == null) ? 0 : getCustomerManagedPolicyReference().hashCode()); return hashCode; } @Override public AttachCustomerManagedPolicyReferenceToPermissionSetRequest clone() { return (AttachCustomerManagedPolicyReferenceToPermissionSetRequest) super.clone(); } }