com.amazonaws.services.ram.model.ResourceSharePermissionSummary Maven / Gradle / Ivy
Show all versions of aws-java-sdk-ram Show documentation
/*
* Copyright 2019-2024 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.ram.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;
/**
*
* Information about an RAM permission.
*
*
* @see AWS
* API Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class ResourceSharePermissionSummary implements Serializable, Cloneable, StructuredPojo {
/**
*
* The Amazon Resource Name
* (ARN) of the permission you want information about.
*
*/
private String arn;
/**
*
* The version of the permission associated with this resource share.
*
*/
private String version;
/**
*
* Specifies whether the version of the managed permission used by this resource share is the default version for
* this managed permission.
*
*/
private Boolean defaultVersion;
/**
*
* The name of this managed permission.
*
*/
private String name;
/**
*
* The type of resource to which this permission applies. This takes the form of: service-code
:
* resource-code
, and is case-insensitive. For example, an Amazon EC2 Subnet would be represented by
* the string ec2:subnet
.
*
*/
private String resourceType;
/**
*
* The current status of the permission.
*
*/
private String status;
/**
*
* The date and time when the permission was created.
*
*/
private java.util.Date creationTime;
/**
*
* The date and time when the permission was last updated.
*
*/
private java.util.Date lastUpdatedTime;
/**
*
* Specifies whether the managed permission associated with this resource share is the default managed permission
* for all resources of this resource type.
*
*/
private Boolean isResourceTypeDefault;
/**
*
* The type of managed permission. This can be one of the following values:
*
*
* -
*
* AWS_MANAGED
– Amazon Web Services created and manages this managed permission. You can associate it
* with your resource shares, but you can't modify it.
*
*
* -
*
* CUSTOMER_MANAGED
– You, or another principal in your account created this managed permission. You
* can associate it with your resource shares and create new versions that have different permissions.
*
*
*
*/
private String permissionType;
/**
*
* Indicates what features are available for this resource share. This parameter can have one of the following
* values:
*
*
* -
*
* STANDARD – A resource share that supports all functionality. These resource shares are visible to all
* principals you share the resource share with. You can modify these resource shares in RAM using the console or
* APIs. This resource share might have been created by RAM, or it might have been CREATED_FROM_POLICY and
* then promoted.
*
*
* -
*
* CREATED_FROM_POLICY – The customer manually shared a resource by attaching a resource-based policy. That
* policy did not match any existing managed permissions, so RAM created this customer managed permission
* automatically on the customer's behalf based on the attached policy document. This type of resource share is
* visible only to the Amazon Web Services account that created it. You can't modify it in RAM unless you promote
* it. For more information, see PromoteResourceShareCreatedFromPolicy.
*
*
* -
*
* PROMOTING_TO_STANDARD – This resource share was originally CREATED_FROM_POLICY
, but the
* customer ran the PromoteResourceShareCreatedFromPolicy and that operation is still in progress. This value
* changes to STANDARD
when complete.
*
*
*
*/
private String featureSet;
/**
*
* A list of the tag key value pairs currently attached to the permission.
*
*/
private java.util.List tags;
/**
*
* The Amazon Resource Name
* (ARN) of the permission you want information about.
*
*
* @param arn
* The Amazon Resource
* Name (ARN) of the permission you want information about.
*/
public void setArn(String arn) {
this.arn = arn;
}
/**
*
* The Amazon Resource Name
* (ARN) of the permission you want information about.
*
*
* @return The Amazon Resource
* Name (ARN) of the permission you want information about.
*/
public String getArn() {
return this.arn;
}
/**
*
* The Amazon Resource Name
* (ARN) of the permission you want information about.
*
*
* @param arn
* The Amazon Resource
* Name (ARN) of the permission you want information about.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ResourceSharePermissionSummary withArn(String arn) {
setArn(arn);
return this;
}
/**
*
* The version of the permission associated with this resource share.
*
*
* @param version
* The version of the permission associated with this resource share.
*/
public void setVersion(String version) {
this.version = version;
}
/**
*
* The version of the permission associated with this resource share.
*
*
* @return The version of the permission associated with this resource share.
*/
public String getVersion() {
return this.version;
}
/**
*
* The version of the permission associated with this resource share.
*
*
* @param version
* The version of the permission associated with this resource share.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ResourceSharePermissionSummary withVersion(String version) {
setVersion(version);
return this;
}
/**
*
* Specifies whether the version of the managed permission used by this resource share is the default version for
* this managed permission.
*
*
* @param defaultVersion
* Specifies whether the version of the managed permission used by this resource share is the default version
* for this managed permission.
*/
public void setDefaultVersion(Boolean defaultVersion) {
this.defaultVersion = defaultVersion;
}
/**
*
* Specifies whether the version of the managed permission used by this resource share is the default version for
* this managed permission.
*
*
* @return Specifies whether the version of the managed permission used by this resource share is the default
* version for this managed permission.
*/
public Boolean getDefaultVersion() {
return this.defaultVersion;
}
/**
*
* Specifies whether the version of the managed permission used by this resource share is the default version for
* this managed permission.
*
*
* @param defaultVersion
* Specifies whether the version of the managed permission used by this resource share is the default version
* for this managed permission.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ResourceSharePermissionSummary withDefaultVersion(Boolean defaultVersion) {
setDefaultVersion(defaultVersion);
return this;
}
/**
*
* Specifies whether the version of the managed permission used by this resource share is the default version for
* this managed permission.
*
*
* @return Specifies whether the version of the managed permission used by this resource share is the default
* version for this managed permission.
*/
public Boolean isDefaultVersion() {
return this.defaultVersion;
}
/**
*
* The name of this managed permission.
*
*
* @param name
* The name of this managed permission.
*/
public void setName(String name) {
this.name = name;
}
/**
*
* The name of this managed permission.
*
*
* @return The name of this managed permission.
*/
public String getName() {
return this.name;
}
/**
*
* The name of this managed permission.
*
*
* @param name
* The name of this managed permission.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ResourceSharePermissionSummary withName(String name) {
setName(name);
return this;
}
/**
*
* The type of resource to which this permission applies. This takes the form of: service-code
:
* resource-code
, and is case-insensitive. For example, an Amazon EC2 Subnet would be represented by
* the string ec2:subnet
.
*
*
* @param resourceType
* The type of resource to which this permission applies. This takes the form of: service-code
:
* resource-code
, and is case-insensitive. For example, an Amazon EC2 Subnet would be
* represented by the string ec2:subnet
.
*/
public void setResourceType(String resourceType) {
this.resourceType = resourceType;
}
/**
*
* The type of resource to which this permission applies. This takes the form of: service-code
:
* resource-code
, and is case-insensitive. For example, an Amazon EC2 Subnet would be represented by
* the string ec2:subnet
.
*
*
* @return The type of resource to which this permission applies. This takes the form of: service-code
:
* resource-code
, and is case-insensitive. For example, an Amazon EC2 Subnet would be
* represented by the string ec2:subnet
.
*/
public String getResourceType() {
return this.resourceType;
}
/**
*
* The type of resource to which this permission applies. This takes the form of: service-code
:
* resource-code
, and is case-insensitive. For example, an Amazon EC2 Subnet would be represented by
* the string ec2:subnet
.
*
*
* @param resourceType
* The type of resource to which this permission applies. This takes the form of: service-code
:
* resource-code
, and is case-insensitive. For example, an Amazon EC2 Subnet would be
* represented by the string ec2:subnet
.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ResourceSharePermissionSummary withResourceType(String resourceType) {
setResourceType(resourceType);
return this;
}
/**
*
* The current status of the permission.
*
*
* @param status
* The current status of the permission.
*/
public void setStatus(String status) {
this.status = status;
}
/**
*
* The current status of the permission.
*
*
* @return The current status of the permission.
*/
public String getStatus() {
return this.status;
}
/**
*
* The current status of the permission.
*
*
* @param status
* The current status of the permission.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ResourceSharePermissionSummary withStatus(String status) {
setStatus(status);
return this;
}
/**
*
* The date and time when the permission was created.
*
*
* @param creationTime
* The date and time when the permission was created.
*/
public void setCreationTime(java.util.Date creationTime) {
this.creationTime = creationTime;
}
/**
*
* The date and time when the permission was created.
*
*
* @return The date and time when the permission was created.
*/
public java.util.Date getCreationTime() {
return this.creationTime;
}
/**
*
* The date and time when the permission was created.
*
*
* @param creationTime
* The date and time when the permission was created.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ResourceSharePermissionSummary withCreationTime(java.util.Date creationTime) {
setCreationTime(creationTime);
return this;
}
/**
*
* The date and time when the permission was last updated.
*
*
* @param lastUpdatedTime
* The date and time when the permission was last updated.
*/
public void setLastUpdatedTime(java.util.Date lastUpdatedTime) {
this.lastUpdatedTime = lastUpdatedTime;
}
/**
*
* The date and time when the permission was last updated.
*
*
* @return The date and time when the permission was last updated.
*/
public java.util.Date getLastUpdatedTime() {
return this.lastUpdatedTime;
}
/**
*
* The date and time when the permission was last updated.
*
*
* @param lastUpdatedTime
* The date and time when the permission was last updated.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ResourceSharePermissionSummary withLastUpdatedTime(java.util.Date lastUpdatedTime) {
setLastUpdatedTime(lastUpdatedTime);
return this;
}
/**
*
* Specifies whether the managed permission associated with this resource share is the default managed permission
* for all resources of this resource type.
*
*
* @param isResourceTypeDefault
* Specifies whether the managed permission associated with this resource share is the default managed
* permission for all resources of this resource type.
*/
public void setIsResourceTypeDefault(Boolean isResourceTypeDefault) {
this.isResourceTypeDefault = isResourceTypeDefault;
}
/**
*
* Specifies whether the managed permission associated with this resource share is the default managed permission
* for all resources of this resource type.
*
*
* @return Specifies whether the managed permission associated with this resource share is the default managed
* permission for all resources of this resource type.
*/
public Boolean getIsResourceTypeDefault() {
return this.isResourceTypeDefault;
}
/**
*
* Specifies whether the managed permission associated with this resource share is the default managed permission
* for all resources of this resource type.
*
*
* @param isResourceTypeDefault
* Specifies whether the managed permission associated with this resource share is the default managed
* permission for all resources of this resource type.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ResourceSharePermissionSummary withIsResourceTypeDefault(Boolean isResourceTypeDefault) {
setIsResourceTypeDefault(isResourceTypeDefault);
return this;
}
/**
*
* Specifies whether the managed permission associated with this resource share is the default managed permission
* for all resources of this resource type.
*
*
* @return Specifies whether the managed permission associated with this resource share is the default managed
* permission for all resources of this resource type.
*/
public Boolean isResourceTypeDefault() {
return this.isResourceTypeDefault;
}
/**
*
* The type of managed permission. This can be one of the following values:
*
*
* -
*
* AWS_MANAGED
– Amazon Web Services created and manages this managed permission. You can associate it
* with your resource shares, but you can't modify it.
*
*
* -
*
* CUSTOMER_MANAGED
– You, or another principal in your account created this managed permission. You
* can associate it with your resource shares and create new versions that have different permissions.
*
*
*
*
* @param permissionType
* The type of managed permission. This can be one of the following values:
*
* -
*
* AWS_MANAGED
– Amazon Web Services created and manages this managed permission. You can
* associate it with your resource shares, but you can't modify it.
*
*
* -
*
* CUSTOMER_MANAGED
– You, or another principal in your account created this managed permission.
* You can associate it with your resource shares and create new versions that have different permissions.
*
*
* @see PermissionType
*/
public void setPermissionType(String permissionType) {
this.permissionType = permissionType;
}
/**
*
* The type of managed permission. This can be one of the following values:
*
*
* -
*
* AWS_MANAGED
– Amazon Web Services created and manages this managed permission. You can associate it
* with your resource shares, but you can't modify it.
*
*
* -
*
* CUSTOMER_MANAGED
– You, or another principal in your account created this managed permission. You
* can associate it with your resource shares and create new versions that have different permissions.
*
*
*
*
* @return The type of managed permission. This can be one of the following values:
*
* -
*
* AWS_MANAGED
– Amazon Web Services created and manages this managed permission. You can
* associate it with your resource shares, but you can't modify it.
*
*
* -
*
* CUSTOMER_MANAGED
– You, or another principal in your account created this managed
* permission. You can associate it with your resource shares and create new versions that have different
* permissions.
*
*
* @see PermissionType
*/
public String getPermissionType() {
return this.permissionType;
}
/**
*
* The type of managed permission. This can be one of the following values:
*
*
* -
*
* AWS_MANAGED
– Amazon Web Services created and manages this managed permission. You can associate it
* with your resource shares, but you can't modify it.
*
*
* -
*
* CUSTOMER_MANAGED
– You, or another principal in your account created this managed permission. You
* can associate it with your resource shares and create new versions that have different permissions.
*
*
*
*
* @param permissionType
* The type of managed permission. This can be one of the following values:
*
* -
*
* AWS_MANAGED
– Amazon Web Services created and manages this managed permission. You can
* associate it with your resource shares, but you can't modify it.
*
*
* -
*
* CUSTOMER_MANAGED
– You, or another principal in your account created this managed permission.
* You can associate it with your resource shares and create new versions that have different permissions.
*
*
* @return Returns a reference to this object so that method calls can be chained together.
* @see PermissionType
*/
public ResourceSharePermissionSummary withPermissionType(String permissionType) {
setPermissionType(permissionType);
return this;
}
/**
*
* The type of managed permission. This can be one of the following values:
*
*
* -
*
* AWS_MANAGED
– Amazon Web Services created and manages this managed permission. You can associate it
* with your resource shares, but you can't modify it.
*
*
* -
*
* CUSTOMER_MANAGED
– You, or another principal in your account created this managed permission. You
* can associate it with your resource shares and create new versions that have different permissions.
*
*
*
*
* @param permissionType
* The type of managed permission. This can be one of the following values:
*
* -
*
* AWS_MANAGED
– Amazon Web Services created and manages this managed permission. You can
* associate it with your resource shares, but you can't modify it.
*
*
* -
*
* CUSTOMER_MANAGED
– You, or another principal in your account created this managed permission.
* You can associate it with your resource shares and create new versions that have different permissions.
*
*
* @return Returns a reference to this object so that method calls can be chained together.
* @see PermissionType
*/
public ResourceSharePermissionSummary withPermissionType(PermissionType permissionType) {
this.permissionType = permissionType.toString();
return this;
}
/**
*
* Indicates what features are available for this resource share. This parameter can have one of the following
* values:
*
*
* -
*
* STANDARD – A resource share that supports all functionality. These resource shares are visible to all
* principals you share the resource share with. You can modify these resource shares in RAM using the console or
* APIs. This resource share might have been created by RAM, or it might have been CREATED_FROM_POLICY and
* then promoted.
*
*
* -
*
* CREATED_FROM_POLICY – The customer manually shared a resource by attaching a resource-based policy. That
* policy did not match any existing managed permissions, so RAM created this customer managed permission
* automatically on the customer's behalf based on the attached policy document. This type of resource share is
* visible only to the Amazon Web Services account that created it. You can't modify it in RAM unless you promote
* it. For more information, see PromoteResourceShareCreatedFromPolicy.
*
*
* -
*
* PROMOTING_TO_STANDARD – This resource share was originally CREATED_FROM_POLICY
, but the
* customer ran the PromoteResourceShareCreatedFromPolicy and that operation is still in progress. This value
* changes to STANDARD
when complete.
*
*
*
*
* @param featureSet
* Indicates what features are available for this resource share. This parameter can have one of the
* following values:
*
* -
*
* STANDARD – A resource share that supports all functionality. These resource shares are visible to
* all principals you share the resource share with. You can modify these resource shares in RAM using the
* console or APIs. This resource share might have been created by RAM, or it might have been
* CREATED_FROM_POLICY and then promoted.
*
*
* -
*
* CREATED_FROM_POLICY – The customer manually shared a resource by attaching a resource-based policy.
* That policy did not match any existing managed permissions, so RAM created this customer managed
* permission automatically on the customer's behalf based on the attached policy document. This type of
* resource share is visible only to the Amazon Web Services account that created it. You can't modify it in
* RAM unless you promote it. For more information, see PromoteResourceShareCreatedFromPolicy.
*
*
* -
*
* PROMOTING_TO_STANDARD – This resource share was originally CREATED_FROM_POLICY
, but
* the customer ran the PromoteResourceShareCreatedFromPolicy and that operation is still in progress.
* This value changes to STANDARD
when complete.
*
*
* @see PermissionFeatureSet
*/
public void setFeatureSet(String featureSet) {
this.featureSet = featureSet;
}
/**
*
* Indicates what features are available for this resource share. This parameter can have one of the following
* values:
*
*
* -
*
* STANDARD – A resource share that supports all functionality. These resource shares are visible to all
* principals you share the resource share with. You can modify these resource shares in RAM using the console or
* APIs. This resource share might have been created by RAM, or it might have been CREATED_FROM_POLICY and
* then promoted.
*
*
* -
*
* CREATED_FROM_POLICY – The customer manually shared a resource by attaching a resource-based policy. That
* policy did not match any existing managed permissions, so RAM created this customer managed permission
* automatically on the customer's behalf based on the attached policy document. This type of resource share is
* visible only to the Amazon Web Services account that created it. You can't modify it in RAM unless you promote
* it. For more information, see PromoteResourceShareCreatedFromPolicy.
*
*
* -
*
* PROMOTING_TO_STANDARD – This resource share was originally CREATED_FROM_POLICY
, but the
* customer ran the PromoteResourceShareCreatedFromPolicy and that operation is still in progress. This value
* changes to STANDARD
when complete.
*
*
*
*
* @return Indicates what features are available for this resource share. This parameter can have one of the
* following values:
*
* -
*
* STANDARD – A resource share that supports all functionality. These resource shares are visible to
* all principals you share the resource share with. You can modify these resource shares in RAM using the
* console or APIs. This resource share might have been created by RAM, or it might have been
* CREATED_FROM_POLICY and then promoted.
*
*
* -
*
* CREATED_FROM_POLICY – The customer manually shared a resource by attaching a resource-based
* policy. That policy did not match any existing managed permissions, so RAM created this customer managed
* permission automatically on the customer's behalf based on the attached policy document. This type of
* resource share is visible only to the Amazon Web Services account that created it. You can't modify it in
* RAM unless you promote it. For more information, see PromoteResourceShareCreatedFromPolicy.
*
*
* -
*
* PROMOTING_TO_STANDARD – This resource share was originally CREATED_FROM_POLICY
, but
* the customer ran the PromoteResourceShareCreatedFromPolicy and that operation is still in
* progress. This value changes to STANDARD
when complete.
*
*
* @see PermissionFeatureSet
*/
public String getFeatureSet() {
return this.featureSet;
}
/**
*
* Indicates what features are available for this resource share. This parameter can have one of the following
* values:
*
*
* -
*
* STANDARD – A resource share that supports all functionality. These resource shares are visible to all
* principals you share the resource share with. You can modify these resource shares in RAM using the console or
* APIs. This resource share might have been created by RAM, or it might have been CREATED_FROM_POLICY and
* then promoted.
*
*
* -
*
* CREATED_FROM_POLICY – The customer manually shared a resource by attaching a resource-based policy. That
* policy did not match any existing managed permissions, so RAM created this customer managed permission
* automatically on the customer's behalf based on the attached policy document. This type of resource share is
* visible only to the Amazon Web Services account that created it. You can't modify it in RAM unless you promote
* it. For more information, see PromoteResourceShareCreatedFromPolicy.
*
*
* -
*
* PROMOTING_TO_STANDARD – This resource share was originally CREATED_FROM_POLICY
, but the
* customer ran the PromoteResourceShareCreatedFromPolicy and that operation is still in progress. This value
* changes to STANDARD
when complete.
*
*
*
*
* @param featureSet
* Indicates what features are available for this resource share. This parameter can have one of the
* following values:
*
* -
*
* STANDARD – A resource share that supports all functionality. These resource shares are visible to
* all principals you share the resource share with. You can modify these resource shares in RAM using the
* console or APIs. This resource share might have been created by RAM, or it might have been
* CREATED_FROM_POLICY and then promoted.
*
*
* -
*
* CREATED_FROM_POLICY – The customer manually shared a resource by attaching a resource-based policy.
* That policy did not match any existing managed permissions, so RAM created this customer managed
* permission automatically on the customer's behalf based on the attached policy document. This type of
* resource share is visible only to the Amazon Web Services account that created it. You can't modify it in
* RAM unless you promote it. For more information, see PromoteResourceShareCreatedFromPolicy.
*
*
* -
*
* PROMOTING_TO_STANDARD – This resource share was originally CREATED_FROM_POLICY
, but
* the customer ran the PromoteResourceShareCreatedFromPolicy and that operation is still in progress.
* This value changes to STANDARD
when complete.
*
*
* @return Returns a reference to this object so that method calls can be chained together.
* @see PermissionFeatureSet
*/
public ResourceSharePermissionSummary withFeatureSet(String featureSet) {
setFeatureSet(featureSet);
return this;
}
/**
*
* Indicates what features are available for this resource share. This parameter can have one of the following
* values:
*
*
* -
*
* STANDARD – A resource share that supports all functionality. These resource shares are visible to all
* principals you share the resource share with. You can modify these resource shares in RAM using the console or
* APIs. This resource share might have been created by RAM, or it might have been CREATED_FROM_POLICY and
* then promoted.
*
*
* -
*
* CREATED_FROM_POLICY – The customer manually shared a resource by attaching a resource-based policy. That
* policy did not match any existing managed permissions, so RAM created this customer managed permission
* automatically on the customer's behalf based on the attached policy document. This type of resource share is
* visible only to the Amazon Web Services account that created it. You can't modify it in RAM unless you promote
* it. For more information, see PromoteResourceShareCreatedFromPolicy.
*
*
* -
*
* PROMOTING_TO_STANDARD – This resource share was originally CREATED_FROM_POLICY
, but the
* customer ran the PromoteResourceShareCreatedFromPolicy and that operation is still in progress. This value
* changes to STANDARD
when complete.
*
*
*
*
* @param featureSet
* Indicates what features are available for this resource share. This parameter can have one of the
* following values:
*
* -
*
* STANDARD – A resource share that supports all functionality. These resource shares are visible to
* all principals you share the resource share with. You can modify these resource shares in RAM using the
* console or APIs. This resource share might have been created by RAM, or it might have been
* CREATED_FROM_POLICY and then promoted.
*
*
* -
*
* CREATED_FROM_POLICY – The customer manually shared a resource by attaching a resource-based policy.
* That policy did not match any existing managed permissions, so RAM created this customer managed
* permission automatically on the customer's behalf based on the attached policy document. This type of
* resource share is visible only to the Amazon Web Services account that created it. You can't modify it in
* RAM unless you promote it. For more information, see PromoteResourceShareCreatedFromPolicy.
*
*
* -
*
* PROMOTING_TO_STANDARD – This resource share was originally CREATED_FROM_POLICY
, but
* the customer ran the PromoteResourceShareCreatedFromPolicy and that operation is still in progress.
* This value changes to STANDARD
when complete.
*
*
* @return Returns a reference to this object so that method calls can be chained together.
* @see PermissionFeatureSet
*/
public ResourceSharePermissionSummary withFeatureSet(PermissionFeatureSet featureSet) {
this.featureSet = featureSet.toString();
return this;
}
/**
*
* A list of the tag key value pairs currently attached to the permission.
*
*
* @return A list of the tag key value pairs currently attached to the permission.
*/
public java.util.List getTags() {
return tags;
}
/**
*
* A list of the tag key value pairs currently attached to the permission.
*
*
* @param tags
* A list of the tag key value pairs currently attached to the permission.
*/
public void setTags(java.util.Collection tags) {
if (tags == null) {
this.tags = null;
return;
}
this.tags = new java.util.ArrayList(tags);
}
/**
*
* A list of the tag key value pairs currently attached to the permission.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setTags(java.util.Collection)} or {@link #withTags(java.util.Collection)} if you want to override the
* existing values.
*
*
* @param tags
* A list of the tag key value pairs currently attached to the permission.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ResourceSharePermissionSummary withTags(Tag... tags) {
if (this.tags == null) {
setTags(new java.util.ArrayList(tags.length));
}
for (Tag ele : tags) {
this.tags.add(ele);
}
return this;
}
/**
*
* A list of the tag key value pairs currently attached to the permission.
*
*
* @param tags
* A list of the tag key value pairs currently attached to the permission.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ResourceSharePermissionSummary withTags(java.util.Collection tags) {
setTags(tags);
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 (getArn() != null)
sb.append("Arn: ").append(getArn()).append(",");
if (getVersion() != null)
sb.append("Version: ").append(getVersion()).append(",");
if (getDefaultVersion() != null)
sb.append("DefaultVersion: ").append(getDefaultVersion()).append(",");
if (getName() != null)
sb.append("Name: ").append(getName()).append(",");
if (getResourceType() != null)
sb.append("ResourceType: ").append(getResourceType()).append(",");
if (getStatus() != null)
sb.append("Status: ").append(getStatus()).append(",");
if (getCreationTime() != null)
sb.append("CreationTime: ").append(getCreationTime()).append(",");
if (getLastUpdatedTime() != null)
sb.append("LastUpdatedTime: ").append(getLastUpdatedTime()).append(",");
if (getIsResourceTypeDefault() != null)
sb.append("IsResourceTypeDefault: ").append(getIsResourceTypeDefault()).append(",");
if (getPermissionType() != null)
sb.append("PermissionType: ").append(getPermissionType()).append(",");
if (getFeatureSet() != null)
sb.append("FeatureSet: ").append(getFeatureSet()).append(",");
if (getTags() != null)
sb.append("Tags: ").append(getTags());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof ResourceSharePermissionSummary == false)
return false;
ResourceSharePermissionSummary other = (ResourceSharePermissionSummary) obj;
if (other.getArn() == null ^ this.getArn() == null)
return false;
if (other.getArn() != null && other.getArn().equals(this.getArn()) == 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.getDefaultVersion() == null ^ this.getDefaultVersion() == null)
return false;
if (other.getDefaultVersion() != null && other.getDefaultVersion().equals(this.getDefaultVersion()) == false)
return false;
if (other.getName() == null ^ this.getName() == null)
return false;
if (other.getName() != null && other.getName().equals(this.getName()) == false)
return false;
if (other.getResourceType() == null ^ this.getResourceType() == null)
return false;
if (other.getResourceType() != null && other.getResourceType().equals(this.getResourceType()) == false)
return false;
if (other.getStatus() == null ^ this.getStatus() == null)
return false;
if (other.getStatus() != null && other.getStatus().equals(this.getStatus()) == false)
return false;
if (other.getCreationTime() == null ^ this.getCreationTime() == null)
return false;
if (other.getCreationTime() != null && other.getCreationTime().equals(this.getCreationTime()) == false)
return false;
if (other.getLastUpdatedTime() == null ^ this.getLastUpdatedTime() == null)
return false;
if (other.getLastUpdatedTime() != null && other.getLastUpdatedTime().equals(this.getLastUpdatedTime()) == false)
return false;
if (other.getIsResourceTypeDefault() == null ^ this.getIsResourceTypeDefault() == null)
return false;
if (other.getIsResourceTypeDefault() != null && other.getIsResourceTypeDefault().equals(this.getIsResourceTypeDefault()) == false)
return false;
if (other.getPermissionType() == null ^ this.getPermissionType() == null)
return false;
if (other.getPermissionType() != null && other.getPermissionType().equals(this.getPermissionType()) == false)
return false;
if (other.getFeatureSet() == null ^ this.getFeatureSet() == null)
return false;
if (other.getFeatureSet() != null && other.getFeatureSet().equals(this.getFeatureSet()) == false)
return false;
if (other.getTags() == null ^ this.getTags() == null)
return false;
if (other.getTags() != null && other.getTags().equals(this.getTags()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getArn() == null) ? 0 : getArn().hashCode());
hashCode = prime * hashCode + ((getVersion() == null) ? 0 : getVersion().hashCode());
hashCode = prime * hashCode + ((getDefaultVersion() == null) ? 0 : getDefaultVersion().hashCode());
hashCode = prime * hashCode + ((getName() == null) ? 0 : getName().hashCode());
hashCode = prime * hashCode + ((getResourceType() == null) ? 0 : getResourceType().hashCode());
hashCode = prime * hashCode + ((getStatus() == null) ? 0 : getStatus().hashCode());
hashCode = prime * hashCode + ((getCreationTime() == null) ? 0 : getCreationTime().hashCode());
hashCode = prime * hashCode + ((getLastUpdatedTime() == null) ? 0 : getLastUpdatedTime().hashCode());
hashCode = prime * hashCode + ((getIsResourceTypeDefault() == null) ? 0 : getIsResourceTypeDefault().hashCode());
hashCode = prime * hashCode + ((getPermissionType() == null) ? 0 : getPermissionType().hashCode());
hashCode = prime * hashCode + ((getFeatureSet() == null) ? 0 : getFeatureSet().hashCode());
hashCode = prime * hashCode + ((getTags() == null) ? 0 : getTags().hashCode());
return hashCode;
}
@Override
public ResourceSharePermissionSummary clone() {
try {
return (ResourceSharePermissionSummary) 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.ram.model.transform.ResourceSharePermissionSummaryMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}