diff options
Diffstat (limited to '')
| -rw-r--r-- | src/lib/libressl/ressl_server.c | 45 |
1 files changed, 43 insertions, 2 deletions
diff --git a/src/lib/libressl/ressl_server.c b/src/lib/libressl/ressl_server.c index d9faa5da45..ba127f8cdd 100644 --- a/src/lib/libressl/ressl_server.c +++ b/src/lib/libressl/ressl_server.c | |||
| @@ -17,6 +17,7 @@ | |||
| 17 | #include <openssl/ec.h> | 17 | #include <openssl/ec.h> |
| 18 | #include <openssl/ssl.h> | 18 | #include <openssl/ssl.h> |
| 19 | 19 | ||
| 20 | #include <ressl.h> | ||
| 20 | #include "ressl_internal.h" | 21 | #include "ressl_internal.h" |
| 21 | 22 | ||
| 22 | struct ressl * | 23 | struct ressl * |
| @@ -92,7 +93,7 @@ err: | |||
| 92 | } | 93 | } |
| 93 | 94 | ||
| 94 | int | 95 | int |
| 95 | ressl_accept(struct ressl *ctx) | 96 | ressl_accept(struct ressl *ctx, struct ressl **cctx) |
| 96 | { | 97 | { |
| 97 | if ((ctx->flags & RESSL_SERVER) == 0) { | 98 | if ((ctx->flags & RESSL_SERVER) == 0) { |
| 98 | ressl_set_error(ctx, "not a server context"); | 99 | ressl_set_error(ctx, "not a server context"); |
| @@ -104,13 +105,53 @@ err: | |||
| 104 | } | 105 | } |
| 105 | 106 | ||
| 106 | int | 107 | int |
| 107 | ressl_accept_socket(struct ressl *ctx, int socket) | 108 | ressl_accept_socket(struct ressl *ctx, struct ressl **cctx, int socket) |
| 108 | { | 109 | { |
| 110 | struct ressl *conn_ctx = *cctx; | ||
| 111 | int ret, ssl_err; | ||
| 112 | |||
| 109 | if ((ctx->flags & RESSL_SERVER) == 0) { | 113 | if ((ctx->flags & RESSL_SERVER) == 0) { |
| 110 | ressl_set_error(ctx, "not a server context"); | 114 | ressl_set_error(ctx, "not a server context"); |
| 111 | goto err; | 115 | goto err; |
| 112 | } | 116 | } |
| 113 | 117 | ||
| 118 | if (conn_ctx == NULL) { | ||
| 119 | if ((conn_ctx = ressl_server_conn(ctx)) == NULL) { | ||
| 120 | ressl_set_error(ctx, "connection context failure"); | ||
| 121 | goto err; | ||
| 122 | } | ||
| 123 | *cctx = conn_ctx; | ||
| 124 | |||
| 125 | conn_ctx->socket = socket; | ||
| 126 | |||
| 127 | if ((conn_ctx->ssl_conn = SSL_new(ctx->ssl_ctx)) == NULL) { | ||
| 128 | ressl_set_error(ctx, "ssl failure"); | ||
| 129 | goto err; | ||
| 130 | } | ||
| 131 | |||
| 132 | if (SSL_set_fd(conn_ctx->ssl_conn, socket) != 1) { | ||
| 133 | ressl_set_error(ctx, "ssl set fd failure"); | ||
| 134 | goto err; | ||
| 135 | } | ||
| 136 | SSL_set_app_data(conn_ctx->ssl_conn, conn_ctx); | ||
| 137 | } | ||
| 138 | |||
| 139 | if ((ret = SSL_accept(conn_ctx->ssl_conn)) != 1) { | ||
| 140 | ssl_err = SSL_get_error(conn_ctx->ssl_conn, ret); | ||
| 141 | switch (ssl_err) { | ||
| 142 | case SSL_ERROR_WANT_READ: | ||
| 143 | return (RESSL_READ_AGAIN); | ||
| 144 | case SSL_ERROR_WANT_WRITE: | ||
| 145 | return (RESSL_WRITE_AGAIN); | ||
| 146 | default: | ||
| 147 | ressl_set_error(ctx, "ssl accept failure (%i)", | ||
| 148 | ssl_err); | ||
| 149 | goto err; | ||
| 150 | } | ||
| 151 | } | ||
| 152 | |||
| 153 | return (0); | ||
| 154 | |||
| 114 | err: | 155 | err: |
| 115 | return (-1); | 156 | return (-1); |
| 116 | } | 157 | } |
