/** * Test with credentials preset */ void test_connect_preset_credentials() { driver.disconnect(); driver.set_sim_pin(MBED_CONF_APP_DEFAULT_PIN); driver.set_credentials(MBED_CONF_APP_APN, MBED_CONF_APP_USERNAME, MBED_CONF_APP_PASSWORD); int num_retries = 0; nsapi_error_t err = NSAPI_ERROR_OK; while (!driver.is_connected()) { err = driver.connect(); if (err == NSAPI_ERROR_OK || num_retries > MBED_CONF_APP_MAX_RETRIES) { break; } } TEST_ASSERT(err == 0); use_connection(&driver); drop_connection(&driver); }
/* \brief easy_connect easy_connect() function to connect the pre-defined network bearer, * config done via mbed_app.json (see README.md for details). * * IN: bool log_messages print out diagnostics or not. */ NetworkInterface* easy_connect(bool log_messages) { NetworkInterface* network_interface = NULL; int connect_success = -1; #if defined (EASY_CONNECT_WIFI) // We check if the _ssid and _password have already been set (via the easy_connect() // that takes thoses parameters or not. // If they have not been set, use the ones we can gain from mbed_app.json. if (_ssid == NULL) { if(strlen(MBED_CONF_APP_WIFI_SSID) > WIFI_SSID_MAX_LEN) { printf("ERROR - MBED_CONF_APP_WIFI_SSID is too long %d vs. %d\n", strlen(MBED_CONF_APP_WIFI_SSID), WIFI_SSID_MAX_LEN); return NULL; } } if (_password == NULL) { if(strlen(MBED_CONF_APP_WIFI_PASSWORD) > WIFI_PASSWORD_MAX_LEN) { printf("ERROR - MBED_CONF_APP_WIFI_PASSWORD is too long %d vs. %d\n", strlen(MBED_CONF_APP_WIFI_PASSWORD), WIFI_PASSWORD_MAX_LEN); return NULL; } } #endif // EASY_CONNECT_WIFI /// This should be removed once mbedOS supports proper dual-stack if (log_messages) { #if defined (EASY_CONNECT_MESH) || (MBED_CONF_LWIP_IPV6_ENABLED==true) printf("[EasyConnect] IPv6 mode\n"); #else printf("[EasyConnect] IPv4 mode\n"); #endif } #if defined (EASY_CONNECT_WIFI) if (log_messages) { printf("[EasyConnect] Using WiFi (%s) \n", EASY_CONNECT_WIFI_TYPE); printf("[EasyConnect] Connecting to WiFi %s\n", ((_ssid == NULL) ? MBED_CONF_APP_WIFI_SSID : _ssid) ); } network_interface = &wifi; if (_ssid == NULL) { connect_success = wifi.connect(MBED_CONF_APP_WIFI_SSID, MBED_CONF_APP_WIFI_PASSWORD, (strlen(MBED_CONF_APP_WIFI_PASSWORD) > 1) ? NSAPI_SECURITY_WPA_WPA2 : NSAPI_SECURITY_NONE); } else { connect_success = wifi.connect(_ssid, _password, (strlen(_password) > 1) ? NSAPI_SECURITY_WPA_WPA2 : NSAPI_SECURITY_NONE); } #elif MBED_CONF_APP_NETWORK_INTERFACE == CELLULAR_ONBOARD || MBED_CONF_APP_NETWORK_INTERFACE == CELLULAR # ifdef MBED_CONF_APP_CELLULAR_SIM_PIN cellular.set_sim_pin(MBED_CONF_APP_CELLULAR_SIM_PIN); # endif # ifdef MBED_CONF_APP_CELLULAR_APN # ifndef MBED_CONF_APP_CELLULAR_USERNAME # define MBED_CONF_APP_CELLULAR_USERNAME 0 # endif # ifndef MBED_CONF_APP_CELLULAR_PASSWORD # define MBED_CONF_APP_CELLULAR_PASSWORD 0 # endif cellular.set_credentials(MBED_CONF_APP_CELLULAR_APN, MBED_CONF_APP_CELLULAR_USERNAME, MBED_CONF_APP_CELLULAR_PASSWORD); if (log_messages) { printf("[EasyConnect] Connecting using Cellular interface and APN %s\n", MBED_CONF_APP_CELLULAR_APN); } # else if (log_messages) { printf("[EasyConnect] Connecting using Cellular interface and default APN\n"); } # endif connect_success = cellular.connect(); network_interface = &cellular; #elif MBED_CONF_APP_NETWORK_INTERFACE == CELLULAR_WNC14A2A if (log_messages) { printf("[EasyConnect] Using WNC14A2A\n"); } # if MBED_CONF_APP_WNC_DEBUG == true printf("[EasyConnect] With WNC14A2A debug output set to 0x%02X\n",MBED_CONF_APP_WNC_DEBUG_SETTING); wnc.doDebug(MBED_CONF_APP_WNC_DEBUG_SETTING); # endif network_interface = &wnc; connect_success = wnc.connect(); #elif MBED_CONF_APP_NETWORK_INTERFACE == ETHERNET if (log_messages) { printf("[EasyConnect] Using Ethernet\n"); } network_interface = ð #if MBED_CONF_EVENTS_SHARED_DISPATCH_FROM_APPLICATION eth.set_blocking(false); #endif connect_success = eth.connect(); #endif #ifdef EASY_CONNECT_MESH if (log_messages) { printf("[EasyConnect] Using Mesh (%s)\n", EASY_CONNECT_MESH_TYPE); printf("[EasyConnect] Connecting to Mesh...\n"); } network_interface = &mesh; #if MBED_CONF_EVENTS_SHARED_DISPATCH_FROM_APPLICATION mesh.set_blocking(false); #endif mesh.initialize(&rf_phy); connect_success = mesh.connect(); #endif if(connect_success == 0 #if (MBED_CONF_EVENTS_SHARED_DISPATCH_FROM_APPLICATION && (MBED_CONF_APP_NETWORK_INTERFACE == ETHERNET || defined(EASY_CONNECT_MESH))) || connect_success == NSAPI_ERROR_IS_CONNECTED || connect_success == NSAPI_ERROR_ALREADY #endif ) { #if (MBED_CONF_EVENTS_SHARED_DISPATCH_FROM_APPLICATION && (MBED_CONF_APP_NETWORK_INTERFACE == ETHERNET || defined(EASY_CONNECT_MESH))) nsapi_connection_status_t connection_status; for (;;) { // Check current connection status. connection_status = network_interface->get_connection_status(); if (connection_status == NSAPI_STATUS_GLOBAL_UP) { // Connection ready. break; } else if (connection_status == NSAPI_STATUS_ERROR_UNSUPPORTED) { if (log_messages) { print_MAC(network_interface, log_messages); printf("[EasyConnect] Connection to Network Failed %d!\n", connection_status); } return NULL; } // Not ready yet, give some runtime to the network stack. mbed::mbed_event_queue()->dispatch(100); } #endif if (log_messages) { printf("[EasyConnect] Connected to Network successfully\n"); print_MAC(network_interface, log_messages); } } else { if (log_messages) { print_MAC(network_interface, log_messages); printf("[EasyConnect] Connection to Network Failed %d!\n", connect_success); } return NULL; } const char *ip_addr = network_interface->get_ip_address(); if (ip_addr == NULL) { if (log_messages) { printf("[EasyConnect] ERROR - No IP address\n"); } return NULL; } if (log_messages) { printf("[EasyConnect] IP address %s\n", ip_addr); } return network_interface; }