com.amazonaws.services.rds.model.AccountQuota Maven / Gradle / Ivy
Show all versions of aws-java-sdk-rds Show documentation
/*
* Copyright 2015-2020 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.rds.model;
import java.io.Serializable;
import javax.annotation.Generated;
/**
*
* Describes a quota for an AWS account.
*
*
* The following are account quotas:
*
*
* -
*
* AllocatedStorage
- The total allocated storage per account, in GiB. The used value is the total
* allocated storage in the account, in GiB.
*
*
* -
*
* AuthorizationsPerDBSecurityGroup
- The number of ingress rules per DB security group. The used value is
* the highest number of ingress rules in a DB security group in the account. Other DB security groups in the account
* might have a lower number of ingress rules.
*
*
* -
*
* CustomEndpointsPerDBCluster
- The number of custom endpoints per DB cluster. The used value is the
* highest number of custom endpoints in a DB clusters in the account. Other DB clusters in the account might have a
* lower number of custom endpoints.
*
*
* -
*
* DBClusterParameterGroups
- The number of DB cluster parameter groups per account, excluding default
* parameter groups. The used value is the count of nondefault DB cluster parameter groups in the account.
*
*
* -
*
* DBClusterRoles
- The number of associated AWS Identity and Access Management (IAM) roles per DB cluster.
* The used value is the highest number of associated IAM roles for a DB cluster in the account. Other DB clusters in
* the account might have a lower number of associated IAM roles.
*
*
* -
*
* DBClusters
- The number of DB clusters per account. The used value is the count of DB clusters in the
* account.
*
*
* -
*
* DBInstanceRoles
- The number of associated IAM roles per DB instance. The used value is the highest
* number of associated IAM roles for a DB instance in the account. Other DB instances in the account might have a lower
* number of associated IAM roles.
*
*
* -
*
* DBInstances
- The number of DB instances per account. The used value is the count of the DB instances in
* the account.
*
*
* Amazon RDS DB instances, Amazon Aurora DB instances, Amazon Neptune instances, and Amazon DocumentDB instances apply
* to this quota.
*
*
* -
*
* DBParameterGroups
- The number of DB parameter groups per account, excluding default parameter groups.
* The used value is the count of nondefault DB parameter groups in the account.
*
*
* -
*
* DBSecurityGroups
- The number of DB security groups (not VPC security groups) per account, excluding the
* default security group. The used value is the count of nondefault DB security groups in the account.
*
*
* -
*
* DBSubnetGroups
- The number of DB subnet groups per account. The used value is the count of the DB
* subnet groups in the account.
*
*
* -
*
* EventSubscriptions
- The number of event subscriptions per account. The used value is the count of the
* event subscriptions in the account.
*
*
* -
*
* ManualClusterSnapshots
- The number of manual DB cluster snapshots per account. The used value is the
* count of the manual DB cluster snapshots in the account.
*
*
* -
*
* ManualSnapshots
- The number of manual DB instance snapshots per account. The used value is the count of
* the manual DB instance snapshots in the account.
*
*
* -
*
* OptionGroups
- The number of DB option groups per account, excluding default option groups. The used
* value is the count of nondefault DB option groups in the account.
*
*
* -
*
* ReadReplicasPerMaster
- The number of read replicas per DB instance. The used value is the highest
* number of read replicas for a DB instance in the account. Other DB instances in the account might have a lower number
* of read replicas.
*
*
* -
*
* ReservedDBInstances
- The number of reserved DB instances per account. The used value is the count of
* the active reserved DB instances in the account.
*
*
* -
*
* SubnetsPerDBSubnetGroup
- The number of subnets per DB subnet group. The used value is highest number of
* subnets for a DB subnet group in the account. Other DB subnet groups in the account might have a lower number of
* subnets.
*
*
*
*
* For more information, see Quotas
* for Amazon RDS in the Amazon RDS User Guide and Quotas for Amazon Aurora in
* the Amazon Aurora User Guide.
*
*
* @see AWS API
* Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class AccountQuota implements Serializable, Cloneable {
/**
*
* The name of the Amazon RDS quota for this AWS account.
*
*/
private String accountQuotaName;
/**
*
* The amount currently used toward the quota maximum.
*
*/
private Long used;
/**
*
* The maximum allowed value for the quota.
*
*/
private Long max;
/**
*
* The name of the Amazon RDS quota for this AWS account.
*
*
* @param accountQuotaName
* The name of the Amazon RDS quota for this AWS account.
*/
public void setAccountQuotaName(String accountQuotaName) {
this.accountQuotaName = accountQuotaName;
}
/**
*
* The name of the Amazon RDS quota for this AWS account.
*
*
* @return The name of the Amazon RDS quota for this AWS account.
*/
public String getAccountQuotaName() {
return this.accountQuotaName;
}
/**
*
* The name of the Amazon RDS quota for this AWS account.
*
*
* @param accountQuotaName
* The name of the Amazon RDS quota for this AWS account.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AccountQuota withAccountQuotaName(String accountQuotaName) {
setAccountQuotaName(accountQuotaName);
return this;
}
/**
*
* The amount currently used toward the quota maximum.
*
*
* @param used
* The amount currently used toward the quota maximum.
*/
public void setUsed(Long used) {
this.used = used;
}
/**
*
* The amount currently used toward the quota maximum.
*
*
* @return The amount currently used toward the quota maximum.
*/
public Long getUsed() {
return this.used;
}
/**
*
* The amount currently used toward the quota maximum.
*
*
* @param used
* The amount currently used toward the quota maximum.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AccountQuota withUsed(Long used) {
setUsed(used);
return this;
}
/**
*
* The maximum allowed value for the quota.
*
*
* @param max
* The maximum allowed value for the quota.
*/
public void setMax(Long max) {
this.max = max;
}
/**
*
* The maximum allowed value for the quota.
*
*
* @return The maximum allowed value for the quota.
*/
public Long getMax() {
return this.max;
}
/**
*
* The maximum allowed value for the quota.
*
*
* @param max
* The maximum allowed value for the quota.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AccountQuota withMax(Long max) {
setMax(max);
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 (getAccountQuotaName() != null)
sb.append("AccountQuotaName: ").append(getAccountQuotaName()).append(",");
if (getUsed() != null)
sb.append("Used: ").append(getUsed()).append(",");
if (getMax() != null)
sb.append("Max: ").append(getMax());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof AccountQuota == false)
return false;
AccountQuota other = (AccountQuota) obj;
if (other.getAccountQuotaName() == null ^ this.getAccountQuotaName() == null)
return false;
if (other.getAccountQuotaName() != null && other.getAccountQuotaName().equals(this.getAccountQuotaName()) == false)
return false;
if (other.getUsed() == null ^ this.getUsed() == null)
return false;
if (other.getUsed() != null && other.getUsed().equals(this.getUsed()) == false)
return false;
if (other.getMax() == null ^ this.getMax() == null)
return false;
if (other.getMax() != null && other.getMax().equals(this.getMax()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getAccountQuotaName() == null) ? 0 : getAccountQuotaName().hashCode());
hashCode = prime * hashCode + ((getUsed() == null) ? 0 : getUsed().hashCode());
hashCode = prime * hashCode + ((getMax() == null) ? 0 : getMax().hashCode());
return hashCode;
}
@Override
public AccountQuota clone() {
try {
return (AccountQuota) super.clone();
} catch (CloneNotSupportedException e) {
throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e);
}
}
}