aboutsummaryrefslogtreecommitdiff
path: root/.local/bin/crt-fp
blob: ec14fccf1d8c1243501a155d109ca8f2cb8dc908 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
#! /usr/bin/env sh

# This program is free software: you can redistribute it and/or modify it under
# the terms of the GNU Affero General Public License as published by the Free
# Software Foundation, either version 3 of the License, or (at your option) any
# later version.
#
# This program is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
# FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
# details.

# Space-separated list of supported algorithms
readonly ALGS="md5 sha1 sha256"

main()
{
	# Handle opts
	while getopts ":g:h" opt
	do
		case "$opt" in
			g) DO_ALGS="$DO_ALGS $OPTARG" ;;
			h) usage && exit 0 ;;
			*)
				printf "Invalid option passed: %s\n" "$OPTARG" >&2
				;;
		esac
	done

	shift $(( OPTIND - 1 ))

	# Set algs to show by default
	[ -z "$DO_ALGS" ] && DO_ALGS="$ALGS"

	# Use STDIN as cert if no arguments are given
	if [ -z "$*" ] || [ "$1" = "-" ]
	then
		no_args=1
		set -- "$(mktemp)"
		cat > "$1"
	fi

	# Generate fingerprint info for all certificates in question
	for crt in "$@"
	do
		# Skip this certificate if it does not exist
		if [ ! -f "$crt" ]
		then
			printf "No such file or directory: %s\n" "$crt" >&2
			continue
		fi

		# Skip the filename if only a single file is being checked
		[ "$#" -gt 1 ] && printf "%s: \n" "$crt"

		# Show fingerprints for files
		for alg in $DO_ALGS
		do
			[ "$#" -gt 1 ] && printf "%s" "\t"
			printf "%-6s %s\n" "$alg" "$(fingerprint "$alg" "$crt")"
		done
	done
}

fingerprint()
{
	openssl x509 -noout -fingerprint "-$1" -inform pem -in "$2" | awk -F= '{ print $NF }'
}

usage()
{
	cat <<EOF
Usage:
	$(basename "$0") -h
	$(basename "$0") [file [file...]]

Generate common fingerprints for a certificate, using openssl.

Options:
	-h  Show this help text and exit.
EOF
}

main "$@"