-static SSL_METHOD *ssl23_get_method(ver)
-int ver;
- {
- if (ver == SSL2_VERSION)
- return(SSLv23_method());
- else if (ver == SSL3_VERSION)
- return(SSLv3_method());
- else if (ver == TLS1_VERSION)
- return(TLSv1_method());
- else
- return(NULL);
- }
-
-SSL_METHOD *SSLv23_method()
- {
- static int init=1;
- static SSL_METHOD SSLv23_data;
-
- if (init)
- {
- init=0;
- memcpy((char *)&SSLv23_data,(char *)sslv23_base_method(),
- sizeof(SSL_METHOD));
- SSLv23_data.ssl_connect=ssl23_connect;
- SSLv23_data.ssl_accept=ssl23_accept;
- SSLv23_data.get_ssl_method=ssl23_get_method;
- }
- return(&SSLv23_data);
- }
+static const SSL_METHOD *ssl23_get_method(int ver);
+static const SSL_METHOD *ssl23_get_method(int ver)
+{
+#ifndef OPENSSL_NO_SSL3
+ if (ver == SSL3_VERSION)
+ return (SSLv3_method());
+ else
+#endif
+ if (ver == TLS1_VERSION)
+ return (TLSv1_method());
+ else if (ver == TLS1_1_VERSION)
+ return (TLSv1_1_method());
+ else if (ver == TLS1_2_VERSION)
+ return (TLSv1_2_method());
+ else
+ return (NULL);
+}