From e146878e4e2c6ba5461e1d2d46fc834e633ad251 Mon Sep 17 00:00:00 2001 From: wanghaemq Date: Thu, 22 Aug 2024 06:39:53 -0400 Subject: [PATCH] * NEW [openssl] Support to read/write to openssl connection. Signed-off-by: wanghaemq --- src/supplemental/tls/openssl/openssl.c | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/src/supplemental/tls/openssl/openssl.c b/src/supplemental/tls/openssl/openssl.c index fed93194..36b5e276 100644 --- a/src/supplemental/tls/openssl/openssl.c +++ b/src/supplemental/tls/openssl/openssl.c @@ -41,7 +41,7 @@ static int open_conn_init(nng_tls_engine_conn *ec, void *tls, nng_tls_engine_config *cfg) { ec->tls = tls; - if ((ex->ssl = SSL_new(cfg->ctx)) == NULL) { + if ((ec->ssl = SSL_new(cfg->ctx)) == NULL) { return (NNG_ENOMEM); // most likely } if (cfg->server_name != NULL) { @@ -67,12 +67,29 @@ open_conn_close(nng_tls_engine_conn *ec) static int open_conn_recv(nng_tls_engine_conn *ec, uint8_t *buf, size_t *szp) { + int rv; + if ((rv = SSL_read(ec->ssl, buf, (int) *szp)) < 0) { + rv = SSL_get_error(ec->ssl, rv); + fprintf(stderr, "error in recv %d\n", rv); + // TODO return codes according openssl documents + return (NNG_ECRYPTO); + } + *szp = (size_t) rv; return (0); } static int open_conn_send(nng_tls_engine_conn *ec, const uint8_t *buf, size_t *szp) { + int rv; + + if ((rv = SSL_write(ec->ssl, buf, (int) (*szp))) <= 0) { + rv = SSL_get_error(ec->ssl, rv); + fprintf(stderr, "error in recv %d\n", rv); + // TODO return codes according openssl documents + return (NNG_ECRYPTO); + } + *szp = (size_t) rv; return (0); }