SSL_get_[rw]fd were documented but not implemented.
authorRichard Levitte <levitte@openssl.org>
Sun, 15 Jul 2001 20:11:57 +0000 (20:11 +0000)
committerRichard Levitte <levitte@openssl.org>
Sun, 15 Jul 2001 20:11:57 +0000 (20:11 +0000)
ssl/ssl.h
ssl/ssl_lib.c

index 216afd917fe4fce6f19ac6c1b500b2370c753ae8..61424ebab5f6e32e7b1e8ffd9cd3c5a820d3b558 100644 (file)
--- a/ssl/ssl.h
+++ b/ssl/ssl.h
@@ -973,6 +973,8 @@ char *      SSL_CIPHER_get_version(SSL_CIPHER *c);
 const char *   SSL_CIPHER_get_name(SSL_CIPHER *c);
 
 int    SSL_get_fd(SSL *s);
+int    SSL_get_rfd(SSL *s);
+int    SSL_get_wfd(SSL *s);
 const char  * SSL_get_cipher_list(SSL *s,int n);
 char * SSL_get_shared_ciphers(SSL *s, char *buf, int len);
 int    SSL_get_read_ahead(SSL * s);
index ad1af7cda354d3fcf6e75735cceca5530cfd15f5..463ed16020afa8e79582a059423cd583e95b6521 100644 (file)
@@ -444,6 +444,11 @@ BIO *SSL_get_wbio(SSL *s)
        { return(s->wbio); }
 
 int SSL_get_fd(SSL *s)
+       {
+       return(SSL_get_rfc(s));
+       }
+
+int SSL_get_rfd(SSL *s)
        {
        int ret= -1;
        BIO *b,*r;
@@ -455,6 +460,18 @@ int SSL_get_fd(SSL *s)
        return(ret);
        }
 
+int SSL_get_wfd(SSL *s)
+       {
+       int ret= -1;
+       BIO *b,*r;
+
+       b=SSL_get_wbio(s);
+       r=BIO_find_type(b,BIO_TYPE_DESCRIPTOR);
+       if (r != NULL)
+               BIO_get_fd(r,&ret);
+       return(ret);
+       }
+
 #ifndef OPENSSL_NO_SOCK
 int SSL_set_fd(SSL *s,int fd)
        {