Class KeySigningKey
- All Implemented Interfaces:
Serializable,SdkPojo,ToCopyableBuilder<KeySigningKey.Builder,KeySigningKey>
A key-signing key (KSK) is a complex type that represents a public/private key pair. The private key is used to generate a digital signature for the zone signing key (ZSK). The public key is stored in the DNS and is used to authenticate the ZSK. A KSK is always associated with a hosted zone; it cannot exist by itself.
- See Also:
-
Nested Class Summary
Nested Classes -
Method Summary
Modifier and TypeMethodDescriptionstatic KeySigningKey.Builderbuilder()final InstantThe date when the key-signing key (KSK) was created.final StringA string used to represent the delegation signer digest algorithm.final IntegerAn integer used to represent the delegation signer digest algorithm.final StringA cryptographic digest of a DNSKEY resource record (RR).final StringA string that represents a DNSKEY record.final StringdsRecord()A string that represents a delegation signer (DS) record.final booleanfinal booleanequalsBySdkFields(Object obj) Indicates whether some other object is "equal to" this one by SDK fields.final Integerflag()An integer that specifies how the key is used.final <T> Optional<T> getValueForField(String fieldName, Class<T> clazz) final inthashCode()final IntegerkeyTag()An integer used to identify the DNSSEC record for the domain name.final StringkmsArn()The Amazon resource name (ARN) used to identify the customer managed key in Key Management Service (KMS).final InstantThe last time that the key-signing key (KSK) was changed.final Stringname()A string used to identify a key-signing key (KSK).final StringThe public key, represented as a Base64 encoding, as required by RFC-4034 Page 5.static Class<? extends KeySigningKey.Builder> final StringA string used to represent the signing algorithm.final IntegerAn integer used to represent the signing algorithm.final Stringstatus()A string that represents the current key-signing key (KSK) status.final StringThe status message provided for the following key-signing key (KSK) statuses:ACTION_NEEDEDorINTERNAL_FAILURE.Take this object and create a builder that contains all of the current property values of this object.final StringtoString()Returns a string representation of this object.Methods inherited from interface software.amazon.awssdk.utils.builder.ToCopyableBuilder
copy
-
Method Details
-
name
A string used to identify a key-signing key (KSK).
Namecan include numbers, letters, and underscores (_).Namemust be unique for each key-signing key in the same hosted zone.- Returns:
- A string used to identify a key-signing key (KSK).
Namecan include numbers, letters, and underscores (_).Namemust be unique for each key-signing key in the same hosted zone.
-
kmsArn
The Amazon resource name (ARN) used to identify the customer managed key in Key Management Service (KMS). The
KmsArnmust be unique for each key-signing key (KSK) in a single hosted zone.You must configure the customer managed key as follows:
- Status
-
Enabled
- Key spec
-
ECC_NIST_P256
- Key usage
-
Sign and verify
- Key policy
-
The key policy must give permission for the following actions:
-
DescribeKey
-
GetPublicKey
-
Sign
The key policy must also include the Amazon Route 53 service in the principal for your account. Specify the following:
-
"Service": "dnssec-route53.amazonaws.com"
-
For more information about working with the customer managed key in KMS, see Key Management Service concepts.
- Returns:
- The Amazon resource name (ARN) used to identify the customer managed key in Key Management Service (KMS).
The
KmsArnmust be unique for each key-signing key (KSK) in a single hosted zone.You must configure the customer managed key as follows:
- Status
-
Enabled
- Key spec
-
ECC_NIST_P256
- Key usage
-
Sign and verify
- Key policy
-
The key policy must give permission for the following actions:
-
DescribeKey
-
GetPublicKey
-
Sign
The key policy must also include the Amazon Route 53 service in the principal for your account. Specify the following:
-
"Service": "dnssec-route53.amazonaws.com"
-
For more information about working with the customer managed key in KMS, see Key Management Service concepts.
-
flag
An integer that specifies how the key is used. For key-signing key (KSK), this value is always 257.
- Returns:
- An integer that specifies how the key is used. For key-signing key (KSK), this value is always 257.
-
signingAlgorithmMnemonic
A string used to represent the signing algorithm. This value must follow the guidelines provided by RFC-8624 Section 3.1.
- Returns:
- A string used to represent the signing algorithm. This value must follow the guidelines provided by RFC-8624 Section 3.1.
-
signingAlgorithmType
An integer used to represent the signing algorithm. This value must follow the guidelines provided by RFC-8624 Section 3.1.
- Returns:
- An integer used to represent the signing algorithm. This value must follow the guidelines provided by RFC-8624 Section 3.1.
-
digestAlgorithmMnemonic
A string used to represent the delegation signer digest algorithm. This value must follow the guidelines provided by RFC-8624 Section 3.3.
- Returns:
- A string used to represent the delegation signer digest algorithm. This value must follow the guidelines provided by RFC-8624 Section 3.3.
-
digestAlgorithmType
An integer used to represent the delegation signer digest algorithm. This value must follow the guidelines provided by RFC-8624 Section 3.3.
- Returns:
- An integer used to represent the delegation signer digest algorithm. This value must follow the guidelines provided by RFC-8624 Section 3.3.
-
keyTag
An integer used to identify the DNSSEC record for the domain name. The process used to calculate the value is described in RFC-4034 Appendix B.
- Returns:
- An integer used to identify the DNSSEC record for the domain name. The process used to calculate the value is described in RFC-4034 Appendix B.
-
digestValue
A cryptographic digest of a DNSKEY resource record (RR). DNSKEY records are used to publish the public key that resolvers can use to verify DNSSEC signatures that are used to secure certain kinds of information provided by the DNS system.
- Returns:
- A cryptographic digest of a DNSKEY resource record (RR). DNSKEY records are used to publish the public key that resolvers can use to verify DNSSEC signatures that are used to secure certain kinds of information provided by the DNS system.
-
publicKey
The public key, represented as a Base64 encoding, as required by RFC-4034 Page 5.
- Returns:
- The public key, represented as a Base64 encoding, as required by RFC-4034 Page 5.
-
dsRecord
A string that represents a delegation signer (DS) record.
- Returns:
- A string that represents a delegation signer (DS) record.
-
dnskeyRecord
A string that represents a DNSKEY record.
- Returns:
- A string that represents a DNSKEY record.
-
status
A string that represents the current key-signing key (KSK) status.
Status can have one of the following values:
- ACTIVE
-
The KSK is being used for signing.
- INACTIVE
-
The KSK is not being used for signing.
- DELETING
-
The KSK is in the process of being deleted.
- ACTION_NEEDED
-
There is a problem with the KSK that requires you to take action to resolve. For example, the customer managed key might have been deleted, or the permissions for the customer managed key might have been changed.
- INTERNAL_FAILURE
-
There was an error during a request. Before you can continue to work with DNSSEC signing, including actions that involve this KSK, you must correct the problem. For example, you may need to activate or deactivate the KSK.
- Returns:
- A string that represents the current key-signing key (KSK) status.
Status can have one of the following values:
- ACTIVE
-
The KSK is being used for signing.
- INACTIVE
-
The KSK is not being used for signing.
- DELETING
-
The KSK is in the process of being deleted.
- ACTION_NEEDED
-
There is a problem with the KSK that requires you to take action to resolve. For example, the customer managed key might have been deleted, or the permissions for the customer managed key might have been changed.
- INTERNAL_FAILURE
-
There was an error during a request. Before you can continue to work with DNSSEC signing, including actions that involve this KSK, you must correct the problem. For example, you may need to activate or deactivate the KSK.
-
statusMessage
The status message provided for the following key-signing key (KSK) statuses:
ACTION_NEEDEDorINTERNAL_FAILURE. The status message includes information about what the problem might be and steps that you can take to correct the issue.- Returns:
- The status message provided for the following key-signing key (KSK) statuses:
ACTION_NEEDEDorINTERNAL_FAILURE. The status message includes information about what the problem might be and steps that you can take to correct the issue.
-
createdDate
The date when the key-signing key (KSK) was created.
- Returns:
- The date when the key-signing key (KSK) was created.
-
lastModifiedDate
The last time that the key-signing key (KSK) was changed.
- Returns:
- The last time that the key-signing key (KSK) was changed.
-
toBuilder
Description copied from interface:ToCopyableBuilderTake this object and create a builder that contains all of the current property values of this object.- Specified by:
toBuilderin interfaceToCopyableBuilder<KeySigningKey.Builder,KeySigningKey> - Returns:
- a builder for type T
-
builder
-
serializableBuilderClass
-
hashCode
-
equals
-
equalsBySdkFields
Description copied from interface:SdkPojoIndicates whether some other object is "equal to" this one by SDK fields. An SDK field is a modeled, non-inherited field in anSdkPojoclass, and is generated based on a service model.If an
SdkPojoclass does not have any inherited fields,equalsBySdkFieldsandequalsare essentially the same.- Specified by:
equalsBySdkFieldsin interfaceSdkPojo- Parameters:
obj- the object to be compared with- Returns:
- true if the other object equals to this object by sdk fields, false otherwise.
-
toString
-
getValueForField
-
sdkFields
-
sdkFieldNameToField
- Specified by:
sdkFieldNameToFieldin interfaceSdkPojo- Returns:
- The mapping between the field name and its corresponding field.
-