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

com.amazonaws.services.storagegateway.model.PoolInfo Maven / Gradle / Ivy

/*
 * Copyright 2017-2022 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.storagegateway.model;

import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;

/**
 * 

* Describes a custom tape pool. *

* * @see AWS API * Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class PoolInfo implements Serializable, Cloneable, StructuredPojo { /** *

* The Amazon Resource Name (ARN) of the custom tape pool. Use the ListTapePools operation to return a list * of custom tape pools for your account and Amazon Web Services Region. *

*/ private String poolARN; /** *

* The name of the custom tape pool. PoolName can use all ASCII characters, except '/' and '\'. *

*/ private String poolName; /** *

* The storage class that is associated with the custom pool. When you use your backup application to eject the * tape, the tape is archived directly into the storage class (S3 Glacier or S3 Glacier Deep Archive) that * corresponds to the pool. *

*/ private String storageClass; /** *

* Tape retention lock type, which can be configured in two modes. When configured in governance mode, Amazon Web * Services accounts with specific IAM permissions are authorized to remove the tape retention lock from archived * virtual tapes. When configured in compliance mode, the tape retention lock cannot be removed by any user, * including the root Amazon Web Services account. *

*/ private String retentionLockType; /** *

* Tape retention lock time is set in days. Tape retention lock can be enabled for up to 100 years (36,500 days). *

*/ private Integer retentionLockTimeInDays; /** *

* Status of the custom tape pool. Pool can be ACTIVE or DELETED. *

*/ private String poolStatus; /** *

* The Amazon Resource Name (ARN) of the custom tape pool. Use the ListTapePools operation to return a list * of custom tape pools for your account and Amazon Web Services Region. *

* * @param poolARN * The Amazon Resource Name (ARN) of the custom tape pool. Use the ListTapePools operation to return a * list of custom tape pools for your account and Amazon Web Services Region. */ public void setPoolARN(String poolARN) { this.poolARN = poolARN; } /** *

* The Amazon Resource Name (ARN) of the custom tape pool. Use the ListTapePools operation to return a list * of custom tape pools for your account and Amazon Web Services Region. *

* * @return The Amazon Resource Name (ARN) of the custom tape pool. Use the ListTapePools operation to return * a list of custom tape pools for your account and Amazon Web Services Region. */ public String getPoolARN() { return this.poolARN; } /** *

* The Amazon Resource Name (ARN) of the custom tape pool. Use the ListTapePools operation to return a list * of custom tape pools for your account and Amazon Web Services Region. *

* * @param poolARN * The Amazon Resource Name (ARN) of the custom tape pool. Use the ListTapePools operation to return a * list of custom tape pools for your account and Amazon Web Services Region. * @return Returns a reference to this object so that method calls can be chained together. */ public PoolInfo withPoolARN(String poolARN) { setPoolARN(poolARN); return this; } /** *

* The name of the custom tape pool. PoolName can use all ASCII characters, except '/' and '\'. *

* * @param poolName * The name of the custom tape pool. PoolName can use all ASCII characters, except '/' and '\'. */ public void setPoolName(String poolName) { this.poolName = poolName; } /** *

* The name of the custom tape pool. PoolName can use all ASCII characters, except '/' and '\'. *

* * @return The name of the custom tape pool. PoolName can use all ASCII characters, except '/' and '\'. */ public String getPoolName() { return this.poolName; } /** *

* The name of the custom tape pool. PoolName can use all ASCII characters, except '/' and '\'. *

* * @param poolName * The name of the custom tape pool. PoolName can use all ASCII characters, except '/' and '\'. * @return Returns a reference to this object so that method calls can be chained together. */ public PoolInfo withPoolName(String poolName) { setPoolName(poolName); return this; } /** *

* The storage class that is associated with the custom pool. When you use your backup application to eject the * tape, the tape is archived directly into the storage class (S3 Glacier or S3 Glacier Deep Archive) that * corresponds to the pool. *

* * @param storageClass * The storage class that is associated with the custom pool. When you use your backup application to eject * the tape, the tape is archived directly into the storage class (S3 Glacier or S3 Glacier Deep Archive) * that corresponds to the pool. * @see TapeStorageClass */ public void setStorageClass(String storageClass) { this.storageClass = storageClass; } /** *

* The storage class that is associated with the custom pool. When you use your backup application to eject the * tape, the tape is archived directly into the storage class (S3 Glacier or S3 Glacier Deep Archive) that * corresponds to the pool. *

* * @return The storage class that is associated with the custom pool. When you use your backup application to eject * the tape, the tape is archived directly into the storage class (S3 Glacier or S3 Glacier Deep Archive) * that corresponds to the pool. * @see TapeStorageClass */ public String getStorageClass() { return this.storageClass; } /** *

* The storage class that is associated with the custom pool. When you use your backup application to eject the * tape, the tape is archived directly into the storage class (S3 Glacier or S3 Glacier Deep Archive) that * corresponds to the pool. *

* * @param storageClass * The storage class that is associated with the custom pool. When you use your backup application to eject * the tape, the tape is archived directly into the storage class (S3 Glacier or S3 Glacier Deep Archive) * that corresponds to the pool. * @return Returns a reference to this object so that method calls can be chained together. * @see TapeStorageClass */ public PoolInfo withStorageClass(String storageClass) { setStorageClass(storageClass); return this; } /** *

* The storage class that is associated with the custom pool. When you use your backup application to eject the * tape, the tape is archived directly into the storage class (S3 Glacier or S3 Glacier Deep Archive) that * corresponds to the pool. *

* * @param storageClass * The storage class that is associated with the custom pool. When you use your backup application to eject * the tape, the tape is archived directly into the storage class (S3 Glacier or S3 Glacier Deep Archive) * that corresponds to the pool. * @return Returns a reference to this object so that method calls can be chained together. * @see TapeStorageClass */ public PoolInfo withStorageClass(TapeStorageClass storageClass) { this.storageClass = storageClass.toString(); return this; } /** *

* Tape retention lock type, which can be configured in two modes. When configured in governance mode, Amazon Web * Services accounts with specific IAM permissions are authorized to remove the tape retention lock from archived * virtual tapes. When configured in compliance mode, the tape retention lock cannot be removed by any user, * including the root Amazon Web Services account. *

* * @param retentionLockType * Tape retention lock type, which can be configured in two modes. When configured in governance mode, Amazon * Web Services accounts with specific IAM permissions are authorized to remove the tape retention lock from * archived virtual tapes. When configured in compliance mode, the tape retention lock cannot be removed by * any user, including the root Amazon Web Services account. * @see RetentionLockType */ public void setRetentionLockType(String retentionLockType) { this.retentionLockType = retentionLockType; } /** *

* Tape retention lock type, which can be configured in two modes. When configured in governance mode, Amazon Web * Services accounts with specific IAM permissions are authorized to remove the tape retention lock from archived * virtual tapes. When configured in compliance mode, the tape retention lock cannot be removed by any user, * including the root Amazon Web Services account. *

* * @return Tape retention lock type, which can be configured in two modes. When configured in governance mode, * Amazon Web Services accounts with specific IAM permissions are authorized to remove the tape retention * lock from archived virtual tapes. When configured in compliance mode, the tape retention lock cannot be * removed by any user, including the root Amazon Web Services account. * @see RetentionLockType */ public String getRetentionLockType() { return this.retentionLockType; } /** *

* Tape retention lock type, which can be configured in two modes. When configured in governance mode, Amazon Web * Services accounts with specific IAM permissions are authorized to remove the tape retention lock from archived * virtual tapes. When configured in compliance mode, the tape retention lock cannot be removed by any user, * including the root Amazon Web Services account. *

* * @param retentionLockType * Tape retention lock type, which can be configured in two modes. When configured in governance mode, Amazon * Web Services accounts with specific IAM permissions are authorized to remove the tape retention lock from * archived virtual tapes. When configured in compliance mode, the tape retention lock cannot be removed by * any user, including the root Amazon Web Services account. * @return Returns a reference to this object so that method calls can be chained together. * @see RetentionLockType */ public PoolInfo withRetentionLockType(String retentionLockType) { setRetentionLockType(retentionLockType); return this; } /** *

* Tape retention lock type, which can be configured in two modes. When configured in governance mode, Amazon Web * Services accounts with specific IAM permissions are authorized to remove the tape retention lock from archived * virtual tapes. When configured in compliance mode, the tape retention lock cannot be removed by any user, * including the root Amazon Web Services account. *

* * @param retentionLockType * Tape retention lock type, which can be configured in two modes. When configured in governance mode, Amazon * Web Services accounts with specific IAM permissions are authorized to remove the tape retention lock from * archived virtual tapes. When configured in compliance mode, the tape retention lock cannot be removed by * any user, including the root Amazon Web Services account. * @return Returns a reference to this object so that method calls can be chained together. * @see RetentionLockType */ public PoolInfo withRetentionLockType(RetentionLockType retentionLockType) { this.retentionLockType = retentionLockType.toString(); return this; } /** *

* Tape retention lock time is set in days. Tape retention lock can be enabled for up to 100 years (36,500 days). *

* * @param retentionLockTimeInDays * Tape retention lock time is set in days. Tape retention lock can be enabled for up to 100 years (36,500 * days). */ public void setRetentionLockTimeInDays(Integer retentionLockTimeInDays) { this.retentionLockTimeInDays = retentionLockTimeInDays; } /** *

* Tape retention lock time is set in days. Tape retention lock can be enabled for up to 100 years (36,500 days). *

* * @return Tape retention lock time is set in days. Tape retention lock can be enabled for up to 100 years (36,500 * days). */ public Integer getRetentionLockTimeInDays() { return this.retentionLockTimeInDays; } /** *

* Tape retention lock time is set in days. Tape retention lock can be enabled for up to 100 years (36,500 days). *

* * @param retentionLockTimeInDays * Tape retention lock time is set in days. Tape retention lock can be enabled for up to 100 years (36,500 * days). * @return Returns a reference to this object so that method calls can be chained together. */ public PoolInfo withRetentionLockTimeInDays(Integer retentionLockTimeInDays) { setRetentionLockTimeInDays(retentionLockTimeInDays); return this; } /** *

* Status of the custom tape pool. Pool can be ACTIVE or DELETED. *

* * @param poolStatus * Status of the custom tape pool. Pool can be ACTIVE or DELETED. * @see PoolStatus */ public void setPoolStatus(String poolStatus) { this.poolStatus = poolStatus; } /** *

* Status of the custom tape pool. Pool can be ACTIVE or DELETED. *

* * @return Status of the custom tape pool. Pool can be ACTIVE or DELETED. * @see PoolStatus */ public String getPoolStatus() { return this.poolStatus; } /** *

* Status of the custom tape pool. Pool can be ACTIVE or DELETED. *

* * @param poolStatus * Status of the custom tape pool. Pool can be ACTIVE or DELETED. * @return Returns a reference to this object so that method calls can be chained together. * @see PoolStatus */ public PoolInfo withPoolStatus(String poolStatus) { setPoolStatus(poolStatus); return this; } /** *

* Status of the custom tape pool. Pool can be ACTIVE or DELETED. *

* * @param poolStatus * Status of the custom tape pool. Pool can be ACTIVE or DELETED. * @return Returns a reference to this object so that method calls can be chained together. * @see PoolStatus */ public PoolInfo withPoolStatus(PoolStatus poolStatus) { this.poolStatus = poolStatus.toString(); 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 (getPoolARN() != null) sb.append("PoolARN: ").append(getPoolARN()).append(","); if (getPoolName() != null) sb.append("PoolName: ").append(getPoolName()).append(","); if (getStorageClass() != null) sb.append("StorageClass: ").append(getStorageClass()).append(","); if (getRetentionLockType() != null) sb.append("RetentionLockType: ").append(getRetentionLockType()).append(","); if (getRetentionLockTimeInDays() != null) sb.append("RetentionLockTimeInDays: ").append(getRetentionLockTimeInDays()).append(","); if (getPoolStatus() != null) sb.append("PoolStatus: ").append(getPoolStatus()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof PoolInfo == false) return false; PoolInfo other = (PoolInfo) obj; if (other.getPoolARN() == null ^ this.getPoolARN() == null) return false; if (other.getPoolARN() != null && other.getPoolARN().equals(this.getPoolARN()) == false) return false; if (other.getPoolName() == null ^ this.getPoolName() == null) return false; if (other.getPoolName() != null && other.getPoolName().equals(this.getPoolName()) == false) return false; if (other.getStorageClass() == null ^ this.getStorageClass() == null) return false; if (other.getStorageClass() != null && other.getStorageClass().equals(this.getStorageClass()) == false) return false; if (other.getRetentionLockType() == null ^ this.getRetentionLockType() == null) return false; if (other.getRetentionLockType() != null && other.getRetentionLockType().equals(this.getRetentionLockType()) == false) return false; if (other.getRetentionLockTimeInDays() == null ^ this.getRetentionLockTimeInDays() == null) return false; if (other.getRetentionLockTimeInDays() != null && other.getRetentionLockTimeInDays().equals(this.getRetentionLockTimeInDays()) == false) return false; if (other.getPoolStatus() == null ^ this.getPoolStatus() == null) return false; if (other.getPoolStatus() != null && other.getPoolStatus().equals(this.getPoolStatus()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getPoolARN() == null) ? 0 : getPoolARN().hashCode()); hashCode = prime * hashCode + ((getPoolName() == null) ? 0 : getPoolName().hashCode()); hashCode = prime * hashCode + ((getStorageClass() == null) ? 0 : getStorageClass().hashCode()); hashCode = prime * hashCode + ((getRetentionLockType() == null) ? 0 : getRetentionLockType().hashCode()); hashCode = prime * hashCode + ((getRetentionLockTimeInDays() == null) ? 0 : getRetentionLockTimeInDays().hashCode()); hashCode = prime * hashCode + ((getPoolStatus() == null) ? 0 : getPoolStatus().hashCode()); return hashCode; } @Override public PoolInfo clone() { try { return (PoolInfo) 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.storagegateway.model.transform.PoolInfoMarshaller.getInstance().marshall(this, protocolMarshaller); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy