blob: 49c267c7057aaccc0a051cbb70448025d1e146db (
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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
|
# $OpenBSD: Makefile,v 1.4 2020/09/11 22:48:00 bluhm Exp $
# Connect a client to a server. Both can be current libressl, or
# openssl 1.0.2, or openssl 1.1. Create lists of supported ciphers
# and pin client and server to one of the ciphers. Use server
# certificate with compatible type. Check that client and server
# have used correct cipher by grepping in their session print out.
run-cipher-GOST2001-GOST89-GOST89-client-libressl-server-libressl \
run-cipher-GOST2012256-GOST89-GOST89-client-libressl-server-libressl \
client-cipher-GOST2012256-GOST89-GOST89-client-libressl-server-libressl.out \
client-cipher-GOST2001-GOST89-GOST89-client-libressl-server-libressl.out \
server-cipher-GOST2001-GOST89-GOST89-client-libressl-server-libressl.out \
server-cipher-GOST2012256-GOST89-GOST89-client-libressl-server-libressl.out \
check-cipher-GOST2001-GOST89-GOST89-client-libressl-server-libressl \
check-cipher-GOST2012256-GOST89-GOST89-client-libressl-server-libressl:
@echo '\n======== $@ ========'
# gost does not work with libressl TLS 1.3 right now
@echo DISABLED
LIBRARIES = libressl
.if exists(/usr/local/bin/eopenssl)
LIBRARIES += openssl
.endif
.if exists(/usr/local/bin/eopenssl11)
LIBRARIES += openssl11
.endif
CLEANFILES = *.tmp *.ciphers ciphers.mk
.for clib in ${LIBRARIES}
client-${clib}.ciphers:
LD_LIBRARY_PATH=/usr/local/lib/e${clib} \
../${clib}/client -l ALL -L >$@.tmp
sed -n 's/^cipher //p' <$@.tmp | sort -u >$@
rm $@.tmp
.endfor
.for slib in ${LIBRARIES}
server-${slib}.ciphers: 127.0.0.1.crt dsa.crt ec.crt rsa.crt
LD_LIBRARY_PATH=/usr/local/lib/e${slib} \
../${slib}/server -l ALL -L >$@.tmp
sed -n 's/^cipher //p' <$@.tmp | sort -u >$@
rm $@.tmp
.endfor
.for clib in ${LIBRARIES}
.for slib in ${LIBRARIES}
ciphers.mk: client-${clib}-server-${slib}.ciphers
client-${clib}-server-${slib}.ciphers: \
client-${clib}.ciphers server-${slib}.ciphers client-libressl.ciphers
# get ciphers shared between client and server
sort client-${clib}.ciphers server-${slib}.ciphers >$@.tmp
uniq -d <$@.tmp >$@
# we are only interested in ciphers supported by libressl
sort $@ client-libressl.ciphers >$@.tmp
uniq -d <$@.tmp >$@
rm $@.tmp
.endfor
.endfor
ciphers.mk:
rm -f $@ $@.tmp
.for clib in ${LIBRARIES}
.for slib in ${LIBRARIES}
echo 'CIPHERS_${clib}_${slib} =' >>$@.tmp \
`cat client-${clib}-server-${slib}.ciphers`
.endfor
.endfor
mv $@.tmp $@
# hack to convert generated lists into usable make variables
.if exists(ciphers.mk)
.include "ciphers.mk"
.else
regress: ciphers.mk
${MAKE} -C ${.CURDIR} regress
.endif
LEVEL_libressl =
LEVEL_openssl =
LEVEL_openssl11 = ,@SECLEVEL=0
.for clib in ${LIBRARIES}
.for slib in ${LIBRARIES}
.for cipher in ${CIPHERS_${clib}_${slib}}
.if "${cipher:M*-DSS-*}" != ""
TYPE_${cipher} = dsa
.elif "${cipher:M*-ECDSA-*}" != ""
TYPE_${cipher} = ec
.elif "${cipher:M*-GOST89-*}" != ""
TYPE_${cipher} = gost
.elif "${cipher:M*-RSA-*}" != ""
TYPE_${cipher} = rsa
.else
TYPE_${cipher} = 127.0.0.1
.endif
.if "${slib}" == "openssl" && \
"${cipher:MADH-*}${cipher:MEDH-*}${cipher:MDHE-*}" != ""
DHPARAM_${cipher}_${slib} = -p dh.param
.else
DHPARAM_${cipher}_${slib} =
.endif
REGRESS_TARGETS += run-cipher-${cipher}-client-${clib}-server-${slib}
run-cipher-${cipher}-client-${clib}-server-${slib} \
client-cipher-${cipher}-client-${clib}-server-${slib}.out \
server-cipher-${cipher}-client-${clib}-server-${slib}.out: dh.param \
127.0.0.1.crt ${TYPE_${cipher}}.crt ../${clib}/client ../${slib}/server
@echo '\n======== $@ ========'
LD_LIBRARY_PATH=/usr/local/lib/e${slib} \
../${slib}/server >${@:S/^run/server/}.out \
-c ${TYPE_${cipher}}.crt -k ${TYPE_${cipher}}.key \
-l ${cipher}${LEVEL_${slib}} ${DHPARAM_${cipher}_${slib}} \
127.0.0.1 0
LD_LIBRARY_PATH=/usr/local/lib/e${clib} \
../${clib}/client >${@:S/^run/client/}.out \
-l ${cipher}${LEVEL_${clib}} \
`sed -n 's/listen sock: //p' ${@:S/^run/server/}.out`
grep -q '^success$$' ${@:S/^run/server/}.out || \
{ sleep 1; grep -q '^success$$' ${@:S/^run/server/}.out; }
grep -q '^success$$' ${@:S/^run/client/}.out
REGRESS_TARGETS += check-cipher-${cipher}-client-${clib}-server-${slib}
check-cipher-${cipher}-client-${clib}-server-${slib}: \
client-cipher-${cipher}-client-${clib}-server-${slib}.out \
server-cipher-${cipher}-client-${clib}-server-${slib}.out
@echo '\n======== $@ ========'
.if "${clib}" != "openssl" && "${slib}" != "openssl" && \
"${cipher:C/AEAD-(AES.*-GCM|CHACHA.*-POLY.*)-SHA.*/TLS1_3/}" != TLS1_3
# client and server 1.3 capable, not TLS 1.3 cipher
.if "${clib}" == "openssl11"
# openssl 1.1 generic client cipher
grep -q ' Cipher *: TLS_AES_256_GCM_SHA384$$' ${@:S/^check/client/}.out
.else
# libressl generic client cipher
grep -q ' Cipher *: AEAD-AES256-GCM-SHA384$$' ${@:S/^check/client/}.out
.endif
.if "${slib}" == "openssl11"
# openssl 1.1 generic server cipher
grep -q ' Cipher *: TLS_AES_256_GCM_SHA384$$' ${@:S/^check/server/}.out
.else
# libressl generic server cipher
grep -q ' Cipher *: AEAD-AES256-GCM-SHA384$$' ${@:S/^check/server/}.out
.endif
.else
grep -q ' Cipher *: ${cipher}$$' ${@:S/^check/client/}.out
grep -q ' Cipher *: ${cipher}$$' ${@:S/^check/server/}.out
.endif
.endfor
.endfor
.endfor
.include <bsd.regress.mk>
|