@Generated(value="com.amazonaws:aws-java-sdk-code-generator") public class CrlConfiguration extends Object implements Serializable, Cloneable, StructuredPojo
Contains configuration information for a certificate revocation list (CRL). Your private certificate authority (CA)
creates base CRLs. Delta CRLs are not supported. You can enable CRLs for your new or an existing private CA by
setting the Enabled parameter to true
. Your private CA writes CRLs to an S3 bucket that you
specify in the S3BucketName parameter. You can hide the name of your bucket by specifying a value for the
CustomCname parameter. Your private CA by default copies the CNAME or the S3 bucket name to the CRL
Distribution Points extension of each certificate it issues. If you want to configure this default behavior to be
something different, you can set the CrlDistributionPointExtensionConfiguration parameter. Your S3 bucket
policy must give write permission to Amazon Web Services Private CA.
Amazon Web Services Private CA assets that are stored in Amazon S3 can be protected with encryption. For more information, see Encrypting Your CRLs.
Your private CA uses the value in the ExpirationInDays parameter to calculate the nextUpdate field in the CRL. The CRL is refreshed prior to a certificate's expiration date or when a certificate is revoked. When a certificate is revoked, it appears in the CRL until the certificate expires, and then in one additional CRL after expiration, and it always appears in the audit report.
A CRL is typically updated approximately 30 minutes after a certificate is revoked. If for any reason a CRL update fails, Amazon Web Services Private CA makes further attempts every 15 minutes.
CRLs contain the following fields:
Version: The current version number defined in RFC 5280 is V2. The integer value is 0x1.
Signature Algorithm: The name of the algorithm used to sign the CRL.
Issuer: The X.500 distinguished name of your private CA that issued the CRL.
Last Update: The issue date and time of this CRL.
Next Update: The day and time by which the next CRL will be issued.
Revoked Certificates: List of revoked certificates. Each list item contains the following information.
Serial Number: The serial number, in hexadecimal format, of the revoked certificate.
Revocation Date: Date and time the certificate was revoked.
CRL Entry Extensions: Optional extensions for the CRL entry.
X509v3 CRL Reason Code: Reason the certificate was revoked.
CRL Extensions: Optional extensions for the CRL.
X509v3 Authority Key Identifier: Identifies the public key associated with the private key used to sign the certificate.
X509v3 CRL Number:: Decimal sequence number for the CRL.
Signature Algorithm: Algorithm used by your private CA to sign the CRL.
Signature Value: Signature computed over the CRL.
Certificate revocation lists created by Amazon Web Services Private CA are DER-encoded. You can use the following OpenSSL command to list a CRL.
openssl crl -inform DER -text -in crl_path -noout
For more information, see Planning a certificate revocation list (CRL) in the Amazon Web Services Private Certificate Authority User Guide
Constructor and Description |
---|
CrlConfiguration() |
Modifier and Type | Method and Description |
---|---|
CrlConfiguration |
clone() |
boolean |
equals(Object obj) |
CrlDistributionPointExtensionConfiguration |
getCrlDistributionPointExtensionConfiguration()
Configures the behavior of the CRL Distribution Point extension for certificates issued by your certificate
authority.
|
String |
getCustomCname()
Name inserted into the certificate CRL Distribution Points extension that enables the use of an alias for
the CRL distribution point.
|
Boolean |
getEnabled()
Boolean value that specifies whether certificate revocation lists (CRLs) are enabled.
|
Integer |
getExpirationInDays()
Validity period of the CRL in days.
|
String |
getS3BucketName()
Name of the S3 bucket that contains the CRL.
|
String |
getS3ObjectAcl()
Determines whether the CRL will be publicly readable or privately held in the CRL Amazon S3 bucket.
|
int |
hashCode() |
Boolean |
isEnabled()
Boolean value that specifies whether certificate revocation lists (CRLs) are enabled.
|
void |
marshall(ProtocolMarshaller protocolMarshaller)
Marshalls this structured data using the given
ProtocolMarshaller . |
void |
setCrlDistributionPointExtensionConfiguration(CrlDistributionPointExtensionConfiguration crlDistributionPointExtensionConfiguration)
Configures the behavior of the CRL Distribution Point extension for certificates issued by your certificate
authority.
|
void |
setCustomCname(String customCname)
Name inserted into the certificate CRL Distribution Points extension that enables the use of an alias for
the CRL distribution point.
|
void |
setEnabled(Boolean enabled)
Boolean value that specifies whether certificate revocation lists (CRLs) are enabled.
|
void |
setExpirationInDays(Integer expirationInDays)
Validity period of the CRL in days.
|
void |
setS3BucketName(String s3BucketName)
Name of the S3 bucket that contains the CRL.
|
void |
setS3ObjectAcl(String s3ObjectAcl)
Determines whether the CRL will be publicly readable or privately held in the CRL Amazon S3 bucket.
|
String |
toString()
Returns a string representation of this object.
|
CrlConfiguration |
withCrlDistributionPointExtensionConfiguration(CrlDistributionPointExtensionConfiguration crlDistributionPointExtensionConfiguration)
Configures the behavior of the CRL Distribution Point extension for certificates issued by your certificate
authority.
|
CrlConfiguration |
withCustomCname(String customCname)
Name inserted into the certificate CRL Distribution Points extension that enables the use of an alias for
the CRL distribution point.
|
CrlConfiguration |
withEnabled(Boolean enabled)
Boolean value that specifies whether certificate revocation lists (CRLs) are enabled.
|
CrlConfiguration |
withExpirationInDays(Integer expirationInDays)
Validity period of the CRL in days.
|
CrlConfiguration |
withS3BucketName(String s3BucketName)
Name of the S3 bucket that contains the CRL.
|
CrlConfiguration |
withS3ObjectAcl(S3ObjectAcl s3ObjectAcl)
Determines whether the CRL will be publicly readable or privately held in the CRL Amazon S3 bucket.
|
CrlConfiguration |
withS3ObjectAcl(String s3ObjectAcl)
Determines whether the CRL will be publicly readable or privately held in the CRL Amazon S3 bucket.
|
public void setEnabled(Boolean enabled)
Boolean value that specifies whether certificate revocation lists (CRLs) are enabled. You can use this value to enable certificate revocation for a new CA when you call the CreateCertificateAuthority action or for an existing CA when you call the UpdateCertificateAuthority action.
enabled
- Boolean value that specifies whether certificate revocation lists (CRLs) are enabled. You can use this
value to enable certificate revocation for a new CA when you call the CreateCertificateAuthority action or for an existing CA when you call the UpdateCertificateAuthority action.public Boolean getEnabled()
Boolean value that specifies whether certificate revocation lists (CRLs) are enabled. You can use this value to enable certificate revocation for a new CA when you call the CreateCertificateAuthority action or for an existing CA when you call the UpdateCertificateAuthority action.
public CrlConfiguration withEnabled(Boolean enabled)
Boolean value that specifies whether certificate revocation lists (CRLs) are enabled. You can use this value to enable certificate revocation for a new CA when you call the CreateCertificateAuthority action or for an existing CA when you call the UpdateCertificateAuthority action.
enabled
- Boolean value that specifies whether certificate revocation lists (CRLs) are enabled. You can use this
value to enable certificate revocation for a new CA when you call the CreateCertificateAuthority action or for an existing CA when you call the UpdateCertificateAuthority action.public Boolean isEnabled()
Boolean value that specifies whether certificate revocation lists (CRLs) are enabled. You can use this value to enable certificate revocation for a new CA when you call the CreateCertificateAuthority action or for an existing CA when you call the UpdateCertificateAuthority action.
public void setExpirationInDays(Integer expirationInDays)
Validity period of the CRL in days.
expirationInDays
- Validity period of the CRL in days.public Integer getExpirationInDays()
Validity period of the CRL in days.
public CrlConfiguration withExpirationInDays(Integer expirationInDays)
Validity period of the CRL in days.
expirationInDays
- Validity period of the CRL in days.public void setCustomCname(String customCname)
Name inserted into the certificate CRL Distribution Points extension that enables the use of an alias for the CRL distribution point. Use this value if you don't want the name of your S3 bucket to be public.
The content of a Canonical Name (CNAME) record must conform to RFC2396 restrictions on the use of special characters in URIs. Additionally, the value of the CNAME must not include a protocol prefix such as "http://" or "https://".
customCname
- Name inserted into the certificate CRL Distribution Points extension that enables the use of an
alias for the CRL distribution point. Use this value if you don't want the name of your S3 bucket to be
public. The content of a Canonical Name (CNAME) record must conform to RFC2396 restrictions on the use of special characters in URIs. Additionally, the value of the CNAME must not include a protocol prefix such as "http://" or "https://".
public String getCustomCname()
Name inserted into the certificate CRL Distribution Points extension that enables the use of an alias for the CRL distribution point. Use this value if you don't want the name of your S3 bucket to be public.
The content of a Canonical Name (CNAME) record must conform to RFC2396 restrictions on the use of special characters in URIs. Additionally, the value of the CNAME must not include a protocol prefix such as "http://" or "https://".
The content of a Canonical Name (CNAME) record must conform to RFC2396 restrictions on the use of special characters in URIs. Additionally, the value of the CNAME must not include a protocol prefix such as "http://" or "https://".
public CrlConfiguration withCustomCname(String customCname)
Name inserted into the certificate CRL Distribution Points extension that enables the use of an alias for the CRL distribution point. Use this value if you don't want the name of your S3 bucket to be public.
The content of a Canonical Name (CNAME) record must conform to RFC2396 restrictions on the use of special characters in URIs. Additionally, the value of the CNAME must not include a protocol prefix such as "http://" or "https://".
customCname
- Name inserted into the certificate CRL Distribution Points extension that enables the use of an
alias for the CRL distribution point. Use this value if you don't want the name of your S3 bucket to be
public. The content of a Canonical Name (CNAME) record must conform to RFC2396 restrictions on the use of special characters in URIs. Additionally, the value of the CNAME must not include a protocol prefix such as "http://" or "https://".
public void setS3BucketName(String s3BucketName)
Name of the S3 bucket that contains the CRL. If you do not provide a value for the CustomCname argument, the name of your S3 bucket is placed into the CRL Distribution Points extension of the issued certificate. You can change the name of your bucket by calling the UpdateCertificateAuthority operation. You must specify a bucket policy that allows Amazon Web Services Private CA to write the CRL to your bucket.
The S3BucketName
parameter must conform to the S3 bucket naming rules.
s3BucketName
- Name of the S3 bucket that contains the CRL. If you do not provide a value for the CustomCname
argument, the name of your S3 bucket is placed into the CRL Distribution Points extension of the
issued certificate. You can change the name of your bucket by calling the UpdateCertificateAuthority operation. You must specify a bucket
policy that allows Amazon Web Services Private CA to write the CRL to your bucket.
The S3BucketName
parameter must conform to the S3 bucket naming
rules.
public String getS3BucketName()
Name of the S3 bucket that contains the CRL. If you do not provide a value for the CustomCname argument, the name of your S3 bucket is placed into the CRL Distribution Points extension of the issued certificate. You can change the name of your bucket by calling the UpdateCertificateAuthority operation. You must specify a bucket policy that allows Amazon Web Services Private CA to write the CRL to your bucket.
The S3BucketName
parameter must conform to the S3 bucket naming rules.
The S3BucketName
parameter must conform to the S3 bucket naming
rules.
public CrlConfiguration withS3BucketName(String s3BucketName)
Name of the S3 bucket that contains the CRL. If you do not provide a value for the CustomCname argument, the name of your S3 bucket is placed into the CRL Distribution Points extension of the issued certificate. You can change the name of your bucket by calling the UpdateCertificateAuthority operation. You must specify a bucket policy that allows Amazon Web Services Private CA to write the CRL to your bucket.
The S3BucketName
parameter must conform to the S3 bucket naming rules.
s3BucketName
- Name of the S3 bucket that contains the CRL. If you do not provide a value for the CustomCname
argument, the name of your S3 bucket is placed into the CRL Distribution Points extension of the
issued certificate. You can change the name of your bucket by calling the UpdateCertificateAuthority operation. You must specify a bucket
policy that allows Amazon Web Services Private CA to write the CRL to your bucket.
The S3BucketName
parameter must conform to the S3 bucket naming
rules.
public void setS3ObjectAcl(String s3ObjectAcl)
Determines whether the CRL will be publicly readable or privately held in the CRL Amazon S3 bucket. If you choose PUBLIC_READ, the CRL will be accessible over the public internet. If you choose BUCKET_OWNER_FULL_CONTROL, only the owner of the CRL S3 bucket can access the CRL, and your PKI clients may need an alternative method of access.
If no value is specified, the default is PUBLIC_READ
.
Note: This default can cause CA creation to fail in some circumstances. If you have have enabled the Block
Public Access (BPA) feature in your S3 account, then you must specify the value of this parameter as
BUCKET_OWNER_FULL_CONTROL
, and not doing so results in an error. If you have disabled BPA in S3,
then you can specify either BUCKET_OWNER_FULL_CONTROL
or PUBLIC_READ
as the value.
For more information, see Blocking public access to the S3 bucket.
s3ObjectAcl
- Determines whether the CRL will be publicly readable or privately held in the CRL Amazon S3 bucket. If you
choose PUBLIC_READ, the CRL will be accessible over the public internet. If you choose
BUCKET_OWNER_FULL_CONTROL, only the owner of the CRL S3 bucket can access the CRL, and your PKI clients
may need an alternative method of access.
If no value is specified, the default is PUBLIC_READ
.
Note: This default can cause CA creation to fail in some circumstances. If you have have enabled
the Block Public Access (BPA) feature in your S3 account, then you must specify the value of this
parameter as BUCKET_OWNER_FULL_CONTROL
, and not doing so results in an error. If you have
disabled BPA in S3, then you can specify either BUCKET_OWNER_FULL_CONTROL
or
PUBLIC_READ
as the value.
For more information, see Blocking public access to the S3 bucket.
S3ObjectAcl
public String getS3ObjectAcl()
Determines whether the CRL will be publicly readable or privately held in the CRL Amazon S3 bucket. If you choose PUBLIC_READ, the CRL will be accessible over the public internet. If you choose BUCKET_OWNER_FULL_CONTROL, only the owner of the CRL S3 bucket can access the CRL, and your PKI clients may need an alternative method of access.
If no value is specified, the default is PUBLIC_READ
.
Note: This default can cause CA creation to fail in some circumstances. If you have have enabled the Block
Public Access (BPA) feature in your S3 account, then you must specify the value of this parameter as
BUCKET_OWNER_FULL_CONTROL
, and not doing so results in an error. If you have disabled BPA in S3,
then you can specify either BUCKET_OWNER_FULL_CONTROL
or PUBLIC_READ
as the value.
For more information, see Blocking public access to the S3 bucket.
If no value is specified, the default is PUBLIC_READ
.
Note: This default can cause CA creation to fail in some circumstances. If you have have enabled
the Block Public Access (BPA) feature in your S3 account, then you must specify the value of this
parameter as BUCKET_OWNER_FULL_CONTROL
, and not doing so results in an error. If you have
disabled BPA in S3, then you can specify either BUCKET_OWNER_FULL_CONTROL
or
PUBLIC_READ
as the value.
For more information, see Blocking public access to the S3 bucket.
S3ObjectAcl
public CrlConfiguration withS3ObjectAcl(String s3ObjectAcl)
Determines whether the CRL will be publicly readable or privately held in the CRL Amazon S3 bucket. If you choose PUBLIC_READ, the CRL will be accessible over the public internet. If you choose BUCKET_OWNER_FULL_CONTROL, only the owner of the CRL S3 bucket can access the CRL, and your PKI clients may need an alternative method of access.
If no value is specified, the default is PUBLIC_READ
.
Note: This default can cause CA creation to fail in some circumstances. If you have have enabled the Block
Public Access (BPA) feature in your S3 account, then you must specify the value of this parameter as
BUCKET_OWNER_FULL_CONTROL
, and not doing so results in an error. If you have disabled BPA in S3,
then you can specify either BUCKET_OWNER_FULL_CONTROL
or PUBLIC_READ
as the value.
For more information, see Blocking public access to the S3 bucket.
s3ObjectAcl
- Determines whether the CRL will be publicly readable or privately held in the CRL Amazon S3 bucket. If you
choose PUBLIC_READ, the CRL will be accessible over the public internet. If you choose
BUCKET_OWNER_FULL_CONTROL, only the owner of the CRL S3 bucket can access the CRL, and your PKI clients
may need an alternative method of access.
If no value is specified, the default is PUBLIC_READ
.
Note: This default can cause CA creation to fail in some circumstances. If you have have enabled
the Block Public Access (BPA) feature in your S3 account, then you must specify the value of this
parameter as BUCKET_OWNER_FULL_CONTROL
, and not doing so results in an error. If you have
disabled BPA in S3, then you can specify either BUCKET_OWNER_FULL_CONTROL
or
PUBLIC_READ
as the value.
For more information, see Blocking public access to the S3 bucket.
S3ObjectAcl
public CrlConfiguration withS3ObjectAcl(S3ObjectAcl s3ObjectAcl)
Determines whether the CRL will be publicly readable or privately held in the CRL Amazon S3 bucket. If you choose PUBLIC_READ, the CRL will be accessible over the public internet. If you choose BUCKET_OWNER_FULL_CONTROL, only the owner of the CRL S3 bucket can access the CRL, and your PKI clients may need an alternative method of access.
If no value is specified, the default is PUBLIC_READ
.
Note: This default can cause CA creation to fail in some circumstances. If you have have enabled the Block
Public Access (BPA) feature in your S3 account, then you must specify the value of this parameter as
BUCKET_OWNER_FULL_CONTROL
, and not doing so results in an error. If you have disabled BPA in S3,
then you can specify either BUCKET_OWNER_FULL_CONTROL
or PUBLIC_READ
as the value.
For more information, see Blocking public access to the S3 bucket.
s3ObjectAcl
- Determines whether the CRL will be publicly readable or privately held in the CRL Amazon S3 bucket. If you
choose PUBLIC_READ, the CRL will be accessible over the public internet. If you choose
BUCKET_OWNER_FULL_CONTROL, only the owner of the CRL S3 bucket can access the CRL, and your PKI clients
may need an alternative method of access.
If no value is specified, the default is PUBLIC_READ
.
Note: This default can cause CA creation to fail in some circumstances. If you have have enabled
the Block Public Access (BPA) feature in your S3 account, then you must specify the value of this
parameter as BUCKET_OWNER_FULL_CONTROL
, and not doing so results in an error. If you have
disabled BPA in S3, then you can specify either BUCKET_OWNER_FULL_CONTROL
or
PUBLIC_READ
as the value.
For more information, see Blocking public access to the S3 bucket.
S3ObjectAcl
public void setCrlDistributionPointExtensionConfiguration(CrlDistributionPointExtensionConfiguration crlDistributionPointExtensionConfiguration)
Configures the behavior of the CRL Distribution Point extension for certificates issued by your certificate authority. If this field is not provided, then the CRl Distribution Point Extension will be present and contain the default CRL URL.
crlDistributionPointExtensionConfiguration
- Configures the behavior of the CRL Distribution Point extension for certificates issued by your
certificate authority. If this field is not provided, then the CRl Distribution Point Extension will be
present and contain the default CRL URL.public CrlDistributionPointExtensionConfiguration getCrlDistributionPointExtensionConfiguration()
Configures the behavior of the CRL Distribution Point extension for certificates issued by your certificate authority. If this field is not provided, then the CRl Distribution Point Extension will be present and contain the default CRL URL.
public CrlConfiguration withCrlDistributionPointExtensionConfiguration(CrlDistributionPointExtensionConfiguration crlDistributionPointExtensionConfiguration)
Configures the behavior of the CRL Distribution Point extension for certificates issued by your certificate authority. If this field is not provided, then the CRl Distribution Point Extension will be present and contain the default CRL URL.
crlDistributionPointExtensionConfiguration
- Configures the behavior of the CRL Distribution Point extension for certificates issued by your
certificate authority. If this field is not provided, then the CRl Distribution Point Extension will be
present and contain the default CRL URL.public String toString()
toString
in class Object
Object.toString()
public CrlConfiguration clone()
public void marshall(ProtocolMarshaller protocolMarshaller)
StructuredPojo
ProtocolMarshaller
.marshall
in interface StructuredPojo
protocolMarshaller
- Implementation of ProtocolMarshaller
used to marshall this object's data.