ESP8266 part of the f105-motor-demo project (see f105-motor-demo_stm32)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

1790 lines
64 KiB

/******************************************************************************
* Copyright 2013-2014 Espressif Systems (Wuxi)
*
* FileName: user_webserver.c
*
* Description: The web server mode configration.
* Check your hardware connection with the host while use this mode.
* Modification history:
* 2014/3/12, v1.0 create this file.
*******************************************************************************/
#include "ets_sys.h"
#include "os_type.h"
#include "osapi.h"
#include "mem.h"
#include "user_interface.h"
#include "user_iot_version.h"
#include "espconn.h"
#include "user_json.h"
#include "user_webserver.h"
#include "upgrade.h"
#if ESP_PLATFORM
#include "user_esp_platform.h"
#endif
#ifdef SERVER_SSL_ENABLE
#include "ssl/cert.h"
#include "ssl/private_key.h"
#endif
#if LIGHT_DEVICE
#include "user_light.h"
#endif
LOCAL struct station_config *sta_conf;
LOCAL struct softap_config *ap_conf;
//LOCAL struct secrty_server_info *sec_server;
//LOCAL struct upgrade_server_info *server;
//struct lewei_login_info *login_info;
LOCAL scaninfo *pscaninfo;
struct bss_info *bss;
struct bss_info *bss_temp;
struct bss_info *bss_head;
extern u16 scannum;
LOCAL uint32 PostCmdNeeRsp = 1;
uint8 upgrade_lock = 0;
LOCAL os_timer_t app_upgrade_10s;
LOCAL os_timer_t upgrade_check_timer;
/******************************************************************************
* FunctionName : device_get
* Description : set up the device information parmer as a JSON format
* Parameters : js_ctx -- A pointer to a JSON set up
* Returns : result
*******************************************************************************/
LOCAL int ICACHE_FLASH_ATTR
device_get(struct jsontree_context *js_ctx)
{
const char *path = jsontree_path_name(js_ctx, js_ctx->depth - 1);
if (os_strncmp(path, "manufacture", 11) == 0) {
jsontree_write_string(js_ctx, "Espressif Systems");
} else if (os_strncmp(path, "product", 7) == 0) {
#if SENSOR_DEVICE
#if HUMITURE_SUB_DEVICE
jsontree_write_string(js_ctx, "Humiture");
#elif FLAMMABLE_GAS_SUB_DEVICE
jsontree_write_string(js_ctx, "Flammable Gas");
#endif
#endif
#if PLUG_DEVICE
jsontree_write_string(js_ctx, "Plug");
#endif
#if LIGHT_DEVICE
jsontree_write_string(js_ctx, "Light");
#endif
}
return 0;
}
LOCAL struct jsontree_callback device_callback =
JSONTREE_CALLBACK(device_get, NULL);
/******************************************************************************
* FunctionName : userbin_get
* Description : get up the user bin paramer as a JSON format
* Parameters : js_ctx -- A pointer to a JSON set up
* Returns : result
*******************************************************************************/
LOCAL int ICACHE_FLASH_ATTR
userbin_get(struct jsontree_context *js_ctx)
{
const char *path = jsontree_path_name(js_ctx, js_ctx->depth - 1);
char string[32];
if (os_strncmp(path, "status", 8) == 0) {
os_sprintf(string, "200");
} else if (os_strncmp(path, "user_bin", 8) == 0) {
if (system_upgrade_userbin_check() == 0x00) {
os_sprintf(string, "user1.bin");
} else if (system_upgrade_userbin_check() == 0x01) {
os_sprintf(string, "user2.bin");
} else{
return 0;
}
}
jsontree_write_string(js_ctx, string);
return 0;
}
LOCAL struct jsontree_callback userbin_callback =
JSONTREE_CALLBACK(userbin_get, NULL);
JSONTREE_OBJECT(userbin_tree,
JSONTREE_PAIR("status", &userbin_callback),
JSONTREE_PAIR("user_bin", &userbin_callback));
JSONTREE_OBJECT(userinfo_tree,JSONTREE_PAIR("user_info",&userbin_tree));
/******************************************************************************
* FunctionName : version_get
* Description : set up the device version paramer as a JSON format
* Parameters : js_ctx -- A pointer to a JSON set up
* Returns : result
*******************************************************************************/
LOCAL int ICACHE_FLASH_ATTR
version_get(struct jsontree_context *js_ctx)
{
const char *path = jsontree_path_name(js_ctx, js_ctx->depth - 1);
char string[32];
if (os_strncmp(path, "hardware", 8) == 0) {
#if SENSOR_DEVICE
os_sprintf(string, "0.3");
#else
os_sprintf(string, "0.1");
#endif
} else if (os_strncmp(path, "sdk_version", 11) == 0) {
os_sprintf(string, "%s", system_get_sdk_version());
} else if (os_strncmp(path, "iot_version", 11) == 0) {
os_sprintf(string,"%s%d.%d.%dt%d(%s)",VERSION_TYPE,IOT_VERSION_MAJOR,\
IOT_VERSION_MINOR,IOT_VERSION_REVISION,device_type,UPGRADE_FALG);
}
jsontree_write_string(js_ctx, string);
return 0;
}
LOCAL struct jsontree_callback version_callback =
JSONTREE_CALLBACK(version_get, NULL);
JSONTREE_OBJECT(device_tree,
JSONTREE_PAIR("product", &device_callback),
JSONTREE_PAIR("manufacturer", &device_callback));
JSONTREE_OBJECT(version_tree,
JSONTREE_PAIR("hardware", &version_callback),
JSONTREE_PAIR("sdk_version", &version_callback),
JSONTREE_PAIR("iot_version", &version_callback),
);
JSONTREE_OBJECT(info_tree,
JSONTREE_PAIR("Version", &version_tree),
JSONTREE_PAIR("Device", &device_tree));
JSONTREE_OBJECT(INFOTree,
JSONTREE_PAIR("info", &info_tree));
LOCAL int ICACHE_FLASH_ATTR
connect_status_get(struct jsontree_context *js_ctx)
{
const char *path = jsontree_path_name(js_ctx, js_ctx->depth - 1);
if (os_strncmp(path, "status", 8) == 0) {
jsontree_write_int(js_ctx, user_esp_platform_get_connect_status());
}
return 0;
}
LOCAL struct jsontree_callback connect_status_callback =
JSONTREE_CALLBACK(connect_status_get, NULL);
JSONTREE_OBJECT(status_sub_tree,
JSONTREE_PAIR("status", &connect_status_callback));
JSONTREE_OBJECT(connect_status_tree,
JSONTREE_PAIR("Status", &status_sub_tree));
JSONTREE_OBJECT(con_status_tree,
JSONTREE_PAIR("info", &connect_status_tree));
#if PLUG_DEVICE
/******************************************************************************
* FunctionName : status_get
* Description : set up the device status as a JSON format
* Parameters : js_ctx -- A pointer to a JSON set up
* Returns : result
*******************************************************************************/
LOCAL int ICACHE_FLASH_ATTR
status_get(struct jsontree_context *js_ctx)
{
if (user_plug_get_status() == 1) {
jsontree_write_int(js_ctx, 1);
} else {
jsontree_write_int(js_ctx, 0);
}
return 0;
}
/******************************************************************************
* FunctionName : status_set
* Description : parse the device status parmer as a JSON format
* Parameters : js_ctx -- A pointer to a JSON set up
* parser -- A pointer to a JSON parser state
* Returns : result
*******************************************************************************/
LOCAL int ICACHE_FLASH_ATTR
status_set(struct jsontree_context *js_ctx, struct jsonparse_state *parser)
{
int type;
while ((type = jsonparse_next(parser)) != 0) {
if (type == JSON_TYPE_PAIR_NAME) {
if (jsonparse_strcmp_value(parser, "status") == 0) {
uint8 status;
jsonparse_next(parser);
jsonparse_next(parser);
status = jsonparse_get_value_as_int(parser);
user_plug_set_status(status);
}
}
}
return 0;
}
LOCAL struct jsontree_callback status_callback =
JSONTREE_CALLBACK(status_get, status_set);
JSONTREE_OBJECT(status_tree,
JSONTREE_PAIR("status", &status_callback));
JSONTREE_OBJECT(response_tree,
JSONTREE_PAIR("Response", &status_tree));
JSONTREE_OBJECT(StatusTree,
JSONTREE_PAIR("switch", &response_tree));
#endif
#if LIGHT_DEVICE
LOCAL int ICACHE_FLASH_ATTR
light_status_get(struct jsontree_context *js_ctx)
{
const char *path = jsontree_path_name(js_ctx, js_ctx->depth - 1);
if (os_strncmp(path, "red", 3) == 0) {
jsontree_write_int(js_ctx, user_light_get_duty(LIGHT_RED));
} else if (os_strncmp(path, "green", 5) == 0) {
jsontree_write_int(js_ctx, user_light_get_duty(LIGHT_GREEN));
} else if (os_strncmp(path, "blue", 4) == 0) {
jsontree_write_int(js_ctx, user_light_get_duty(LIGHT_BLUE));
} else if (os_strncmp(path, "wwhite", 6) == 0) {
if(PWM_CHANNEL>LIGHT_WARM_WHITE){
jsontree_write_int(js_ctx, user_light_get_duty(LIGHT_WARM_WHITE));
}else{
jsontree_write_int(js_ctx, 0);
}
} else if (os_strncmp(path, "cwhite", 6) == 0) {
if(PWM_CHANNEL>LIGHT_COLD_WHITE){
jsontree_write_int(js_ctx, user_light_get_duty(LIGHT_COLD_WHITE));
}else{
jsontree_write_int(js_ctx, 0);
}
} else if (os_strncmp(path, "period", 6) == 0) {
jsontree_write_int(js_ctx, user_light_get_period());
}
return 0;
}
LOCAL int ICACHE_FLASH_ATTR
light_status_set(struct jsontree_context *js_ctx, struct jsonparse_state *parser)
{
int type;
static uint32 r,g,b,cw,ww,period;
period = 1000;
cw=0;
ww=0;
extern uint8 light_sleep_flg;
while ((type = jsonparse_next(parser)) != 0) {
if (type == JSON_TYPE_PAIR_NAME) {
if (jsonparse_strcmp_value(parser, "red") == 0) {
uint32 status;
jsonparse_next(parser);
jsonparse_next(parser);
status = jsonparse_get_value_as_int(parser);
r=status;
os_printf("R: %d \n",status);
//user_light_set_duty(status, LIGHT_RED);
//light_set_aim_r( r);
} else if (jsonparse_strcmp_value(parser, "green") == 0) {
uint32 status;
jsonparse_next(parser);
jsonparse_next(parser);
status = jsonparse_get_value_as_int(parser);
g=status;
os_printf("G: %d \n",status);
//user_light_set_duty(status, LIGHT_GREEN);
//light_set_aim_g( g);
} else if (jsonparse_strcmp_value(parser, "blue") == 0) {
uint32 status;
jsonparse_next(parser);
jsonparse_next(parser);
status = jsonparse_get_value_as_int(parser);
b=status;
os_printf("B: %d \n",status);
//user_light_set_duty(status, LIGHT_BLUE);
//set_aim_b( b);
} else if (jsonparse_strcmp_value(parser, "cwhite") == 0) {
uint32 status;
jsonparse_next(parser);
jsonparse_next(parser);
status = jsonparse_get_value_as_int(parser);
cw=status;
os_printf("CW: %d \n",status);
//user_light_set_duty(status, LIGHT_BLUE);
//set_aim_b( b);
} else if (jsonparse_strcmp_value(parser, "wwhite") == 0) {
uint32 status;
jsonparse_next(parser);
jsonparse_next(parser);
status = jsonparse_get_value_as_int(parser);
ww=status;
os_printf("WW: %d \n",status);
//user_light_set_duty(status, LIGHT_BLUE);
//set_aim_b( b);
} else if (jsonparse_strcmp_value(parser, "period") == 0) {
uint32 status;
jsonparse_next(parser);
jsonparse_next(parser);
status = jsonparse_get_value_as_int(parser);
os_printf("PERIOD: %d \n",status);
period=status;
//user_light_set_period(status);
}else if (jsonparse_strcmp_value(parser, "response") == 0) {
uint32 status;
jsonparse_next(parser);
jsonparse_next(parser);
status = jsonparse_get_value_as_int(parser);
os_printf("rspneed: %d \n",status);
PostCmdNeeRsp = status;
}
}
}
if((r|g|b|ww|cw) == 0){
if(light_sleep_flg==0){
}
}else{
if(light_sleep_flg==1){
os_printf("modem sleep en\r\n");
wifi_set_sleep_type(MODEM_SLEEP_T);
light_sleep_flg =0;
}
}
light_set_aim(r,g,b,cw,ww,period);
return 0;
}
LOCAL struct jsontree_callback light_callback =
JSONTREE_CALLBACK(light_status_get, light_status_set);
JSONTREE_OBJECT(rgb_tree,
JSONTREE_PAIR("red", &light_callback),
JSONTREE_PAIR("green", &light_callback),
JSONTREE_PAIR("blue", &light_callback),
JSONTREE_PAIR("cwhite", &light_callback),
JSONTREE_PAIR("wwhite", &light_callback),
);
JSONTREE_OBJECT(sta_tree,
JSONTREE_PAIR("period", &light_callback),
JSONTREE_PAIR("rgb", &rgb_tree));
JSONTREE_OBJECT(PwmTree,
JSONTREE_PAIR("light", &sta_tree));
#endif
/******************************************************************************
* FunctionName : wifi_station_get
* Description : set up the station paramer as a JSON format
* Parameters : js_ctx -- A pointer to a JSON set up
* Returns : result
*******************************************************************************/
LOCAL int ICACHE_FLASH_ATTR
wifi_station_get(struct jsontree_context *js_ctx)
{
const char *path = jsontree_path_name(js_ctx, js_ctx->depth - 1);
struct ip_info ipconfig;
uint8 buf[20];
os_bzero(buf, sizeof(buf));
wifi_station_get_config(sta_conf);
wifi_get_ip_info(STATION_IF, &ipconfig);
if (os_strncmp(path, "ssid", 4) == 0) {
jsontree_write_string(js_ctx, sta_conf->ssid);
} else if (os_strncmp(path, "password", 8) == 0) {
jsontree_write_string(js_ctx, sta_conf->password);
} else if (os_strncmp(path, "ip", 2) == 0) {
os_sprintf(buf, IPSTR, IP2STR(&ipconfig.ip));
jsontree_write_string(js_ctx, buf);
} else if (os_strncmp(path, "mask", 4) == 0) {
os_sprintf(buf, IPSTR, IP2STR(&ipconfig.netmask));
jsontree_write_string(js_ctx, buf);
} else if (os_strncmp(path, "gw", 2) == 0) {
os_sprintf(buf, IPSTR, IP2STR(&ipconfig.gw));
jsontree_write_string(js_ctx, buf);
}
return 0;
}
/******************************************************************************
* FunctionName : wifi_station_set
* Description : parse the station parmer as a JSON format
* Parameters : js_ctx -- A pointer to a JSON set up
* parser -- A pointer to a JSON parser state
* Returns : result
*******************************************************************************/
LOCAL int ICACHE_FLASH_ATTR
wifi_station_set(struct jsontree_context *js_ctx, struct jsonparse_state *parser)
{
int type;
uint8 station_tree;
while ((type = jsonparse_next(parser)) != 0) {
if (type == JSON_TYPE_PAIR_NAME) {
char buffer[64];
os_bzero(buffer, 64);
if (jsonparse_strcmp_value(parser, "Station") == 0) {
station_tree = 1;
} else if (jsonparse_strcmp_value(parser, "Softap") == 0) {
station_tree = 0;
}
if (station_tree) {
if (jsonparse_strcmp_value(parser, "ssid") == 0) {
jsonparse_next(parser);
jsonparse_next(parser);
jsonparse_copy_value(parser, buffer, sizeof(buffer));
os_memcpy(sta_conf->ssid, buffer, os_strlen(buffer));
} else if (jsonparse_strcmp_value(parser, "password") == 0) {
jsonparse_next(parser);
jsonparse_next(parser);
jsonparse_copy_value(parser, buffer, sizeof(buffer));
os_memcpy(sta_conf->password, buffer, os_strlen(buffer));
}
#if ESP_PLATFORM
else if (jsonparse_strcmp_value(parser, "token") == 0) {
jsonparse_next(parser);
jsonparse_next(parser);
jsonparse_copy_value(parser, buffer, sizeof(buffer));
user_esp_platform_set_token(buffer);
}
#endif
}
}
}
return 0;
}
LOCAL struct jsontree_callback wifi_station_callback =
JSONTREE_CALLBACK(wifi_station_get, wifi_station_set);
JSONTREE_OBJECT(get_station_config_tree,
JSONTREE_PAIR("ssid", &wifi_station_callback),
JSONTREE_PAIR("password", &wifi_station_callback));
JSONTREE_OBJECT(set_station_config_tree,
JSONTREE_PAIR("ssid", &wifi_station_callback),
JSONTREE_PAIR("password", &wifi_station_callback),
JSONTREE_PAIR("token", &wifi_station_callback));
JSONTREE_OBJECT(ip_tree,
JSONTREE_PAIR("ip", &wifi_station_callback),
JSONTREE_PAIR("mask", &wifi_station_callback),
JSONTREE_PAIR("gw", &wifi_station_callback));
JSONTREE_OBJECT(get_station_tree,
JSONTREE_PAIR("Connect_Station", &get_station_config_tree),
JSONTREE_PAIR("Ipinfo_Station", &ip_tree));
JSONTREE_OBJECT(set_station_tree,
JSONTREE_PAIR("Connect_Station", &set_station_config_tree));
//JSONTREE_OBJECT(get_wifi_station_info_tree,
// JSONTREE_PAIR("Station", &get_station_tree));
//JSONTREE_OBJECT(set_wifi_station_info_tree,
// JSONTREE_PAIR("station", &set_station_tree));
/******************************************************************************
* FunctionName : wifi_softap_get
* Description : set up the softap paramer as a JSON format
* Parameters : js_ctx -- A pointer to a JSON set up
* Returns : result
*******************************************************************************/
LOCAL int ICACHE_FLASH_ATTR
wifi_softap_get(struct jsontree_context *js_ctx)
{
const char *path = jsontree_path_name(js_ctx, js_ctx->depth - 1);
struct ip_info ipconfig;
uint8 buf[20];
os_bzero(buf, sizeof(buf));
wifi_softap_get_config(ap_conf);
wifi_get_ip_info(SOFTAP_IF, &ipconfig);
if (os_strncmp(path, "ssid", 4) == 0) {
jsontree_write_string(js_ctx, ap_conf->ssid);
} else if (os_strncmp(path, "password", 8) == 0) {
jsontree_write_string(js_ctx, ap_conf->password);
} else if (os_strncmp(path, "channel", 7) == 0) {
jsontree_write_int(js_ctx, ap_conf->channel);
} else if (os_strncmp(path, "authmode", 8) == 0) {
switch (ap_conf->authmode) {
case AUTH_OPEN:
jsontree_write_string(js_ctx, "OPEN");
break;
case AUTH_WEP:
jsontree_write_string(js_ctx, "WEP");
break;
case AUTH_WPA_PSK:
jsontree_write_string(js_ctx, "WPAPSK");
break;
case AUTH_WPA2_PSK:
jsontree_write_string(js_ctx, "WPA2PSK");
break;
case AUTH_WPA_WPA2_PSK:
jsontree_write_string(js_ctx, "WPAPSK/WPA2PSK");
break;
default :
jsontree_write_int(js_ctx, ap_conf->authmode);
break;
}
} else if (os_strncmp(path, "ip", 2) == 0) {
os_sprintf(buf, IPSTR, IP2STR(&ipconfig.ip));
jsontree_write_string(js_ctx, buf);
} else if (os_strncmp(path, "mask", 4) == 0) {
os_sprintf(buf, IPSTR, IP2STR(&ipconfig.netmask));
jsontree_write_string(js_ctx, buf);
} else if (os_strncmp(path, "gw", 2) == 0) {
os_sprintf(buf, IPSTR, IP2STR(&ipconfig.gw));
jsontree_write_string(js_ctx, buf);
}
return 0;
}
/******************************************************************************
* FunctionName : wifi_softap_set
* Description : parse the softap parmer as a JSON format
* Parameters : js_ctx -- A pointer to a JSON set up
* parser -- A pointer to a JSON parser state
* Returns : result
*******************************************************************************/
LOCAL int ICACHE_FLASH_ATTR
wifi_softap_set(struct jsontree_context *js_ctx, struct jsonparse_state *parser)
{
int type;
uint8 softap_tree;
while ((type = jsonparse_next(parser)) != 0) {
if (type == JSON_TYPE_PAIR_NAME) {
char buffer[64];
os_bzero(buffer, 64);
if (jsonparse_strcmp_value(parser, "Station") == 0) {
softap_tree = 0;
} else if (jsonparse_strcmp_value(parser, "Softap") == 0) {
softap_tree = 1;
}
if (softap_tree) {
if (jsonparse_strcmp_value(parser, "authmode") == 0) {
jsonparse_next(parser);
jsonparse_next(parser);
jsonparse_copy_value(parser, buffer, sizeof(buffer));
// other mode will be supported later...
if (os_strcmp(buffer, "OPEN") == 0) {
ap_conf->authmode = AUTH_OPEN;
} else if (os_strcmp(buffer, "WPAPSK") == 0) {
ap_conf->authmode = AUTH_WPA_PSK;
os_printf("%d %s\n", ap_conf->authmode, buffer);
} else if (os_strcmp(buffer, "WPA2PSK") == 0) {
ap_conf->authmode = AUTH_WPA2_PSK;
} else if (os_strcmp(buffer, "WPAPSK/WPA2PSK") == 0) {
ap_conf->authmode = AUTH_WPA_WPA2_PSK;
} else {
ap_conf->authmode = AUTH_OPEN;
return 0;
}
}
if (jsonparse_strcmp_value(parser, "channel") == 0) {
jsonparse_next(parser);
jsonparse_next(parser);
ap_conf->channel = jsonparse_get_value_as_int(parser);
} else if (jsonparse_strcmp_value(parser, "ssid") == 0) {
jsonparse_next(parser);
jsonparse_next(parser);
jsonparse_copy_value(parser, buffer, sizeof(buffer));
os_memcpy(ap_conf->ssid, buffer, os_strlen(buffer));
} else if (jsonparse_strcmp_value(parser, "password") == 0) {
jsonparse_next(parser);
jsonparse_next(parser);
jsonparse_copy_value(parser, buffer, sizeof(buffer));
os_memcpy(ap_conf->password, buffer, os_strlen(buffer));
}
}
}
}
return 0;
}
LOCAL struct jsontree_callback wifi_softap_callback =
JSONTREE_CALLBACK(wifi_softap_get, wifi_softap_set);
JSONTREE_OBJECT(softap_config_tree,
JSONTREE_PAIR("authmode", &wifi_softap_callback),
JSONTREE_PAIR("channel", &wifi_softap_callback),
JSONTREE_PAIR("ssid", &wifi_softap_callback),
JSONTREE_PAIR("password", &wifi_softap_callback));
JSONTREE_OBJECT(softap_ip_tree,
JSONTREE_PAIR("ip", &wifi_softap_callback),
JSONTREE_PAIR("mask", &wifi_softap_callback),
JSONTREE_PAIR("gw", &wifi_softap_callback));
JSONTREE_OBJECT(get_softap_tree,
JSONTREE_PAIR("Connect_Softap", &softap_config_tree),
JSONTREE_PAIR("Ipinfo_Softap", &softap_ip_tree));
JSONTREE_OBJECT(set_softap_tree,
JSONTREE_PAIR("Ipinfo_Softap", &softap_config_tree));
JSONTREE_OBJECT(get_wifi_tree,
JSONTREE_PAIR("Station", &get_station_tree),
JSONTREE_PAIR("Softap", &get_softap_tree));
JSONTREE_OBJECT(set_wifi_tree,
JSONTREE_PAIR("Station", &set_station_tree),
JSONTREE_PAIR("Softap", &set_softap_tree));
JSONTREE_OBJECT(wifi_response_tree,
JSONTREE_PAIR("Response", &get_wifi_tree));
JSONTREE_OBJECT(wifi_request_tree,
JSONTREE_PAIR("Request", &set_wifi_tree));
JSONTREE_OBJECT(wifi_info_tree,
JSONTREE_PAIR("wifi", &wifi_response_tree));
JSONTREE_OBJECT(wifi_req_tree,
JSONTREE_PAIR("wifi", &wifi_request_tree));
/******************************************************************************
* FunctionName : scan_get
* Description : set up the scan data as a JSON format
* Parameters : js_ctx -- A pointer to a JSON set up
* Returns : result
*******************************************************************************/
LOCAL int ICACHE_FLASH_ATTR
scan_get(struct jsontree_context *js_ctx)
{
const char *path = jsontree_path_name(js_ctx, js_ctx->depth - 1);
// STAILQ_HEAD(, bss_info) *pbss = scanarg;
// LOCAL struct bss_info *bss;
if (os_strncmp(path, "TotalPage", 9) == 0) {
jsontree_write_int(js_ctx, pscaninfo->totalpage);
} else if (os_strncmp(path, "PageNum", 7) == 0) {
jsontree_write_int(js_ctx, pscaninfo->pagenum);
} else if (os_strncmp(path, "bssid", 5) == 0) {
if( bss == NULL )
bss = bss_head;
u8 buffer[32];
//if (bss != NULL){
os_memset(buffer, 0, sizeof(buffer));
os_sprintf(buffer, MACSTR, MAC2STR(bss->bssid));
jsontree_write_string(js_ctx, buffer);
//}
} else if (os_strncmp(path, "ssid", 4) == 0) {
//if (bss != NULL)
jsontree_write_string(js_ctx, bss->ssid);
} else if (os_strncmp(path, "rssi", 4) == 0) {
//if (bss != NULL)
jsontree_write_int(js_ctx, -(bss->rssi));
} else if (os_strncmp(path, "channel", 7) == 0) {
//if (bss != NULL)
jsontree_write_int(js_ctx, bss->channel);
} else if (os_strncmp(path, "authmode", 8) == 0) {
//if (bss != NULL){
switch (bss->authmode) {
case AUTH_OPEN:
jsontree_write_string(js_ctx, "OPEN");
break;
case AUTH_WEP:
jsontree_write_string(js_ctx, "WEP");
break;
case AUTH_WPA_PSK:
jsontree_write_string(js_ctx, "WPAPSK");
break;
case AUTH_WPA2_PSK:
jsontree_write_string(js_ctx, "WPA2PSK");
break;
case AUTH_WPA_WPA2_PSK:
jsontree_write_string(js_ctx, "WPAPSK/WPA2PSK");
break;
default :
jsontree_write_int(js_ctx, bss->authmode);
break;
}
bss = STAILQ_NEXT(bss, next);
// os_free(bss);
//}
}
return 0;
}
LOCAL struct jsontree_callback scan_callback =
JSONTREE_CALLBACK(scan_get, NULL);
JSONTREE_OBJECT(scaninfo_tree,
JSONTREE_PAIR("bssid", &scan_callback),
JSONTREE_PAIR("ssid", &scan_callback),
JSONTREE_PAIR("rssi", &scan_callback),
JSONTREE_PAIR("channel", &scan_callback),
JSONTREE_PAIR("authmode", &scan_callback));
JSONTREE_ARRAY(scanrslt_tree,
JSONTREE_PAIR_ARRAY(&scaninfo_tree),
JSONTREE_PAIR_ARRAY(&scaninfo_tree),
JSONTREE_PAIR_ARRAY(&scaninfo_tree),
JSONTREE_PAIR_ARRAY(&scaninfo_tree),
JSONTREE_PAIR_ARRAY(&scaninfo_tree),
JSONTREE_PAIR_ARRAY(&scaninfo_tree),
JSONTREE_PAIR_ARRAY(&scaninfo_tree),
JSONTREE_PAIR_ARRAY(&scaninfo_tree));
JSONTREE_OBJECT(scantree,
JSONTREE_PAIR("TotalPage", &scan_callback),
JSONTREE_PAIR("PageNum", &scan_callback),
JSONTREE_PAIR("ScanResult", &scanrslt_tree));
JSONTREE_OBJECT(scanres_tree,
JSONTREE_PAIR("Response", &scantree));
JSONTREE_OBJECT(scan_tree,
JSONTREE_PAIR("scan", &scanres_tree));
/******************************************************************************
* FunctionName : parse_url
* Description : parse the received data from the server
* Parameters : precv -- the received data
* purl_frame -- the result of parsing the url
* Returns : none
*******************************************************************************/
LOCAL void ICACHE_FLASH_ATTR
parse_url(char *precv, URL_Frame *purl_frame)
{
char *str = NULL;
uint8 length = 0;
char *pbuffer = NULL;
char *pbufer = NULL;
if (purl_frame == NULL || precv == NULL) {
return;
}
pbuffer = (char *)os_strstr(precv, "Host:");
if (pbuffer != NULL) {
length = pbuffer - precv;
pbufer = (char *)os_zalloc(length + 1);
pbuffer = pbufer;
os_memcpy(pbuffer, precv, length);
os_memset(purl_frame->pSelect, 0, URLSize);
os_memset(purl_frame->pCommand, 0, URLSize);
os_memset(purl_frame->pFilename, 0, URLSize);
if (os_strncmp(pbuffer, "GET ", 4) == 0) {
purl_frame->Type = GET;
pbuffer += 4;
} else if (os_strncmp(pbuffer, "POST ", 5) == 0) {
purl_frame->Type = POST;
pbuffer += 5;
}
pbuffer ++;
str = (char *)os_strstr(pbuffer, "?");
if (str != NULL) {
length = str - pbuffer;
os_memcpy(purl_frame->pSelect, pbuffer, length);
str ++;
pbuffer = (char *)os_strstr(str, "=");
if (pbuffer != NULL) {
length = pbuffer - str;
os_memcpy(purl_frame->pCommand, str, length);
pbuffer ++;
str = (char *)os_strstr(pbuffer, "&");
if (str != NULL) {
length = str - pbuffer;
os_memcpy(purl_frame->pFilename, pbuffer, length);
} else {
str = (char *)os_strstr(pbuffer, " HTTP");
if (str != NULL) {
length = str - pbuffer;
os_memcpy(purl_frame->pFilename, pbuffer, length);
}
}
}
}
os_free(pbufer);
} else {
return;
}
}
LOCAL char *precvbuffer;
static uint32 dat_sumlength = 0;
LOCAL bool ICACHE_FLASH_ATTR
save_data(char *precv, uint16 length)
{
bool flag = false;
char length_buf[10] = {0};
char *ptemp = NULL;
char *pdata = NULL;
uint16 headlength = 0;
static uint32 totallength = 0;
ptemp = (char *)os_strstr(precv, "\r\n\r\n");
if (ptemp != NULL) {
length -= ptemp - precv;
length -= 4;
totallength += length;
headlength = ptemp - precv + 4;
pdata = (char *)os_strstr(precv, "Content-Length: ");
if (pdata != NULL) {
pdata += 16;
precvbuffer = (char *)os_strstr(pdata, "\r\n");
if (precvbuffer != NULL) {
os_memcpy(length_buf, pdata, precvbuffer - pdata);
dat_sumlength = atoi(length_buf);
}
} else {
if (totallength != 0x00){
totallength = 0;
dat_sumlength = 0;
return false;
}
}
if ((dat_sumlength + headlength) >= 1024) {
precvbuffer = (char *)os_zalloc(headlength + 1);
os_memcpy(precvbuffer, precv, headlength + 1);
} else {
precvbuffer = (char *)os_zalloc(dat_sumlength + headlength + 1);
os_memcpy(precvbuffer, precv, os_strlen(precv));
}
} else {
if (precvbuffer != NULL) {
totallength += length;
os_memcpy(precvbuffer + os_strlen(precvbuffer), precv, length);
} else {
totallength = 0;
dat_sumlength = 0;
return false;
}
}
if (totallength == dat_sumlength) {
totallength = 0;
dat_sumlength = 0;
return true;
} else {
return false;
}
}
LOCAL bool ICACHE_FLASH_ATTR
check_data(char *precv, uint16 length)
{
//bool flag = true;
char length_buf[10] = {0};
char *ptemp = NULL;
char *pdata = NULL;
char *tmp_precvbuffer;
uint16 tmp_length = length;
uint32 tmp_totallength = 0;
ptemp = (char *)os_strstr(precv, "\r\n\r\n");
if (ptemp != NULL) {
tmp_length -= ptemp - precv;
tmp_length -= 4;
tmp_totallength += tmp_length;
pdata = (char *)os_strstr(precv, "Content-Length: ");
if (pdata != NULL){
pdata += 16;
tmp_precvbuffer = (char *)os_strstr(pdata, "\r\n");
if (tmp_precvbuffer != NULL){
os_memcpy(length_buf, pdata, tmp_precvbuffer - pdata);
dat_sumlength = atoi(length_buf);
os_printf("A_dat:%u,tot:%u,lenght:%u\n",dat_sumlength,tmp_totallength,tmp_length);
if(dat_sumlength != tmp_totallength){
return false;
}
}
}
}
return true;
}
LOCAL os_timer_t *restart_10ms;
LOCAL rst_parm *rstparm;
/******************************************************************************
* FunctionName : restart_10ms_cb
* Description : system restart or wifi reconnected after a certain time.
* Parameters : arg -- Additional argument to pass to the function
* Returns : none
*******************************************************************************/
LOCAL void ICACHE_FLASH_ATTR
restart_10ms_cb(void *arg)
{
if (rstparm != NULL && rstparm->pespconn != NULL) {
switch (rstparm->parmtype) {
case WIFI:
//if (rstparm->pespconn->state == ESPCONN_CLOSE) {
if (sta_conf->ssid[0] != 0x00) {
wifi_station_set_config(sta_conf);
wifi_station_disconnect();
wifi_station_connect();
user_esp_platform_check_ip(1);
}
if (ap_conf->ssid[0] != 0x00) {
wifi_softap_set_config(ap_conf);
system_restart();
}
os_free(ap_conf);
ap_conf = NULL;
os_free(sta_conf);
sta_conf = NULL;
os_free(rstparm);
rstparm = NULL;
os_free(restart_10ms);
restart_10ms = NULL;
//} else {
// os_timer_arm(restart_10ms, 10, 0);
//}
break;
case DEEP_SLEEP:
case REBOOT:
if (rstparm->pespconn->state == ESPCONN_CLOSE) {
wifi_set_opmode(STATION_MODE);
if (rstparm->parmtype == DEEP_SLEEP) {
#if SENSOR_DEVICE
system_deep_sleep(SENSOR_DEEP_SLEEP_TIME);
#endif
}
} else {
os_timer_arm(restart_10ms, 10, 0);
}
break;
default:
break;
}
}
}
/******************************************************************************
* FunctionName : data_send
* Description : processing the data as http format and send to the client or server
* Parameters : arg -- argument to set for client or server
* responseOK -- true or false
* psend -- The send data
* Returns :
*******************************************************************************/
LOCAL void ICACHE_FLASH_ATTR
data_send(void *arg, bool responseOK, char *psend)
{
uint16 length = 0;
char *pbuf = NULL;
char httphead[256];
struct espconn *ptrespconn = arg;
os_memset(httphead, 0, 256);
if (responseOK) {
os_sprintf(httphead,
"HTTP/1.0 200 OK\r\nContent-Length: %d\r\nServer: lwIP/1.4.0\r\n",
psend ? os_strlen(psend) : 0);
if (psend) {
os_sprintf(httphead + os_strlen(httphead),
"Content-type: application/json\r\nExpires: Fri, 10 Apr 2008 14:00:00 GMT\r\nPragma: no-cache\r\n\r\n");
length = os_strlen(httphead) + os_strlen(psend);
pbuf = (char *)os_zalloc(length + 1);
os_memcpy(pbuf, httphead, os_strlen(httphead));
os_memcpy(pbuf + os_strlen(httphead), psend, os_strlen(psend));
} else {
os_sprintf(httphead + os_strlen(httphead), "\n");
length = os_strlen(httphead);
}
} else {
os_sprintf(httphead, "HTTP/1.0 400 BadRequest\r\n\
Content-Length: 0\r\nServer: lwIP/1.4.0\r\n\n");
length = os_strlen(httphead);
}
if (psend) {
#ifdef SERVER_SSL_ENABLE
espconn_secure_sent(ptrespconn, pbuf, length);
#else
espconn_sent(ptrespconn, pbuf, length);
#endif
} else {
#ifdef SERVER_SSL_ENABLE
espconn_secure_sent(ptrespconn, httphead, length);
#else
espconn_sent(ptrespconn, httphead, length);
#endif
}
if (pbuf) {
os_free(pbuf);
pbuf = NULL;
}
}
/******************************************************************************
* FunctionName : json_send
* Description : processing the data as json format and send to the client or server
* Parameters : arg -- argument to set for client or server
* ParmType -- json format type
* Returns : none
*******************************************************************************/
LOCAL void ICACHE_FLASH_ATTR
json_send(void *arg, ParmType ParmType)
{
char *pbuf = NULL;
pbuf = (char *)os_zalloc(jsonSize);
struct espconn *ptrespconn = arg;
switch (ParmType) {
#if LIGHT_DEVICE
case LIGHT_STATUS:
json_ws_send((struct jsontree_value *)&PwmTree, "light", pbuf);
break;
#endif
#if PLUG_DEVICE
case SWITCH_STATUS:
json_ws_send((struct jsontree_value *)&StatusTree, "switch", pbuf);
break;
#endif
case INFOMATION:
json_ws_send((struct jsontree_value *)&INFOTree, "info", pbuf);
break;
case WIFI:
json_ws_send((struct jsontree_value *)&wifi_info_tree, "wifi", pbuf);
break;
case CONNECT_STATUS:
json_ws_send((struct jsontree_value *)&con_status_tree, "info", pbuf);
break;
case USER_BIN:
json_ws_send((struct jsontree_value *)&userinfo_tree, "user_info", pbuf);
break;
case SCAN: {
u8 i = 0;
u8 scancount = 0;
struct bss_info *bss = NULL;
// bss = STAILQ_FIRST(pscaninfo->pbss);
bss = bss_head;
if (bss == NULL) {
os_free(pscaninfo);
pscaninfo = NULL;
os_sprintf(pbuf, "{\n\"successful\": false,\n\"data\": null\n}");
} else {
do {
if (pscaninfo->page_sn == pscaninfo->pagenum) {
pscaninfo->page_sn = 0;
os_sprintf(pbuf, "{\n\"successful\": false,\n\"meessage\": \"repeated page\"\n}");
break;
}
scancount = scannum - (pscaninfo->pagenum - 1) * 8;
if (scancount >= 8) {
pscaninfo->data_cnt += 8;
pscaninfo->page_sn = pscaninfo->pagenum;
if (pscaninfo->data_cnt > scannum) {
pscaninfo->data_cnt -= 8;
os_sprintf(pbuf, "{\n\"successful\": false,\n\"meessage\": \"error page\"\n}");
break;
}
json_ws_send((struct jsontree_value *)&scan_tree, "scan", pbuf);
} else {
pscaninfo->data_cnt += scancount;
pscaninfo->page_sn = pscaninfo->pagenum;
if (pscaninfo->data_cnt > scannum) {
pscaninfo->data_cnt -= scancount;
os_sprintf(pbuf, "{\n\"successful\": false,\n\"meessage\": \"error page\"\n}");
break;
}
char *ptrscanbuf = (char *)os_zalloc(jsonSize);
char *pscanbuf = ptrscanbuf;
os_sprintf(pscanbuf, ",\n\"ScanResult\": [\n");
pscanbuf += os_strlen(pscanbuf);
for (i = 0; i < scancount; i ++) {
JSONTREE_OBJECT(page_tree,
JSONTREE_PAIR("page", &scaninfo_tree));
json_ws_send((struct jsontree_value *)&page_tree, "page", pscanbuf);
os_sprintf(pscanbuf + os_strlen(pscanbuf), ",\n");
pscanbuf += os_strlen(pscanbuf);
}
os_sprintf(pscanbuf - 2, "]\n");
JSONTREE_OBJECT(scantree,
JSONTREE_PAIR("TotalPage", &scan_callback),
JSONTREE_PAIR("PageNum", &scan_callback));
JSONTREE_OBJECT(scanres_tree,
JSONTREE_PAIR("Response", &scantree));
JSONTREE_OBJECT(scan_tree,
JSONTREE_PAIR("scan", &scanres_tree));
json_ws_send((struct jsontree_value *)&scan_tree, "scan", pbuf);
os_memcpy(pbuf + os_strlen(pbuf) - 4, ptrscanbuf, os_strlen(ptrscanbuf));
os_sprintf(pbuf + os_strlen(pbuf), "}\n}");
os_free(ptrscanbuf);
}
} while (0);
}
break;
}
default :
break;
}
data_send(ptrespconn, true, pbuf);
os_free(pbuf);
pbuf = NULL;
}
/******************************************************************************
* FunctionName : response_send
* Description : processing the send result
* Parameters : arg -- argument to set for client or server
* responseOK -- true or false
* Returns : none
*******************************************************************************/
LOCAL void ICACHE_FLASH_ATTR
response_send(void *arg, bool responseOK)
{
struct espconn *ptrespconn = arg;
data_send(ptrespconn, responseOK, NULL);
}
/******************************************************************************
* FunctionName : json_scan_cb
* Description : processing the scan result
* Parameters : arg -- Additional argument to pass to the callback function
* status -- scan status
* Returns : none
*******************************************************************************/
LOCAL void ICACHE_FLASH_ATTR json_scan_cb(void *arg, STATUS status)
{
pscaninfo->pbss = arg;
if (scannum % 8 == 0) {
pscaninfo->totalpage = scannum / 8;
} else {
pscaninfo->totalpage = scannum / 8 + 1;
}
JSONTREE_OBJECT(totaltree,
JSONTREE_PAIR("TotalPage", &scan_callback));
JSONTREE_OBJECT(totalres_tree,
JSONTREE_PAIR("Response", &totaltree));
JSONTREE_OBJECT(total_tree,
JSONTREE_PAIR("total", &totalres_tree));
bss_temp = bss_head;
while(bss_temp !=NULL) {
bss_head = bss_temp->next.stqe_next;
os_free(bss_temp);
bss_temp = bss_head;
}
bss_head = NULL;
bss_temp = NULL;
bss = STAILQ_FIRST(pscaninfo->pbss);
while(bss != NULL) {
if(bss_temp == NULL){
bss_temp = (struct bss_info *)os_zalloc(sizeof(struct bss_info));
bss_head = bss_temp;
} else {
bss_temp->next.stqe_next = (struct bss_info *)os_zalloc(sizeof(struct bss_info));
bss_temp = bss_temp->next.stqe_next;
}
if(bss_temp == NULL) {
os_printf("malloc scan info failed\n");
break;
} else{
os_memcpy(bss_temp->bssid,bss->bssid,sizeof(bss->bssid));
os_memcpy(bss_temp->ssid,bss->ssid,sizeof(bss->ssid));
bss_temp->authmode = bss->authmode;
bss_temp->rssi = bss->rssi;
bss_temp->channel = bss->channel;
}
bss = STAILQ_NEXT(bss,next);
}
char *pbuf = NULL;
pbuf = (char *)os_zalloc(jsonSize);
json_ws_send((struct jsontree_value *)&total_tree, "total", pbuf);
data_send(pscaninfo->pespconn, true, pbuf);
os_free(pbuf);
}
void ICACHE_FLASH_ATTR
upgrade_check_func(void *arg)
{
struct espconn *ptrespconn = arg;
os_timer_disarm(&upgrade_check_timer);
if(system_upgrade_flag_check() == UPGRADE_FLAG_START) {
response_send(ptrespconn, false);
system_upgrade_deinit();
system_upgrade_flag_set(UPGRADE_FLAG_IDLE);
upgrade_lock = 0;
os_printf("local upgrade failed\n");
} else if( system_upgrade_flag_check() == UPGRADE_FLAG_FINISH ) {
os_printf("local upgrade success\n");
response_send(ptrespconn, true);
upgrade_lock = 0;
} else {
}
}
/******************************************************************************
* FunctionName : upgrade_deinit
* Description : disconnect the connection with the host
* Parameters : bin -- server number
* Returns : none
*******************************************************************************/
void ICACHE_FLASH_ATTR
LOCAL local_upgrade_deinit(void)
{
if (system_upgrade_flag_check() != UPGRADE_FLAG_START) {
os_printf("system upgrade deinit\n");
system_upgrade_deinit();
}
}
/******************************************************************************
* FunctionName : upgrade_download
* Description : Processing the upgrade data from the host
* Parameters : bin -- server number
* pusrdata -- The upgrade data (or NULL when the connection has been closed!)
* length -- The length of upgrade data
* Returns : none
*******************************************************************************/
LOCAL void ICACHE_FLASH_ATTR
local_upgrade_download(void * arg,char *pusrdata, unsigned short length)
{
char *ptr = NULL;
char *ptmp2 = NULL;
char lengthbuffer[32];
static uint32 totallength = 0;
static uint32 sumlength = 0;
static uint32 erase_length = 0;
char A_buf[2] = {0xE9 ,0x03}; char B_buf[2] = {0xEA,0x04};
struct espconn *pespconn = arg;
if (totallength == 0 && (ptr = (char *)os_strstr(pusrdata, "\r\n\r\n")) != NULL &&
(ptr = (char *)os_strstr(pusrdata, "Content-Length")) != NULL) {
ptr = (char *)os_strstr(pusrdata, "Content-Length: ");
if (ptr != NULL) {
ptr += 16;
ptmp2 = (char *)os_strstr(ptr, "\r\n");
if (ptmp2 != NULL) {
os_memset(lengthbuffer, 0, sizeof(lengthbuffer));
os_memcpy(lengthbuffer, ptr, ptmp2 - ptr);
sumlength = atoi(lengthbuffer);
if (sumlength == 0) {
os_timer_disarm(&upgrade_check_timer);
os_timer_setfn(&upgrade_check_timer, (os_timer_func_t *)upgrade_check_func, pespconn);
os_timer_arm(&upgrade_check_timer, 10, 0);
return;
}
} else {
os_printf("sumlength failed\n");
}
} else {
os_printf("Content-Length: failed\n");
}
if (sumlength != 0) {
if (sumlength >= LIMIT_ERASE_SIZE){
system_upgrade_erase_flash(0xFFFF);
erase_length = sumlength - LIMIT_ERASE_SIZE;
} else {
system_upgrade_erase_flash(sumlength);
erase_length = 0;
}
}
ptr = (char *)os_strstr(pusrdata, "\r\n\r\n");
length -= ptr - pusrdata;
length -= 4;
totallength += length;
os_printf("upgrade file download start.\n");
system_upgrade(ptr + 4, length);
} else {
totallength += length;
if (erase_length >= LIMIT_ERASE_SIZE){
system_upgrade_erase_flash(0xFFFF);
erase_length -= LIMIT_ERASE_SIZE;
} else {
system_upgrade_erase_flash(erase_length);
erase_length = 0;
}
system_upgrade(pusrdata, length);
}
if (totallength == sumlength) {
os_printf("upgrade file download finished.\n");
system_upgrade_flag_set(UPGRADE_FLAG_FINISH);
totallength = 0;
sumlength = 0;
upgrade_check_func(pespconn);
os_timer_disarm(&app_upgrade_10s);
os_timer_setfn(&app_upgrade_10s, (os_timer_func_t *)local_upgrade_deinit, NULL);
os_timer_arm(&app_upgrade_10s, 10, 0);
}
}
/******************************************************************************
* FunctionName : webserver_recv
* Description : Processing the received data from the server
* Parameters : arg -- Additional argument to pass to the callback function
* pusrdata -- The received data (or NULL when the connection has been closed!)
* length -- The length of received data
* Returns : none
*******************************************************************************/
LOCAL void ICACHE_FLASH_ATTR
webserver_recv(void *arg, char *pusrdata, unsigned short length)
{
URL_Frame *pURL_Frame = NULL;
char *pParseBuffer = NULL;
bool parse_flag = false;
struct espconn *ptrespconn = arg;
if(upgrade_lock == 0){
os_printf("len:%u\n",length);
if(check_data(pusrdata, length) == false)
{
os_printf("goto\n");
goto _temp_exit;
}
parse_flag = save_data(pusrdata, length);
if (parse_flag == false) {
response_send(ptrespconn, false);
}
// os_printf(precvbuffer);
pURL_Frame = (URL_Frame *)os_zalloc(sizeof(URL_Frame));
parse_url(precvbuffer, pURL_Frame);
switch (pURL_Frame->Type) {
case GET:
os_printf("We have a GET request.\n");
if (os_strcmp(pURL_Frame->pSelect, "client") == 0 &&
os_strcmp(pURL_Frame->pCommand, "command") == 0) {
if (os_strcmp(pURL_Frame->pFilename, "info") == 0) {
json_send(ptrespconn, INFOMATION);
}
if (os_strcmp(pURL_Frame->pFilename, "status") == 0) {
json_send(ptrespconn, CONNECT_STATUS);
} else if (os_strcmp(pURL_Frame->pFilename, "scan") == 0) {
char *strstr = NULL;
strstr = (char *)os_strstr(pusrdata, "&");
if (strstr == NULL) {
if (pscaninfo == NULL) {
pscaninfo = (scaninfo *)os_zalloc(sizeof(scaninfo));
}
pscaninfo->pespconn = ptrespconn;
pscaninfo->pagenum = 0;
pscaninfo->page_sn = 0;
pscaninfo->data_cnt = 0;
wifi_station_scan(NULL, json_scan_cb);
} else {
strstr ++;
if (os_strncmp(strstr, "page", 4) == 0) {
if (pscaninfo != NULL) {
pscaninfo->pagenum = *(strstr + 5);
pscaninfo->pagenum -= 0x30;
if (pscaninfo->pagenum > pscaninfo->totalpage || pscaninfo->pagenum == 0) {
response_send(ptrespconn, false);
} else {
json_send(ptrespconn, SCAN);
}
} else {
response_send(ptrespconn, false);
}
} else if(os_strncmp(strstr, "finish", 6) == 0){
bss_temp = bss_head;
while(bss_temp != NULL) {
bss_head = bss_temp->next.stqe_next;
os_free(bss_temp);
bss_temp = bss_head;
}
bss_head = NULL;
bss_temp = NULL;
response_send(ptrespconn, true);
} else {
response_send(ptrespconn, false);
}
}
} else {
response_send(ptrespconn, false);
}
} else if (os_strcmp(pURL_Frame->pSelect, "config") == 0 &&
os_strcmp(pURL_Frame->pCommand, "command") == 0) {
if (os_strcmp(pURL_Frame->pFilename, "wifi") == 0) {
ap_conf = (struct softap_config *)os_zalloc(sizeof(struct softap_config));
sta_conf = (struct station_config *)os_zalloc(sizeof(struct station_config));
json_send(ptrespconn, WIFI);
os_free(sta_conf);
os_free(ap_conf);
sta_conf = NULL;
ap_conf = NULL;
}
#if PLUG_DEVICE
else if (os_strcmp(pURL_Frame->pFilename, "switch") == 0) {
json_send(ptrespconn, SWITCH_STATUS);
}
#endif
#if LIGHT_DEVICE
else if (os_strcmp(pURL_Frame->pFilename, "light") == 0) {
json_send(ptrespconn, LIGHT_STATUS);
}
#endif
else if (os_strcmp(pURL_Frame->pFilename, "reboot") == 0) {
json_send(ptrespconn, REBOOT);
} else {
response_send(ptrespconn, false);
}
} else if (os_strcmp(pURL_Frame->pSelect, "upgrade") == 0 &&
os_strcmp(pURL_Frame->pCommand, "command") == 0) {
if (os_strcmp(pURL_Frame->pFilename, "getuser") == 0) {
json_send(ptrespconn , USER_BIN);
}
} else {
response_send(ptrespconn, false);
}
break;
case POST:
os_printf("We have a POST request.\n");
pParseBuffer = (char *)os_strstr(precvbuffer, "\r\n\r\n");
if (pParseBuffer == NULL) {
break;
}
pParseBuffer += 4;
if (os_strcmp(pURL_Frame->pSelect, "config") == 0 &&
os_strcmp(pURL_Frame->pCommand, "command") == 0) {
#if SENSOR_DEVICE
if (os_strcmp(pURL_Frame->pFilename, "sleep") == 0) {
#else
if (os_strcmp(pURL_Frame->pFilename, "reboot") == 0) {
#endif
if (pParseBuffer != NULL) {
if (restart_10ms != NULL) {
os_timer_disarm(restart_10ms);
}
if (rstparm == NULL) {
rstparm = (rst_parm *)os_zalloc(sizeof(rst_parm));
}
rstparm->pespconn = ptrespconn;
#if SENSOR_DEVICE
rstparm->parmtype = DEEP_SLEEP;
#else
rstparm->parmtype = REBOOT;
#endif
if (restart_10ms == NULL) {
restart_10ms = (os_timer_t *)os_malloc(sizeof(os_timer_t));
}
os_timer_setfn(restart_10ms, (os_timer_func_t *)restart_10ms_cb, NULL);
os_timer_arm(restart_10ms, 10, 0); // delay 10ms, then do
response_send(ptrespconn, true);
} else {
response_send(ptrespconn, false);
}
} else if (os_strcmp(pURL_Frame->pFilename, "wifi") == 0) {
if (pParseBuffer != NULL) {
struct jsontree_context js;
user_esp_platform_set_connect_status(DEVICE_CONNECTING);
if (restart_10ms != NULL) {
os_timer_disarm(restart_10ms);
}
if (ap_conf == NULL) {
ap_conf = (struct softap_config *)os_zalloc(sizeof(struct softap_config));
}
if (sta_conf == NULL) {
sta_conf = (struct station_config *)os_zalloc(sizeof(struct station_config));
}
jsontree_setup(&js, (struct jsontree_value *)&wifi_req_tree, json_putchar);
json_parse(&js, pParseBuffer);
if (rstparm == NULL) {
rstparm = (rst_parm *)os_zalloc(sizeof(rst_parm));
}
rstparm->pespconn = ptrespconn;
rstparm->parmtype = WIFI;
if (sta_conf->ssid[0] != 0x00 || ap_conf->ssid[0] != 0x00) {
ap_conf->ssid_hidden = 0;
ap_conf->max_connection = 4;
if (restart_10ms == NULL) {
restart_10ms = (os_timer_t *)os_malloc(sizeof(os_timer_t));
}
os_timer_disarm(restart_10ms);
os_timer_setfn(restart_10ms, (os_timer_func_t *)restart_10ms_cb, NULL);
os_timer_arm(restart_10ms, 10, 0); // delay 10ms, then do
} else {
os_free(ap_conf);
os_free(sta_conf);
os_free(rstparm);
sta_conf = NULL;
ap_conf = NULL;
rstparm =NULL;
}
response_send(ptrespconn, true);
} else {
response_send(ptrespconn, false);
}
}
#if PLUG_DEVICE
else if (os_strcmp(pURL_Frame->pFilename, "switch") == 0) {
if (pParseBuffer != NULL) {
struct jsontree_context js;
jsontree_setup(&js, (struct jsontree_value *)&StatusTree, json_putchar);
json_parse(&js, pParseBuffer);
response_send(ptrespconn, true);
} else {
response_send(ptrespconn, false);
}
}
#endif
#if LIGHT_DEVICE
else if (os_strcmp(pURL_Frame->pFilename, "light") == 0) {
if (pParseBuffer != NULL) {
struct jsontree_context js;
jsontree_setup(&js, (struct jsontree_value *)&PwmTree, json_putchar);
json_parse(&js, pParseBuffer);
os_printf("rsp1:%u\n",PostCmdNeeRsp);
if(PostCmdNeeRsp == 0)
PostCmdNeeRsp = 1;
else
response_send(ptrespconn, true);
} else {
response_send(ptrespconn, false);
}
}
else if (os_strcmp(pURL_Frame->pFilename, "reset") == 0) {
response_send(ptrespconn, true);
extern struct esp_platform_saved_param esp_param;
esp_param.activeflag = 0;
system_param_save_with_protect(ESP_PARAM_START_SEC, &esp_param, sizeof(esp_param));
system_restore();
system_restart();
}
#endif
else {
response_send(ptrespconn, false);
}
}
else if(os_strcmp(pURL_Frame->pSelect, "upgrade") == 0 &&
os_strcmp(pURL_Frame->pCommand, "command") == 0){
if (os_strcmp(pURL_Frame->pFilename, "start") == 0){
response_send(ptrespconn, true);
os_printf("local upgrade start\n");
upgrade_lock = 1;
system_upgrade_init();
system_upgrade_flag_set(UPGRADE_FLAG_START);
os_timer_disarm(&upgrade_check_timer);
os_timer_setfn(&upgrade_check_timer, (os_timer_func_t *)upgrade_check_func, NULL);
os_timer_arm(&upgrade_check_timer, 120000, 0);
} else if (os_strcmp(pURL_Frame->pFilename, "reset") == 0) {
response_send(ptrespconn, true);
os_printf("local upgrade restart\n");
system_upgrade_reboot();
} else {
response_send(ptrespconn, false);
}
}else {
response_send(ptrespconn, false);
}
break;
}
if (precvbuffer != NULL){
os_free(precvbuffer);
precvbuffer = NULL;
}
os_free(pURL_Frame);
pURL_Frame = NULL;
_temp_exit:
;
}
else if(upgrade_lock == 1){
local_upgrade_download(ptrespconn,pusrdata, length);
if (precvbuffer != NULL){
os_free(precvbuffer);
precvbuffer = NULL;
}
os_free(pURL_Frame);
pURL_Frame = NULL;
}
}
/******************************************************************************
* FunctionName : webserver_recon
* Description : the connection has been err, reconnection
* Parameters : arg -- Additional argument to pass to the callback function
* Returns : none
*******************************************************************************/
LOCAL ICACHE_FLASH_ATTR
void webserver_recon(void *arg, sint8 err)
{
struct espconn *pesp_conn = arg;
os_printf("webserver's %d.%d.%d.%d:%d err %d reconnect\n", pesp_conn->proto.tcp->remote_ip[0],
pesp_conn->proto.tcp->remote_ip[1],pesp_conn->proto.tcp->remote_ip[2],
pesp_conn->proto.tcp->remote_ip[3],pesp_conn->proto.tcp->remote_port, err);
}
/******************************************************************************
* FunctionName : webserver_recon
* Description : the connection has been err, reconnection
* Parameters : arg -- Additional argument to pass to the callback function
* Returns : none
*******************************************************************************/
LOCAL ICACHE_FLASH_ATTR
void webserver_discon(void *arg)
{
struct espconn *pesp_conn = arg;
os_printf("webserver's %d.%d.%d.%d:%d disconnect\n", pesp_conn->proto.tcp->remote_ip[0],
pesp_conn->proto.tcp->remote_ip[1],pesp_conn->proto.tcp->remote_ip[2],
pesp_conn->proto.tcp->remote_ip[3],pesp_conn->proto.tcp->remote_port);
}
/******************************************************************************
* FunctionName : user_accept_listen
* Description : server listened a connection successfully
* Parameters : arg -- Additional argument to pass to the callback function
* Returns : none
*******************************************************************************/
LOCAL void ICACHE_FLASH_ATTR
webserver_listen(void *arg)
{
struct espconn *pesp_conn = arg;
espconn_regist_recvcb(pesp_conn, webserver_recv);
espconn_regist_reconcb(pesp_conn, webserver_recon);
espconn_regist_disconcb(pesp_conn, webserver_discon);
}
/******************************************************************************
* FunctionName : user_webserver_init
* Description : parameter initialize as a server
* Parameters : port -- server port
* Returns : none
*******************************************************************************/
void ICACHE_FLASH_ATTR
user_webserver_init(uint32 port)
{
LOCAL struct espconn esp_conn;
LOCAL esp_tcp esptcp;
esp_conn.type = ESPCONN_TCP;
esp_conn.state = ESPCONN_NONE;
esp_conn.proto.tcp = &esptcp;
esp_conn.proto.tcp->local_port = port;
espconn_regist_connectcb(&esp_conn, webserver_listen);
#ifdef SERVER_SSL_ENABLE
espconn_secure_set_default_certificate(default_certificate, default_certificate_len);
espconn_secure_set_default_private_key(default_private_key, default_private_key_len);
espconn_secure_accept(&esp_conn);
#else
espconn_accept(&esp_conn);
#endif
}