diff options
| author | Simon L. B. Nielsen <simon@FreeBSD.org> | 2008-09-21 14:56:30 +0000 | 
|---|---|---|
| committer | Simon L. B. Nielsen <simon@FreeBSD.org> | 2008-09-21 14:56:30 +0000 | 
| commit | bb1499d2aac1d25a95b8573ff425751f06f159e1 (patch) | |
| tree | a136b5b2317abe8eb83b021afe5e088230fd67e2 /ssl/d1_lib.c | |
| parent | ee266f1253f9cc49430572463d26f72910dfb49e (diff) | |
Diffstat (limited to 'ssl/d1_lib.c')
| -rw-r--r-- | ssl/d1_lib.c | 20 | 
1 files changed, 20 insertions, 0 deletions
| diff --git a/ssl/d1_lib.c b/ssl/d1_lib.c index d07a212facea..fc088b414893 100644 --- a/ssl/d1_lib.c +++ b/ssl/d1_lib.c @@ -188,3 +188,23 @@ void dtls1_clear(SSL *s)  	ssl3_clear(s);  	s->version=DTLS1_VERSION;  	} + +/* + * As it's impossible to use stream ciphers in "datagram" mode, this + * simple filter is designed to disengage them in DTLS. Unfortunately + * there is no universal way to identify stream SSL_CIPHER, so we have + * to explicitly list their SSL_* codes. Currently RC4 is the only one + * available, but if new ones emerge, they will have to be added... + */ +SSL_CIPHER *dtls1_get_cipher(unsigned int u) +	{ +	SSL_CIPHER *ciph = ssl3_get_cipher(u); + +	if (ciph != NULL) +		{ +		if ((ciph->algorithms&SSL_ENC_MASK) == SSL_RC4) +			return NULL; +		} + +	return ciph; +	} | 
