com.amazonaws.services.paymentcryptography.model.Key Maven / Gradle / Ivy
/*
* Copyright 2018-2023 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.paymentcryptography.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;
/**
*
* Metadata about an Amazon Web Services Payment Cryptography key.
*
*
* @see AWS API
* Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class Key implements Serializable, Cloneable, StructuredPojo {
/**
*
* The date and time when the key was created.
*
*/
private java.util.Date createTimestamp;
/**
*
* The date and time after which Amazon Web Services Payment Cryptography will delete the key. This value is present
* only when KeyState
is DELETE_PENDING
and the key is scheduled for deletion.
*
*/
private java.util.Date deletePendingTimestamp;
/**
*
* The date and time after which Amazon Web Services Payment Cryptography will delete the key. This value is present
* only when when the KeyState
is DELETE_COMPLETE
and the Amazon Web Services Payment
* Cryptography key is deleted.
*
*/
private java.util.Date deleteTimestamp;
/**
*
* Specifies whether the key is enabled.
*
*/
private Boolean enabled;
/**
*
* Specifies whether the key is exportable. This data is immutable after the key is created.
*
*/
private Boolean exportable;
/**
*
* The Amazon Resource Name (ARN) of the key.
*
*/
private String keyArn;
/**
*
* The role of the key, the algorithm it supports, and the cryptographic operations allowed with the key. This data
* is immutable after the key is created.
*
*/
private KeyAttributes keyAttributes;
/**
*
* The key check value (KCV) is used to check if all parties holding a given key have the same key or to detect that
* a key has changed. Amazon Web Services Payment Cryptography calculates the KCV by using standard algorithms,
* typically by encrypting 8 or 16 bytes or "00" or "01" and then truncating the result to the first 3 bytes, or 6
* hex digits, of the resulting cryptogram.
*
*/
private String keyCheckValue;
/**
*
* The algorithm used for calculating key check value (KCV) for DES and AES keys. For a DES key, Amazon Web Services
* Payment Cryptography computes the KCV by encrypting 8 bytes, each with value '00', with the key to be checked and
* retaining the 3 highest order bytes of the encrypted result. For an AES key, Amazon Web Services Payment
* Cryptography computes the KCV by encrypting 8 bytes, each with value '01', with the key to be checked and
* retaining the 3 highest order bytes of the encrypted result.
*
*/
private String keyCheckValueAlgorithm;
/**
*
* The source of the key material. For keys created within Amazon Web Services Payment Cryptography, the value is
* AWS_PAYMENT_CRYPTOGRAPHY
. For keys imported into Amazon Web Services Payment Cryptography, the value
* is EXTERNAL
.
*
*/
private String keyOrigin;
/**
*
* The state of key that is being created or deleted.
*
*/
private String keyState;
/**
*
* The date and time after which Amazon Web Services Payment Cryptography will start using the key material for
* cryptographic operations.
*
*/
private java.util.Date usageStartTimestamp;
/**
*
* The date and time after which Amazon Web Services Payment Cryptography will stop using the key material for
* cryptographic operations.
*
*/
private java.util.Date usageStopTimestamp;
/**
*
* The date and time when the key was created.
*
*
* @param createTimestamp
* The date and time when the key was created.
*/
public void setCreateTimestamp(java.util.Date createTimestamp) {
this.createTimestamp = createTimestamp;
}
/**
*
* The date and time when the key was created.
*
*
* @return The date and time when the key was created.
*/
public java.util.Date getCreateTimestamp() {
return this.createTimestamp;
}
/**
*
* The date and time when the key was created.
*
*
* @param createTimestamp
* The date and time when the key was created.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Key withCreateTimestamp(java.util.Date createTimestamp) {
setCreateTimestamp(createTimestamp);
return this;
}
/**
*
* The date and time after which Amazon Web Services Payment Cryptography will delete the key. This value is present
* only when KeyState
is DELETE_PENDING
and the key is scheduled for deletion.
*
*
* @param deletePendingTimestamp
* The date and time after which Amazon Web Services Payment Cryptography will delete the key. This value is
* present only when KeyState
is DELETE_PENDING
and the key is scheduled for
* deletion.
*/
public void setDeletePendingTimestamp(java.util.Date deletePendingTimestamp) {
this.deletePendingTimestamp = deletePendingTimestamp;
}
/**
*
* The date and time after which Amazon Web Services Payment Cryptography will delete the key. This value is present
* only when KeyState
is DELETE_PENDING
and the key is scheduled for deletion.
*
*
* @return The date and time after which Amazon Web Services Payment Cryptography will delete the key. This value is
* present only when KeyState
is DELETE_PENDING
and the key is scheduled for
* deletion.
*/
public java.util.Date getDeletePendingTimestamp() {
return this.deletePendingTimestamp;
}
/**
*
* The date and time after which Amazon Web Services Payment Cryptography will delete the key. This value is present
* only when KeyState
is DELETE_PENDING
and the key is scheduled for deletion.
*
*
* @param deletePendingTimestamp
* The date and time after which Amazon Web Services Payment Cryptography will delete the key. This value is
* present only when KeyState
is DELETE_PENDING
and the key is scheduled for
* deletion.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Key withDeletePendingTimestamp(java.util.Date deletePendingTimestamp) {
setDeletePendingTimestamp(deletePendingTimestamp);
return this;
}
/**
*
* The date and time after which Amazon Web Services Payment Cryptography will delete the key. This value is present
* only when when the KeyState
is DELETE_COMPLETE
and the Amazon Web Services Payment
* Cryptography key is deleted.
*
*
* @param deleteTimestamp
* The date and time after which Amazon Web Services Payment Cryptography will delete the key. This value is
* present only when when the KeyState
is DELETE_COMPLETE
and the Amazon Web
* Services Payment Cryptography key is deleted.
*/
public void setDeleteTimestamp(java.util.Date deleteTimestamp) {
this.deleteTimestamp = deleteTimestamp;
}
/**
*
* The date and time after which Amazon Web Services Payment Cryptography will delete the key. This value is present
* only when when the KeyState
is DELETE_COMPLETE
and the Amazon Web Services Payment
* Cryptography key is deleted.
*
*
* @return The date and time after which Amazon Web Services Payment Cryptography will delete the key. This value is
* present only when when the KeyState
is DELETE_COMPLETE
and the Amazon Web
* Services Payment Cryptography key is deleted.
*/
public java.util.Date getDeleteTimestamp() {
return this.deleteTimestamp;
}
/**
*
* The date and time after which Amazon Web Services Payment Cryptography will delete the key. This value is present
* only when when the KeyState
is DELETE_COMPLETE
and the Amazon Web Services Payment
* Cryptography key is deleted.
*
*
* @param deleteTimestamp
* The date and time after which Amazon Web Services Payment Cryptography will delete the key. This value is
* present only when when the KeyState
is DELETE_COMPLETE
and the Amazon Web
* Services Payment Cryptography key is deleted.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Key withDeleteTimestamp(java.util.Date deleteTimestamp) {
setDeleteTimestamp(deleteTimestamp);
return this;
}
/**
*
* Specifies whether the key is enabled.
*
*
* @param enabled
* Specifies whether the key is enabled.
*/
public void setEnabled(Boolean enabled) {
this.enabled = enabled;
}
/**
*
* Specifies whether the key is enabled.
*
*
* @return Specifies whether the key is enabled.
*/
public Boolean getEnabled() {
return this.enabled;
}
/**
*
* Specifies whether the key is enabled.
*
*
* @param enabled
* Specifies whether the key is enabled.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Key withEnabled(Boolean enabled) {
setEnabled(enabled);
return this;
}
/**
*
* Specifies whether the key is enabled.
*
*
* @return Specifies whether the key is enabled.
*/
public Boolean isEnabled() {
return this.enabled;
}
/**
*
* Specifies whether the key is exportable. This data is immutable after the key is created.
*
*
* @param exportable
* Specifies whether the key is exportable. This data is immutable after the key is created.
*/
public void setExportable(Boolean exportable) {
this.exportable = exportable;
}
/**
*
* Specifies whether the key is exportable. This data is immutable after the key is created.
*
*
* @return Specifies whether the key is exportable. This data is immutable after the key is created.
*/
public Boolean getExportable() {
return this.exportable;
}
/**
*
* Specifies whether the key is exportable. This data is immutable after the key is created.
*
*
* @param exportable
* Specifies whether the key is exportable. This data is immutable after the key is created.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Key withExportable(Boolean exportable) {
setExportable(exportable);
return this;
}
/**
*
* Specifies whether the key is exportable. This data is immutable after the key is created.
*
*
* @return Specifies whether the key is exportable. This data is immutable after the key is created.
*/
public Boolean isExportable() {
return this.exportable;
}
/**
*
* The Amazon Resource Name (ARN) of the key.
*
*
* @param keyArn
* The Amazon Resource Name (ARN) of the key.
*/
public void setKeyArn(String keyArn) {
this.keyArn = keyArn;
}
/**
*
* The Amazon Resource Name (ARN) of the key.
*
*
* @return The Amazon Resource Name (ARN) of the key.
*/
public String getKeyArn() {
return this.keyArn;
}
/**
*
* The Amazon Resource Name (ARN) of the key.
*
*
* @param keyArn
* The Amazon Resource Name (ARN) of the key.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Key withKeyArn(String keyArn) {
setKeyArn(keyArn);
return this;
}
/**
*
* The role of the key, the algorithm it supports, and the cryptographic operations allowed with the key. This data
* is immutable after the key is created.
*
*
* @param keyAttributes
* The role of the key, the algorithm it supports, and the cryptographic operations allowed with the key.
* This data is immutable after the key is created.
*/
public void setKeyAttributes(KeyAttributes keyAttributes) {
this.keyAttributes = keyAttributes;
}
/**
*
* The role of the key, the algorithm it supports, and the cryptographic operations allowed with the key. This data
* is immutable after the key is created.
*
*
* @return The role of the key, the algorithm it supports, and the cryptographic operations allowed with the key.
* This data is immutable after the key is created.
*/
public KeyAttributes getKeyAttributes() {
return this.keyAttributes;
}
/**
*
* The role of the key, the algorithm it supports, and the cryptographic operations allowed with the key. This data
* is immutable after the key is created.
*
*
* @param keyAttributes
* The role of the key, the algorithm it supports, and the cryptographic operations allowed with the key.
* This data is immutable after the key is created.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Key withKeyAttributes(KeyAttributes keyAttributes) {
setKeyAttributes(keyAttributes);
return this;
}
/**
*
* The key check value (KCV) is used to check if all parties holding a given key have the same key or to detect that
* a key has changed. Amazon Web Services Payment Cryptography calculates the KCV by using standard algorithms,
* typically by encrypting 8 or 16 bytes or "00" or "01" and then truncating the result to the first 3 bytes, or 6
* hex digits, of the resulting cryptogram.
*
*
* @param keyCheckValue
* The key check value (KCV) is used to check if all parties holding a given key have the same key or to
* detect that a key has changed. Amazon Web Services Payment Cryptography calculates the KCV by using
* standard algorithms, typically by encrypting 8 or 16 bytes or "00" or "01" and then truncating the result
* to the first 3 bytes, or 6 hex digits, of the resulting cryptogram.
*/
public void setKeyCheckValue(String keyCheckValue) {
this.keyCheckValue = keyCheckValue;
}
/**
*
* The key check value (KCV) is used to check if all parties holding a given key have the same key or to detect that
* a key has changed. Amazon Web Services Payment Cryptography calculates the KCV by using standard algorithms,
* typically by encrypting 8 or 16 bytes or "00" or "01" and then truncating the result to the first 3 bytes, or 6
* hex digits, of the resulting cryptogram.
*
*
* @return The key check value (KCV) is used to check if all parties holding a given key have the same key or to
* detect that a key has changed. Amazon Web Services Payment Cryptography calculates the KCV by using
* standard algorithms, typically by encrypting 8 or 16 bytes or "00" or "01" and then truncating the result
* to the first 3 bytes, or 6 hex digits, of the resulting cryptogram.
*/
public String getKeyCheckValue() {
return this.keyCheckValue;
}
/**
*
* The key check value (KCV) is used to check if all parties holding a given key have the same key or to detect that
* a key has changed. Amazon Web Services Payment Cryptography calculates the KCV by using standard algorithms,
* typically by encrypting 8 or 16 bytes or "00" or "01" and then truncating the result to the first 3 bytes, or 6
* hex digits, of the resulting cryptogram.
*
*
* @param keyCheckValue
* The key check value (KCV) is used to check if all parties holding a given key have the same key or to
* detect that a key has changed. Amazon Web Services Payment Cryptography calculates the KCV by using
* standard algorithms, typically by encrypting 8 or 16 bytes or "00" or "01" and then truncating the result
* to the first 3 bytes, or 6 hex digits, of the resulting cryptogram.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Key withKeyCheckValue(String keyCheckValue) {
setKeyCheckValue(keyCheckValue);
return this;
}
/**
*
* The algorithm used for calculating key check value (KCV) for DES and AES keys. For a DES key, Amazon Web Services
* Payment Cryptography computes the KCV by encrypting 8 bytes, each with value '00', with the key to be checked and
* retaining the 3 highest order bytes of the encrypted result. For an AES key, Amazon Web Services Payment
* Cryptography computes the KCV by encrypting 8 bytes, each with value '01', with the key to be checked and
* retaining the 3 highest order bytes of the encrypted result.
*
*
* @param keyCheckValueAlgorithm
* The algorithm used for calculating key check value (KCV) for DES and AES keys. For a DES key, Amazon Web
* Services Payment Cryptography computes the KCV by encrypting 8 bytes, each with value '00', with the key
* to be checked and retaining the 3 highest order bytes of the encrypted result. For an AES key, Amazon Web
* Services Payment Cryptography computes the KCV by encrypting 8 bytes, each with value '01', with the key
* to be checked and retaining the 3 highest order bytes of the encrypted result.
* @see KeyCheckValueAlgorithm
*/
public void setKeyCheckValueAlgorithm(String keyCheckValueAlgorithm) {
this.keyCheckValueAlgorithm = keyCheckValueAlgorithm;
}
/**
*
* The algorithm used for calculating key check value (KCV) for DES and AES keys. For a DES key, Amazon Web Services
* Payment Cryptography computes the KCV by encrypting 8 bytes, each with value '00', with the key to be checked and
* retaining the 3 highest order bytes of the encrypted result. For an AES key, Amazon Web Services Payment
* Cryptography computes the KCV by encrypting 8 bytes, each with value '01', with the key to be checked and
* retaining the 3 highest order bytes of the encrypted result.
*
*
* @return The algorithm used for calculating key check value (KCV) for DES and AES keys. For a DES key, Amazon Web
* Services Payment Cryptography computes the KCV by encrypting 8 bytes, each with value '00', with the key
* to be checked and retaining the 3 highest order bytes of the encrypted result. For an AES key, Amazon Web
* Services Payment Cryptography computes the KCV by encrypting 8 bytes, each with value '01', with the key
* to be checked and retaining the 3 highest order bytes of the encrypted result.
* @see KeyCheckValueAlgorithm
*/
public String getKeyCheckValueAlgorithm() {
return this.keyCheckValueAlgorithm;
}
/**
*
* The algorithm used for calculating key check value (KCV) for DES and AES keys. For a DES key, Amazon Web Services
* Payment Cryptography computes the KCV by encrypting 8 bytes, each with value '00', with the key to be checked and
* retaining the 3 highest order bytes of the encrypted result. For an AES key, Amazon Web Services Payment
* Cryptography computes the KCV by encrypting 8 bytes, each with value '01', with the key to be checked and
* retaining the 3 highest order bytes of the encrypted result.
*
*
* @param keyCheckValueAlgorithm
* The algorithm used for calculating key check value (KCV) for DES and AES keys. For a DES key, Amazon Web
* Services Payment Cryptography computes the KCV by encrypting 8 bytes, each with value '00', with the key
* to be checked and retaining the 3 highest order bytes of the encrypted result. For an AES key, Amazon Web
* Services Payment Cryptography computes the KCV by encrypting 8 bytes, each with value '01', with the key
* to be checked and retaining the 3 highest order bytes of the encrypted result.
* @return Returns a reference to this object so that method calls can be chained together.
* @see KeyCheckValueAlgorithm
*/
public Key withKeyCheckValueAlgorithm(String keyCheckValueAlgorithm) {
setKeyCheckValueAlgorithm(keyCheckValueAlgorithm);
return this;
}
/**
*
* The algorithm used for calculating key check value (KCV) for DES and AES keys. For a DES key, Amazon Web Services
* Payment Cryptography computes the KCV by encrypting 8 bytes, each with value '00', with the key to be checked and
* retaining the 3 highest order bytes of the encrypted result. For an AES key, Amazon Web Services Payment
* Cryptography computes the KCV by encrypting 8 bytes, each with value '01', with the key to be checked and
* retaining the 3 highest order bytes of the encrypted result.
*
*
* @param keyCheckValueAlgorithm
* The algorithm used for calculating key check value (KCV) for DES and AES keys. For a DES key, Amazon Web
* Services Payment Cryptography computes the KCV by encrypting 8 bytes, each with value '00', with the key
* to be checked and retaining the 3 highest order bytes of the encrypted result. For an AES key, Amazon Web
* Services Payment Cryptography computes the KCV by encrypting 8 bytes, each with value '01', with the key
* to be checked and retaining the 3 highest order bytes of the encrypted result.
* @return Returns a reference to this object so that method calls can be chained together.
* @see KeyCheckValueAlgorithm
*/
public Key withKeyCheckValueAlgorithm(KeyCheckValueAlgorithm keyCheckValueAlgorithm) {
this.keyCheckValueAlgorithm = keyCheckValueAlgorithm.toString();
return this;
}
/**
*
* The source of the key material. For keys created within Amazon Web Services Payment Cryptography, the value is
* AWS_PAYMENT_CRYPTOGRAPHY
. For keys imported into Amazon Web Services Payment Cryptography, the value
* is EXTERNAL
.
*
*
* @param keyOrigin
* The source of the key material. For keys created within Amazon Web Services Payment Cryptography, the
* value is AWS_PAYMENT_CRYPTOGRAPHY
. For keys imported into Amazon Web Services Payment
* Cryptography, the value is EXTERNAL
.
* @see KeyOrigin
*/
public void setKeyOrigin(String keyOrigin) {
this.keyOrigin = keyOrigin;
}
/**
*
* The source of the key material. For keys created within Amazon Web Services Payment Cryptography, the value is
* AWS_PAYMENT_CRYPTOGRAPHY
. For keys imported into Amazon Web Services Payment Cryptography, the value
* is EXTERNAL
.
*
*
* @return The source of the key material. For keys created within Amazon Web Services Payment Cryptography, the
* value is AWS_PAYMENT_CRYPTOGRAPHY
. For keys imported into Amazon Web Services Payment
* Cryptography, the value is EXTERNAL
.
* @see KeyOrigin
*/
public String getKeyOrigin() {
return this.keyOrigin;
}
/**
*
* The source of the key material. For keys created within Amazon Web Services Payment Cryptography, the value is
* AWS_PAYMENT_CRYPTOGRAPHY
. For keys imported into Amazon Web Services Payment Cryptography, the value
* is EXTERNAL
.
*
*
* @param keyOrigin
* The source of the key material. For keys created within Amazon Web Services Payment Cryptography, the
* value is AWS_PAYMENT_CRYPTOGRAPHY
. For keys imported into Amazon Web Services Payment
* Cryptography, the value is EXTERNAL
.
* @return Returns a reference to this object so that method calls can be chained together.
* @see KeyOrigin
*/
public Key withKeyOrigin(String keyOrigin) {
setKeyOrigin(keyOrigin);
return this;
}
/**
*
* The source of the key material. For keys created within Amazon Web Services Payment Cryptography, the value is
* AWS_PAYMENT_CRYPTOGRAPHY
. For keys imported into Amazon Web Services Payment Cryptography, the value
* is EXTERNAL
.
*
*
* @param keyOrigin
* The source of the key material. For keys created within Amazon Web Services Payment Cryptography, the
* value is AWS_PAYMENT_CRYPTOGRAPHY
. For keys imported into Amazon Web Services Payment
* Cryptography, the value is EXTERNAL
.
* @return Returns a reference to this object so that method calls can be chained together.
* @see KeyOrigin
*/
public Key withKeyOrigin(KeyOrigin keyOrigin) {
this.keyOrigin = keyOrigin.toString();
return this;
}
/**
*
* The state of key that is being created or deleted.
*
*
* @param keyState
* The state of key that is being created or deleted.
* @see KeyState
*/
public void setKeyState(String keyState) {
this.keyState = keyState;
}
/**
*
* The state of key that is being created or deleted.
*
*
* @return The state of key that is being created or deleted.
* @see KeyState
*/
public String getKeyState() {
return this.keyState;
}
/**
*
* The state of key that is being created or deleted.
*
*
* @param keyState
* The state of key that is being created or deleted.
* @return Returns a reference to this object so that method calls can be chained together.
* @see KeyState
*/
public Key withKeyState(String keyState) {
setKeyState(keyState);
return this;
}
/**
*
* The state of key that is being created or deleted.
*
*
* @param keyState
* The state of key that is being created or deleted.
* @return Returns a reference to this object so that method calls can be chained together.
* @see KeyState
*/
public Key withKeyState(KeyState keyState) {
this.keyState = keyState.toString();
return this;
}
/**
*
* The date and time after which Amazon Web Services Payment Cryptography will start using the key material for
* cryptographic operations.
*
*
* @param usageStartTimestamp
* The date and time after which Amazon Web Services Payment Cryptography will start using the key material
* for cryptographic operations.
*/
public void setUsageStartTimestamp(java.util.Date usageStartTimestamp) {
this.usageStartTimestamp = usageStartTimestamp;
}
/**
*
* The date and time after which Amazon Web Services Payment Cryptography will start using the key material for
* cryptographic operations.
*
*
* @return The date and time after which Amazon Web Services Payment Cryptography will start using the key material
* for cryptographic operations.
*/
public java.util.Date getUsageStartTimestamp() {
return this.usageStartTimestamp;
}
/**
*
* The date and time after which Amazon Web Services Payment Cryptography will start using the key material for
* cryptographic operations.
*
*
* @param usageStartTimestamp
* The date and time after which Amazon Web Services Payment Cryptography will start using the key material
* for cryptographic operations.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Key withUsageStartTimestamp(java.util.Date usageStartTimestamp) {
setUsageStartTimestamp(usageStartTimestamp);
return this;
}
/**
*
* The date and time after which Amazon Web Services Payment Cryptography will stop using the key material for
* cryptographic operations.
*
*
* @param usageStopTimestamp
* The date and time after which Amazon Web Services Payment Cryptography will stop using the key material
* for cryptographic operations.
*/
public void setUsageStopTimestamp(java.util.Date usageStopTimestamp) {
this.usageStopTimestamp = usageStopTimestamp;
}
/**
*
* The date and time after which Amazon Web Services Payment Cryptography will stop using the key material for
* cryptographic operations.
*
*
* @return The date and time after which Amazon Web Services Payment Cryptography will stop using the key material
* for cryptographic operations.
*/
public java.util.Date getUsageStopTimestamp() {
return this.usageStopTimestamp;
}
/**
*
* The date and time after which Amazon Web Services Payment Cryptography will stop using the key material for
* cryptographic operations.
*
*
* @param usageStopTimestamp
* The date and time after which Amazon Web Services Payment Cryptography will stop using the key material
* for cryptographic operations.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Key withUsageStopTimestamp(java.util.Date usageStopTimestamp) {
setUsageStopTimestamp(usageStopTimestamp);
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 (getCreateTimestamp() != null)
sb.append("CreateTimestamp: ").append(getCreateTimestamp()).append(",");
if (getDeletePendingTimestamp() != null)
sb.append("DeletePendingTimestamp: ").append(getDeletePendingTimestamp()).append(",");
if (getDeleteTimestamp() != null)
sb.append("DeleteTimestamp: ").append(getDeleteTimestamp()).append(",");
if (getEnabled() != null)
sb.append("Enabled: ").append(getEnabled()).append(",");
if (getExportable() != null)
sb.append("Exportable: ").append(getExportable()).append(",");
if (getKeyArn() != null)
sb.append("KeyArn: ").append(getKeyArn()).append(",");
if (getKeyAttributes() != null)
sb.append("KeyAttributes: ").append(getKeyAttributes()).append(",");
if (getKeyCheckValue() != null)
sb.append("KeyCheckValue: ").append(getKeyCheckValue()).append(",");
if (getKeyCheckValueAlgorithm() != null)
sb.append("KeyCheckValueAlgorithm: ").append(getKeyCheckValueAlgorithm()).append(",");
if (getKeyOrigin() != null)
sb.append("KeyOrigin: ").append(getKeyOrigin()).append(",");
if (getKeyState() != null)
sb.append("KeyState: ").append(getKeyState()).append(",");
if (getUsageStartTimestamp() != null)
sb.append("UsageStartTimestamp: ").append(getUsageStartTimestamp()).append(",");
if (getUsageStopTimestamp() != null)
sb.append("UsageStopTimestamp: ").append(getUsageStopTimestamp());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof Key == false)
return false;
Key other = (Key) obj;
if (other.getCreateTimestamp() == null ^ this.getCreateTimestamp() == null)
return false;
if (other.getCreateTimestamp() != null && other.getCreateTimestamp().equals(this.getCreateTimestamp()) == false)
return false;
if (other.getDeletePendingTimestamp() == null ^ this.getDeletePendingTimestamp() == null)
return false;
if (other.getDeletePendingTimestamp() != null && other.getDeletePendingTimestamp().equals(this.getDeletePendingTimestamp()) == false)
return false;
if (other.getDeleteTimestamp() == null ^ this.getDeleteTimestamp() == null)
return false;
if (other.getDeleteTimestamp() != null && other.getDeleteTimestamp().equals(this.getDeleteTimestamp()) == false)
return false;
if (other.getEnabled() == null ^ this.getEnabled() == null)
return false;
if (other.getEnabled() != null && other.getEnabled().equals(this.getEnabled()) == false)
return false;
if (other.getExportable() == null ^ this.getExportable() == null)
return false;
if (other.getExportable() != null && other.getExportable().equals(this.getExportable()) == false)
return false;
if (other.getKeyArn() == null ^ this.getKeyArn() == null)
return false;
if (other.getKeyArn() != null && other.getKeyArn().equals(this.getKeyArn()) == false)
return false;
if (other.getKeyAttributes() == null ^ this.getKeyAttributes() == null)
return false;
if (other.getKeyAttributes() != null && other.getKeyAttributes().equals(this.getKeyAttributes()) == false)
return false;
if (other.getKeyCheckValue() == null ^ this.getKeyCheckValue() == null)
return false;
if (other.getKeyCheckValue() != null && other.getKeyCheckValue().equals(this.getKeyCheckValue()) == false)
return false;
if (other.getKeyCheckValueAlgorithm() == null ^ this.getKeyCheckValueAlgorithm() == null)
return false;
if (other.getKeyCheckValueAlgorithm() != null && other.getKeyCheckValueAlgorithm().equals(this.getKeyCheckValueAlgorithm()) == false)
return false;
if (other.getKeyOrigin() == null ^ this.getKeyOrigin() == null)
return false;
if (other.getKeyOrigin() != null && other.getKeyOrigin().equals(this.getKeyOrigin()) == false)
return false;
if (other.getKeyState() == null ^ this.getKeyState() == null)
return false;
if (other.getKeyState() != null && other.getKeyState().equals(this.getKeyState()) == false)
return false;
if (other.getUsageStartTimestamp() == null ^ this.getUsageStartTimestamp() == null)
return false;
if (other.getUsageStartTimestamp() != null && other.getUsageStartTimestamp().equals(this.getUsageStartTimestamp()) == false)
return false;
if (other.getUsageStopTimestamp() == null ^ this.getUsageStopTimestamp() == null)
return false;
if (other.getUsageStopTimestamp() != null && other.getUsageStopTimestamp().equals(this.getUsageStopTimestamp()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getCreateTimestamp() == null) ? 0 : getCreateTimestamp().hashCode());
hashCode = prime * hashCode + ((getDeletePendingTimestamp() == null) ? 0 : getDeletePendingTimestamp().hashCode());
hashCode = prime * hashCode + ((getDeleteTimestamp() == null) ? 0 : getDeleteTimestamp().hashCode());
hashCode = prime * hashCode + ((getEnabled() == null) ? 0 : getEnabled().hashCode());
hashCode = prime * hashCode + ((getExportable() == null) ? 0 : getExportable().hashCode());
hashCode = prime * hashCode + ((getKeyArn() == null) ? 0 : getKeyArn().hashCode());
hashCode = prime * hashCode + ((getKeyAttributes() == null) ? 0 : getKeyAttributes().hashCode());
hashCode = prime * hashCode + ((getKeyCheckValue() == null) ? 0 : getKeyCheckValue().hashCode());
hashCode = prime * hashCode + ((getKeyCheckValueAlgorithm() == null) ? 0 : getKeyCheckValueAlgorithm().hashCode());
hashCode = prime * hashCode + ((getKeyOrigin() == null) ? 0 : getKeyOrigin().hashCode());
hashCode = prime * hashCode + ((getKeyState() == null) ? 0 : getKeyState().hashCode());
hashCode = prime * hashCode + ((getUsageStartTimestamp() == null) ? 0 : getUsageStartTimestamp().hashCode());
hashCode = prime * hashCode + ((getUsageStopTimestamp() == null) ? 0 : getUsageStopTimestamp().hashCode());
return hashCode;
}
@Override
public Key clone() {
try {
return (Key) 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.paymentcryptography.model.transform.KeyMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}