com.amazonaws.services.storagegateway.model.BandwidthRateLimitInterval Maven / Gradle / Ivy
/*
* 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.storagegateway.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;
/**
*
* Describes a bandwidth rate limit interval for a gateway. A bandwidth rate limit schedule consists of one or more
* bandwidth rate limit intervals. A bandwidth rate limit interval defines a period of time on one or more days of the
* week, during which bandwidth rate limits are specified for uploading, downloading, or both.
*
*
* @see AWS API Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class BandwidthRateLimitInterval implements Serializable, Cloneable, StructuredPojo {
/**
*
* The hour of the day to start the bandwidth rate limit interval.
*
*/
private Integer startHourOfDay;
/**
*
* The minute of the hour to start the bandwidth rate limit interval. The interval begins at the start of that
* minute. To begin an interval exactly at the start of the hour, use the value 0
.
*
*/
private Integer startMinuteOfHour;
/**
*
* The hour of the day to end the bandwidth rate limit interval.
*
*/
private Integer endHourOfDay;
/**
*
* The minute of the hour to end the bandwidth rate limit interval.
*
*
*
* The bandwidth rate limit interval ends at the end of the minute. To end an interval at the end of an hour, use
* the value 59
.
*
*
*/
private Integer endMinuteOfHour;
/**
*
* The days of the week component of the bandwidth rate limit interval, represented as ordinal numbers from 0 to 6,
* where 0 represents Sunday and 6 represents Saturday.
*
*/
private com.amazonaws.internal.SdkInternalList daysOfWeek;
/**
*
* The average upload rate limit component of the bandwidth rate limit interval, in bits per second. This field does
* not appear in the response if the upload rate limit is not set.
*
*
*
* For Tape Gateway and Volume Gateway, the minimum value is 51200
.
*
*
* For S3 File Gateway and FSx File Gateway, the minimum value is 104857600
.
*
*
*/
private Long averageUploadRateLimitInBitsPerSec;
/**
*
* The average download rate limit component of the bandwidth rate limit interval, in bits per second. This field
* does not appear in the response if the download rate limit is not set.
*
*/
private Long averageDownloadRateLimitInBitsPerSec;
/**
*
* The hour of the day to start the bandwidth rate limit interval.
*
*
* @param startHourOfDay
* The hour of the day to start the bandwidth rate limit interval.
*/
public void setStartHourOfDay(Integer startHourOfDay) {
this.startHourOfDay = startHourOfDay;
}
/**
*
* The hour of the day to start the bandwidth rate limit interval.
*
*
* @return The hour of the day to start the bandwidth rate limit interval.
*/
public Integer getStartHourOfDay() {
return this.startHourOfDay;
}
/**
*
* The hour of the day to start the bandwidth rate limit interval.
*
*
* @param startHourOfDay
* The hour of the day to start the bandwidth rate limit interval.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public BandwidthRateLimitInterval withStartHourOfDay(Integer startHourOfDay) {
setStartHourOfDay(startHourOfDay);
return this;
}
/**
*
* The minute of the hour to start the bandwidth rate limit interval. The interval begins at the start of that
* minute. To begin an interval exactly at the start of the hour, use the value 0
.
*
*
* @param startMinuteOfHour
* The minute of the hour to start the bandwidth rate limit interval. The interval begins at the start of
* that minute. To begin an interval exactly at the start of the hour, use the value 0
.
*/
public void setStartMinuteOfHour(Integer startMinuteOfHour) {
this.startMinuteOfHour = startMinuteOfHour;
}
/**
*
* The minute of the hour to start the bandwidth rate limit interval. The interval begins at the start of that
* minute. To begin an interval exactly at the start of the hour, use the value 0
.
*
*
* @return The minute of the hour to start the bandwidth rate limit interval. The interval begins at the start of
* that minute. To begin an interval exactly at the start of the hour, use the value 0
.
*/
public Integer getStartMinuteOfHour() {
return this.startMinuteOfHour;
}
/**
*
* The minute of the hour to start the bandwidth rate limit interval. The interval begins at the start of that
* minute. To begin an interval exactly at the start of the hour, use the value 0
.
*
*
* @param startMinuteOfHour
* The minute of the hour to start the bandwidth rate limit interval. The interval begins at the start of
* that minute. To begin an interval exactly at the start of the hour, use the value 0
.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public BandwidthRateLimitInterval withStartMinuteOfHour(Integer startMinuteOfHour) {
setStartMinuteOfHour(startMinuteOfHour);
return this;
}
/**
*
* The hour of the day to end the bandwidth rate limit interval.
*
*
* @param endHourOfDay
* The hour of the day to end the bandwidth rate limit interval.
*/
public void setEndHourOfDay(Integer endHourOfDay) {
this.endHourOfDay = endHourOfDay;
}
/**
*
* The hour of the day to end the bandwidth rate limit interval.
*
*
* @return The hour of the day to end the bandwidth rate limit interval.
*/
public Integer getEndHourOfDay() {
return this.endHourOfDay;
}
/**
*
* The hour of the day to end the bandwidth rate limit interval.
*
*
* @param endHourOfDay
* The hour of the day to end the bandwidth rate limit interval.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public BandwidthRateLimitInterval withEndHourOfDay(Integer endHourOfDay) {
setEndHourOfDay(endHourOfDay);
return this;
}
/**
*
* The minute of the hour to end the bandwidth rate limit interval.
*
*
*
* The bandwidth rate limit interval ends at the end of the minute. To end an interval at the end of an hour, use
* the value 59
.
*
*
*
* @param endMinuteOfHour
* The minute of the hour to end the bandwidth rate limit interval.
*
* The bandwidth rate limit interval ends at the end of the minute. To end an interval at the end of an hour,
* use the value 59
.
*
*/
public void setEndMinuteOfHour(Integer endMinuteOfHour) {
this.endMinuteOfHour = endMinuteOfHour;
}
/**
*
* The minute of the hour to end the bandwidth rate limit interval.
*
*
*
* The bandwidth rate limit interval ends at the end of the minute. To end an interval at the end of an hour, use
* the value 59
.
*
*
*
* @return The minute of the hour to end the bandwidth rate limit interval.
*
* The bandwidth rate limit interval ends at the end of the minute. To end an interval at the end of an
* hour, use the value 59
.
*
*/
public Integer getEndMinuteOfHour() {
return this.endMinuteOfHour;
}
/**
*
* The minute of the hour to end the bandwidth rate limit interval.
*
*
*
* The bandwidth rate limit interval ends at the end of the minute. To end an interval at the end of an hour, use
* the value 59
.
*
*
*
* @param endMinuteOfHour
* The minute of the hour to end the bandwidth rate limit interval.
*
* The bandwidth rate limit interval ends at the end of the minute. To end an interval at the end of an hour,
* use the value 59
.
*
* @return Returns a reference to this object so that method calls can be chained together.
*/
public BandwidthRateLimitInterval withEndMinuteOfHour(Integer endMinuteOfHour) {
setEndMinuteOfHour(endMinuteOfHour);
return this;
}
/**
*
* The days of the week component of the bandwidth rate limit interval, represented as ordinal numbers from 0 to 6,
* where 0 represents Sunday and 6 represents Saturday.
*
*
* @return The days of the week component of the bandwidth rate limit interval, represented as ordinal numbers from
* 0 to 6, where 0 represents Sunday and 6 represents Saturday.
*/
public java.util.List getDaysOfWeek() {
if (daysOfWeek == null) {
daysOfWeek = new com.amazonaws.internal.SdkInternalList();
}
return daysOfWeek;
}
/**
*
* The days of the week component of the bandwidth rate limit interval, represented as ordinal numbers from 0 to 6,
* where 0 represents Sunday and 6 represents Saturday.
*
*
* @param daysOfWeek
* The days of the week component of the bandwidth rate limit interval, represented as ordinal numbers from 0
* to 6, where 0 represents Sunday and 6 represents Saturday.
*/
public void setDaysOfWeek(java.util.Collection daysOfWeek) {
if (daysOfWeek == null) {
this.daysOfWeek = null;
return;
}
this.daysOfWeek = new com.amazonaws.internal.SdkInternalList(daysOfWeek);
}
/**
*
* The days of the week component of the bandwidth rate limit interval, represented as ordinal numbers from 0 to 6,
* where 0 represents Sunday and 6 represents Saturday.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setDaysOfWeek(java.util.Collection)} or {@link #withDaysOfWeek(java.util.Collection)} if you want to
* override the existing values.
*
*
* @param daysOfWeek
* The days of the week component of the bandwidth rate limit interval, represented as ordinal numbers from 0
* to 6, where 0 represents Sunday and 6 represents Saturday.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public BandwidthRateLimitInterval withDaysOfWeek(Integer... daysOfWeek) {
if (this.daysOfWeek == null) {
setDaysOfWeek(new com.amazonaws.internal.SdkInternalList(daysOfWeek.length));
}
for (Integer ele : daysOfWeek) {
this.daysOfWeek.add(ele);
}
return this;
}
/**
*
* The days of the week component of the bandwidth rate limit interval, represented as ordinal numbers from 0 to 6,
* where 0 represents Sunday and 6 represents Saturday.
*
*
* @param daysOfWeek
* The days of the week component of the bandwidth rate limit interval, represented as ordinal numbers from 0
* to 6, where 0 represents Sunday and 6 represents Saturday.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public BandwidthRateLimitInterval withDaysOfWeek(java.util.Collection daysOfWeek) {
setDaysOfWeek(daysOfWeek);
return this;
}
/**
*
* The average upload rate limit component of the bandwidth rate limit interval, in bits per second. This field does
* not appear in the response if the upload rate limit is not set.
*
*
*
* For Tape Gateway and Volume Gateway, the minimum value is 51200
.
*
*
* For S3 File Gateway and FSx File Gateway, the minimum value is 104857600
.
*
*
*
* @param averageUploadRateLimitInBitsPerSec
* The average upload rate limit component of the bandwidth rate limit interval, in bits per second. This
* field does not appear in the response if the upload rate limit is not set.
*
* For Tape Gateway and Volume Gateway, the minimum value is 51200
.
*
*
* For S3 File Gateway and FSx File Gateway, the minimum value is 104857600
.
*
*/
public void setAverageUploadRateLimitInBitsPerSec(Long averageUploadRateLimitInBitsPerSec) {
this.averageUploadRateLimitInBitsPerSec = averageUploadRateLimitInBitsPerSec;
}
/**
*
* The average upload rate limit component of the bandwidth rate limit interval, in bits per second. This field does
* not appear in the response if the upload rate limit is not set.
*
*
*
* For Tape Gateway and Volume Gateway, the minimum value is 51200
.
*
*
* For S3 File Gateway and FSx File Gateway, the minimum value is 104857600
.
*
*
*
* @return The average upload rate limit component of the bandwidth rate limit interval, in bits per second. This
* field does not appear in the response if the upload rate limit is not set.
*
* For Tape Gateway and Volume Gateway, the minimum value is 51200
.
*
*
* For S3 File Gateway and FSx File Gateway, the minimum value is 104857600
.
*
*/
public Long getAverageUploadRateLimitInBitsPerSec() {
return this.averageUploadRateLimitInBitsPerSec;
}
/**
*
* The average upload rate limit component of the bandwidth rate limit interval, in bits per second. This field does
* not appear in the response if the upload rate limit is not set.
*
*
*
* For Tape Gateway and Volume Gateway, the minimum value is 51200
.
*
*
* For S3 File Gateway and FSx File Gateway, the minimum value is 104857600
.
*
*
*
* @param averageUploadRateLimitInBitsPerSec
* The average upload rate limit component of the bandwidth rate limit interval, in bits per second. This
* field does not appear in the response if the upload rate limit is not set.
*
* For Tape Gateway and Volume Gateway, the minimum value is 51200
.
*
*
* For S3 File Gateway and FSx File Gateway, the minimum value is 104857600
.
*
* @return Returns a reference to this object so that method calls can be chained together.
*/
public BandwidthRateLimitInterval withAverageUploadRateLimitInBitsPerSec(Long averageUploadRateLimitInBitsPerSec) {
setAverageUploadRateLimitInBitsPerSec(averageUploadRateLimitInBitsPerSec);
return this;
}
/**
*
* The average download rate limit component of the bandwidth rate limit interval, in bits per second. This field
* does not appear in the response if the download rate limit is not set.
*
*
* @param averageDownloadRateLimitInBitsPerSec
* The average download rate limit component of the bandwidth rate limit interval, in bits per second. This
* field does not appear in the response if the download rate limit is not set.
*/
public void setAverageDownloadRateLimitInBitsPerSec(Long averageDownloadRateLimitInBitsPerSec) {
this.averageDownloadRateLimitInBitsPerSec = averageDownloadRateLimitInBitsPerSec;
}
/**
*
* The average download rate limit component of the bandwidth rate limit interval, in bits per second. This field
* does not appear in the response if the download rate limit is not set.
*
*
* @return The average download rate limit component of the bandwidth rate limit interval, in bits per second. This
* field does not appear in the response if the download rate limit is not set.
*/
public Long getAverageDownloadRateLimitInBitsPerSec() {
return this.averageDownloadRateLimitInBitsPerSec;
}
/**
*
* The average download rate limit component of the bandwidth rate limit interval, in bits per second. This field
* does not appear in the response if the download rate limit is not set.
*
*
* @param averageDownloadRateLimitInBitsPerSec
* The average download rate limit component of the bandwidth rate limit interval, in bits per second. This
* field does not appear in the response if the download rate limit is not set.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public BandwidthRateLimitInterval withAverageDownloadRateLimitInBitsPerSec(Long averageDownloadRateLimitInBitsPerSec) {
setAverageDownloadRateLimitInBitsPerSec(averageDownloadRateLimitInBitsPerSec);
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 (getStartHourOfDay() != null)
sb.append("StartHourOfDay: ").append(getStartHourOfDay()).append(",");
if (getStartMinuteOfHour() != null)
sb.append("StartMinuteOfHour: ").append(getStartMinuteOfHour()).append(",");
if (getEndHourOfDay() != null)
sb.append("EndHourOfDay: ").append(getEndHourOfDay()).append(",");
if (getEndMinuteOfHour() != null)
sb.append("EndMinuteOfHour: ").append(getEndMinuteOfHour()).append(",");
if (getDaysOfWeek() != null)
sb.append("DaysOfWeek: ").append(getDaysOfWeek()).append(",");
if (getAverageUploadRateLimitInBitsPerSec() != null)
sb.append("AverageUploadRateLimitInBitsPerSec: ").append(getAverageUploadRateLimitInBitsPerSec()).append(",");
if (getAverageDownloadRateLimitInBitsPerSec() != null)
sb.append("AverageDownloadRateLimitInBitsPerSec: ").append(getAverageDownloadRateLimitInBitsPerSec());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof BandwidthRateLimitInterval == false)
return false;
BandwidthRateLimitInterval other = (BandwidthRateLimitInterval) obj;
if (other.getStartHourOfDay() == null ^ this.getStartHourOfDay() == null)
return false;
if (other.getStartHourOfDay() != null && other.getStartHourOfDay().equals(this.getStartHourOfDay()) == false)
return false;
if (other.getStartMinuteOfHour() == null ^ this.getStartMinuteOfHour() == null)
return false;
if (other.getStartMinuteOfHour() != null && other.getStartMinuteOfHour().equals(this.getStartMinuteOfHour()) == false)
return false;
if (other.getEndHourOfDay() == null ^ this.getEndHourOfDay() == null)
return false;
if (other.getEndHourOfDay() != null && other.getEndHourOfDay().equals(this.getEndHourOfDay()) == false)
return false;
if (other.getEndMinuteOfHour() == null ^ this.getEndMinuteOfHour() == null)
return false;
if (other.getEndMinuteOfHour() != null && other.getEndMinuteOfHour().equals(this.getEndMinuteOfHour()) == false)
return false;
if (other.getDaysOfWeek() == null ^ this.getDaysOfWeek() == null)
return false;
if (other.getDaysOfWeek() != null && other.getDaysOfWeek().equals(this.getDaysOfWeek()) == false)
return false;
if (other.getAverageUploadRateLimitInBitsPerSec() == null ^ this.getAverageUploadRateLimitInBitsPerSec() == null)
return false;
if (other.getAverageUploadRateLimitInBitsPerSec() != null
&& other.getAverageUploadRateLimitInBitsPerSec().equals(this.getAverageUploadRateLimitInBitsPerSec()) == false)
return false;
if (other.getAverageDownloadRateLimitInBitsPerSec() == null ^ this.getAverageDownloadRateLimitInBitsPerSec() == null)
return false;
if (other.getAverageDownloadRateLimitInBitsPerSec() != null
&& other.getAverageDownloadRateLimitInBitsPerSec().equals(this.getAverageDownloadRateLimitInBitsPerSec()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getStartHourOfDay() == null) ? 0 : getStartHourOfDay().hashCode());
hashCode = prime * hashCode + ((getStartMinuteOfHour() == null) ? 0 : getStartMinuteOfHour().hashCode());
hashCode = prime * hashCode + ((getEndHourOfDay() == null) ? 0 : getEndHourOfDay().hashCode());
hashCode = prime * hashCode + ((getEndMinuteOfHour() == null) ? 0 : getEndMinuteOfHour().hashCode());
hashCode = prime * hashCode + ((getDaysOfWeek() == null) ? 0 : getDaysOfWeek().hashCode());
hashCode = prime * hashCode + ((getAverageUploadRateLimitInBitsPerSec() == null) ? 0 : getAverageUploadRateLimitInBitsPerSec().hashCode());
hashCode = prime * hashCode + ((getAverageDownloadRateLimitInBitsPerSec() == null) ? 0 : getAverageDownloadRateLimitInBitsPerSec().hashCode());
return hashCode;
}
@Override
public BandwidthRateLimitInterval clone() {
try {
return (BandwidthRateLimitInterval) 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.BandwidthRateLimitIntervalMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}