diff options
author | jsing <> | 2014-05-24 12:44:48 +0000 |
---|---|---|
committer | jsing <> | 2014-05-24 12:44:48 +0000 |
commit | 52c89a2661760a5549aeb55a62ea9957c3379e64 (patch) | |
tree | d69c2da4faf1b7f2a4d061a5b3cf3601197a246a /src/lib/libssl/s3_clnt.c | |
parent | 423deaf23c5a306d0f9bc96d6e1e9584d85f7c16 (diff) | |
download | openbsd-52c89a2661760a5549aeb55a62ea9957c3379e64.tar.gz openbsd-52c89a2661760a5549aeb55a62ea9957c3379e64.tar.bz2 openbsd-52c89a2661760a5549aeb55a62ea9957c3379e64.zip |
DeIMPLEMENT libssl. Expand the IMPLEMENT_* macros since it is far more
readable and one less layer of abstraction. Use C99 initialisers for
clarity, grepability and to protect from future field reordering/removal.
ok miod@ (tedu@ also thought it was a wonderful idea, beck@ also agreed,
but ran away squealing since it reminded him of the VOP layer...)
Diffstat (limited to 'src/lib/libssl/s3_clnt.c')
-rw-r--r-- | src/lib/libssl/s3_clnt.c | 41 |
1 files changed, 38 insertions, 3 deletions
diff --git a/src/lib/libssl/s3_clnt.c b/src/lib/libssl/s3_clnt.c index 010f9e4e12..16d5dacfc4 100644 --- a/src/lib/libssl/s3_clnt.c +++ b/src/lib/libssl/s3_clnt.c | |||
@@ -166,6 +166,44 @@ | |||
166 | static const SSL_METHOD *ssl3_get_client_method(int ver); | 166 | static const SSL_METHOD *ssl3_get_client_method(int ver); |
167 | static int ca_dn_cmp(const X509_NAME * const *a, const X509_NAME * const *b); | 167 | static int ca_dn_cmp(const X509_NAME * const *a, const X509_NAME * const *b); |
168 | 168 | ||
169 | const SSL_METHOD SSLv3_client_method_data = { | ||
170 | .version = SSL3_VERSION, | ||
171 | .ssl_new = ssl3_new, | ||
172 | .ssl_clear = ssl3_clear, | ||
173 | .ssl_free = ssl3_free, | ||
174 | .ssl_accept = ssl_undefined_function, | ||
175 | .ssl_connect = ssl3_connect, | ||
176 | .ssl_read = ssl3_read, | ||
177 | .ssl_peek = ssl3_peek, | ||
178 | .ssl_write = ssl3_write, | ||
179 | .ssl_shutdown = ssl3_shutdown, | ||
180 | .ssl_renegotiate = ssl3_renegotiate, | ||
181 | .ssl_renegotiate_check = ssl3_renegotiate_check, | ||
182 | .ssl_get_message = ssl3_get_message, | ||
183 | .ssl_read_bytes = ssl3_read_bytes, | ||
184 | .ssl_write_bytes = ssl3_write_bytes, | ||
185 | .ssl_dispatch_alert = ssl3_dispatch_alert, | ||
186 | .ssl_ctrl = ssl3_ctrl, | ||
187 | .ssl_ctx_ctrl = ssl3_ctx_ctrl, | ||
188 | .get_cipher_by_char = ssl3_get_cipher_by_char, | ||
189 | .put_cipher_by_char = ssl3_put_cipher_by_char, | ||
190 | .ssl_pending = ssl3_pending, | ||
191 | .num_ciphers = ssl3_num_ciphers, | ||
192 | .get_cipher = ssl3_get_cipher, | ||
193 | .get_ssl_method = ssl3_get_client_method, | ||
194 | .get_timeout = ssl3_default_timeout, | ||
195 | .ssl3_enc = &SSLv3_enc_data, | ||
196 | .ssl_version = ssl_undefined_void_function, | ||
197 | .ssl_callback_ctrl = ssl3_callback_ctrl, | ||
198 | .ssl_ctx_callback_ctrl = ssl3_ctx_callback_ctrl, | ||
199 | }; | ||
200 | |||
201 | const SSL_METHOD * | ||
202 | SSLv3_client_method(void) | ||
203 | { | ||
204 | return &SSLv3_client_method_data; | ||
205 | } | ||
206 | |||
169 | static const SSL_METHOD * | 207 | static const SSL_METHOD * |
170 | ssl3_get_client_method(int ver) | 208 | ssl3_get_client_method(int ver) |
171 | { | 209 | { |
@@ -174,9 +212,6 @@ ssl3_get_client_method(int ver) | |||
174 | return (NULL); | 212 | return (NULL); |
175 | } | 213 | } |
176 | 214 | ||
177 | IMPLEMENT_ssl3_meth_func(SSLv3_client_method, | ||
178 | ssl_undefined_function, ssl3_connect, ssl3_get_client_method) | ||
179 | |||
180 | int | 215 | int |
181 | ssl3_connect(SSL *s) | 216 | ssl3_connect(SSL *s) |
182 | { | 217 | { |