File: send-keyring

package info (click to toggle)
debian-keyring 2013.04.21
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 63,116 kB
  • sloc: sh: 510; perl: 256; makefile: 108
file content (36 lines) | stat: -rwxr-xr-x 991 bytes parent folder | download
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
#!/bin/sh

# Copyright (c) 2012 Jonathan McDowell <noodles@earth.li>
# GNU GPL; v2 or later
# Send an entire keyring to a keyserver

set -e

if [ -z "$1" ]; then
	echo "Usage: send-keyring keyring" >&2
	exit 1
fi

# avoid gnupg touching ~/.gnupg
GNUPGHOME=$(mktemp -d -t jetring.XXXXXXXX)
export GNUPGHOME
touch $GNUPGHOME/options
trap cleanup exit
cleanup () {
	rm -rf "$GNUPGHOME"
}

keyring=$(readlink -f "$1") # gpg works better with absolute keyring paths

basename=$(basename "$keyring")

for key in $(gpg --no-auto-check-trustdb --options /dev/null --no-default-keyring --keyring "$keyring" --list-keys --keyid-format long | grep '^pub' | sed -e 's!.*/!!' -e 's/ .*//'); do
	gpg --no-auto-check-trustdb --options $GNUPGHOME/options \
		--no-default-keyring --keyring "$keyring" \
		--keyserver the.earth.li \
		--send-key $key
	gpg --no-auto-check-trustdb --options $GNUPGHOME/options \
		--no-default-keyring --keyring "$keyring" \
		--keyserver pgp.mit.edu \
		--send-key $key
done