Skip to content

Instantly share code, notes, and snippets.

@dcode
Last active May 9, 2026 04:14
Show Gist options
  • Select an option

  • Save dcode/2fcac5735c6812ea8c25798ff38224b7 to your computer and use it in GitHub Desktop.

Select an option

Save dcode/2fcac5735c6812ea8c25798ff38224b7 to your computer and use it in GitHub Desktop.
Install and trust DoD CA certificates on Mac OS X. Tested on Catalina and Mojave. *NOTE*: This should also enable CAC if you didn't override the system drivers.
#!/bin/bash
set -eu -o pipefail
export CERT_URL='https://dl.dod.cyber.mil/wp-content/uploads/pki-pke/zip/unclass-certificates_pkcs7_DoD.zip'
# Download & Extract DoD root certificates
cd ~/Downloads/ || exit 1
/usr/bin/curl -LOJ "${CERT_URL}"
/usr/bin/unzip -o "$(basename "${CERT_URL}")"
cd "$(/usr/bin/zipinfo -1 "$(basename "${CERT_URL}")" | /usr/bin/awk -F/ '{ print $1 }' | head -1)" || exit 1
# Convert .p7b certs to straight pem and import
for item in *.p7b; do
TOPDIR=$(pwd)
TMPDIR=$(mktemp -d "/tmp/$(basename "${item}" .p7b).XXXXXX") || exit 1
PEMNAME=$(basename "${item}" .p7b)
openssl pkcs7 -print_certs -in "${item}" -inform der -out "${TMPDIR}/${PEMNAME}"
cd "${TMPDIR}"
/usr/bin/split -p '^$' "${PEMNAME}"
rm "$(find . -name "x*" | sort | tail -1)"
for cert in x??; do
sudo security add-trusted-cert -d -r trustRoot -k /Library/Keychains/System.keychain "${cert}"
done
cd "${TOPDIR}"
rm -rf "${TMPDIR}"
done
@jasondgreene

Copy link
Copy Markdown

Thanks @Crimsonize and @dcode, it worked great.

@getcake

getcake commented May 9, 2026

Copy link
Copy Markdown

anyone tried this on Tahoe? not working for me

@k10urzd

k10urzd commented May 9, 2026 via email

Copy link
Copy Markdown

@getcake

getcake commented May 9, 2026

Copy link
Copy Markdown

@k10urzd lmao yeah that was my issue srry, all good now. i just ended up forcing my little brother tap my yubikey until it finished

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment