#define TAG "smartlinkd-demo" #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "aw_smartlinkd_connect.h" #include #define SMARTLINK_TEST_TIMES 10 int debug_enable = 1; int success_times = 0; int fail_times = 0; /* param used to wifi connect test ,add by Kirin 2016/11/22 */ const aw_wifi_interface_t *p_wifi_interface = NULL; tKEY_MGMT key_mgmt; int event_label = 0; static int event = WIFIMG_NETWORK_DISCONNECTED; static int connect_ap_finished_flag = 0; static void wifi_event_handle(tWIFI_EVENT wifi_event, void *buf, int event_label) { printf("event_label 0x%x\n", event_label); switch(wifi_event) { case WIFIMG_WIFI_ON_SUCCESS: { printf("WiFi on success!\n"); event = WIFIMG_WIFI_ON_SUCCESS; break; } case WIFIMG_WIFI_ON_FAILED: { printf("WiFi on failed!\n"); event = WIFIMG_WIFI_ON_FAILED; break; } case WIFIMG_WIFI_OFF_FAILED: { printf("wifi off failed!\n"); event = WIFIMG_WIFI_OFF_FAILED; break; } case WIFIMG_WIFI_OFF_SUCCESS: { printf("wifi off success!\n"); event = WIFIMG_WIFI_OFF_SUCCESS; break; } case WIFIMG_NETWORK_CONNECTED: { printf("WiFi connected ap!\n"); event = WIFIMG_NETWORK_CONNECTED; break; } case WIFIMG_NETWORK_DISCONNECTED: { printf("WiFi disconnected!\n"); event = WIFIMG_NETWORK_DISCONNECTED; break; } case WIFIMG_PASSWORD_FAILED: { printf("Password authentication failed!\n"); event = WIFIMG_PASSWORD_FAILED; break; } case WIFIMG_CONNECT_TIMEOUT: { printf("Connected timeout!\n"); event = WIFIMG_CONNECT_TIMEOUT; break; } case WIFIMG_NO_NETWORK_CONNECTING: { printf("It has no wifi auto connect when wifi on!\n"); event = WIFIMG_NO_NETWORK_CONNECTING; break; } case WIFIMG_CMD_OR_PARAMS_ERROR: { printf("cmd or params error!\n"); event = WIFIMG_CMD_OR_PARAMS_ERROR; break; } case WIFIMG_KEY_MGMT_NOT_SUPPORT: { printf("key mgmt is not supported!\n"); event = WIFIMG_KEY_MGMT_NOT_SUPPORT; break; } case WIFIMG_OPT_NO_USE_EVENT: { printf("operation no use!\n"); event = WIFIMG_OPT_NO_USE_EVENT; break; } case WIFIMG_NETWORK_NOT_EXIST: { printf("network not exist!\n"); event = WIFIMG_NETWORK_NOT_EXIST; break; } case WIFIMG_DEV_BUSING_EVENT: { printf("wifi device busing!\n"); event = WIFIMG_DEV_BUSING_EVENT; break; } default: { printf("Other event, no care!\n"); } } } int onRead(char* buf,int length) { pid_t pid; char ssid[256] = {0}; char passwd[256] = {0}; int status; if(length == THREAD_INIT){ printf("if(length == THREAD_INIT)...\n"); } else if(length == -1){ //RST printf("else if(length == -1)...\n"); }else if(length == 0){ //EOF printf("server close the connection...\n"); //exit(0); return THREAD_EXIT; }else { printf("length: %d\n",length); //printf_info((struct _cmd *)buf); struct _cmd* c = (struct _cmd *)buf; if(c->cmd == AW_SMARTLINKD_FAILED){ printf("smartlinkd_demo:response failed\n"); return THREAD_CONTINUE; } if(c->info.protocol == AW_SMARTLINKD_PROTO_FAIL){ printf("proto scan fail"); connect_ap_finished_flag = 1; return THREAD_EXIT; } printf("cmd: %d\n",c->cmd); printf("pcol: %d\n",c->info.protocol); printf("ssid: %s\n",c->info.base_info.ssid); printf("pasd: %s\n",c->info.base_info.password); printf("security: %d\n",c->info.base_info.security); if(c->info.protocol == AW_SMARTLINKD_PROTO_AKISS) printf("radm: %d\n",c->info.airkiss_random); if(c->info.protocol == AW_SMARTLINKD_PROTO_COOEE){ printf("ip: %s\n",c->info.ip_info.ip); printf("port: %d\n",c->info.ip_info.port); } if(c->info.protocol == AW_SMARTLINKD_PROTO_ADT){ printf("adt get: %s\n",c->info.adt_str); } printf("\n:*********************************\n"); printf("***Starting to connect ap!***\n"); printf("*********************************\n"); if ((pid = fork()) < 0) { printf("smartlinkd_demo: fork 2 error\n"); } else if(pid == 0) { event_label = rand(); p_wifi_interface = aw_wifi_on(wifi_event_handle, event_label); if(p_wifi_interface == NULL){ printf("wifi on failed event 0x%x\n", event); return -1; } while(aw_wifi_get_wifi_state() == WIFIMG_WIFI_BUSING){ printf("wifi state busing,waiting 11111\n"); usleep(2000000); } if(c->info.protocol == AW_SMARTLINKD_PROTO_COOEE || c->info.protocol == AW_SMARTLINKD_PROTO_AKISS) { //judge the encryption method of wifi if(c->info.base_info.security ==0) key_mgmt = 0; else if(c->info.base_info.security ==1) key_mgmt = 3; else if(c->info.base_info.security ==2) key_mgmt = 1; else if(c->info.base_info.security ==3) key_mgmt = 2; /* WLAN_SECURITY_NONE = 0, WLAN_SECURITY_WEP, WLAN_SECURITY_WPA, WLAN_SECURITY_WPA2, typedef enum { WIFIMG_NONE = 0, WIFIMG_WPA_PSK, WIFIMG_WPA2_PSK, WIFIMG_WEP, }tKEY_MGMT; */ event_label++; p_wifi_interface->add_network(c->info.base_info.ssid,key_mgmt,c->info.base_info.password,event_label); } else { convert_adt_str_to_info(ssid, passwd, c->info.adt_str); event_label++; p_wifi_interface->connect_ap(ssid, passwd, event_label); } while(aw_wifi_get_wifi_state() == WIFIMG_WIFI_BUSING){ printf("wifi state busing,waiting 22222\n"); usleep(2000000); } if(aw_wifi_get_wifi_state() == WIFIMG_WIFI_CONNECTED) exit(0); else exit(-1); } if(waitpid(pid,&status,0) != pid) { printf("waitpid 2 error!\n"); } if(WIFEXITED(status)) { if(0 == WEXITSTATUS(status)) { success_times++; printf("*****************************************\n"); printf("Smartlink demo:wifi connect ap: Successful!\n"); printf("*****************************************\n"); } else { fail_times++; printf("*****************************************\n"); printf("Smartlink demo:wifi connect ap: failed!\n"); printf("*****************************************\n"); } } connect_ap_finished_flag = 1; return THREAD_EXIT; } return THREAD_CONTINUE; } static void help_message( ) { } int main(int argc, char* argv[]) { int proto = 0; pid_t pid; int ret = 0; int test_times = 0; int i = 0; char prt_buf[256] = {0}; if(argc < 2) { printf("ERROR: parameter error!\n"); help_message(); return -1; } if(2 == argc && (!strcmp(argv[1],"-h") || !strcmp(argv[1],"-help"))) { help_message(); return 0; } printf("#########start smartlinkd#########\n"); printf("#########check wifi statue#########\n"); system("ifconfig wlan0 down"); while( 0 == check_wlan_interface()){ printf("wating for wlan interface to be down...\n"); sleep(1); } printf("#########check wifi statue ok#########\n"); system("ifconfig wlan0 up"); if(argc > 1){ proto = atoi(argv[1]); } if(argv[2] && NULL != argv[2]) { test_times = atoi(argv[2]); printf("===================Total test times(with setup): %d!===================\n", test_times); } else { test_times = SMARTLINK_TEST_TIMES; printf("===================Total test times(with default): %d!===================\n", test_times); } success_times = 0; fail_times = 0; for(i = 0; i < test_times; i++) { printf("===================The %drd time!===================\n", i+1); //aw_smartlinkd_prepare(); if(aw_smartlinkd_init(0,onRead) == 0){ if(proto == 0){ printf("#########start airkiss#########\n"); aw_startairkiss(); } else if(proto == 1){ printf("#########start cooee#########\n"); aw_startcooee(); } else if(proto == 2){ printf("#########start adt#########\n"); aw_startadt(); } else if(proto ==3){ printf("#########start composite#########\n"); aw_startcomposite(AW_SMARTLINKD_PROTO_COOEE|AW_SMARTLINKD_PROTO_ADT); } } while(connect_ap_finished_flag == 0) sleep(1); connect_ap_finished_flag = 0; printf("===================The %drd time test finished!===================\n", i+1); } sprintf(prt_buf,"echo \"Test Times:%d, Success Times:%d, Failed Times:%d\" > /etc/smartlinkd_test_results",i,success_times,fail_times); system(prt_buf); if(success_times == test_times) { sprintf(prt_buf,"echo Congratulations! >> /etc/smartlinkd_test_results"); system(prt_buf); } return 0; }