diff options
| author | Dirk Ziegelmeier <[email protected]> | 2019-04-30 13:22:09 +0200 |
|---|---|---|
| committer | Dirk Ziegelmeier <[email protected]> | 2019-04-30 13:22:09 +0200 |
| commit | 3d7ff530701cbc4f304c41e45398a10425c9d595 (patch) | |
| tree | c8c168c5e07b64fe3fad800b3f9f83bc6065b5c2 | |
| parent | 295996f9127b5425b211393011a9acb4c01d0acc (diff) | |
Apply patch for bug #56098: Support for MQTT over TLS port 443 instead of 8883
| -rw-r--r-- | src/apps/altcp_tls/altcp_tls_mbedtls.c | 15 | ||||
| -rw-r--r-- | src/include/lwip/altcp_tls.h | 9 |
2 files changed, 24 insertions, 0 deletions
diff --git a/src/apps/altcp_tls/altcp_tls_mbedtls.c b/src/apps/altcp_tls/altcp_tls_mbedtls.c index f3a07e30..9f419223 100644 --- a/src/apps/altcp_tls/altcp_tls_mbedtls.c +++ b/src/apps/altcp_tls/altcp_tls_mbedtls.c @@ -945,6 +945,21 @@ altcp_tls_create_config_client_2wayauth(const u8_t *ca, size_t ca_len, const u8_ return conf; } +int +altcp_tls_configure_alpn_protocols(struct altcp_tls_config *conf, const char **protos) +{ +#if defined(MBEDTLS_SSL_ALPN) + int ret = mbedtls_ssl_conf_alpn_protocols(&conf->conf, protos); + if (ret != 0) { + LWIP_DEBUGF(ALTCP_MBEDTLS_DEBUG, ("mbedtls_ssl_conf_alpn_protocols failed: %d\n", ret)); + } + + return ret; +#else + return -1; +#endif +} + void altcp_tls_free_config(struct altcp_tls_config *conf) { diff --git a/src/include/lwip/altcp_tls.h b/src/include/lwip/altcp_tls.h index 4239c125..5f1cb7c4 100644 --- a/src/include/lwip/altcp_tls.h +++ b/src/include/lwip/altcp_tls.h @@ -95,6 +95,15 @@ struct altcp_tls_config *altcp_tls_create_config_client_2wayauth(const u8_t *ca, const u8_t *cert, size_t cert_len); /** @ingroup altcp_tls + * Configure ALPN TLS extension + * Example:<br> + * static const char *g_alpn_protocols[] = { "x-amzn-mqtt-ca", NULL };<br> + * tls_config = altcp_tls_create_config_client(ca, ca_len);<br> + * altcp_tls_conf_alpn_protocols(tls_config, g_alpn_protocols);<br> + */ +int altcp_tls_configure_alpn_protocols(struct altcp_tls_config *conf, const char **protos); + +/** @ingroup altcp_tls * Free an ALTCP_TLS configuration handle */ void altcp_tls_free_config(struct altcp_tls_config *conf); |
