com.amazonaws.services.fsx.model.UpdateSnaplockConfiguration 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.fsx.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;
/**
*
* Updates the SnapLock configuration for an existing FSx for ONTAP volume.
*
*
* @see AWS
* API Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class UpdateSnaplockConfiguration implements Serializable, Cloneable, StructuredPojo {
/**
*
* Enables or disables the audit log volume for an FSx for ONTAP SnapLock volume. The default value is
* false
. If you set AuditLogVolume
to true
, the SnapLock volume is created
* as an audit log volume. The minimum retention period for an audit log volume is six months.
*
*
* For more information, see
* SnapLock audit log volumes.
*
*/
private Boolean auditLogVolume;
/**
*
* The configuration object for setting the autocommit period of files in an FSx for ONTAP SnapLock volume.
*
*/
private AutocommitPeriod autocommitPeriod;
/**
*
* Enables, disables, or permanently disables privileged delete on an FSx for ONTAP SnapLock Enterprise volume.
* Enabling privileged delete allows SnapLock administrators to delete write once, read many (WORM) files even if
* they have active retention periods. PERMANENTLY_DISABLED
is a terminal state. If privileged delete
* is permanently disabled on a SnapLock volume, you can't re-enable it. The default value is DISABLED
.
*
*
* For more information, see Privileged
* delete.
*
*/
private String privilegedDelete;
/**
*
* Specifies the retention period of an FSx for ONTAP SnapLock volume.
*
*/
private SnaplockRetentionPeriod retentionPeriod;
/**
*
* Enables or disables volume-append mode on an FSx for ONTAP SnapLock volume. Volume-append mode allows you to
* create WORM-appendable files and write data to them incrementally. The default value is false
.
*
*
* For more information, see Volume-append
* mode.
*
*/
private Boolean volumeAppendModeEnabled;
/**
*
* Enables or disables the audit log volume for an FSx for ONTAP SnapLock volume. The default value is
* false
. If you set AuditLogVolume
to true
, the SnapLock volume is created
* as an audit log volume. The minimum retention period for an audit log volume is six months.
*
*
* For more information, see
* SnapLock audit log volumes.
*
*
* @param auditLogVolume
* Enables or disables the audit log volume for an FSx for ONTAP SnapLock volume. The default value is
* false
. If you set AuditLogVolume
to true
, the SnapLock volume is
* created as an audit log volume. The minimum retention period for an audit log volume is six months.
*
* For more information, see
* SnapLock audit log volumes.
*/
public void setAuditLogVolume(Boolean auditLogVolume) {
this.auditLogVolume = auditLogVolume;
}
/**
*
* Enables or disables the audit log volume for an FSx for ONTAP SnapLock volume. The default value is
* false
. If you set AuditLogVolume
to true
, the SnapLock volume is created
* as an audit log volume. The minimum retention period for an audit log volume is six months.
*
*
* For more information, see
* SnapLock audit log volumes.
*
*
* @return Enables or disables the audit log volume for an FSx for ONTAP SnapLock volume. The default value is
* false
. If you set AuditLogVolume
to true
, the SnapLock volume is
* created as an audit log volume. The minimum retention period for an audit log volume is six months.
*
* For more information, see
* SnapLock audit log volumes.
*/
public Boolean getAuditLogVolume() {
return this.auditLogVolume;
}
/**
*
* Enables or disables the audit log volume for an FSx for ONTAP SnapLock volume. The default value is
* false
. If you set AuditLogVolume
to true
, the SnapLock volume is created
* as an audit log volume. The minimum retention period for an audit log volume is six months.
*
*
* For more information, see
* SnapLock audit log volumes.
*
*
* @param auditLogVolume
* Enables or disables the audit log volume for an FSx for ONTAP SnapLock volume. The default value is
* false
. If you set AuditLogVolume
to true
, the SnapLock volume is
* created as an audit log volume. The minimum retention period for an audit log volume is six months.
*
* For more information, see
* SnapLock audit log volumes.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public UpdateSnaplockConfiguration withAuditLogVolume(Boolean auditLogVolume) {
setAuditLogVolume(auditLogVolume);
return this;
}
/**
*
* Enables or disables the audit log volume for an FSx for ONTAP SnapLock volume. The default value is
* false
. If you set AuditLogVolume
to true
, the SnapLock volume is created
* as an audit log volume. The minimum retention period for an audit log volume is six months.
*
*
* For more information, see
* SnapLock audit log volumes.
*
*
* @return Enables or disables the audit log volume for an FSx for ONTAP SnapLock volume. The default value is
* false
. If you set AuditLogVolume
to true
, the SnapLock volume is
* created as an audit log volume. The minimum retention period for an audit log volume is six months.
*
* For more information, see
* SnapLock audit log volumes.
*/
public Boolean isAuditLogVolume() {
return this.auditLogVolume;
}
/**
*
* The configuration object for setting the autocommit period of files in an FSx for ONTAP SnapLock volume.
*
*
* @param autocommitPeriod
* The configuration object for setting the autocommit period of files in an FSx for ONTAP SnapLock volume.
*/
public void setAutocommitPeriod(AutocommitPeriod autocommitPeriod) {
this.autocommitPeriod = autocommitPeriod;
}
/**
*
* The configuration object for setting the autocommit period of files in an FSx for ONTAP SnapLock volume.
*
*
* @return The configuration object for setting the autocommit period of files in an FSx for ONTAP SnapLock volume.
*/
public AutocommitPeriod getAutocommitPeriod() {
return this.autocommitPeriod;
}
/**
*
* The configuration object for setting the autocommit period of files in an FSx for ONTAP SnapLock volume.
*
*
* @param autocommitPeriod
* The configuration object for setting the autocommit period of files in an FSx for ONTAP SnapLock volume.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public UpdateSnaplockConfiguration withAutocommitPeriod(AutocommitPeriod autocommitPeriod) {
setAutocommitPeriod(autocommitPeriod);
return this;
}
/**
*
* Enables, disables, or permanently disables privileged delete on an FSx for ONTAP SnapLock Enterprise volume.
* Enabling privileged delete allows SnapLock administrators to delete write once, read many (WORM) files even if
* they have active retention periods. PERMANENTLY_DISABLED
is a terminal state. If privileged delete
* is permanently disabled on a SnapLock volume, you can't re-enable it. The default value is DISABLED
.
*
*
* For more information, see Privileged
* delete.
*
*
* @param privilegedDelete
* Enables, disables, or permanently disables privileged delete on an FSx for ONTAP SnapLock Enterprise
* volume. Enabling privileged delete allows SnapLock administrators to delete write once, read many (WORM)
* files even if they have active retention periods. PERMANENTLY_DISABLED
is a terminal state.
* If privileged delete is permanently disabled on a SnapLock volume, you can't re-enable it. The default
* value is DISABLED
.
*
* For more information, see Privileged delete.
* @see PrivilegedDelete
*/
public void setPrivilegedDelete(String privilegedDelete) {
this.privilegedDelete = privilegedDelete;
}
/**
*
* Enables, disables, or permanently disables privileged delete on an FSx for ONTAP SnapLock Enterprise volume.
* Enabling privileged delete allows SnapLock administrators to delete write once, read many (WORM) files even if
* they have active retention periods. PERMANENTLY_DISABLED
is a terminal state. If privileged delete
* is permanently disabled on a SnapLock volume, you can't re-enable it. The default value is DISABLED
.
*
*
* For more information, see Privileged
* delete.
*
*
* @return Enables, disables, or permanently disables privileged delete on an FSx for ONTAP SnapLock Enterprise
* volume. Enabling privileged delete allows SnapLock administrators to delete write once, read many (WORM)
* files even if they have active retention periods. PERMANENTLY_DISABLED
is a terminal state.
* If privileged delete is permanently disabled on a SnapLock volume, you can't re-enable it. The default
* value is DISABLED
.
*
* For more information, see Privileged delete.
* @see PrivilegedDelete
*/
public String getPrivilegedDelete() {
return this.privilegedDelete;
}
/**
*
* Enables, disables, or permanently disables privileged delete on an FSx for ONTAP SnapLock Enterprise volume.
* Enabling privileged delete allows SnapLock administrators to delete write once, read many (WORM) files even if
* they have active retention periods. PERMANENTLY_DISABLED
is a terminal state. If privileged delete
* is permanently disabled on a SnapLock volume, you can't re-enable it. The default value is DISABLED
.
*
*
* For more information, see Privileged
* delete.
*
*
* @param privilegedDelete
* Enables, disables, or permanently disables privileged delete on an FSx for ONTAP SnapLock Enterprise
* volume. Enabling privileged delete allows SnapLock administrators to delete write once, read many (WORM)
* files even if they have active retention periods. PERMANENTLY_DISABLED
is a terminal state.
* If privileged delete is permanently disabled on a SnapLock volume, you can't re-enable it. The default
* value is DISABLED
.
*
* For more information, see Privileged delete.
* @return Returns a reference to this object so that method calls can be chained together.
* @see PrivilegedDelete
*/
public UpdateSnaplockConfiguration withPrivilegedDelete(String privilegedDelete) {
setPrivilegedDelete(privilegedDelete);
return this;
}
/**
*
* Enables, disables, or permanently disables privileged delete on an FSx for ONTAP SnapLock Enterprise volume.
* Enabling privileged delete allows SnapLock administrators to delete write once, read many (WORM) files even if
* they have active retention periods. PERMANENTLY_DISABLED
is a terminal state. If privileged delete
* is permanently disabled on a SnapLock volume, you can't re-enable it. The default value is DISABLED
.
*
*
* For more information, see Privileged
* delete.
*
*
* @param privilegedDelete
* Enables, disables, or permanently disables privileged delete on an FSx for ONTAP SnapLock Enterprise
* volume. Enabling privileged delete allows SnapLock administrators to delete write once, read many (WORM)
* files even if they have active retention periods. PERMANENTLY_DISABLED
is a terminal state.
* If privileged delete is permanently disabled on a SnapLock volume, you can't re-enable it. The default
* value is DISABLED
.
*
* For more information, see Privileged delete.
* @return Returns a reference to this object so that method calls can be chained together.
* @see PrivilegedDelete
*/
public UpdateSnaplockConfiguration withPrivilegedDelete(PrivilegedDelete privilegedDelete) {
this.privilegedDelete = privilegedDelete.toString();
return this;
}
/**
*
* Specifies the retention period of an FSx for ONTAP SnapLock volume.
*
*
* @param retentionPeriod
* Specifies the retention period of an FSx for ONTAP SnapLock volume.
*/
public void setRetentionPeriod(SnaplockRetentionPeriod retentionPeriod) {
this.retentionPeriod = retentionPeriod;
}
/**
*
* Specifies the retention period of an FSx for ONTAP SnapLock volume.
*
*
* @return Specifies the retention period of an FSx for ONTAP SnapLock volume.
*/
public SnaplockRetentionPeriod getRetentionPeriod() {
return this.retentionPeriod;
}
/**
*
* Specifies the retention period of an FSx for ONTAP SnapLock volume.
*
*
* @param retentionPeriod
* Specifies the retention period of an FSx for ONTAP SnapLock volume.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public UpdateSnaplockConfiguration withRetentionPeriod(SnaplockRetentionPeriod retentionPeriod) {
setRetentionPeriod(retentionPeriod);
return this;
}
/**
*
* Enables or disables volume-append mode on an FSx for ONTAP SnapLock volume. Volume-append mode allows you to
* create WORM-appendable files and write data to them incrementally. The default value is false
.
*
*
* For more information, see Volume-append
* mode.
*
*
* @param volumeAppendModeEnabled
* Enables or disables volume-append mode on an FSx for ONTAP SnapLock volume. Volume-append mode allows you
* to create WORM-appendable files and write data to them incrementally. The default value is
* false
.
*
* For more information, see Volume-append
* mode.
*/
public void setVolumeAppendModeEnabled(Boolean volumeAppendModeEnabled) {
this.volumeAppendModeEnabled = volumeAppendModeEnabled;
}
/**
*
* Enables or disables volume-append mode on an FSx for ONTAP SnapLock volume. Volume-append mode allows you to
* create WORM-appendable files and write data to them incrementally. The default value is false
.
*
*
* For more information, see Volume-append
* mode.
*
*
* @return Enables or disables volume-append mode on an FSx for ONTAP SnapLock volume. Volume-append mode allows you
* to create WORM-appendable files and write data to them incrementally. The default value is
* false
.
*
* For more information, see Volume-append
* mode.
*/
public Boolean getVolumeAppendModeEnabled() {
return this.volumeAppendModeEnabled;
}
/**
*
* Enables or disables volume-append mode on an FSx for ONTAP SnapLock volume. Volume-append mode allows you to
* create WORM-appendable files and write data to them incrementally. The default value is false
.
*
*
* For more information, see Volume-append
* mode.
*
*
* @param volumeAppendModeEnabled
* Enables or disables volume-append mode on an FSx for ONTAP SnapLock volume. Volume-append mode allows you
* to create WORM-appendable files and write data to them incrementally. The default value is
* false
.
*
* For more information, see Volume-append
* mode.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public UpdateSnaplockConfiguration withVolumeAppendModeEnabled(Boolean volumeAppendModeEnabled) {
setVolumeAppendModeEnabled(volumeAppendModeEnabled);
return this;
}
/**
*
* Enables or disables volume-append mode on an FSx for ONTAP SnapLock volume. Volume-append mode allows you to
* create WORM-appendable files and write data to them incrementally. The default value is false
.
*
*
* For more information, see Volume-append
* mode.
*
*
* @return Enables or disables volume-append mode on an FSx for ONTAP SnapLock volume. Volume-append mode allows you
* to create WORM-appendable files and write data to them incrementally. The default value is
* false
.
*
* For more information, see Volume-append
* mode.
*/
public Boolean isVolumeAppendModeEnabled() {
return this.volumeAppendModeEnabled;
}
/**
* 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 (getAuditLogVolume() != null)
sb.append("AuditLogVolume: ").append(getAuditLogVolume()).append(",");
if (getAutocommitPeriod() != null)
sb.append("AutocommitPeriod: ").append(getAutocommitPeriod()).append(",");
if (getPrivilegedDelete() != null)
sb.append("PrivilegedDelete: ").append(getPrivilegedDelete()).append(",");
if (getRetentionPeriod() != null)
sb.append("RetentionPeriod: ").append(getRetentionPeriod()).append(",");
if (getVolumeAppendModeEnabled() != null)
sb.append("VolumeAppendModeEnabled: ").append(getVolumeAppendModeEnabled());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof UpdateSnaplockConfiguration == false)
return false;
UpdateSnaplockConfiguration other = (UpdateSnaplockConfiguration) obj;
if (other.getAuditLogVolume() == null ^ this.getAuditLogVolume() == null)
return false;
if (other.getAuditLogVolume() != null && other.getAuditLogVolume().equals(this.getAuditLogVolume()) == false)
return false;
if (other.getAutocommitPeriod() == null ^ this.getAutocommitPeriod() == null)
return false;
if (other.getAutocommitPeriod() != null && other.getAutocommitPeriod().equals(this.getAutocommitPeriod()) == false)
return false;
if (other.getPrivilegedDelete() == null ^ this.getPrivilegedDelete() == null)
return false;
if (other.getPrivilegedDelete() != null && other.getPrivilegedDelete().equals(this.getPrivilegedDelete()) == false)
return false;
if (other.getRetentionPeriod() == null ^ this.getRetentionPeriod() == null)
return false;
if (other.getRetentionPeriod() != null && other.getRetentionPeriod().equals(this.getRetentionPeriod()) == false)
return false;
if (other.getVolumeAppendModeEnabled() == null ^ this.getVolumeAppendModeEnabled() == null)
return false;
if (other.getVolumeAppendModeEnabled() != null && other.getVolumeAppendModeEnabled().equals(this.getVolumeAppendModeEnabled()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getAuditLogVolume() == null) ? 0 : getAuditLogVolume().hashCode());
hashCode = prime * hashCode + ((getAutocommitPeriod() == null) ? 0 : getAutocommitPeriod().hashCode());
hashCode = prime * hashCode + ((getPrivilegedDelete() == null) ? 0 : getPrivilegedDelete().hashCode());
hashCode = prime * hashCode + ((getRetentionPeriod() == null) ? 0 : getRetentionPeriod().hashCode());
hashCode = prime * hashCode + ((getVolumeAppendModeEnabled() == null) ? 0 : getVolumeAppendModeEnabled().hashCode());
return hashCode;
}
@Override
public UpdateSnaplockConfiguration clone() {
try {
return (UpdateSnaplockConfiguration) 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.fsx.model.transform.UpdateSnaplockConfigurationMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}