HoYa's MBED (Nucleo-F401RE)
Dependencies: NetworkSocketAPI X_NUCLEO_IDW01M1v2 mbed
main.cpp
- Committer:
- HoYa
- Date:
- 2017-07-21
- Revision:
- 3:ad353d5bf223
- Parent:
- 2:d7647babe160
File content as of revision 3:ad353d5bf223:
#include "mbed.h"
#include "SpwfInterface.h"
#include "TCPSocket.h"
Serial pc(USBTX, USBRX, 115200);
DigitalOut led(LED1);
SpwfSAInterface spwf(D8, D2, false);
//www.mbed.com CA certificate in PEM format
char CA_cert []="-----BEGIN CERTIFICATE-----\r\n"
"MIIDVDCCAjygAwIBAgIDAjRWMA0GCSqGSIb3DQEBBQUAMEIxCzAJBgNVBAYTAlVT\r\n"
"MRYwFAYDVQQKEw1HZW9UcnVzdCBJbmMuMRswGQYDVQQDExJHZW9UcnVzdCBHbG9i\r\n"
"YWwgQ0EwHhcNMDIwNTIxMDQwMDAwWhcNMjIwNTIxMDQwMDAwWjBCMQswCQYDVQQG\r\n"
"EwJVUzEWMBQGA1UEChMNR2VvVHJ1c3QgSW5jLjEbMBkGA1UEAxMSR2VvVHJ1c3Qg\r\n"
"R2xvYmFsIENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA2swYYzD9\r\n"
"9BcjGlZ+W988bDjkcbd4kdS8odhM+KhDtgPpTSEHCIjaWC9mOSm9BXiLnTjoBbdq\r\n"
"fnGk5sRgprDvgOSJKA+eJdbtg/OtppHHmMlCGDUUna2YRpIuT8rxh0PBFpVXLVDv\r\n"
"iS2Aelet8u5fa9IAjbkU+BQVNdnARqN7csiRv8lVK83Qlz6cJmTM386DGXHKTubU\r\n"
"1XupGc1V3sjs0l44U+VcT4wt/lAjNvxm5suOpDkZALeVAjmRCw7+OC7RHQWa9k0+\r\n"
"bw8HHa8sHo9gOeL6NlMTOdReJivbPagUvTLrGAMoUgRx5aszPeE4uwc2hGKceeoW\r\n"
"MPRfwCvocWvk+QIDAQABo1MwUTAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBTA\r\n"
"ephojYn7qwVkDBF9qn1luMrMTjAfBgNVHSMEGDAWgBTAephojYn7qwVkDBF9qn1l\r\n"
"uMrMTjANBgkqhkiG9w0BAQUFAAOCAQEANeMpauUvXVSOKVCUn5kaFOSPeCpilKIn\r\n"
"Z57QzxpeR+nBsqTP3UEaBU6bS+5Kb1VSsyShNwrrZHYqLizz/Tt1kL/6cdjHPTfS\r\n"
"tQWVYrmm3ok9Nns4d0iXrKYgjy6myQzCsplFAMfOEVEiIuCl6rYVSAlk6l5PdPcF\r\n"
"PseKUgzbFbS9bZvlxrFUaKnjaZC2mqUPuLk/IH2uSrW4nOQdtqvmlKXBx4Ot2/Un\r\n"
"hw4EbNX/3aBd7YdStysVAq45pmp06drE57xNNB6pXE0zX5IJL4hmXXeXxx12E6nV\r\n"
"5fEWCRE11azbJHFwLJhWC9kXtNHjUStedejV0NxPNO3CBWaAocvmMw==\r\n"
"-----END CERTIFICATE-----\r\n";
int main() {
pc.printf("\r\n");
pc.printf("Start Application\r\n");
// Wi-Fi
pc.printf("\r\n");
pc.printf("Connecting to AP...\r\n");
if (spwf.connect("hRPi3-AP", "rlawjdgh", NSAPI_SECURITY_WPA2)) {
pc.printf("=> Success.\r\n");
} else {
pc.printf("=> Failed to connect.\r\n");
return -1;
}
const char* ip = spwf.get_ip_address();
pc.printf("=> IP Address is: %s\r\n", (ip) ? ip : "No IP");
const char* mac = spwf.get_mac_address();
pc.printf("=> MAC Address is: %s\r\n", (mac) ? mac : "No MAC");
// DNS
/*
pc.printf("\r\n");
pc.printf("DNS Testing...\r\n");
SocketAddress addr(&spwf, "st.com");
pc.printf("<st.com> is resolved to: %s\r\n", addr.get_ip_address());
*/
// Unsecured TCP
/*
pc.printf("\r\n");
pc.printf("Unsecured TCP Testing...\r\n");
TCPSocket socket(&spwf);
pc.printf("Connecting to <4.ifcfg.me>...\r\n");
int err = socket.connect("4.ifcfg.me", 23);
if (err) {
pc.printf("=> Failed to connect. (%d)\r\n", err);
return -1;
} else {
pc.printf("=> Success.\r\n");
}
pc.printf("Receiving Data\r\n");
char buffer[100];
int count = socket.recv(buffer, sizeof buffer);
if (count > 0) {
buffer[count] = '\0';
printf("=> %s\r\n", buffer);
}
else {
pc.printf("=> Nothing to receive.\r\n");
}
pc.printf("Close TCP socket\r\n");
socket.close();
*/
// Secured TCP
pc.printf("\r\n");
pc.printf("Secured TCP Testing...\r\n");
if (!spwf.clean_TLS_certificate(ALL))
pc.printf("=> Failed to clean TLS certificate\r\n");
if (!spwf.set_TLS_certificate(CA_cert, sizeof(CA_cert), FLASH_CA_ROOT_CERT))
pc.printf("=> Failed to set TLS certificate\r\n");
if (!spwf.set_TLS_SRV_domain("*.mbed.com", FLASH_DOMAIN))
printf("=> Failed to set TLS CA domain\r\n");
spwf.set_secure_mode();
TCPSocket socket(&spwf);
spwf.set_unsecure_mode();
int err = socket.connect("www.mbed.com", 443);
if (err != 0)
pc.printf("=> Failed to connect. (%d)\r\n", err);
else
pc.printf("=> Success.\r\n");
pc.printf("Close TCP socket\r\n");
socket.close();
pc.printf("Disconnect from AP\r\n");
spwf.disconnect();
while (1) {
led = !led;
wait(0.5);
}
}