#!/bin/bash # This Source Code Form is subject to the terms of the Mozilla Public # License, v. 2.0. If a copy of the MPL was not distributed with this # file, You can obtain one at http://mozilla.org/MPL/2.0/. # # Create an NSS certificate database for ssl_gtest. # Usage: ssl_gtest_db.sh [db_dir [certutil [noise_file]]] # db_dir - directory for the NSS cert DB (default: ./ssl_gtest_certdb) # certutil - path to certutil binary (default: found in PATH) # noise_file - entropy file for key generation (default: auto-generated) set -e SCRIPT_DIR="$(cd "$(dirname "$0")" && pwd)" PROFILEDIR="${1:-./ssl_gtest_certdb}" CERTUTIL="${2:-}" R_NOISE_FILE="${3:-}" html_msg() { :; } . "${SCRIPT_DIR}/../common/certsetup.sh" # Use certutil from PATH if not provided if [ -z "$CERTUTIL" ]; then CERTUTIL="$(command -v certutil 2>/dev/null || true)" fi if [ -z "$CERTUTIL" ]; then echo "certutil not found; pass it as \$2 or ensure it is in PATH" >&2 exit 1 fi BINDIR="$(dirname "$CERTUTIL")" # Auto-generate a noise file if not provided if [ -z "$R_NOISE_FILE" ]; then _noise_tmp="$(mktemp)" trap 'rm -f "$_noise_tmp"' EXIT dd if=/dev/urandom of="$_noise_tmp" bs=2048 count=1 2>/dev/null R_NOISE_FILE="$_noise_tmp" fi mkdir -p "$PROFILEDIR" PROFILEDIR="$(cd "$PROFILEDIR" && pwd)" "$CERTUTIL" -N -d "$PROFILEDIR" --empty-password cd "$PROFILEDIR" counter=0 make_cert client rsa sign make_cert rsa rsa sign kex make_cert rsa2048 rsa2048 sign kex make_cert rsa8192 rsa8192 sign kex make_cert rsa_sign rsa sign make_cert rsa_pss rsapss sign make_cert rsa_pss384 rsapss384 sign make_cert rsa_pss512 rsapss512 sign make_cert rsa_pss_noparam rsapss_noparam sign make_cert rsa_decrypt rsa kex make_cert ecdsa256 p256 sign make_cert ecdsa384 p384 sign make_cert ecdsa521 p521 sign make_cert ecdh_ecdsa p256 kex make_cert rsa_ca rsa_ca ca make_cert rsa_chain rsa_chain sign make_cert rsa_pss_ca rsapss_ca ca make_cert rsa_pss_chain rsapss_chain sign make_cert rsa_ca_rsa_pss_chain rsa_ca_rsapss_chain sign make_cert ecdh_rsa ecdh_rsa kex if [ -z "${NSS_DISABLE_DSA}" ]; then make_cert dsa dsa sign fi make_cert delegator_ecdsa256 delegator_p256 sign make_cert delegator_rsae2048 delegator_rsae2048 sign make_cert delegator_rsa_pss2048 delegator_rsa_pss2048 sign