mirror of
https://github.com/yuzu-emu/mbedtls.git
synced 2025-01-11 06:05:39 +00:00
Update version of mbed-net-socket
This commit is contained in:
parent
0adc7f7b0f
commit
ae5398a0cf
|
@ -34,8 +34,9 @@ int main() {
|
||||||
#define UNSAFE 0
|
#define UNSAFE 0
|
||||||
|
|
||||||
#include "mbed.h"
|
#include "mbed.h"
|
||||||
#include <mbed-net-lwip-eth/EthernetInterface.h>
|
#include "mbed-net-lwip-eth/EthernetInterface.h"
|
||||||
#include <mbed-net-sockets/TCPStream.h>
|
#include "mbed-net-sockets/TCPStream.h"
|
||||||
|
#include "minar/minar.h"
|
||||||
|
|
||||||
#include "mbedtls/ssl.h"
|
#include "mbedtls/ssl.h"
|
||||||
#include "mbedtls/entropy.h"
|
#include "mbedtls/entropy.h"
|
||||||
|
@ -90,6 +91,8 @@ const char SSL_CA_PEM[] =
|
||||||
"-----END CERTIFICATE-----\n";
|
"-----END CERTIFICATE-----\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
using namespace mbed::Sockets::v0;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief HelloHTTPS implements the logic for fetching a file from a webserver
|
* \brief HelloHTTPS implements the logic for fetching a file from a webserver
|
||||||
* using a TCP socket and parsing the result.
|
* using a TCP socket and parsing the result.
|
||||||
|
@ -194,7 +197,7 @@ public:
|
||||||
/* Connect to the server */
|
/* Connect to the server */
|
||||||
printf("Connecting to %s:%d\r\n", _domain, _port);
|
printf("Connecting to %s:%d\r\n", _domain, _port);
|
||||||
/* Resolve the domain name: */
|
/* Resolve the domain name: */
|
||||||
socket_error_t err = _stream.resolve(_domain, handler_t(this, &HelloHTTPS::onDNS));
|
socket_error_t err = _stream.resolve(_domain, TCPStream::DNSHandler_t(this, &HelloHTTPS::onDNS));
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
|
@ -271,7 +274,7 @@ protected:
|
||||||
* Receive callback for mbed TLS
|
* Receive callback for mbed TLS
|
||||||
*/
|
*/
|
||||||
static int ssl_recv(void *ctx, unsigned char *buf, size_t len) {
|
static int ssl_recv(void *ctx, unsigned char *buf, size_t len) {
|
||||||
mbed::TCPStream *stream = static_cast<mbed::TCPStream *>(ctx);
|
TCPStream *stream = static_cast<TCPStream *>(ctx);
|
||||||
socket_error_t err = stream->recv(buf, &len);
|
socket_error_t err = stream->recv(buf, &len);
|
||||||
|
|
||||||
if (err == SOCKET_ERROR_NONE) {
|
if (err == SOCKET_ERROR_NONE) {
|
||||||
|
@ -287,7 +290,7 @@ protected:
|
||||||
* Send callback for mbed TLS
|
* Send callback for mbed TLS
|
||||||
*/
|
*/
|
||||||
static int ssl_send(void *ctx, const unsigned char *buf, size_t len) {
|
static int ssl_send(void *ctx, const unsigned char *buf, size_t len) {
|
||||||
mbed::TCPStream *stream = static_cast<mbed::TCPStream *>(ctx);
|
TCPStream *stream = static_cast<TCPStream *>(ctx);
|
||||||
|
|
||||||
socket_error_t err = stream->send(buf, len);
|
socket_error_t err = stream->send(buf, len);
|
||||||
|
|
||||||
|
@ -300,15 +303,20 @@ protected:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void onError(Socket *s, socket_error_t err) {
|
||||||
|
(void) s;
|
||||||
|
printf("MBED: Socket Error: %s (%d)\r\n", socket_strerror(err), err);
|
||||||
|
_stream.close();
|
||||||
|
_error = true;
|
||||||
|
minar::Scheduler::stop();
|
||||||
|
}
|
||||||
/**
|
/**
|
||||||
* On Connect handler
|
* On Connect handler
|
||||||
* Sends the request which was generated in startTest
|
* Starts the TLS handshake
|
||||||
*/
|
*/
|
||||||
void onConnect(socket_error_t err) {
|
void onConnect(TCPStream *s) {
|
||||||
(void) err;
|
s->setOnReadable(TCPStream::ReadableHandler_t(this, &HelloHTTPS::onReceive));
|
||||||
|
s->setOnDisconnect(TCPStream::DisconnectHandler_t(this, &HelloHTTPS::onDisconnect));
|
||||||
_stream.setOnReadable(handler_t(this, &HelloHTTPS::onReceive));
|
|
||||||
_stream.setOnDisconnect(handler_t(this, &HelloHTTPS::onDisconnect));
|
|
||||||
|
|
||||||
/* Start the handshake, the rest will be done in onReceive() */
|
/* Start the handshake, the rest will be done in onReceive() */
|
||||||
int ret = mbedtls_ssl_handshake(&_ssl);
|
int ret = mbedtls_ssl_handshake(&_ssl);
|
||||||
|
@ -325,9 +333,7 @@ protected:
|
||||||
* On Receive handler
|
* On Receive handler
|
||||||
* Parses the response from the server, to check for the HTTPS 200 status code and the expected response ("Hello World!")
|
* Parses the response from the server, to check for the HTTPS 200 status code and the expected response ("Hello World!")
|
||||||
*/
|
*/
|
||||||
void onReceive(socket_error_t err) {
|
void onReceive(Socket *s) {
|
||||||
(void) err;
|
|
||||||
|
|
||||||
if (_error)
|
if (_error)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -392,41 +398,44 @@ protected:
|
||||||
printf("HTTPS: Received message:\r\n\r\n");
|
printf("HTTPS: Received message:\r\n\r\n");
|
||||||
printf("%s", _buffer);
|
printf("%s", _buffer);
|
||||||
_error = !(_got200 && _gothello);
|
_error = !(_got200 && _gothello);
|
||||||
|
|
||||||
|
s->close();
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* On DNS Handler
|
* On DNS Handler
|
||||||
* Reads the address returned by DNS, then starts the connect process.
|
* Reads the address returned by DNS, then starts the connect process.
|
||||||
*/
|
*/
|
||||||
void onDNS(socket_error_t err) {
|
void onDNS(Socket *s, struct socket_addr addr, const char *domain) {
|
||||||
socket_event_t *e = _stream.getEvent();
|
|
||||||
/* Check that the result is a valid DNS response */
|
/* Check that the result is a valid DNS response */
|
||||||
if (socket_addr_is_any(&e->i.d.addr)) {
|
if (socket_addr_is_any(&addr)) {
|
||||||
/* Could not find DNS entry */
|
/* Could not find DNS entry */
|
||||||
_error = true;
|
|
||||||
printf("Could not find DNS entry for %s", HTTPS_SERVER_NAME);
|
printf("Could not find DNS entry for %s", HTTPS_SERVER_NAME);
|
||||||
return;
|
onError(s, SOCKET_ERROR_DNS_FAILED);
|
||||||
} else {
|
} else {
|
||||||
/* Start connecting to the remote host */
|
/* Start connecting to the remote host */
|
||||||
_remoteAddr.setAddr(&e->i.d.addr);
|
char buf[16];
|
||||||
err = _stream.connect(&_remoteAddr, _port, handler_t(this, &HelloHTTPS::onConnect));
|
_remoteAddr.setAddr(&addr);
|
||||||
|
_remoteAddr.fmtIPv4(buf,sizeof(buf));
|
||||||
|
printf("%s address: %s\r\n",domain, buf);
|
||||||
|
socket_error_t err = _stream.connect(_remoteAddr, _port, TCPStream::ConnectHandler_t(this, &HelloHTTPS::onConnect));
|
||||||
|
|
||||||
if (err != SOCKET_ERROR_NONE) {
|
if (err != SOCKET_ERROR_NONE) {
|
||||||
_error = true;
|
onError(s, err);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
void onDisconnect(socket_error_t err) {
|
void onDisconnect(TCPStream *s) {
|
||||||
(void) err;
|
s->close();
|
||||||
_disconnected = true;
|
minar::Scheduler::stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
mbed::TCPStream _stream; /**< The TCP Socket */
|
TCPStream _stream; /**< The TCP Socket */
|
||||||
const char *_domain; /**< The domain name of the HTTPS server */
|
const char *_domain; /**< The domain name of the HTTPS server */
|
||||||
const uint16_t _port; /**< The HTTPS server port */
|
const uint16_t _port; /**< The HTTPS server port */
|
||||||
char _buffer[RECV_BUFFER_SIZE]; /**< The response buffer */
|
char _buffer[RECV_BUFFER_SIZE]; /**< The response buffer */
|
||||||
size_t _bpos; /**< The current offset in the response buffer */
|
size_t _bpos; /**< The current offset in the response buffer */
|
||||||
mbed::SocketAddr _remoteAddr; /**< The remote address */
|
SocketAddr _remoteAddr; /**< The remote address */
|
||||||
volatile bool _got200; /**< Status flag for HTTPS 200 */
|
volatile bool _got200; /**< Status flag for HTTPS 200 */
|
||||||
volatile bool _gothello; /**< Status flag for finding the test string */
|
volatile bool _gothello; /**< Status flag for finding the test string */
|
||||||
volatile bool _error; /**< Status flag for an error */
|
volatile bool _error; /**< Status flag for an error */
|
||||||
|
|
|
@ -5,9 +5,9 @@
|
||||||
"license": "GPL-2.0",
|
"license": "GPL-2.0",
|
||||||
"dependencies": {},
|
"dependencies": {},
|
||||||
"targetDependencies": {
|
"targetDependencies": {
|
||||||
"mbed": { "cmsis-core": "~0.2.1" }
|
"mbed": { "cmsis-core": "~0.2.3" }
|
||||||
},
|
},
|
||||||
"testTargetDependencies": {
|
"testTargetDependencies": {
|
||||||
"mbed": { "mbed-net-sockets": "~0.1.3" }
|
"mbed": { "mbed-net-sockets": "~0.2.0" }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue