summaryrefslogtreecommitdiff
path: root/regress/unittests/authopt/testdata/mktestdata.sh
blob: 06a24e39002c522802ab732f07a2a16d8d79fee7 (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
#/bin/sh

set -xe

rm -f ca_key ca_key.pub
rm -f user_key user_key.pub
rm -f *.cert

ssh-keygen -q -f ca_key -t ed25519 -C CA -N ''
ssh-keygen -q -f user_key -t ed25519 -C "user key" -N ''

sign() {
	output=$1
	shift
	set -xe
	ssh-keygen -q -s ca_key -I user -n user \
	    -V 19990101:19991231 -z 1 "$@" user_key.pub
	mv user_key-cert.pub "$output"
}

sign all_permit.cert -Opermit-agent-forwarding -Opermit-port-forwarding \
    -Opermit-pty -Opermit-user-rc -Opermit-X11-forwarding
sign no_permit.cert -Oclear

sign no_agentfwd.cert -Ono-agent-forwarding
sign no_portfwd.cert -Ono-port-forwarding
sign no_pty.cert -Ono-pty
sign no_user_rc.cert -Ono-user-rc
sign no_x11fwd.cert -Ono-X11-forwarding

sign only_agentfwd.cert -Oclear -Opermit-agent-forwarding
sign only_portfwd.cert -Oclear -Opermit-port-forwarding
sign only_pty.cert -Oclear -Opermit-pty
sign only_user_rc.cert -Oclear -Opermit-user-rc
sign only_x11fwd.cert -Oclear -Opermit-X11-forwarding

sign force_command.cert -Oforce-command="foo"
sign sourceaddr.cert -Osource-address="127.0.0.1/32,::1/128"

# ssh-keygen won't permit generation of certs with invalid source-address
# values, so we do it as a custom extension.
sign bad_sourceaddr.cert -Ocritical:source-address=xxxxx

sign unknown_critical.cert -Ocritical:blah=foo

sign host.cert -h

rm -f user_key ca_key user_key.pub ca_key.pub