Rotating KRA Transport Key - dogtagpki/pki GitHub Wiki
KRA transport key and certificate generation is part KRA Transport Key Rotation process.
Here is the manual process for KRA transport certificate generation and KRA configuration update.
-
Stop KRA
$ systemctl stop [email protected]
-
Go to KRA’s NSS database directory
$ cd /var/lib/pki/pki-tomcat/conf/alias
-
Create subdirectory
$ mkdir saved
and save all NSS database files
$ cp *.db saved
-
Create new request by running the following command
$ PKCS10Client \ -d . \ -p <password> \ -o req.txt \ -n "CN=DRM Transport 2 Certificate,O=example.com Security Domain"
or
$ certutil -R \ -d . \ -f <password-file> \ -k rsa \ -g 2048 \ -s "CN=DRM Transport 2 Certificate,O=example.com Security Domain" \ -o <transport-certificate-request-file> \ -a
-
Start KRA
$ systemctl start [email protected]
-
Submit transport certificate request on Manual Data Recovery Manager Transport Certificate Enrollment page
data:image/s3,"s3://crabby-images/80365/803652b91d4ff5e5ba743163328b0ec21e542e27" alt="Submit transport certificate request"
data:image/s3,"s3://crabby-images/da600/da6003df85f7860e7132adc52d05bd3b5b009bb8" alt="Submit transport certificate request"
data:image/s3,"s3://crabby-images/22c70/22c70226cadf605b46bc07349f308d42548f4441" alt="Submit transport certificate request"
data:image/s3,"s3://crabby-images/1491b/1491bfe7c66c92738bb34d432fe38b679dc6eeed" alt="Submit transport certificate request"
data:image/s3,"s3://crabby-images/b195a/b195ad42bc04200f6434a0e0ca0c1457cf94f29c" alt="Submit transport certificate request"
-
Wait for agent approval of submitted request to retrieve certificate by checking request status on EE retrieval page
-
Go to KRA’s NSS database directory
$ cd /var/lib/pki/pki-tomcat/conf/alias
-
Wait for agent approval of submitted request to retrieve certificate by checking request status on EE retrieval page
data:image/s3,"s3://crabby-images/bf777/bf7773ad3cdd7873aef42d9d87d8756afe046ff5" alt="Retrieve KRA Transport Certificate"
data:image/s3,"s3://crabby-images/0cafa/0cafa4656946c73ba3d789bc73790bd78551509b" alt="Retrieve KRA Transport Certificate"
data:image/s3,"s3://crabby-images/ccaf5/ccaf596006123f8f21594e8bf919ea373713dd46" alt="Retrieve KRA Transport Certificate"
data:image/s3,"s3://crabby-images/44c1f/44c1fbd3ad5faf2ffe9643fa08c328ef1f3e474d" alt="Retrieve KRA Transport Certificate"
-
Once new KRA transport certificate certificate is available then paste its base64-encoded value into a text file
cert-<serial-number>.txt
. Do not include header-----BEGIN CERTIFICATE-----
or footer-----END CERTIFICATE-----
.
-
Go to KRA’s NSS database directory
$ cd /var/lib/pki/pki-tomcat/conf/alias
-
Stop KRA
$ systemctl stop [email protected]
-
Import transport certificate into KRA’s NSS database by:
$ certutil -A \ -d . \ -n "transportCert-<serial-number> cert-pki-tomcat KRA" \ -t "u,u,u" \ -i cert-<serial-number>.txt \ -a
-
Go to KRA’s NSS database directory
$ cd /var/lib/pki/pki-tomcat/conf/alias
-
Stop KRA
$ systemctl stop [email protected]
-
Verify if new KRA transport certificate is imported by running
$ certutil -L -d .
followed by
$ certutil -L -d . -n "transportCert-<serial-number> cert-pki-tomcat KRA"
-
Edit
/var/lib/pki/pki-tomcat/kra/conf/CS.cfg
to add the following line:
kra.transportUnit.newNickName=transportCert-<serial-number> cert-pki-tomcat KRA
-
Start KRA
$ systemctl start [email protected]
Here is how to transfer new transport key and certificate to KRA clone:
-
Go to KRA’s NSS database directory
$ cd /var/lib/pki/pki-tomcat/conf/alias
-
Stop KRA
$ systemctl stop [email protected]
-
Verify if new KRA transport certificate is present by running
$ certutil -L -d .
followed by
$ certutil -L -d . -n "transportCert-<serial-number> cert-pki-tomcat KRA"
-
Export KRA’s new transport key and certificate by
$ pk12util -o transport.p12 -d . -n "transportCert-021 cert-pki-tomcat KRA"
-
Verify exported KRA’s transport key and certificate by
$ pk12util -l transport.p12
-
Transport
transport.p12
file including transport key and certificate to KRA’s clone location. -
Go to clone’s NSS database directory
$ cd /var/lib/pki/pki-tomcat/conf/alias
-
Stop KRA clone
$ systemctl stop [email protected]
-
Check content of clone’s KRA database by running
$ certutil -L -d .
-
Import clone’s new transport key and certificate by
$ pk12util -i transport.p12 -d .
-
Edit clone’s configuration file
/var/lib/pki/pki-tomcat/kra/conf/CS.cfg
to add the following line:
kra.transportUnit.newNickName=transportCert-<serial-number> cert-pki-tomcat KRA
-
Start KRA clone
$ systemctl start [email protected]
-
Go to KRA’s NSS database directory
$ cd /var/lib/pki/pki-tomcat/conf/alias
-
Stop KRA
$ systemctl stop [email protected]
-
Verify if new KRA transport certificate is imported by running
$ certutil -L -d .
followed by
$ certutil -L -d . -n "transportCert-<serial-number> cert-pki-tomcat KRA"
-
Edit
/var/lib/pki/pki-tomcat/kra/conf/CS.cfg
by replacing nickName included in line
kra.transportUnit.nickName=transportCert cert-pki-tomcat KRA
with newNickName included in line
kra.transportUnit.newNickName=transportCert-<serial-number> cert-pki-tomcat KRA
to obtain
kra.transportUnit.nickName=transportCert-<serial-number> cert-pki-tomcat KRA
-
Edit
/var/lib/pki/pki-tomcat/kra/conf/CS.cfg
by removingnewNickName
line
kra.transportUnit.newNickName=transportCert-<serial-number> cert-pki-tomcat KRA
-
Save updated
/var/lib/pki/pki-tomcat/kra/conf/CS.cfg
-
Start KRA
$ systemctl start [email protected]
Here is how to update CA configuration with new KRA transport certificate:
-
Stop CA
$ systemctl stop [email protected]
-
Get the KRA transport certificate file
cert-<serial-number>.txt
obtained in Ticket #734 comment #2 -
Convert base64-encoded certificate included in
cert-<serial-number>.txt
to single line file by
$ tr -d '\n' < cert-<serial-number>.txt > cert-one-line-<serial-number>.txt
-
Edit
/var/lib/pki/pki-tomcat/ca/conf/CS.cfg
by replacing certificate included in line
ca.connector.KRA.transportCert=...
with certificate included in cert-one-line-<serial-number>.txt
-
Save updated
/var/lib/pki/pki-tomcat/ca/conf/CS.cfg
-
Start CA
$ systemctl start [email protected]