Class CertificateBundle
java.lang.Object
org.springframework.vault.support.Certificate
org.springframework.vault.support.CertificateBundle
Value object representing a certificate bundle consisting of a private key, the
certificate and the issuer certificate. Certificate and keys can be either DER or PEM
encoded. RSA and Elliptic Curve keys and certificates can be converted to a
KeySpec
respective X509Certificate
object. Supports creation of
key stores
that contain the key and the certificate
chain.- Author:
- Mark Paluch, Alex Bremora, Bogdan Cardos
- See Also:
-
Method Summary
Modifier and TypeMethodDescriptioncreateKeyStore
(String keyAlias) Create aKeyStore
from thisCertificateBundle
containing the private key and certificate chain.createKeyStore
(String keyAlias, boolean includeCaChain) Create aKeyStore
from thisCertificateBundle
containing the private key and certificate chain.createKeyStore
(String keyAlias, boolean includeCaChain, char[] password) Create aKeyStore
from thisCertificateBundle
containing the private key and certificate chain.createKeyStore
(String keyAlias, boolean includeCaChain, CharSequence password) Create aKeyStore
from thisCertificateBundle
containing the private key and certificate chain.createKeyStore
(String keyAlias, char[] password) Create aKeyStore
from thisCertificateBundle
containing the private key and certificate chain.createKeyStore
(String keyAlias, CharSequence password) Create aKeyStore
from thisCertificateBundle
containing the private key and certificate chain.Retrieve the private key asKeySpec
.Retrieve the issuing CA certificates as list ofX509Certificate
.static CertificateBundle
Create aCertificateBundle
given a private key with certificates and the serial number.static CertificateBundle
of
(String serialNumber, String certificate, String issuingCaCertificate, String privateKey, String privateKeyType) Create aCertificateBundle
given a private key with certificates and the serial number.Methods inherited from class org.springframework.vault.support.Certificate
createTrustStore, getCertificate, getIssuingCaCertificate, getSerialNumber, getX509Certificate, getX509IssuerCertificate, of
-
Method Details
-
of
public static CertificateBundle of(String serialNumber, String certificate, String issuingCaCertificate, String privateKey) Create aCertificateBundle
given a private key with certificates and the serial number.- Parameters:
serialNumber
- must not be empty or null.certificate
- must not be empty or null.issuingCaCertificate
- must not be empty or null.privateKey
- must not be empty or null.- Returns:
- the
CertificateBundle
instead.
-
of
public static CertificateBundle of(String serialNumber, String certificate, String issuingCaCertificate, String privateKey, @Nullable String privateKeyType) Create aCertificateBundle
given a private key with certificates and the serial number.- Parameters:
serialNumber
- must not be empty or null.certificate
- must not be empty or null.issuingCaCertificate
- must not be empty or null.privateKey
- must not be empty or null.privateKeyType
- must not be empty or null.- Returns:
- the
CertificateBundle
- Since:
- 2.4
-
getPrivateKey
- Returns:
- the private key (decrypted form, PEM or DER-encoded)
-
getPrivateKeyType
- Returns:
- the private key type, can be null.
- Since:
- 2.4
-
getRequiredPrivateKeyType
- Returns:
- the required private key type, can be null.
- Throws:
IllegalStateException
- if the private key type is null- Since:
- 2.4
-
getPrivateKeySpec
Retrieve the private key asKeySpec
.- Returns:
- the private
KeySpec
.KeyFactory
can generate aPrivateKey
from thisKeySpec
.
-
createKeyStore
Create aKeyStore
from thisCertificateBundle
containing the private key and certificate chain.- Parameters:
keyAlias
- the key alias to use.- Returns:
- the
KeyStore
containing the private key and certificate chain.
-
createKeyStore
Create aKeyStore
from thisCertificateBundle
containing the private key and certificate chain.- Parameters:
keyAlias
- the key alias to use.password
- the password to use.- Returns:
- the
KeyStore
containing the private key and certificate chain. - Since:
- 2.4
-
createKeyStore
Create aKeyStore
from thisCertificateBundle
containing the private key and certificate chain.- Parameters:
keyAlias
- the key alias to use.password
- the password to use.- Returns:
- the
KeyStore
containing the private key and certificate chain. - Since:
- 2.4
-
createKeyStore
Create aKeyStore
from thisCertificateBundle
containing the private key and certificate chain.- Parameters:
keyAlias
- the key alias to use.includeCaChain
- whether to include the certificate authority chain instead of just the issuer certificate.- Returns:
- the
KeyStore
containing the private key and certificate chain. - Since:
- 2.3.3
-
createKeyStore
Create aKeyStore
from thisCertificateBundle
containing the private key and certificate chain.- Parameters:
keyAlias
- the key alias to use.includeCaChain
- whether to include the certificate authority chain instead of just the issuer certificate.password
- the password to use.- Returns:
- the
KeyStore
containing the private key and certificate chain. - Since:
- 2.4
-
createKeyStore
Create aKeyStore
from thisCertificateBundle
containing the private key and certificate chain.- Parameters:
keyAlias
- the key alias to use.includeCaChain
- whether to include the certificate authority chain instead of just the issuer certificate.password
- the password to use.- Returns:
- the
KeyStore
containing the private key and certificate chain. - Since:
- 2.4
-
getX509IssuerCertificates
Retrieve the issuing CA certificates as list ofX509Certificate
.- Returns:
- the issuing CA
X509Certificate
. - Since:
- 2.3.3
-