#include "user_wifi.h" #include "main.h" #include "mico_socket.h" #include "user_gpio.h" #include "time_server/user_sntp.h" #include "mqtt_server/user_function.h" #include "http_server/web_log.h" #define os_log(format, ...) custom_log("WIFI", format, ##__VA_ARGS__); web_log(format, ##__VA_ARGS__) char wifi_status = WIFI_STATE_NOCONNECT; mico_timer_t wifi_led_timer; IpStatus ip_status = { 0, ELAND_AP_LOCAL_IP, ELAND_AP_LOCAL_IP, ELAND_AP_NET_MASK }; char ap_name[16]; //wifi已连接获取到IP地址回调 static void WifiGetIpCallback(IPStatusTypedef *pnet, void * arg) { strcpy(ip_status.ip, pnet->ip); strcpy(ip_status.gateway, pnet->gate); strcpy(ip_status.mask, pnet->mask); os_log("got IP:%s", pnet->ip); wifi_status = WIFI_STATE_CONNECTED; user_function_cmd_received(1,"{\"cmd\":\"device report\"}"); } //wifi连接状态改变回调 static void WifiStatusCallback(WiFiEvent status, void* arg) { if (status == NOTIFY_STATION_UP) //wifi连接成功 { //user_config->last_wifi_status = status; sys_config->micoSystemConfig.reserved = status; mico_system_context_update(sys_config); OSStatus status = micoWlanSuspendSoftAP(); //关闭AP if (status != kNoErr) { os_log("close ap error[%d]", status); } ip_status.mode = 1; //wifi_status = WIFI_STATE_CONNECTED; } else if (status == NOTIFY_STATION_DOWN) //wifi断开 { //user_config->last_wifi_status = status; sys_config->micoSystemConfig.reserved = status; mico_system_context_update(sys_config); ApInit(); //打开AP wifi_status = WIFI_STATE_NOCONNECT; if (!mico_rtos_is_timer_running(&wifi_led_timer)) { mico_rtos_start_timer(&wifi_led_timer); } } else if (status == NOTIFY_AP_UP) { ip_status.mode = 0; } } bool scaned = false; char* wifi_ret = NULL; //wifi扫描结果回调 void WifiScanCallback(ScanResult_adv* scan_ret, void* arg) { int count = (int)scan_ret->ApNum; os_log("wifi_scan_callback ApNum[%d] ApList[0](%s)", count, scan_ret->ApList[0].ssid); int i = 0; wifi_ret = malloc(sizeof(char)*count * (32 + 2) + 50); char* ssids = malloc(sizeof(char)*count * 32); char* secs = malloc(sizeof(char)*count * 2); char* tmp1 = ssids; char* tmp2 = secs; for (; i < count; i++) { char* ssid = scan_ret->ApList[i].ssid; if (strstr(ssid, "'") || strstr(ssid, "\"")) continue; sprintf(tmp1, "'%s',", ssid); tmp1 += (strlen(ssid) + 3); sprintf(tmp2, "%d,", scan_ret->ApList[i].security); tmp2 += 2; } *(--tmp1) = 0; *(--tmp2) = 0; sprintf(wifi_ret, WIFI_SCAN_RESULT_JSON, 1, ssids, secs); scaned = true; free(ssids); free(secs); } //100ms定时器回调 static void WifiLedTimerCallback(void* arg) { static unsigned int num = 0; num++; switch (wifi_status) { case WIFI_STATE_FAIL: os_log("wifi connect fail"); UserLedSet(0); mico_rtos_stop_timer(&wifi_led_timer); break; case WIFI_STATE_NOCONNECT: //wifi_connect_sys_config(); break; case WIFI_STATE_CONNECTING: num = 0; UserLedSet(-1); break; case WIFI_STATE_CONNECTED: UserLedSet(0); mico_rtos_stop_timer(&wifi_led_timer); if (RelayOut()) UserLedSet(1); else UserLedSet(0); break; } } void WifiConnect(char* wifi_ssid, char* wifi_key) { //wifi配置初始化 network_InitTypeDef_st wNetConfig; memset(&wNetConfig, 0, sizeof(network_InitTypeDef_st)); wNetConfig.wifi_mode = Station; snprintf(wNetConfig.wifi_ssid, 32, wifi_ssid); strcpy((char*)wNetConfig.wifi_key, wifi_key); wNetConfig.dhcpMode = DHCP_Client; wNetConfig.wifi_retry_interval = 6000; micoWlanStart(&wNetConfig); //保存wifi及密码到Flash strcpy(sys_config->micoSystemConfig.ssid, wifi_ssid); strcpy(sys_config->micoSystemConfig.user_key, wifi_key); sys_config->micoSystemConfig.user_keyLength = strlen(wifi_key); mico_system_context_update(sys_config); wifi_status = WIFI_STATE_NOCONNECT; } void WifiInit(void) { //wifi状态下led闪烁定时器初始化 mico_rtos_init_timer(&wifi_led_timer, 100, (void*)WifiLedTimerCallback, NULL); //wifi已连接获取到IP地址 回调 mico_system_notify_register(mico_notify_DHCP_COMPLETED, (void*)WifiGetIpCallback, NULL); //wifi连接状态改变回调 mico_system_notify_register(mico_notify_WIFI_STATUS_CHANGED, (void*)WifiStatusCallback, NULL); //wifi扫描结果回调 mico_system_notify_register(mico_notify_WIFI_SCAN_ADV_COMPLETED, (void*)WifiScanCallback, NULL); //sntp_init(); //启动定时器开始进行wifi连接 if (!mico_rtos_is_timer_running(&wifi_led_timer)) mico_rtos_start_timer(&wifi_led_timer); } void ApInit() { sprintf(ap_name, ELAND_AP_SSID, str_mac+6); os_log("ApInit ap_name[%s]", ap_name); network_InitTypeDef_st wNetConfig; memset(&wNetConfig, 0x0, sizeof(network_InitTypeDef_st)); strcpy((char *)wNetConfig.wifi_ssid, ap_name); strcpy((char *)wNetConfig.wifi_key, ELAND_AP_KEY); wNetConfig.wifi_mode = Soft_AP; wNetConfig.dhcpMode = DHCP_Server; wNetConfig.wifi_retry_interval = 100; strcpy((char *)wNetConfig.local_ip_addr, ELAND_AP_LOCAL_IP); strcpy((char *)wNetConfig.net_mask, ELAND_AP_NET_MASK); strcpy((char *)wNetConfig.dnsServer_ip_addr, ELAND_AP_DNS_SERVER); micoWlanStart(&wNetConfig); os_log("ApInit ssid[%s] key[%s]", wNetConfig.wifi_ssid, wNetConfig.wifi_key); }