<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://tech.uvoo.io/index.php?action=history&amp;feed=atom&amp;title=Cert_extraction_from_pfx</id>
	<title>Cert extraction from pfx - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://tech.uvoo.io/index.php?action=history&amp;feed=atom&amp;title=Cert_extraction_from_pfx"/>
	<link rel="alternate" type="text/html" href="https://tech.uvoo.io/index.php?title=Cert_extraction_from_pfx&amp;action=history"/>
	<updated>2026-04-26T10:00:26Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.35.2</generator>
	<entry>
		<id>https://tech.uvoo.io/index.php?title=Cert_extraction_from_pfx&amp;diff=4009&amp;oldid=prev</id>
		<title>Busk: Created page with &quot;# Simple example using pure bash  .env ``` export PASSIN=&quot;&lt;Your venafi PKCS#12 download pfx file password&gt;&quot; export AD_USER=&quot;&lt;Your AD username&gt;&quot; export AD_PASS=&quot;Your AD user pa...&quot;</title>
		<link rel="alternate" type="text/html" href="https://tech.uvoo.io/index.php?title=Cert_extraction_from_pfx&amp;diff=4009&amp;oldid=prev"/>
		<updated>2023-04-14T15:08:14Z</updated>

		<summary type="html">&lt;p&gt;Created page with &amp;quot;# Simple example using pure bash  .env ``` export PASSIN=&amp;quot;&amp;lt;Your venafi PKCS#12 download pfx file password&amp;gt;&amp;quot; export AD_USER=&amp;quot;&amp;lt;Your AD username&amp;gt;&amp;quot; export AD_PASS=&amp;quot;Your AD user pa...&amp;quot;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;# Simple example using pure bash&lt;br /&gt;
&lt;br /&gt;
.env&lt;br /&gt;
```&lt;br /&gt;
export PASSIN=&amp;quot;&amp;lt;Your venafi PKCS#12 download pfx file password&amp;gt;&amp;quot;&lt;br /&gt;
export AD_USER=&amp;quot;&amp;lt;Your AD username&amp;gt;&amp;quot;&lt;br /&gt;
export AD_PASS=&amp;quot;Your AD user password&amp;quot;&lt;br /&gt;
```&lt;br /&gt;
&lt;br /&gt;
updateCerts.sh&lt;br /&gt;
```&lt;br /&gt;
#!/bin/bash&lt;br /&gt;
set -eu&lt;br /&gt;
ca_crt_file=&amp;quot;~/ca.crt&amp;quot;&lt;br /&gt;
entity_crt_file=&amp;quot;~/entity.crt&amp;quot;&lt;br /&gt;
entity_key_file=&amp;quot;~/entity.key&amp;quot;&lt;br /&gt;
&lt;br /&gt;
hosts=(&lt;br /&gt;
  &amp;quot;foo.example.com&amp;quot;&lt;br /&gt;
)&lt;br /&gt;
# cn=$1&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
ssh_cmd(){&lt;br /&gt;
  cmd=$1&lt;br /&gt;
  sshpass -p &amp;quot;${AD_PASS}&amp;quot; ssh -l &amp;quot;${AD_USER}&amp;quot;  $cn &amp;quot;${cmd}&amp;quot;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
ssh_cmd_sudo(){&lt;br /&gt;
  cmd=$1&lt;br /&gt;
  sshpass -p &amp;quot;${AD_PASS}&amp;quot; ssh -l &amp;quot;${AD_USER}&amp;quot;  $cn &amp;quot;echo ${AD_PASS} | sudo -S ${cmd}&amp;quot;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
view_cmds=(&lt;br /&gt;
  &amp;quot;openssl x509 -text -in ${entity_key_file}&amp;quot;&lt;br /&gt;
  &amp;quot;openssl x509 -text -in ${entity_crt_file}&amp;quot;&lt;br /&gt;
  &amp;quot;openssl x509 -text -in ${ca_crt_file}&amp;quot;&lt;br /&gt;
  &amp;quot;openssl verify -verbose -CAfile ${ca_crt_file} ${entity_crt_file}&amp;quot;&lt;br /&gt;
)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
extract_crts_keys_from_pfx(){&lt;br /&gt;
  cn=$1&lt;br /&gt;
  openssl pkcs12 -passin env:PASSIN -in ${cn}.pfx -nocerts -nodes &amp;gt; ${cn}.key.pem&lt;br /&gt;
  openssl pkcs12 -passin env:PASSIN -in ${cn}.pfx -clcerts -nokeys &amp;gt; ${cn}.crt.pem&lt;br /&gt;
  openssl pkcs12 -passin env:PASSIN -in ${cn}.pfx -cacerts -nokeys -chain &amp;gt; ${cn}.ca.crt.pem&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
update_certs(){&lt;br /&gt;
  cn=$1&lt;br /&gt;
&lt;br /&gt;
  extract_crts_keys_from_pfx &amp;quot;${cn}&amp;quot;&lt;br /&gt;
&lt;br /&gt;
  ts=$(date &amp;quot;+%Y%m%d-%H%M&amp;quot;)&lt;br /&gt;
  echo &amp;quot;Updating host with cn: $cn&amp;quot;; sleep 1&lt;br /&gt;
  sshpass -p &amp;quot;${AD_PASS}&amp;quot; scp ca.chains.crt $cn.* $cn:~/&lt;br /&gt;
  # ssh_cmd_sudo &amp;quot;cp ${cn}.ca.crt.pem ${ca_crt_file}&amp;quot;&lt;br /&gt;
  ssh_cmd_sudo &amp;quot;cp ca.chains.crt ${ca_crt_file}&amp;quot;&lt;br /&gt;
  ssh_cmd_sudo &amp;quot;cp ${ca_crt_file} ${ca_crt_file}.bkp.${ts}&amp;quot;&lt;br /&gt;
  ssh_cmd_sudo &amp;quot;cp ${entity_crt_file} ${entity_crt_file}.bkp.${ts}&amp;quot;&lt;br /&gt;
  ssh_cmd_sudo &amp;quot;cp ${entity_key_file} ${entity_key_file}.bkp.${ts}&amp;quot;&lt;br /&gt;
  ssh_cmd_sudo &amp;quot;cp ${cn}.key.pem ${entity_key_file}&amp;quot;&lt;br /&gt;
  ssh_cmd_sudo &amp;quot;cp ${cn}.crt.pem ${entity_crt_file}&amp;quot;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
main(){&lt;br /&gt;
  for host in &amp;quot;${hosts[@]}&amp;quot;; do&lt;br /&gt;
    echo updating &amp;quot;$host&amp;quot;; sleep 1&lt;br /&gt;
    update_certs &amp;quot;${host}&amp;quot;&lt;br /&gt;
  done&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
main&lt;br /&gt;
```&lt;/div&gt;</summary>
		<author><name>Busk</name></author>
	</entry>
</feed>