Class PodCertificateProjection
- java.lang.Object
-
- io.fabric8.kubernetes.api.model.PodCertificateProjection
-
- All Implemented Interfaces:
io.fabric8.kubernetes.api.builder.Editable<PodCertificateProjectionBuilder>,KubernetesResource,Serializable
@Generated("io.fabric8.kubernetes.schema.generator.model.ModelGenerator") public class PodCertificateProjection extends Object implements io.fabric8.kubernetes.api.builder.Editable<PodCertificateProjectionBuilder>, KubernetesResource
PodCertificateProjection provides a private key and X.509 certificate in the pod filesystem.- See Also:
- Serialized Form
-
-
Constructor Summary
Constructors Constructor Description PodCertificateProjection()No args constructor for use in serializationPodCertificateProjection(String certificateChainPath, String credentialBundlePath, String keyPath, String keyType, Integer maxExpirationSeconds, String signerName)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description PodCertificateProjectionBuilderedit()Map<String,Object>getAdditionalProperties()StringgetCertificateChainPath()Write the certificate chain at this path in the projected volume.StringgetCredentialBundlePath()Write the credential bundle at this path in the projected volume.StringgetKeyPath()Write the key at this path in the projected volume.StringgetKeyType()The type of keypair Kubelet will generate for the pod.IntegergetMaxExpirationSeconds()maxExpirationSeconds is the maximum lifetime permitted for the certificate.StringgetSignerName()Kubelet's generated CSRs will be addressed to this signer.voidsetAdditionalProperties(Map<String,Object> additionalProperties)voidsetAdditionalProperty(String name, Object value)voidsetCertificateChainPath(String certificateChainPath)Write the certificate chain at this path in the projected volume.voidsetCredentialBundlePath(String credentialBundlePath)Write the credential bundle at this path in the projected volume.voidsetKeyPath(String keyPath)Write the key at this path in the projected volume.voidsetKeyType(String keyType)The type of keypair Kubelet will generate for the pod.voidsetMaxExpirationSeconds(Integer maxExpirationSeconds)maxExpirationSeconds is the maximum lifetime permitted for the certificate.voidsetSignerName(String signerName)Kubelet's generated CSRs will be addressed to this signer.PodCertificateProjectionBuildertoBuilder()
-
-
-
Method Detail
-
getCertificateChainPath
public String getCertificateChainPath()
Write the certificate chain at this path in the projected volume.Most applications should use credentialBundlePath. When using keyPath and certificateChainPath, your application needs to check that the key and leaf certificate are consistent, because it is possible to read the files mid-rotation.
-
setCertificateChainPath
public void setCertificateChainPath(String certificateChainPath)
Write the certificate chain at this path in the projected volume.Most applications should use credentialBundlePath. When using keyPath and certificateChainPath, your application needs to check that the key and leaf certificate are consistent, because it is possible to read the files mid-rotation.
-
getCredentialBundlePath
public String getCredentialBundlePath()
Write the credential bundle at this path in the projected volume.The credential bundle is a single file that contains multiple PEM blocks. The first PEM block is a PRIVATE KEY block, containing a PKCS#8 private key.
The remaining blocks are CERTIFICATE blocks, containing the issued certificate chain from the signer (leaf and any intermediates).
Using credentialBundlePath lets your Pod's application code make a single atomic read that retrieves a consistent key and certificate chain. If you project them to separate files, your application code will need to additionally check that the leaf certificate was issued to the key.
-
setCredentialBundlePath
public void setCredentialBundlePath(String credentialBundlePath)
Write the credential bundle at this path in the projected volume.The credential bundle is a single file that contains multiple PEM blocks. The first PEM block is a PRIVATE KEY block, containing a PKCS#8 private key.
The remaining blocks are CERTIFICATE blocks, containing the issued certificate chain from the signer (leaf and any intermediates).
Using credentialBundlePath lets your Pod's application code make a single atomic read that retrieves a consistent key and certificate chain. If you project them to separate files, your application code will need to additionally check that the leaf certificate was issued to the key.
-
getKeyPath
public String getKeyPath()
Write the key at this path in the projected volume.Most applications should use credentialBundlePath. When using keyPath and certificateChainPath, your application needs to check that the key and leaf certificate are consistent, because it is possible to read the files mid-rotation.
-
setKeyPath
public void setKeyPath(String keyPath)
Write the key at this path in the projected volume.Most applications should use credentialBundlePath. When using keyPath and certificateChainPath, your application needs to check that the key and leaf certificate are consistent, because it is possible to read the files mid-rotation.
-
getKeyType
public String getKeyType()
The type of keypair Kubelet will generate for the pod.Valid values are "RSA3072", "RSA4096", "ECDSAP256", "ECDSAP384", "ECDSAP521", and "ED25519".
-
setKeyType
public void setKeyType(String keyType)
The type of keypair Kubelet will generate for the pod.Valid values are "RSA3072", "RSA4096", "ECDSAP256", "ECDSAP384", "ECDSAP521", and "ED25519".
-
getMaxExpirationSeconds
public Integer getMaxExpirationSeconds()
maxExpirationSeconds is the maximum lifetime permitted for the certificate.Kubelet copies this value verbatim into the PodCertificateRequests it generates for this projection.
If omitted, kube-apiserver will set it to 86400(24 hours). kube-apiserver will reject values shorter than 3600 (1 hour). The maximum allowable value is 7862400 (91 days).
The signer implementation is then free to issue a certificate with any lifetime *shorter* than MaxExpirationSeconds, but no shorter than 3600 seconds (1 hour). This constraint is enforced by kube-apiserver. `kubernetes.io` signers will never issue certificates with a lifetime longer than 24 hours.
-
setMaxExpirationSeconds
public void setMaxExpirationSeconds(Integer maxExpirationSeconds)
maxExpirationSeconds is the maximum lifetime permitted for the certificate.Kubelet copies this value verbatim into the PodCertificateRequests it generates for this projection.
If omitted, kube-apiserver will set it to 86400(24 hours). kube-apiserver will reject values shorter than 3600 (1 hour). The maximum allowable value is 7862400 (91 days).
The signer implementation is then free to issue a certificate with any lifetime *shorter* than MaxExpirationSeconds, but no shorter than 3600 seconds (1 hour). This constraint is enforced by kube-apiserver. `kubernetes.io` signers will never issue certificates with a lifetime longer than 24 hours.
-
getSignerName
public String getSignerName()
Kubelet's generated CSRs will be addressed to this signer.
-
setSignerName
public void setSignerName(String signerName)
Kubelet's generated CSRs will be addressed to this signer.
-
edit
public PodCertificateProjectionBuilder edit()
- Specified by:
editin interfaceio.fabric8.kubernetes.api.builder.Editable<PodCertificateProjectionBuilder>
-
toBuilder
public PodCertificateProjectionBuilder toBuilder()
-
-