From d57495cb1ce58ed534adbc0847234e4215ea38be Mon Sep 17 00:00:00 2001 From: Jitin George Date: Fri, 20 Apr 2018 10:50:38 +0530 Subject: [PATCH] esp-tls: Fix HTTP2 failure Closes https://github.com/espressif/esp-idf/issues/1874 --- components/esp-tls/esp_tls.c | 4 ++++ components/esp-tls/esp_tls.h | 2 +- .../protocols/http2_request/components/sh2lib/sh2lib.c | 8 +++++++- .../protocols/http2_request/components/sh2lib/sh2lib.h | 1 - 4 files changed, 12 insertions(+), 3 deletions(-) diff --git a/components/esp-tls/esp_tls.c b/components/esp-tls/esp_tls.c index 5309d7796a..a7040b3d2c 100644 --- a/components/esp-tls/esp_tls.c +++ b/components/esp-tls/esp_tls.c @@ -182,6 +182,10 @@ static int create_ssl_handle(esp_tls_t *tls, const char *hostname, size_t hostle goto exit; } + if (cfg->alpn_protos) { + mbedtls_ssl_conf_alpn_protocols(&tls->conf, cfg->alpn_protos); + } + if (cfg->cacert_pem_buf != NULL) { mbedtls_x509_crt_init(&tls->cacert); ret = mbedtls_x509_crt_parse(&tls->cacert, cfg->cacert_pem_buf, cfg->cacert_pem_bytes); diff --git a/components/esp-tls/esp_tls.h b/components/esp-tls/esp_tls.h index 4f2f35a03a..92b0734ebe 100644 --- a/components/esp-tls/esp_tls.h +++ b/components/esp-tls/esp_tls.h @@ -36,7 +36,7 @@ extern "C" { * @brief ESP-TLS configuration parameters */ typedef struct esp_tls_cfg { - const unsigned char *alpn_protos; /*!< Application protocols required for HTTP2. + const char **alpn_protos; /*!< Application protocols required for HTTP2. If HTTP2/ALPN support is required, a list of protocols that should be negotiated. The format is length followed by protocol diff --git a/examples/protocols/http2_request/components/sh2lib/sh2lib.c b/examples/protocols/http2_request/components/sh2lib/sh2lib.c index 4026db4562..8273265aef 100644 --- a/examples/protocols/http2_request/components/sh2lib/sh2lib.c +++ b/examples/protocols/http2_request/components/sh2lib/sh2lib.c @@ -20,6 +20,7 @@ #include #include #include +#include #include "sh2lib.h" @@ -240,14 +241,19 @@ static int do_http2_connect(struct sh2lib_handle *hd) int sh2lib_connect(struct sh2lib_handle *hd, const char *uri) { memset(hd, 0, sizeof(*hd)); + const char *proto[] = {"h2", NULL}; esp_tls_cfg_t tls_cfg = { - .alpn_protos = (unsigned char *) "\x02h2", + .alpn_protos = proto, .non_block = true, }; if ((hd->http2_tls = esp_tls_conn_http_new(uri, &tls_cfg)) == NULL) { ESP_LOGE(TAG, "[sh2-connect] esp-tls connection failed"); goto error; } + struct http_parser_url u; + http_parser_url_init(&u); + http_parser_parse_url(uri, strlen(uri), 0, &u); + hd->hostname = strndup(&uri[u.field_data[UF_HOST].off], u.field_data[UF_HOST].len); /* HTTP/2 Connection */ if (do_http2_connect(hd) != 0) { diff --git a/examples/protocols/http2_request/components/sh2lib/sh2lib.h b/examples/protocols/http2_request/components/sh2lib/sh2lib.h index 44d1a5333e..f67137695c 100644 --- a/examples/protocols/http2_request/components/sh2lib/sh2lib.h +++ b/examples/protocols/http2_request/components/sh2lib/sh2lib.h @@ -34,7 +34,6 @@ */ struct sh2lib_handle { nghttp2_session *http2_sess; /*!< Pointer to the HTTP2 session handle */ - int sockfd; /*!< Socket file descriptor */ char *hostname; /*!< The hostname we are connected to */ struct esp_tls *http2_tls; /*!< Pointer to the TLS session handle */ }; -- 2.40.0