Merge branch 'dev' of https://github.com/nodemcu/nodemcu-firmware
This commit is contained in:
commit
4b4f600038
|
@ -410,7 +410,8 @@ u8glib comes with a wide range of fonts for small displays. Since they need to b
|
||||||
They'll be available as `u8g.<font_name>` in Lua.
|
They'll be available as `u8g.<font_name>` in Lua.
|
||||||
|
|
||||||
#####Bitmaps
|
#####Bitmaps
|
||||||
Bitmaps and XBMs are supplied as strings to `drawBitmap()` and `drawXBM()`. This off-loads all data handling from the u8g module to generic methods for binary files. See `lua_examples/u8glib/u8g_bitmaps.lua`. Binary files can be uploaded with [nodemcu-uploader.py](https://github.com/kmpm/nodemcu-uploader).
|
Bitmaps and XBMs are supplied as strings to `drawBitmap()` and `drawXBM()`. This off-loads all data handling from the u8g module to generic methods for binary files. See `lua_examples/u8glib/u8g_bitmaps.lua`.
|
||||||
|
In contrast to the source code based inclusion of XBMs into u8glib, it's required to provide precompiled binary files. This can be performed online with [Online-Utility's Image Converter](http://www.online-utility.org/image_converter.jsp): Convert from XBM to MONO format and upload the binary result with [nodemcu-uploader.py](https://github.com/kmpm/nodemcu-uploader).
|
||||||
|
|
||||||
#####Unimplemented functions
|
#####Unimplemented functions
|
||||||
- [ ] Cursor handling
|
- [ ] Cursor handling
|
||||||
|
|
|
@ -7,6 +7,6 @@
|
||||||
#define NODE_VERSION_INTERNAL 0U
|
#define NODE_VERSION_INTERNAL 0U
|
||||||
|
|
||||||
#define NODE_VERSION "NodeMCU 0.9.5"
|
#define NODE_VERSION "NodeMCU 0.9.5"
|
||||||
#define BUILD_DATE "build 20150403"
|
#define BUILD_DATE "build 20150405"
|
||||||
|
|
||||||
#endif /* __USER_VERSION_H__ */
|
#endif /* __USER_VERSION_H__ */
|
||||||
|
|
|
@ -541,8 +541,12 @@ extern int readline4lua(const char *prompt, char *buffer, int length);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ LUAL_BUFFERSIZE is the buffer size used by the lauxlib buffer system.
|
@@ LUAL_BUFFERSIZE is the buffer size used by the lauxlib buffer system.
|
||||||
|
** Attention: This value should probably not be set higher than 1K.
|
||||||
|
** The size has direct impact on the C stack size needed be auxlib functions.
|
||||||
|
** For example: If set to 4K a call to string.gsub will need more than
|
||||||
|
** 5k C stack space.
|
||||||
*/
|
*/
|
||||||
#define LUAL_BUFFERSIZE ((BUFSIZ)*4)
|
#define LUAL_BUFFERSIZE BUFSIZ
|
||||||
|
|
||||||
/* }================================================================== */
|
/* }================================================================== */
|
||||||
|
|
||||||
|
|
|
@ -80,7 +80,7 @@ LUALIB_API int ( luaopen_file )( lua_State *L );
|
||||||
LUALIB_API int ( luaopen_ow )( lua_State *L );
|
LUALIB_API int ( luaopen_ow )( lua_State *L );
|
||||||
|
|
||||||
#define AUXLIB_CJSON "cjson"
|
#define AUXLIB_CJSON "cjson"
|
||||||
LUALIB_API int ( luaopen_ow )( lua_State *L );
|
LUALIB_API int ( luaopen_cjson )( lua_State *L );
|
||||||
|
|
||||||
// Helper macros
|
// Helper macros
|
||||||
#define MOD_CHECK_ID( mod, id )\
|
#define MOD_CHECK_ID( mod, id )\
|
||||||
|
|
|
@ -146,6 +146,82 @@ static int lgpio_write( lua_State* L )
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define DELAY_TABLE_MAX_LEN 256
|
||||||
|
#define noInterrupts os_intr_lock
|
||||||
|
#define interrupts os_intr_unlock
|
||||||
|
#define delayMicroseconds os_delay_us
|
||||||
|
#define DIRECT_WRITE(pin, level) (GPIO_OUTPUT_SET(GPIO_ID_PIN(pin_num[pin]), level))
|
||||||
|
// Lua: serout( pin, firstLevel, delay_table, [repeatNum] )
|
||||||
|
// -- serout( pin, firstLevel, delay_table, [repeatNum] )
|
||||||
|
// gpio.mode(1,gpio.OUTPUT,gpio.PULLUP)
|
||||||
|
// gpio.serout(1,1,{30,30,60,60,30,30}) -- serial one byte, b10110010
|
||||||
|
// gpio.serout(1,1,{30,70},8) -- serial 30% pwm 10k, lasts 8 cycles
|
||||||
|
// gpio.serout(1,1,{3,7},8) -- serial 30% pwm 100k, lasts 8 cycles
|
||||||
|
// gpio.serout(1,1,{0,0},8) -- serial 50% pwm as fast as possible, lasts 8 cycles
|
||||||
|
// gpio.mode(1,gpio.OUTPUT,gpio.PULLUP)
|
||||||
|
// gpio.serout(1,0,{20,10,10,20,10,10,10,100}) -- sim uart one byte 0x5A at about 100kbps
|
||||||
|
// gpio.serout(1,1,{8,18},8) -- serial 30% pwm 38k, lasts 8 cycles
|
||||||
|
static int lgpio_serout( lua_State* L )
|
||||||
|
{
|
||||||
|
unsigned level;
|
||||||
|
unsigned pin;
|
||||||
|
unsigned table_len = 0;
|
||||||
|
unsigned repeat = 0;
|
||||||
|
int delay_table[DELAY_TABLE_MAX_LEN];
|
||||||
|
|
||||||
|
pin = luaL_checkinteger( L, 1 );
|
||||||
|
MOD_CHECK_ID( gpio, pin );
|
||||||
|
level = luaL_checkinteger( L, 2 );
|
||||||
|
if ( level!=HIGH && level!=LOW )
|
||||||
|
return luaL_error( L, "wrong arg type" );
|
||||||
|
if( lua_istable( L, 3 ) )
|
||||||
|
{
|
||||||
|
table_len = lua_objlen( L, 3 );
|
||||||
|
if (table_len <= 0 || table_len>DELAY_TABLE_MAX_LEN)
|
||||||
|
return luaL_error( L, "wrong arg range" );
|
||||||
|
int i;
|
||||||
|
for( i = 0; i < table_len; i ++ )
|
||||||
|
{
|
||||||
|
lua_rawgeti( L, 3, i + 1 );
|
||||||
|
delay_table[i] = ( int )luaL_checkinteger( L, -1 );
|
||||||
|
lua_pop( L, 1 );
|
||||||
|
if( delay_table[i] < 0 || delay_table[i] > 1000000 ) // can not delay more than 1000000 us
|
||||||
|
return luaL_error( L, "delay must < 1000000 us" );
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return luaL_error( L, "wrong arg range" );
|
||||||
|
}
|
||||||
|
|
||||||
|
if(lua_isnumber(L, 4))
|
||||||
|
repeat = lua_tointeger( L, 4 );
|
||||||
|
if( repeat < 0 || repeat > DELAY_TABLE_MAX_LEN )
|
||||||
|
return luaL_error( L, "delay must < 256" );
|
||||||
|
|
||||||
|
if(repeat==0)
|
||||||
|
repeat = 1;
|
||||||
|
int j;
|
||||||
|
bool skip_loop = true;
|
||||||
|
do
|
||||||
|
{
|
||||||
|
if(skip_loop){ // skip the first loop.
|
||||||
|
skip_loop = false;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
for(j=0;j<table_len;j++){
|
||||||
|
noInterrupts();
|
||||||
|
// platform_gpio_write(pin, level);
|
||||||
|
DIRECT_WRITE(pin, level);
|
||||||
|
interrupts();
|
||||||
|
delayMicroseconds(delay_table[j]);
|
||||||
|
level=!level;
|
||||||
|
}
|
||||||
|
repeat--;
|
||||||
|
} while (repeat>0);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#undef DELAY_TABLE_MAX_LEN
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
#define MIN_OPT_LEVEL 2
|
||||||
#include "lrodefs.h"
|
#include "lrodefs.h"
|
||||||
|
@ -154,6 +230,7 @@ const LUA_REG_TYPE gpio_map[] =
|
||||||
{ LSTRKEY( "mode" ), LFUNCVAL( lgpio_mode ) },
|
{ LSTRKEY( "mode" ), LFUNCVAL( lgpio_mode ) },
|
||||||
{ LSTRKEY( "read" ), LFUNCVAL( lgpio_read ) },
|
{ LSTRKEY( "read" ), LFUNCVAL( lgpio_read ) },
|
||||||
{ LSTRKEY( "write" ), LFUNCVAL( lgpio_write ) },
|
{ LSTRKEY( "write" ), LFUNCVAL( lgpio_write ) },
|
||||||
|
{ LSTRKEY( "serout" ), LFUNCVAL( lgpio_serout ) },
|
||||||
#ifdef GPIO_INTERRUPT_ENABLE
|
#ifdef GPIO_INTERRUPT_ENABLE
|
||||||
{ LSTRKEY( "trig" ), LFUNCVAL( lgpio_trig ) },
|
{ LSTRKEY( "trig" ), LFUNCVAL( lgpio_trig ) },
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -47,8 +47,6 @@ typedef struct mqtt_state_t
|
||||||
uint16_t port;
|
uint16_t port;
|
||||||
int auto_reconnect;
|
int auto_reconnect;
|
||||||
mqtt_connect_info_t* connect_info;
|
mqtt_connect_info_t* connect_info;
|
||||||
uint8_t* in_buffer;
|
|
||||||
int in_buffer_length;
|
|
||||||
uint16_t message_length;
|
uint16_t message_length;
|
||||||
uint16_t message_length_read;
|
uint16_t message_length_read;
|
||||||
mqtt_connection_t mqtt_connection;
|
mqtt_connection_t mqtt_connection;
|
||||||
|
@ -166,7 +164,6 @@ static void deliver_publish(lmqtt_userdata * mud, uint8_t* message, int length)
|
||||||
NODE_DBG("enter deliver_publish.\n");
|
NODE_DBG("enter deliver_publish.\n");
|
||||||
if(mud == NULL)
|
if(mud == NULL)
|
||||||
return;
|
return;
|
||||||
const char comma[] = ",";
|
|
||||||
mqtt_event_data_t event_data;
|
mqtt_event_data_t event_data;
|
||||||
|
|
||||||
event_data.topic_length = length;
|
event_data.topic_length = length;
|
||||||
|
@ -181,11 +178,15 @@ static void deliver_publish(lmqtt_userdata * mud, uint8_t* message, int length)
|
||||||
return;
|
return;
|
||||||
if(mud->L == NULL)
|
if(mud->L == NULL)
|
||||||
return;
|
return;
|
||||||
lua_rawgeti(mud->L, LUA_REGISTRYINDEX, mud->cb_message_ref);
|
if(event_data.topic && (event_data.topic_length > 0)){
|
||||||
lua_rawgeti(mud->L, LUA_REGISTRYINDEX, mud->self_ref); // pass the userdata to callback func in lua
|
lua_rawgeti(mud->L, LUA_REGISTRYINDEX, mud->cb_message_ref);
|
||||||
|
lua_rawgeti(mud->L, LUA_REGISTRYINDEX, mud->self_ref); // pass the userdata to callback func in lua
|
||||||
lua_pushlstring(mud->L, event_data.topic, event_data.topic_length);
|
lua_pushlstring(mud->L, event_data.topic, event_data.topic_length);
|
||||||
if(event_data.data_length > 0){
|
} else {
|
||||||
|
NODE_DBG("get wrong packet.\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(event_data.data && (event_data.data_length > 0)){
|
||||||
lua_pushlstring(mud->L, event_data.data, event_data.data_length);
|
lua_pushlstring(mud->L, event_data.data, event_data.data_length);
|
||||||
lua_call(mud->L, 3, 0);
|
lua_call(mud->L, 3, 0);
|
||||||
} else {
|
} else {
|
||||||
|
@ -202,6 +203,9 @@ static void mqtt_socket_received(void *arg, char *pdata, unsigned short len)
|
||||||
uint8_t msg_qos;
|
uint8_t msg_qos;
|
||||||
uint16_t msg_id;
|
uint16_t msg_id;
|
||||||
msg_queue_t *node = NULL;
|
msg_queue_t *node = NULL;
|
||||||
|
int length = (int)len;
|
||||||
|
// uint8_t in_buffer[MQTT_BUF_SIZE];
|
||||||
|
uint8_t *in_buffer = (uint8_t *)pdata;
|
||||||
|
|
||||||
struct espconn *pesp_conn = arg;
|
struct espconn *pesp_conn = arg;
|
||||||
if(pesp_conn == NULL)
|
if(pesp_conn == NULL)
|
||||||
|
@ -211,17 +215,17 @@ static void mqtt_socket_received(void *arg, char *pdata, unsigned short len)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
READPACKET:
|
READPACKET:
|
||||||
if(len > MQTT_BUF_SIZE && len <= 0)
|
if(length > MQTT_BUF_SIZE || length <= 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
c_memcpy(mud->mqtt_state.in_buffer, pdata, len);
|
// c_memcpy(in_buffer, pdata, length);
|
||||||
uint8_t temp_buffer[MQTT_BUF_SIZE];
|
uint8_t temp_buffer[MQTT_BUF_SIZE];
|
||||||
mqtt_msg_init(&mud->mqtt_state.mqtt_connection, temp_buffer, MQTT_BUF_SIZE);
|
mqtt_msg_init(&mud->mqtt_state.mqtt_connection, temp_buffer, MQTT_BUF_SIZE);
|
||||||
mqtt_message_t *temp_msg = NULL;
|
mqtt_message_t *temp_msg = NULL;
|
||||||
switch(mud->connState){
|
switch(mud->connState){
|
||||||
case MQTT_CONNECT_SENDING:
|
case MQTT_CONNECT_SENDING:
|
||||||
case MQTT_CONNECT_SENT:
|
case MQTT_CONNECT_SENT:
|
||||||
if(mqtt_get_type(mud->mqtt_state.in_buffer) != MQTT_MSG_TYPE_CONNACK){
|
if(mqtt_get_type(in_buffer) != MQTT_MSG_TYPE_CONNACK){
|
||||||
NODE_DBG("MQTT: Invalid packet\r\n");
|
NODE_DBG("MQTT: Invalid packet\r\n");
|
||||||
mud->connState = MQTT_INIT;
|
mud->connState = MQTT_INIT;
|
||||||
if(mud->secure)
|
if(mud->secure)
|
||||||
|
@ -245,11 +249,11 @@ READPACKET:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MQTT_DATA:
|
case MQTT_DATA:
|
||||||
mud->mqtt_state.message_length_read = len;
|
mud->mqtt_state.message_length_read = length;
|
||||||
mud->mqtt_state.message_length = mqtt_get_total_length(mud->mqtt_state.in_buffer, mud->mqtt_state.message_length_read);
|
mud->mqtt_state.message_length = mqtt_get_total_length(in_buffer, mud->mqtt_state.message_length_read);
|
||||||
msg_type = mqtt_get_type(mud->mqtt_state.in_buffer);
|
msg_type = mqtt_get_type(in_buffer);
|
||||||
msg_qos = mqtt_get_qos(mud->mqtt_state.in_buffer);
|
msg_qos = mqtt_get_qos(in_buffer);
|
||||||
msg_id = mqtt_get_id(mud->mqtt_state.in_buffer, mud->mqtt_state.in_buffer_length);
|
msg_id = mqtt_get_id(in_buffer, mud->mqtt_state.message_length);
|
||||||
|
|
||||||
msg_queue_t *pending_msg = msg_peek(&(mud->mqtt_state.pending_msg_q));
|
msg_queue_t *pending_msg = msg_peek(&(mud->mqtt_state.pending_msg_q));
|
||||||
|
|
||||||
|
@ -295,7 +299,7 @@ READPACKET:
|
||||||
if(msg_qos == 1 || msg_qos == 2){
|
if(msg_qos == 1 || msg_qos == 2){
|
||||||
NODE_DBG("MQTT: Queue response QoS: %d\r\n", msg_qos);
|
NODE_DBG("MQTT: Queue response QoS: %d\r\n", msg_qos);
|
||||||
}
|
}
|
||||||
deliver_publish(mud, mud->mqtt_state.in_buffer, mud->mqtt_state.message_length_read);
|
deliver_publish(mud, in_buffer, mud->mqtt_state.message_length);
|
||||||
break;
|
break;
|
||||||
case MQTT_MSG_TYPE_PUBACK:
|
case MQTT_MSG_TYPE_PUBACK:
|
||||||
if(pending_msg && pending_msg->msg_type == MQTT_MSG_TYPE_PUBLISH && pending_msg->msg_id == msg_id){
|
if(pending_msg && pending_msg->msg_type == MQTT_MSG_TYPE_PUBLISH && pending_msg->msg_id == msg_id){
|
||||||
|
@ -365,11 +369,11 @@ READPACKET:
|
||||||
if(msg_type == MQTT_MSG_TYPE_PUBLISH)
|
if(msg_type == MQTT_MSG_TYPE_PUBLISH)
|
||||||
{
|
{
|
||||||
|
|
||||||
len = mud->mqtt_state.message_length_read;
|
length = mud->mqtt_state.message_length_read;
|
||||||
|
|
||||||
if(mud->mqtt_state.message_length < mud->mqtt_state.message_length_read)
|
if(mud->mqtt_state.message_length < mud->mqtt_state.message_length_read)
|
||||||
{
|
{
|
||||||
len -= mud->mqtt_state.message_length;
|
length -= mud->mqtt_state.message_length;
|
||||||
pdata += mud->mqtt_state.message_length;
|
pdata += mud->mqtt_state.message_length;
|
||||||
|
|
||||||
NODE_DBG("Get another published message\r\n");
|
NODE_DBG("Get another published message\r\n");
|
||||||
|
@ -386,8 +390,8 @@ READPACKET:
|
||||||
espconn_secure_sent( pesp_conn, node->msg.data, node->msg.length );
|
espconn_secure_sent( pesp_conn, node->msg.data, node->msg.length );
|
||||||
else
|
else
|
||||||
espconn_sent( pesp_conn, node->msg.data, node->msg.length );
|
espconn_sent( pesp_conn, node->msg.data, node->msg.length );
|
||||||
mud->keep_alive_tick = 0;
|
|
||||||
}
|
}
|
||||||
|
mud->keep_alive_tick = 0;
|
||||||
NODE_DBG("receive, queue size: %d\n", msg_size(&(mud->mqtt_state.pending_msg_q)));
|
NODE_DBG("receive, queue size: %d\n", msg_size(&(mud->mqtt_state.pending_msg_q)));
|
||||||
NODE_DBG("leave mqtt_socket_received.\n");
|
NODE_DBG("leave mqtt_socket_received.\n");
|
||||||
return;
|
return;
|
||||||
|
@ -406,6 +410,7 @@ static void mqtt_socket_sent(void *arg)
|
||||||
return;
|
return;
|
||||||
// call mqtt_sent()
|
// call mqtt_sent()
|
||||||
mud->event_timeout = 0;
|
mud->event_timeout = 0;
|
||||||
|
mud->keep_alive_tick = 0;
|
||||||
|
|
||||||
if(mud->connState == MQTT_CONNECT_SENDING){
|
if(mud->connState == MQTT_CONNECT_SENDING){
|
||||||
mud->connState = MQTT_CONNECT_SENT;
|
mud->connState = MQTT_CONNECT_SENT;
|
||||||
|
@ -430,7 +435,7 @@ static void mqtt_socket_sent(void *arg)
|
||||||
msg_destroy(msg_dequeue(&(mud->mqtt_state.pending_msg_q)));
|
msg_destroy(msg_dequeue(&(mud->mqtt_state.pending_msg_q)));
|
||||||
} else if(node && node->msg_type == MQTT_MSG_TYPE_PUBCOMP) {
|
} else if(node && node->msg_type == MQTT_MSG_TYPE_PUBCOMP) {
|
||||||
msg_destroy(msg_dequeue(&(mud->mqtt_state.pending_msg_q)));
|
msg_destroy(msg_dequeue(&(mud->mqtt_state.pending_msg_q)));
|
||||||
} else if(node && node->msg_type == MQTT_MSG_TYPE_PINGRESP) {
|
} else if(node && node->msg_type == MQTT_MSG_TYPE_PINGREQ) {
|
||||||
msg_destroy(msg_dequeue(&(mud->mqtt_state.pending_msg_q)));
|
msg_destroy(msg_dequeue(&(mud->mqtt_state.pending_msg_q)));
|
||||||
}
|
}
|
||||||
NODE_DBG("sent2, queue size: %d\n", msg_size(&(mud->mqtt_state.pending_msg_q)));
|
NODE_DBG("sent2, queue size: %d\n", msg_size(&(mud->mqtt_state.pending_msg_q)));
|
||||||
|
@ -462,6 +467,7 @@ static void mqtt_socket_connected(void *arg)
|
||||||
espconn_secure_sent(pesp_conn, temp_msg->data, temp_msg->length);
|
espconn_secure_sent(pesp_conn, temp_msg->data, temp_msg->length);
|
||||||
else
|
else
|
||||||
espconn_sent(pesp_conn, temp_msg->data, temp_msg->length);
|
espconn_sent(pesp_conn, temp_msg->data, temp_msg->length);
|
||||||
|
mud->keep_alive_tick = 0;
|
||||||
|
|
||||||
mud->connState = MQTT_CONNECT_SENDING;
|
mud->connState = MQTT_CONNECT_SENDING;
|
||||||
NODE_DBG("leave mqtt_socket_connected.\n");
|
NODE_DBG("leave mqtt_socket_connected.\n");
|
||||||
|
@ -625,8 +631,7 @@ static int mqtt_socket_client( lua_State* L )
|
||||||
mud->connect_info.client_id = (uint8_t *)c_zalloc(idl+1);
|
mud->connect_info.client_id = (uint8_t *)c_zalloc(idl+1);
|
||||||
mud->connect_info.username = (uint8_t *)c_zalloc(unl + 1);
|
mud->connect_info.username = (uint8_t *)c_zalloc(unl + 1);
|
||||||
mud->connect_info.password = (uint8_t *)c_zalloc(pwl + 1);
|
mud->connect_info.password = (uint8_t *)c_zalloc(pwl + 1);
|
||||||
mud->mqtt_state.in_buffer = (uint8_t *)c_zalloc(MQTT_BUF_SIZE);
|
if(!mud->connect_info.client_id || !mud->connect_info.username || !mud->connect_info.password){
|
||||||
if(!mud->connect_info.client_id || !mud->connect_info.username || !mud->connect_info.password || !mud->mqtt_state.in_buffer){
|
|
||||||
if(mud->connect_info.client_id) {
|
if(mud->connect_info.client_id) {
|
||||||
c_free(mud->connect_info.client_id);
|
c_free(mud->connect_info.client_id);
|
||||||
mud->connect_info.client_id = NULL;
|
mud->connect_info.client_id = NULL;
|
||||||
|
@ -638,10 +643,6 @@ static int mqtt_socket_client( lua_State* L )
|
||||||
if(mud->connect_info.password) {
|
if(mud->connect_info.password) {
|
||||||
c_free(mud->connect_info.password);
|
c_free(mud->connect_info.password);
|
||||||
mud->connect_info.password = NULL;
|
mud->connect_info.password = NULL;
|
||||||
}
|
|
||||||
if(mud->mqtt_state.in_buffer) {
|
|
||||||
c_free(mud->mqtt_state.in_buffer);
|
|
||||||
mud->mqtt_state.in_buffer = NULL;
|
|
||||||
}
|
}
|
||||||
return luaL_error(L, "not enough memory");
|
return luaL_error(L, "not enough memory");
|
||||||
}
|
}
|
||||||
|
@ -660,9 +661,8 @@ static int mqtt_socket_client( lua_State* L )
|
||||||
mud->connect_info.will_retain = 0;
|
mud->connect_info.will_retain = 0;
|
||||||
mud->connect_info.keepalive = keepalive;
|
mud->connect_info.keepalive = keepalive;
|
||||||
|
|
||||||
mud->mqtt_state.in_buffer_length = MQTT_BUF_SIZE;
|
|
||||||
mud->mqtt_state.pending_msg_q = NULL;
|
mud->mqtt_state.pending_msg_q = NULL;
|
||||||
mud->mqtt_state.auto_reconnect = 1;
|
mud->mqtt_state.auto_reconnect = 0;
|
||||||
mud->mqtt_state.port = 1883;
|
mud->mqtt_state.port = 1883;
|
||||||
mud->mqtt_state.connect_info = &mud->connect_info;
|
mud->mqtt_state.connect_info = &mud->connect_info;
|
||||||
|
|
||||||
|
@ -722,10 +722,6 @@ static int mqtt_delete( lua_State* L )
|
||||||
c_free(mud->connect_info.password);
|
c_free(mud->connect_info.password);
|
||||||
mud->connect_info.password = NULL;
|
mud->connect_info.password = NULL;
|
||||||
}
|
}
|
||||||
if(mud->mqtt_state.in_buffer){
|
|
||||||
c_free(mud->mqtt_state.in_buffer);
|
|
||||||
mud->mqtt_state.in_buffer = NULL;
|
|
||||||
}
|
|
||||||
// -------
|
// -------
|
||||||
|
|
||||||
// free (unref) callback ref
|
// free (unref) callback ref
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
#include "lrotable.h"
|
#include "lrotable.h"
|
||||||
|
|
||||||
#include "c_string.h"
|
#include "c_string.h"
|
||||||
|
#include "c_stdlib.h"
|
||||||
|
|
||||||
#include "c_types.h"
|
#include "c_types.h"
|
||||||
#include "user_interface.h"
|
#include "user_interface.h"
|
||||||
|
@ -327,8 +328,8 @@ static int wifi_station_config( lua_State* L )
|
||||||
if (sl>32 || ssid == NULL)
|
if (sl>32 || ssid == NULL)
|
||||||
return luaL_error( L, "ssid:<32" );
|
return luaL_error( L, "ssid:<32" );
|
||||||
const char *password = luaL_checklstring( L, 2, &pl );
|
const char *password = luaL_checklstring( L, 2, &pl );
|
||||||
if (pl>64 || password == NULL)
|
if (pl<8 || pl>64 || password == NULL)
|
||||||
return luaL_error( L, "pwd:<64" );
|
return luaL_error( L, "pwd:8~64" );
|
||||||
|
|
||||||
c_memset(sta_conf.ssid, 0, 32);
|
c_memset(sta_conf.ssid, 0, 32);
|
||||||
c_memset(sta_conf.password, 0, 64);
|
c_memset(sta_conf.password, 0, 64);
|
||||||
|
@ -380,6 +381,7 @@ static int wifi_station_setauto( lua_State* L )
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Lua: table = wifi.sta.getap()
|
||||||
static int wifi_station_listap( lua_State* L )
|
static int wifi_station_listap( lua_State* L )
|
||||||
{
|
{
|
||||||
if(wifi_get_opmode() == SOFTAP_MODE)
|
if(wifi_get_opmode() == SOFTAP_MODE)
|
||||||
|
@ -437,44 +439,46 @@ static int wifi_ap_getbroadcast( lua_State* L ){
|
||||||
// Lua: wifi.ap.config(table)
|
// Lua: wifi.ap.config(table)
|
||||||
static int wifi_ap_config( lua_State* L )
|
static int wifi_ap_config( lua_State* L )
|
||||||
{
|
{
|
||||||
struct softap_config config;
|
|
||||||
size_t len;
|
|
||||||
wifi_softap_get_config(&config);
|
|
||||||
if (!lua_istable(L, 1))
|
if (!lua_istable(L, 1))
|
||||||
return luaL_error( L, "wrong arg type" );
|
return luaL_error( L, "wrong arg type" );
|
||||||
|
|
||||||
|
struct softap_config config;
|
||||||
|
wifi_softap_get_config(&config);
|
||||||
|
|
||||||
|
size_t len;
|
||||||
|
|
||||||
lua_getfield(L, 1, "ssid");
|
lua_getfield(L, 1, "ssid");
|
||||||
if (!lua_isnil(L, -1)){ /* found? */
|
if (!lua_isnil(L, -1)){ /* found? */
|
||||||
if( lua_isstring(L, -1) ) // deal with the ssid string
|
if( lua_isstring(L, -1) ) // deal with the ssid string
|
||||||
{
|
{
|
||||||
const char *ssid = luaL_checklstring( L, -1, &len );
|
const char *ssid = luaL_checklstring( L, -1, &len );
|
||||||
if(len>32)
|
if(len<1 || len>32 || ssid == NULL)
|
||||||
return luaL_error( L, "ssid:<32" );
|
return luaL_error( L, "ssid:1~32" );
|
||||||
c_memset(config.ssid, 0, 32);
|
c_memset(config.ssid, 0, 32);
|
||||||
c_memcpy(config.ssid, ssid, len);
|
c_memcpy(config.ssid, ssid, len);
|
||||||
config.ssid_len = len;
|
|
||||||
config.ssid_hidden = 0;
|
|
||||||
NODE_DBG(config.ssid);
|
NODE_DBG(config.ssid);
|
||||||
NODE_DBG("\n");
|
NODE_DBG("\n");
|
||||||
|
config.ssid_len = len;
|
||||||
|
config.ssid_hidden = 0;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
return luaL_error( L, "wrong arg type" );
|
return luaL_error( L, "wrong arg type" );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
return luaL_error( L, "wrong arg type" );
|
return luaL_error( L, "ssid required" );
|
||||||
|
|
||||||
lua_getfield(L, 1, "pwd");
|
lua_getfield(L, 1, "pwd");
|
||||||
if (!lua_isnil(L, -1)){ /* found? */
|
if (!lua_isnil(L, -1)){ /* found? */
|
||||||
if( lua_isstring(L, -1) ) // deal with the password string
|
if( lua_isstring(L, -1) ) // deal with the password string
|
||||||
{
|
{
|
||||||
const char *pwd = luaL_checklstring( L, -1, &len );
|
const char *pwd = luaL_checklstring( L, -1, &len );
|
||||||
if(len>64)
|
if(len<8 || len>64 || pwd == NULL)
|
||||||
return luaL_error( L, "pwd:<64" );
|
return luaL_error( L, "pwd:8~64" );
|
||||||
c_memset(config.password, 0, 64);
|
c_memset(config.password, 0, 64);
|
||||||
c_memcpy(config.password, pwd, len);
|
c_memcpy(config.password, pwd, len);
|
||||||
config.authmode = AUTH_WPA_WPA2_PSK;
|
|
||||||
NODE_DBG(config.password);
|
NODE_DBG(config.password);
|
||||||
NODE_DBG("\n");
|
NODE_DBG("\n");
|
||||||
|
config.authmode = AUTH_WPA_WPA2_PSK;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
return luaL_error( L, "wrong arg type" );
|
return luaL_error( L, "wrong arg type" );
|
||||||
|
@ -483,11 +487,162 @@ static int wifi_ap_config( lua_State* L )
|
||||||
config.authmode = AUTH_OPEN;
|
config.authmode = AUTH_OPEN;
|
||||||
}
|
}
|
||||||
|
|
||||||
config.max_connection = 4;
|
lua_getfield(L, 1, "auth");
|
||||||
|
if (!lua_isnil(L, -1))
|
||||||
|
{
|
||||||
|
config.authmode = (uint8_t)luaL_checkinteger(L, -1);
|
||||||
|
NODE_DBG(config.authmode);
|
||||||
|
NODE_DBG("\n");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// keep whatever value resulted from "pwd" logic above
|
||||||
|
}
|
||||||
|
|
||||||
|
lua_getfield(L, 1, "channel");
|
||||||
|
if (!lua_isnil(L, -1))
|
||||||
|
{
|
||||||
|
unsigned channel = luaL_checkinteger(L, -1);
|
||||||
|
if (channel < 1 || channel > 13)
|
||||||
|
return luaL_error( L, "channel:1~13" );
|
||||||
|
|
||||||
|
config.channel = (uint8_t)channel;
|
||||||
|
NODE_DBG(config.channel);
|
||||||
|
NODE_DBG("\n");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
config.channel = 6;
|
||||||
|
}
|
||||||
|
|
||||||
|
lua_getfield(L, 1, "hidden");
|
||||||
|
if (!lua_isnil(L, -1))
|
||||||
|
{
|
||||||
|
config.ssid_hidden = (uint8_t)luaL_checkinteger(L, -1);
|
||||||
|
NODE_DBG(config.ssid_hidden);
|
||||||
|
NODE_DBG("\n");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
config.ssid_hidden = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
lua_getfield(L, 1, "max");
|
||||||
|
if (!lua_isnil(L, -1))
|
||||||
|
{
|
||||||
|
unsigned max = luaL_checkinteger(L, -1);
|
||||||
|
if (max < 1 || max > 4)
|
||||||
|
return luaL_error( L, "max:1~4" );
|
||||||
|
|
||||||
|
config.max_connection = (uint8_t)max;
|
||||||
|
NODE_DBG(config.max_connection);
|
||||||
|
NODE_DBG("\n");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
config.max_connection = 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
lua_getfield(L, 1, "beacon");
|
||||||
|
if (!lua_isnil(L, -1))
|
||||||
|
{
|
||||||
|
unsigned beacon = luaL_checkinteger(L, -1);
|
||||||
|
if (beacon < 100 || beacon > 60000)
|
||||||
|
return luaL_error( L, "beacon:100~60000" );
|
||||||
|
|
||||||
|
config.beacon_interval = (uint16_t)beacon;
|
||||||
|
NODE_DBG(config.beacon_interval);
|
||||||
|
NODE_DBG("\n");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
config.beacon_interval = 100;
|
||||||
|
}
|
||||||
|
|
||||||
wifi_softap_set_config(&config);
|
wifi_softap_set_config(&config);
|
||||||
// system_restart();
|
// system_restart();
|
||||||
return 0;
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Lua: table = wifi.ap.getclient()
|
||||||
|
static int wifi_ap_listclient( lua_State* L )
|
||||||
|
{
|
||||||
|
if (wifi_get_opmode() == STATION_MODE)
|
||||||
|
{
|
||||||
|
return luaL_error( L, "Can't list client in STATION_MODE mode" );
|
||||||
|
}
|
||||||
|
|
||||||
|
char temp[64];
|
||||||
|
|
||||||
|
lua_newtable(L);
|
||||||
|
|
||||||
|
struct station_info * station = wifi_softap_get_station_info();
|
||||||
|
struct station_info * next_station;
|
||||||
|
while (station != NULL)
|
||||||
|
{
|
||||||
|
c_sprintf(temp, IPSTR, IP2STR(&station->ip));
|
||||||
|
lua_pushstring(L, temp);
|
||||||
|
|
||||||
|
c_sprintf(temp, MACSTR, MAC2STR(station->bssid));
|
||||||
|
lua_setfield(L, -2, temp);
|
||||||
|
|
||||||
|
next_station = STAILQ_NEXT(station, next);
|
||||||
|
c_free(station);
|
||||||
|
station = next_station;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Lua: ip = wifi.ap.dhcp.config()
|
||||||
|
static int wifi_ap_dhcp_config( lua_State* L )
|
||||||
|
{
|
||||||
|
if (!lua_istable(L, 1))
|
||||||
|
return luaL_error( L, "wrong arg type" );
|
||||||
|
|
||||||
|
struct dhcps_lease lease;
|
||||||
|
uint32_t ip;
|
||||||
|
|
||||||
|
ip = parse_key(L, "start");
|
||||||
|
if (ip == 0)
|
||||||
|
return luaL_error( L, "wrong arg type" );
|
||||||
|
|
||||||
|
lease.start_ip = ip;
|
||||||
|
NODE_DBG(IPSTR, IP2STR(&lease.start_ip));
|
||||||
|
NODE_DBG("\n");
|
||||||
|
|
||||||
|
// use configured max_connection to determine end
|
||||||
|
struct softap_config config;
|
||||||
|
wifi_softap_get_config(&config);
|
||||||
|
lease.end_ip = lease.start_ip;
|
||||||
|
ip4_addr4(&lease.end_ip) += config.max_connection - 1;
|
||||||
|
|
||||||
|
char temp[64];
|
||||||
|
c_sprintf(temp, IPSTR, IP2STR(&lease.start_ip));
|
||||||
|
lua_pushstring(L, temp);
|
||||||
|
c_sprintf(temp, IPSTR, IP2STR(&lease.end_ip));
|
||||||
|
lua_pushstring(L, temp);
|
||||||
|
|
||||||
|
// note: DHCP max range = 101 from start_ip to end_ip
|
||||||
|
wifi_softap_dhcps_stop();
|
||||||
|
wifi_softap_set_dhcps_lease(&lease);
|
||||||
|
wifi_softap_dhcps_start();
|
||||||
|
|
||||||
|
return 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Lua: wifi.ap.dhcp.start()
|
||||||
|
static int wifi_ap_dhcp_start( lua_State* L )
|
||||||
|
{
|
||||||
|
lua_pushboolean(L, wifi_softap_dhcps_start());
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Lua: wifi.ap.dhcp.stop()
|
||||||
|
static int wifi_ap_dhcp_stop( lua_State* L )
|
||||||
|
{
|
||||||
|
lua_pushboolean(L, wifi_softap_dhcps_stop());
|
||||||
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
|
@ -509,6 +664,14 @@ static const LUA_REG_TYPE wifi_station_map[] =
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const LUA_REG_TYPE wifi_ap_dhcp_map[] =
|
||||||
|
{
|
||||||
|
{ LSTRKEY( "config" ), LFUNCVAL( wifi_ap_dhcp_config ) },
|
||||||
|
{ LSTRKEY( "start" ), LFUNCVAL( wifi_ap_dhcp_start ) },
|
||||||
|
{ LSTRKEY( "stop" ), LFUNCVAL( wifi_ap_dhcp_stop ) },
|
||||||
|
{ LNILKEY, LNILVAL }
|
||||||
|
};
|
||||||
|
|
||||||
static const LUA_REG_TYPE wifi_ap_map[] =
|
static const LUA_REG_TYPE wifi_ap_map[] =
|
||||||
{
|
{
|
||||||
{ LSTRKEY( "config" ), LFUNCVAL( wifi_ap_config ) },
|
{ LSTRKEY( "config" ), LFUNCVAL( wifi_ap_config ) },
|
||||||
|
@ -517,6 +680,12 @@ static const LUA_REG_TYPE wifi_ap_map[] =
|
||||||
{ LSTRKEY( "getbroadcast" ), LFUNCVAL ( wifi_ap_getbroadcast) },
|
{ LSTRKEY( "getbroadcast" ), LFUNCVAL ( wifi_ap_getbroadcast) },
|
||||||
{ LSTRKEY( "getmac" ), LFUNCVAL ( wifi_ap_getmac ) },
|
{ LSTRKEY( "getmac" ), LFUNCVAL ( wifi_ap_getmac ) },
|
||||||
{ LSTRKEY( "setmac" ), LFUNCVAL ( wifi_ap_setmac ) },
|
{ LSTRKEY( "setmac" ), LFUNCVAL ( wifi_ap_setmac ) },
|
||||||
|
{ LSTRKEY( "getclient" ), LFUNCVAL ( wifi_ap_listclient ) },
|
||||||
|
#if LUA_OPTIMIZE_MEMORY > 0
|
||||||
|
{ LSTRKEY( "dhcp" ), LROVAL( wifi_ap_dhcp_map ) },
|
||||||
|
|
||||||
|
// { LSTRKEY( "__metatable" ), LROVAL( wifi_ap_map ) },
|
||||||
|
#endif
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -540,6 +709,12 @@ const LUA_REG_TYPE wifi_map[] =
|
||||||
{ LSTRKEY( "LIGHT_SLEEP" ), LNUMVAL( LIGHT_SLEEP_T ) },
|
{ LSTRKEY( "LIGHT_SLEEP" ), LNUMVAL( LIGHT_SLEEP_T ) },
|
||||||
{ LSTRKEY( "MODEM_SLEEP" ), LNUMVAL( MODEM_SLEEP_T ) },
|
{ LSTRKEY( "MODEM_SLEEP" ), LNUMVAL( MODEM_SLEEP_T ) },
|
||||||
|
|
||||||
|
{ LSTRKEY( "OPEN" ), LNUMVAL( AUTH_OPEN ) },
|
||||||
|
// { LSTRKEY( "WEP" ), LNUMVAL( AUTH_WEP ) },
|
||||||
|
{ LSTRKEY( "WPA_PSK" ), LNUMVAL( AUTH_WPA_PSK ) },
|
||||||
|
{ LSTRKEY( "WPA2_PSK" ), LNUMVAL( AUTH_WPA2_PSK ) },
|
||||||
|
{ LSTRKEY( "WPA_WPA2_PSK" ), LNUMVAL( AUTH_WPA_WPA2_PSK ) },
|
||||||
|
|
||||||
// { LSTRKEY( "STA_IDLE" ), LNUMVAL( STATION_IDLE ) },
|
// { LSTRKEY( "STA_IDLE" ), LNUMVAL( STATION_IDLE ) },
|
||||||
// { LSTRKEY( "STA_CONNECTING" ), LNUMVAL( STATION_CONNECTING ) },
|
// { LSTRKEY( "STA_CONNECTING" ), LNUMVAL( STATION_CONNECTING ) },
|
||||||
// { LSTRKEY( "STA_WRONGPWD" ), LNUMVAL( STATION_WRONG_PASSWORD ) },
|
// { LSTRKEY( "STA_WRONGPWD" ), LNUMVAL( STATION_WRONG_PASSWORD ) },
|
||||||
|
@ -573,6 +748,12 @@ LUALIB_API int luaopen_wifi( lua_State *L )
|
||||||
MOD_REG_NUMBER( L, "LIGHT_SLEEP", LIGHT_SLEEP_T );
|
MOD_REG_NUMBER( L, "LIGHT_SLEEP", LIGHT_SLEEP_T );
|
||||||
MOD_REG_NUMBER( L, "MODEM_SLEEP", MODEM_SLEEP_T );
|
MOD_REG_NUMBER( L, "MODEM_SLEEP", MODEM_SLEEP_T );
|
||||||
|
|
||||||
|
MOD_REG_NUMBER( L, "OPEN", AUTH_OPEN );
|
||||||
|
// MOD_REG_NUMBER( L, "WEP", AUTH_WEP );
|
||||||
|
MOD_REG_NUMBER( L, "WPA_PSK", AUTH_WPA_PSK );
|
||||||
|
MOD_REG_NUMBER( L, "WPA2_PSK", AUTH_WPA2_PSK );
|
||||||
|
MOD_REG_NUMBER( L, "WPA_WPA2_PSK", AUTH_WPA_WPA2_PSK );
|
||||||
|
|
||||||
// MOD_REG_NUMBER( L, "STA_IDLE", STATION_IDLE );
|
// MOD_REG_NUMBER( L, "STA_IDLE", STATION_IDLE );
|
||||||
// MOD_REG_NUMBER( L, "STA_CONNECTING", STATION_CONNECTING );
|
// MOD_REG_NUMBER( L, "STA_CONNECTING", STATION_CONNECTING );
|
||||||
// MOD_REG_NUMBER( L, "STA_WRONGPWD", STATION_WRONG_PASSWORD );
|
// MOD_REG_NUMBER( L, "STA_WRONGPWD", STATION_WRONG_PASSWORD );
|
||||||
|
@ -589,6 +770,11 @@ LUALIB_API int luaopen_wifi( lua_State *L )
|
||||||
luaL_register( L, NULL, wifi_ap_map );
|
luaL_register( L, NULL, wifi_ap_map );
|
||||||
lua_setfield( L, -2, "ap" );
|
lua_setfield( L, -2, "ap" );
|
||||||
|
|
||||||
|
// Setup the new table (dhcp) inside ap
|
||||||
|
lua_newtable( L );
|
||||||
|
luaL_register( L, NULL, wifi_ap_dhcp_map );
|
||||||
|
lua_setfield( L, -1, "dhcp" );
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,6 +3,8 @@
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
#include "auxmods.h"
|
||||||
#include "lrotable.h"
|
#include "lrotable.h"
|
||||||
|
#include "c_stdlib.h"
|
||||||
|
#include "c_string.h"
|
||||||
/**
|
/**
|
||||||
* All this code is mostly from http://www.esp8266.com/viewtopic.php?f=21&t=1143&sid=a620a377672cfe9f666d672398415fcb
|
* All this code is mostly from http://www.esp8266.com/viewtopic.php?f=21&t=1143&sid=a620a377672cfe9f666d672398415fcb
|
||||||
* from user Markus Gritsch.
|
* from user Markus Gritsch.
|
||||||
|
@ -35,7 +37,10 @@ static int ICACHE_FLASH_ATTR ws2812_writergb(lua_State* L)
|
||||||
{
|
{
|
||||||
const uint8_t pin = luaL_checkinteger(L, 1);
|
const uint8_t pin = luaL_checkinteger(L, 1);
|
||||||
size_t length;
|
size_t length;
|
||||||
char *buffer = (char *)luaL_checklstring(L, 2, &length); // Cast away the constness.
|
const char *rgb = luaL_checklstring(L, 2, &length);
|
||||||
|
// dont modify lua-internal lstring - make a copy instead
|
||||||
|
char *buffer = (char *)c_malloc(length);
|
||||||
|
c_memcpy(buffer, rgb, length);
|
||||||
|
|
||||||
// Initialize the output pin:
|
// Initialize the output pin:
|
||||||
platform_gpio_mode(pin, PLATFORM_GPIO_OUTPUT, PLATFORM_GPIO_FLOAT);
|
platform_gpio_mode(pin, PLATFORM_GPIO_OUTPUT, PLATFORM_GPIO_FLOAT);
|
||||||
|
@ -59,17 +64,17 @@ static int ICACHE_FLASH_ATTR ws2812_writergb(lua_State* L)
|
||||||
|
|
||||||
// Send the buffer:
|
// Send the buffer:
|
||||||
os_intr_lock();
|
os_intr_lock();
|
||||||
const char * const end = buffer + length;
|
for (i = 0; i < length; i++) {
|
||||||
while (buffer != end) {
|
|
||||||
uint8_t mask = 0x80;
|
uint8_t mask = 0x80;
|
||||||
while (mask) {
|
while (mask) {
|
||||||
(*buffer & mask) ? send_ws_1(pin_num[pin]) : send_ws_0(pin_num[pin]);
|
(buffer[i] & mask) ? send_ws_1(pin_num[pin]) : send_ws_0(pin_num[pin]);
|
||||||
mask >>= 1;
|
mask >>= 1;
|
||||||
}
|
}
|
||||||
++buffer;
|
|
||||||
}
|
}
|
||||||
os_intr_unlock();
|
os_intr_unlock();
|
||||||
|
|
||||||
|
c_free(buffer);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -472,3 +472,50 @@ m:on("offline", function(conn)
|
||||||
print(node.heap())
|
print(node.heap())
|
||||||
end)
|
end)
|
||||||
m:connect("192.168.18.88",1883,0,1)
|
m:connect("192.168.18.88",1883,0,1)
|
||||||
|
|
||||||
|
-- serout( pin, firstLevel, delay_table, [repeatNum] )
|
||||||
|
gpio.mode(1,gpio.OUTPUT,gpio.PULLUP)
|
||||||
|
gpio.serout(1,1,{30,30,60,60,30,30}) -- serial one byte, b10110010
|
||||||
|
gpio.serout(1,1,{30,70},8) -- serial 30% pwm 10k, lasts 8 cycles
|
||||||
|
gpio.serout(1,1,{3,7},8) -- serial 30% pwm 100k, lasts 8 cycles
|
||||||
|
gpio.serout(1,1,{0,0},8) -- serial 50% pwm as fast as possible, lasts 8 cycles
|
||||||
|
|
||||||
|
gpio.mode(1,gpio.OUTPUT,gpio.PULLUP)
|
||||||
|
gpio.serout(1,0,{20,10,10,20,10,10,10,100}) -- sim uart one byte 0x5A at about 100kbps
|
||||||
|
|
||||||
|
gpio.serout(1,1,{8,18},8) -- serial 30% pwm 38k, lasts 8 cycles
|
||||||
|
|
||||||
|
-- Lua: mqtt.Client(clientid, keepalive, user, pass)
|
||||||
|
-- test with cloudmqtt.com
|
||||||
|
m_dis={}
|
||||||
|
function dispatch(m,t,pl)
|
||||||
|
if pl~=nil and m_dis[t] then
|
||||||
|
m_dis[t](pl)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
function topic1func(pl)
|
||||||
|
print("get1: "..pl)
|
||||||
|
end
|
||||||
|
function topic2func(pl)
|
||||||
|
print("get2: "..pl)
|
||||||
|
end
|
||||||
|
m_dis["/topic1"]=topic1func
|
||||||
|
m_dis["/topic2"]=topic2func
|
||||||
|
m=mqtt.Client("nodemcu1",60,"test","test123")
|
||||||
|
m:on("connect",function(m)
|
||||||
|
print("connection "..node.heap())
|
||||||
|
m:subscribe("/topic1",0,function(m) print("sub done") end)
|
||||||
|
m:subscribe("/topic2",0,function(m) print("sub done") end)
|
||||||
|
m:publish("/topic1","hello",0,0) m:publish("/topic2","world",0,0)
|
||||||
|
end )
|
||||||
|
m:on("offline", function(conn)
|
||||||
|
print("disconnect to broker...")
|
||||||
|
print(node.heap())
|
||||||
|
end)
|
||||||
|
m:on("message",dispatch )
|
||||||
|
m:connect("m11.cloudmqtt.com",11214,0,1)
|
||||||
|
-- Lua: mqtt:connect( host, port, secure, auto_reconnect, function(client) )
|
||||||
|
|
||||||
|
tmr.alarm(0,10000,1,function() local pl = "time: "..tmr.time()
|
||||||
|
m:publish("/topic1",pl,0,0)
|
||||||
|
end)
|
||||||
|
|
|
@ -0,0 +1,98 @@
|
||||||
|
--[[
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated
|
||||||
|
documentation files (the "Software"), to deal in the Software without restriction,
|
||||||
|
including without limitation the rights to use, copy, modify, merge, publish, distribute,
|
||||||
|
sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be
|
||||||
|
included in all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
||||||
|
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
||||||
|
WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR
|
||||||
|
IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
]]--
|
||||||
|
|
||||||
|
-- Your access point's SSID and password
|
||||||
|
local SSID = "xxxxxx"
|
||||||
|
local SSID_PASSWORD = "xxxxxx"
|
||||||
|
|
||||||
|
-- configure ESP as a station
|
||||||
|
wifi.setmode(wifi.STATION)
|
||||||
|
wifi.sta.config(SSID,SSID_PASSWORD)
|
||||||
|
wifi.sta.autoconnect(1)
|
||||||
|
|
||||||
|
local TWILIO_ACCOUNT_SID = "xxxxxx"
|
||||||
|
local TWILIO_TOKEN = "xxxxxx"
|
||||||
|
|
||||||
|
local HOST = "iot-https-relay.appspot.com" -- visit http://iot-https-relay.appspot.com/ to learn more about this service
|
||||||
|
-- Please be sure to understand the security issues of using this relay app and use at your own risk.
|
||||||
|
local URI = "/twilio/Calls.json"
|
||||||
|
|
||||||
|
function build_post_request(host, uri, data_table)
|
||||||
|
|
||||||
|
local data = ""
|
||||||
|
|
||||||
|
for param,value in pairs(data_table) do
|
||||||
|
data = data .. param.."="..value.."&"
|
||||||
|
end
|
||||||
|
|
||||||
|
request = "POST "..uri.." HTTP/1.1\r\n"..
|
||||||
|
"Host: "..host.."\r\n"..
|
||||||
|
"Connection: close\r\n"..
|
||||||
|
"Content-Type: application/x-www-form-urlencoded\r\n"..
|
||||||
|
"Content-Length: "..string.len(data).."\r\n"..
|
||||||
|
"\r\n"..
|
||||||
|
data
|
||||||
|
|
||||||
|
print(request)
|
||||||
|
|
||||||
|
return request
|
||||||
|
end
|
||||||
|
|
||||||
|
local function display(sck,response)
|
||||||
|
print(response)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- When using send_sms: the "from" number HAS to be your twilio number.
|
||||||
|
-- If you have a free twilio account the "to" number HAS to be your twilio verified number.
|
||||||
|
local function make_call(from,to,body)
|
||||||
|
|
||||||
|
local data = {
|
||||||
|
sid = TWILIO_ACCOUNT_SID,
|
||||||
|
token = TWILIO_TOKEN,
|
||||||
|
Body = string.gsub(body," ","+"),
|
||||||
|
From = from,
|
||||||
|
To = to
|
||||||
|
}
|
||||||
|
|
||||||
|
socket = net.createConnection(net.TCP,0)
|
||||||
|
socket:on("receive",display)
|
||||||
|
socket:connect(80,HOST)
|
||||||
|
|
||||||
|
socket:on("connection",function(sck)
|
||||||
|
|
||||||
|
local post_request = build_post_request(HOST,URI,data)
|
||||||
|
sck:send(post_request)
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
function check_wifi()
|
||||||
|
local ip = wifi.sta.getip()
|
||||||
|
|
||||||
|
if(ip==nil) then
|
||||||
|
print("Connecting...")
|
||||||
|
else
|
||||||
|
tmr.stop(0)
|
||||||
|
print("Connected to AP!")
|
||||||
|
print(ip)
|
||||||
|
-- make a call with a voice message "your house is on fire"
|
||||||
|
make_call("15558976687","1334856679","Your house is on fire!")
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
tmr.alarm(0,2000,1,check_wifi)
|
|
@ -0,0 +1,33 @@
|
||||||
|
-- test with cloudmqtt.com
|
||||||
|
m_dis={}
|
||||||
|
function dispatch(m,t,pl)
|
||||||
|
if pl~=nil and m_dis[t] then
|
||||||
|
m_dis[t](m,pl)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
function topic1func(m,pl)
|
||||||
|
print("get1: "..pl)
|
||||||
|
end
|
||||||
|
function topic2func(m,pl)
|
||||||
|
print("get2: "..pl)
|
||||||
|
end
|
||||||
|
m_dis["/topic1"]=topic1func
|
||||||
|
m_dis["/topic2"]=topic2func
|
||||||
|
-- Lua: mqtt.Client(clientid, keepalive, user, pass)
|
||||||
|
m=mqtt.Client("nodemcu1",60,"test","test123")
|
||||||
|
m:on("connect",function(m)
|
||||||
|
print("connection "..node.heap())
|
||||||
|
m:subscribe("/topic1",0,function(m) print("sub done") end)
|
||||||
|
m:subscribe("/topic2",0,function(m) print("sub done") end)
|
||||||
|
m:publish("/topic1","hello",0,0) m:publish("/topic2","world",0,0)
|
||||||
|
end )
|
||||||
|
m:on("offline", function(conn)
|
||||||
|
print("disconnect to broker...")
|
||||||
|
print(node.heap())
|
||||||
|
end)
|
||||||
|
m:on("message",dispatch )
|
||||||
|
-- Lua: mqtt:connect( host, port, secure, auto_reconnect, function(client) )
|
||||||
|
m:connect("m11.cloudmqtt.com",11214,0,1)
|
||||||
|
tmr.alarm(0,10000,1,function() local pl = "time: "..tmr.time()
|
||||||
|
m:publish("/topic1",pl,0,0)
|
||||||
|
end)
|
|
@ -0,0 +1,56 @@
|
||||||
|
-- test transfer files over mqtt.
|
||||||
|
m_dis={}
|
||||||
|
function dispatch(m,t,pl)
|
||||||
|
if pl~=nil and m_dis[t] then
|
||||||
|
m_dis[t](m,pl)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function pubfile(m,filename)
|
||||||
|
file.close()
|
||||||
|
file.open(filename)
|
||||||
|
repeat
|
||||||
|
local pl=file.read(1024)
|
||||||
|
if pl then m:publish("/topic2",pl,0,0) end
|
||||||
|
until not pl
|
||||||
|
file.close()
|
||||||
|
end
|
||||||
|
-- payload(json): {"cmd":xxx,"content":xxx}
|
||||||
|
function topic1func(m,pl)
|
||||||
|
print("get1: "..pl)
|
||||||
|
local pack = cjson.decode(pl)
|
||||||
|
if pack.content then
|
||||||
|
if pack.cmd == "open" then file.open(pack.content,"w+")
|
||||||
|
elseif pack.cmd == "write" then file.write(pack.content)
|
||||||
|
elseif pack.cmd == "close" then file.close()
|
||||||
|
elseif pack.cmd == "remove" then file.remove(pack.content)
|
||||||
|
elseif pack.cmd == "run" then dofile(pack.content)
|
||||||
|
elseif pack.cmd == "read" then pubfile(m, pack.content)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
m_dis["/topic1"]=topic1func
|
||||||
|
-- Lua: mqtt.Client(clientid, keepalive, user, pass)
|
||||||
|
m=mqtt.Client()
|
||||||
|
m:on("connect",function(m)
|
||||||
|
print("connection "..node.heap())
|
||||||
|
m:subscribe("/topic1",0,function(m) print("sub done") end)
|
||||||
|
end )
|
||||||
|
m:on("offline", function(conn)
|
||||||
|
print("disconnect to broker...")
|
||||||
|
print(node.heap())
|
||||||
|
end)
|
||||||
|
m:on("message",dispatch )
|
||||||
|
-- Lua: mqtt:connect( host, port, secure, auto_reconnect, function(client) )
|
||||||
|
m:connect(192.168.18.88,1883,0,1)
|
||||||
|
|
||||||
|
-- usage:
|
||||||
|
-- another client(pc) subscribe to /topic2, will receive the test.lua content.
|
||||||
|
-- and publish below message to /topic1
|
||||||
|
-- {"cmd":"open","content":"test.lua"}
|
||||||
|
-- {"cmd":"write","content":"print([[hello world]])\n"}
|
||||||
|
-- {"cmd":"write","content":"print(\"hello2 world2\")\n"}
|
||||||
|
-- {"cmd":"write","content":"test.lua"}
|
||||||
|
-- {"cmd":"run","content":"test.lua"}
|
||||||
|
-- {"cmd":"read","content":"test.lua"}
|
|
@ -0,0 +1,98 @@
|
||||||
|
--[[
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated
|
||||||
|
documentation files (the "Software"), to deal in the Software without restriction,
|
||||||
|
including without limitation the rights to use, copy, modify, merge, publish, distribute,
|
||||||
|
sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be
|
||||||
|
included in all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
||||||
|
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
||||||
|
WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR
|
||||||
|
IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
]]--
|
||||||
|
|
||||||
|
-- Your access point's SSID and password
|
||||||
|
local SSID = "xxxxxx"
|
||||||
|
local SSID_PASSWORD = "xxxxxx"
|
||||||
|
|
||||||
|
-- configure ESP as a station
|
||||||
|
wifi.setmode(wifi.STATION)
|
||||||
|
wifi.sta.config(SSID,SSID_PASSWORD)
|
||||||
|
wifi.sta.autoconnect(1)
|
||||||
|
|
||||||
|
local TWILIO_ACCOUNT_SID = "xxxxxx"
|
||||||
|
local TWILIO_TOKEN = "xxxxxx"
|
||||||
|
|
||||||
|
local HOST = "iot-https-relay.appspot.com" -- visit http://iot-https-relay.appspot.com/ to learn more about this service
|
||||||
|
-- Please be sure to understand the security issues of using this relay app and use at your own risk.
|
||||||
|
local URI = "/twilio/Messages.json"
|
||||||
|
|
||||||
|
function build_post_request(host, uri, data_table)
|
||||||
|
|
||||||
|
local data = ""
|
||||||
|
|
||||||
|
for param,value in pairs(data_table) do
|
||||||
|
data = data .. param.."="..value.."&"
|
||||||
|
end
|
||||||
|
|
||||||
|
request = "POST "..uri.." HTTP/1.1\r\n"..
|
||||||
|
"Host: "..host.."\r\n"..
|
||||||
|
"Connection: close\r\n"..
|
||||||
|
"Content-Type: application/x-www-form-urlencoded\r\n"..
|
||||||
|
"Content-Length: "..string.len(data).."\r\n"..
|
||||||
|
"\r\n"..
|
||||||
|
data
|
||||||
|
|
||||||
|
print(request)
|
||||||
|
|
||||||
|
return request
|
||||||
|
end
|
||||||
|
|
||||||
|
local function display(sck,response)
|
||||||
|
print(response)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- When using send_sms: the "from" number HAS to be your twilio number.
|
||||||
|
-- If you have a free twilio account the "to" number HAS to be your twilio verified number.
|
||||||
|
local function send_sms(from,to,body)
|
||||||
|
|
||||||
|
local data = {
|
||||||
|
sid = TWILIO_ACCOUNT_SID,
|
||||||
|
token = TWILIO_TOKEN,
|
||||||
|
Body = string.gsub(body," ","+"),
|
||||||
|
From = from,
|
||||||
|
To = to
|
||||||
|
}
|
||||||
|
|
||||||
|
socket = net.createConnection(net.TCP,0)
|
||||||
|
socket:on("receive",display)
|
||||||
|
socket:connect(80,HOST)
|
||||||
|
|
||||||
|
socket:on("connection",function(sck)
|
||||||
|
|
||||||
|
local post_request = build_post_request(HOST,URI,data)
|
||||||
|
sck:send(post_request)
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
function check_wifi()
|
||||||
|
local ip = wifi.sta.getip()
|
||||||
|
|
||||||
|
if(ip==nil) then
|
||||||
|
print("Connecting...")
|
||||||
|
else
|
||||||
|
tmr.stop(0)
|
||||||
|
print("Connected to AP!")
|
||||||
|
print(ip)
|
||||||
|
-- send a text message with the text "Hello from your esp8266"
|
||||||
|
send_sms("15558889944","15559998845","Hello from your ESP8266")
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
tmr.alarm(0,7000,1,check_wifi)
|
|
@ -2,9 +2,9 @@
|
||||||
-- setup I2c and connect display
|
-- setup I2c and connect display
|
||||||
function init_i2c_display()
|
function init_i2c_display()
|
||||||
-- SDA and SCL can be assigned freely to available GPIOs
|
-- SDA and SCL can be assigned freely to available GPIOs
|
||||||
sda = 5 -- GPIO14
|
local sda = 5 -- GPIO14
|
||||||
scl = 6 -- GPIO12
|
local scl = 6 -- GPIO12
|
||||||
sla = 0x3c
|
local sla = 0x3c
|
||||||
i2c.setup(0, sda, scl, i2c.SLOW)
|
i2c.setup(0, sda, scl, i2c.SLOW)
|
||||||
disp = u8g.ssd1306_128x64_i2c(sla)
|
disp = u8g.ssd1306_128x64_i2c(sla)
|
||||||
end
|
end
|
||||||
|
@ -15,9 +15,9 @@ function init_spi_display()
|
||||||
-- Hardware SPI MOSI = GPIO13
|
-- Hardware SPI MOSI = GPIO13
|
||||||
-- Hardware SPI MISO = GPIO12 (not used)
|
-- Hardware SPI MISO = GPIO12 (not used)
|
||||||
-- CS, D/C, and RES can be assigned freely to available GPIOs
|
-- CS, D/C, and RES can be assigned freely to available GPIOs
|
||||||
cs = 8 -- GPIO15, pull-down 10k to GND
|
local cs = 8 -- GPIO15, pull-down 10k to GND
|
||||||
dc = 4 -- GPIO2
|
local dc = 4 -- GPIO2
|
||||||
res = 0 -- GPIO16
|
local res = 0 -- GPIO16
|
||||||
|
|
||||||
spi.setup(1, spi.MASTER, spi.CPOL_LOW, spi.CPHA_LOW, spi.DATABITS_8, 0)
|
spi.setup(1, spi.MASTER, spi.CPOL_LOW, spi.CPHA_LOW, spi.DATABITS_8, 0)
|
||||||
disp = u8g.ssd1306_128x64_spi(cs, dc, res)
|
disp = u8g.ssd1306_128x64_spi(cs, dc, res)
|
||||||
|
|
|
@ -2,9 +2,9 @@
|
||||||
-- setup I2c and connect display
|
-- setup I2c and connect display
|
||||||
function init_i2c_display()
|
function init_i2c_display()
|
||||||
-- SDA and SCL can be assigned freely to available GPIOs
|
-- SDA and SCL can be assigned freely to available GPIOs
|
||||||
sda = 5 -- GPIO14
|
local sda = 5 -- GPIO14
|
||||||
scl = 6 -- GPIO12
|
local scl = 6 -- GPIO12
|
||||||
sla = 0x3c
|
local sla = 0x3c
|
||||||
i2c.setup(0, sda, scl, i2c.SLOW)
|
i2c.setup(0, sda, scl, i2c.SLOW)
|
||||||
disp = u8g.ssd1306_128x64_i2c(sla)
|
disp = u8g.ssd1306_128x64_i2c(sla)
|
||||||
end
|
end
|
||||||
|
@ -15,9 +15,9 @@ function init_spi_display()
|
||||||
-- Hardware SPI MOSI = GPIO13
|
-- Hardware SPI MOSI = GPIO13
|
||||||
-- Hardware SPI MISO = GPIO12 (not used)
|
-- Hardware SPI MISO = GPIO12 (not used)
|
||||||
-- CS, D/C, and RES can be assigned freely to available GPIOs
|
-- CS, D/C, and RES can be assigned freely to available GPIOs
|
||||||
cs = 8 -- GPIO15, pull-down 10k to GND
|
local cs = 8 -- GPIO15, pull-down 10k to GND
|
||||||
dc = 4 -- GPIO2
|
local dc = 4 -- GPIO2
|
||||||
res = 0 -- GPIO16
|
local res = 0 -- GPIO16
|
||||||
|
|
||||||
spi.setup(1, spi.MASTER, spi.CPOL_LOW, spi.CPHA_LOW, spi.DATABITS_8, 0)
|
spi.setup(1, spi.MASTER, spi.CPOL_LOW, spi.CPHA_LOW, spi.DATABITS_8, 0)
|
||||||
disp = u8g.ssd1306_128x64_spi(cs, dc, res)
|
disp = u8g.ssd1306_128x64_spi(cs, dc, res)
|
||||||
|
@ -91,17 +91,6 @@ function ascii_1()
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function ascii_2()
|
|
||||||
local x, y, s
|
|
||||||
disp:drawStr(0, 0, "ASCII page 2")
|
|
||||||
for y = 0, 5, 1 do
|
|
||||||
for x = 0, 15, 1 do
|
|
||||||
s = y*16 + x + 160
|
|
||||||
disp:drawStr(x*7, y*10+10, string.char(s))
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
function extra_page(a)
|
function extra_page(a)
|
||||||
disp:drawStr(0, 12, "setScale2x2")
|
disp:drawStr(0, 12, "setScale2x2")
|
||||||
disp:setScale2x2()
|
disp:setScale2x2()
|
||||||
|
@ -131,8 +120,6 @@ function draw(draw_state)
|
||||||
elseif (component == 6) then
|
elseif (component == 6) then
|
||||||
ascii_1()
|
ascii_1()
|
||||||
elseif (component == 7) then
|
elseif (component == 7) then
|
||||||
ascii_2()
|
|
||||||
elseif (component == 8) then
|
|
||||||
extra_page(bit.band(draw_state, 7))
|
extra_page(bit.band(draw_state, 7))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -2,9 +2,9 @@
|
||||||
-- setup I2c and connect display
|
-- setup I2c and connect display
|
||||||
function init_i2c_display()
|
function init_i2c_display()
|
||||||
-- SDA and SCL can be assigned freely to available GPIOs
|
-- SDA and SCL can be assigned freely to available GPIOs
|
||||||
sda = 5 -- GPIO14
|
local sda = 5 -- GPIO14
|
||||||
scl = 6 -- GPIO12
|
local scl = 6 -- GPIO12
|
||||||
sla = 0x3c
|
local sla = 0x3c
|
||||||
i2c.setup(0, sda, scl, i2c.SLOW)
|
i2c.setup(0, sda, scl, i2c.SLOW)
|
||||||
disp = u8g.ssd1306_128x64_i2c(sla)
|
disp = u8g.ssd1306_128x64_i2c(sla)
|
||||||
end
|
end
|
||||||
|
@ -15,9 +15,9 @@ function init_spi_display()
|
||||||
-- Hardware SPI MOSI = GPIO13
|
-- Hardware SPI MOSI = GPIO13
|
||||||
-- Hardware SPI MISO = GPIO12 (not used)
|
-- Hardware SPI MISO = GPIO12 (not used)
|
||||||
-- CS, D/C, and RES can be assigned freely to available GPIOs
|
-- CS, D/C, and RES can be assigned freely to available GPIOs
|
||||||
cs = 8 -- GPIO15, pull-down 10k to GND
|
local cs = 8 -- GPIO15, pull-down 10k to GND
|
||||||
dc = 4 -- GPIO2
|
local dc = 4 -- GPIO2
|
||||||
res = 0 -- GPIO16
|
local res = 0 -- GPIO16
|
||||||
|
|
||||||
spi.setup(1, spi.MASTER, spi.CPOL_LOW, spi.CPHA_LOW, spi.DATABITS_8, 0)
|
spi.setup(1, spi.MASTER, spi.CPOL_LOW, spi.CPHA_LOW, spi.DATABITS_8, 0)
|
||||||
disp = u8g.ssd1306_128x64_spi(cs, dc, res)
|
disp = u8g.ssd1306_128x64_spi(cs, dc, res)
|
||||||
|
|
|
@ -1,58 +0,0 @@
|
||||||
# DHT22 module
|
|
||||||
|
|
||||||
This module is compatible with DHT22 and DHT21.
|
|
||||||
Supports nodemcu with or without floating point.
|
|
||||||
No need to use a resistor to connect the pin data of DHT22 to ESP8266.
|
|
||||||
|
|
||||||
## Example
|
|
||||||
```lua
|
|
||||||
PIN = 4 -- data pin, GPIO2
|
|
||||||
|
|
||||||
dht22 = require("dht22")
|
|
||||||
dht22.read(PIN)
|
|
||||||
t = dht22.getTemperature()
|
|
||||||
h = dht22.getHumidity()
|
|
||||||
|
|
||||||
if h == nil then
|
|
||||||
print("Error reading from DHT22")
|
|
||||||
else
|
|
||||||
-- temperature in degrees Celsius and Farenheit
|
|
||||||
-- floating point and integer version:
|
|
||||||
print("Temperature: "..((t-(t % 10)) / 10).."."..(t % 10).." deg C")
|
|
||||||
-- only integer version:
|
|
||||||
print("Temperature: "..(9 * t / 50 + 32).."."..(9 * t / 5 % 10).." deg F")
|
|
||||||
-- only float point version:
|
|
||||||
print("Temperature: "..(9 * t / 50 + 32).." deg F")
|
|
||||||
|
|
||||||
-- humidity
|
|
||||||
-- floating point and integer version
|
|
||||||
print("Humidity: "..((h - (h % 10)) / 10).."."..(h % 10).."%")
|
|
||||||
end
|
|
||||||
|
|
||||||
-- release module
|
|
||||||
dht22 = nil
|
|
||||||
package.loaded["dht22"]=nil
|
|
||||||
```
|
|
||||||
## Functions
|
|
||||||
### read
|
|
||||||
read(pin)
|
|
||||||
Read humidity and temperature from DHT22.
|
|
||||||
|
|
||||||
**Parameters:**
|
|
||||||
|
|
||||||
* pin - ESP8266 pin connect to data pin in DHT22
|
|
||||||
|
|
||||||
### getHumidity
|
|
||||||
getHumidity()
|
|
||||||
Returns the humidity of the last reading.
|
|
||||||
|
|
||||||
**Returns:**
|
|
||||||
* last humidity reading in per thousand
|
|
||||||
|
|
||||||
### getTemperature
|
|
||||||
getTemperature()
|
|
||||||
Returns the temperature of the last reading.
|
|
||||||
|
|
||||||
**Returns:**
|
|
||||||
* last temperature reading in 0.1ºC
|
|
||||||
|
|
|
@ -1,102 +0,0 @@
|
||||||
-- ***************************************************************************
|
|
||||||
-- DHT22 module for ESP8266 with nodeMCU
|
|
||||||
--
|
|
||||||
-- Written by Javier Yanez
|
|
||||||
-- but based on a script of Pigs Fly from ESP8266.com forum
|
|
||||||
--
|
|
||||||
-- MIT license, http://opensource.org/licenses/MIT
|
|
||||||
-- ***************************************************************************
|
|
||||||
|
|
||||||
local moduleName = ...
|
|
||||||
local M = {}
|
|
||||||
_G[moduleName] = M
|
|
||||||
|
|
||||||
local humidity
|
|
||||||
local temperature
|
|
||||||
|
|
||||||
function M.read(pin)
|
|
||||||
local checksum
|
|
||||||
local checksumTest
|
|
||||||
humidity = 0
|
|
||||||
temperature = 0
|
|
||||||
checksum = 0
|
|
||||||
|
|
||||||
-- Use Markus Gritsch trick to speed up read/write on GPIO
|
|
||||||
local gpio_read = gpio.read
|
|
||||||
|
|
||||||
local bitStream = {}
|
|
||||||
for j = 1, 40, 1 do
|
|
||||||
bitStream[j] = 0
|
|
||||||
end
|
|
||||||
local bitlength = 0
|
|
||||||
|
|
||||||
-- Step 1: send out start signal to DHT22
|
|
||||||
gpio.mode(pin, gpio.OUTPUT)
|
|
||||||
gpio.write(pin, gpio.HIGH)
|
|
||||||
tmr.delay(100)
|
|
||||||
gpio.write(pin, gpio.LOW)
|
|
||||||
tmr.delay(20000)
|
|
||||||
gpio.write(pin, gpio.HIGH)
|
|
||||||
gpio.mode(pin, gpio.INPUT)
|
|
||||||
|
|
||||||
-- Step 2: DHT22 send response signal
|
|
||||||
-- bus will always let up eventually, don't bother with timeout
|
|
||||||
while (gpio_read(pin) == 0 ) do end
|
|
||||||
local c=0
|
|
||||||
while (gpio_read(pin) == 1 and c < 500) do c = c + 1 end
|
|
||||||
-- bus will always let up eventually, don't bother with timeout
|
|
||||||
while (gpio_read(pin) == 0 ) do end
|
|
||||||
c=0
|
|
||||||
while (gpio_read(pin) == 1 and c < 500) do c = c + 1 end
|
|
||||||
|
|
||||||
-- Step 3: DHT22 send data
|
|
||||||
for j = 1, 40, 1 do
|
|
||||||
while (gpio_read(pin) == 1 and bitlength < 10 ) do
|
|
||||||
bitlength = bitlength + 1
|
|
||||||
end
|
|
||||||
bitStream[j] = bitlength
|
|
||||||
bitlength = 0
|
|
||||||
-- bus will always let up eventually, don't bother with timeout
|
|
||||||
while (gpio_read(pin) == 0) do end
|
|
||||||
end
|
|
||||||
|
|
||||||
--DHT data acquired, process.
|
|
||||||
for i = 1, 16, 1 do
|
|
||||||
if (bitStream[i] > 3) then
|
|
||||||
humidity = humidity + 2 ^ (16 - i)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
for i = 1, 16, 1 do
|
|
||||||
if (bitStream[i + 16] > 3) then
|
|
||||||
temperature = temperature + 2 ^ (16 - i)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
for i = 1, 8, 1 do
|
|
||||||
if (bitStream[i + 32] > 3) then
|
|
||||||
checksum = checksum + 2 ^ (8 - i)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
checksumTest = (bit.band(humidity, 0xFF) + bit.rshift(humidity, 8) + bit.band(temperature, 0xFF) + bit.rshift(temperature, 8))
|
|
||||||
checksumTest = bit.band(checksumTest, 0xFF)
|
|
||||||
|
|
||||||
if temperature > 0x8000 then
|
|
||||||
-- convert to negative format
|
|
||||||
temperature = -(temperature - 0x8000)
|
|
||||||
end
|
|
||||||
|
|
||||||
-- conditions compatible con float point and integer
|
|
||||||
if (checksumTest - checksum >= 1) or (checksum - checksumTest >= 1) then
|
|
||||||
humidity = nil
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
function M.getTemperature()
|
|
||||||
return temperature
|
|
||||||
end
|
|
||||||
|
|
||||||
function M.getHumidity()
|
|
||||||
return humidity
|
|
||||||
end
|
|
||||||
|
|
||||||
return M
|
|
|
@ -0,0 +1,89 @@
|
||||||
|
# DHTxx module
|
||||||
|
|
||||||
|
This module is compatible with DHT11, DHT21 and DHT22.
|
||||||
|
And is able to auto-select wheather you are using DHT11 or DHT2x
|
||||||
|
|
||||||
|
No need to use a resistor to connect the pin data of DHT22 to ESP8266.
|
||||||
|
|
||||||
|
##Integer Verison[When using DHT11, Float version is useless...]
|
||||||
|
### Example
|
||||||
|
```lua
|
||||||
|
PIN = 4 -- data pin, GPIO2
|
||||||
|
|
||||||
|
DHT= require("dht_lib")
|
||||||
|
|
||||||
|
DHT.read(PIN)
|
||||||
|
|
||||||
|
t = DHT.getTemperature()
|
||||||
|
h = DHT.getHumidity()
|
||||||
|
|
||||||
|
if h == nil then
|
||||||
|
print("Error reading from DHTxx")
|
||||||
|
else
|
||||||
|
-- temperature in degrees Celsius and Farenheit
|
||||||
|
|
||||||
|
print("Temperature: "..((t-(t % 10)) / 10).."."..(t % 10).." deg C")
|
||||||
|
|
||||||
|
print("Temperature: "..(9 * t / 50 + 32).."."..(9 * t / 5 % 10).." deg F")
|
||||||
|
|
||||||
|
-- humidity
|
||||||
|
|
||||||
|
print("Humidity: "..((h - (h % 10)) / 10).."."..(h % 10).."%")
|
||||||
|
end
|
||||||
|
|
||||||
|
-- release module
|
||||||
|
DHT = nil
|
||||||
|
package.loaded["dht_lib"]=nil
|
||||||
|
```
|
||||||
|
##Float Verison
|
||||||
|
###Example
|
||||||
|
```lua
|
||||||
|
PIN = 4 -- data pin, GPIO2
|
||||||
|
|
||||||
|
DHT= require("dht_lib")
|
||||||
|
|
||||||
|
DHT.read(PIN)
|
||||||
|
|
||||||
|
t = DHT.getTemperature()
|
||||||
|
h = DHT.getHumidity()
|
||||||
|
|
||||||
|
if h == nil then
|
||||||
|
print("Error reading from DHT11/22")
|
||||||
|
else
|
||||||
|
-- temperature in degrees Celsius and Farenheit
|
||||||
|
-- floating point and integer version:
|
||||||
|
|
||||||
|
print("Temperature: "..(t/10).." deg C")
|
||||||
|
print("Temperature: "..(9 * t / 50 + 32).." deg F")
|
||||||
|
|
||||||
|
-- humidity
|
||||||
|
print("Humidity: "..(h/10).."%")
|
||||||
|
end
|
||||||
|
|
||||||
|
-- release module
|
||||||
|
DHT = nil
|
||||||
|
package.loaded["dht_lib"]=nil
|
||||||
|
```
|
||||||
|
## Functions
|
||||||
|
|
||||||
|
###read
|
||||||
|
read(pin)
|
||||||
|
Read humidity and temperature from DHTxx(11,21,22...).
|
||||||
|
**Parameters:**
|
||||||
|
|
||||||
|
* pin - ESP8266 pin connect to data pin
|
||||||
|
|
||||||
|
### getHumidity
|
||||||
|
getHumidity()
|
||||||
|
Returns the humidity of the last reading.
|
||||||
|
|
||||||
|
**Returns:**
|
||||||
|
* last humidity reading in per thousand
|
||||||
|
|
||||||
|
### getTemperature
|
||||||
|
getTemperature()
|
||||||
|
Returns the temperature of the last reading.
|
||||||
|
|
||||||
|
**Returns:**
|
||||||
|
* last temperature reading in(dht22) 0.1ºC (dht11)1ºC
|
||||||
|
*
|
|
@ -0,0 +1,178 @@
|
||||||
|
-- ***************************************************************************
|
||||||
|
-- DHTxx(11,21,22) module for ESP8266 with nodeMCU
|
||||||
|
--
|
||||||
|
-- Written by Javier Yanez mod by Martin
|
||||||
|
-- but based on a script of Pigs Fly from ESP8266.com forum
|
||||||
|
--
|
||||||
|
-- MIT license, http://opensource.org/licenses/MIT
|
||||||
|
-- ***************************************************************************
|
||||||
|
|
||||||
|
--Support list:
|
||||||
|
|
||||||
|
--DHT11 Tested
|
||||||
|
--DHT21 Not Test yet
|
||||||
|
--DHT22(AM2302) Tested
|
||||||
|
--AM2320 Not Test yet
|
||||||
|
|
||||||
|
--Output format-> Real temperature times 10(or DHT22 will miss it float part in Int Version)
|
||||||
|
--==========================Module Part======================
|
||||||
|
local moduleName = ...
|
||||||
|
local M = {}
|
||||||
|
_G[moduleName] = M
|
||||||
|
--==========================Local the UMI and TEMP===========
|
||||||
|
local humidity
|
||||||
|
local temperature
|
||||||
|
--==========================Local the bitStream==============
|
||||||
|
local bitStream = {}
|
||||||
|
|
||||||
|
---------------------------Read bitStream from DHTXX--------------------------
|
||||||
|
local function read(pin)
|
||||||
|
|
||||||
|
local bitlength = 0
|
||||||
|
humidity = 0
|
||||||
|
temperature = 0
|
||||||
|
|
||||||
|
-- Use Markus Gritsch trick to speed up read/write on GPIO
|
||||||
|
local gpio_read = gpio.read
|
||||||
|
|
||||||
|
|
||||||
|
for j = 1, 40, 1 do
|
||||||
|
bitStream[j] = 0
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Step 1: send out start signal to DHT22
|
||||||
|
gpio.mode(pin, gpio.OUTPUT)
|
||||||
|
gpio.write(pin, gpio.HIGH)
|
||||||
|
tmr.delay(100)
|
||||||
|
gpio.write(pin, gpio.LOW)
|
||||||
|
tmr.delay(20000)
|
||||||
|
gpio.write(pin, gpio.HIGH)
|
||||||
|
gpio.mode(pin, gpio.INPUT)
|
||||||
|
|
||||||
|
-- Step 2: Receive bitStream from DHT11/22
|
||||||
|
-- bus will always let up eventually, don't bother with timeout
|
||||||
|
while (gpio_read(pin) == 0 ) do end
|
||||||
|
local c=0
|
||||||
|
while (gpio_read(pin) == 1 and c < 500) do c = c + 1 end
|
||||||
|
-- bus will always let up eventually, don't bother with timeout
|
||||||
|
while (gpio_read(pin) == 0 ) do end
|
||||||
|
c=0
|
||||||
|
while (gpio_read(pin) == 1 and c < 500) do c = c + 1 end
|
||||||
|
|
||||||
|
-- Step 3: DHT22 send data
|
||||||
|
for j = 1, 40, 1 do
|
||||||
|
while (gpio_read(pin) == 1 and bitlength < 10 ) do
|
||||||
|
bitlength = bitlength + 1
|
||||||
|
end
|
||||||
|
bitStream[j] = bitlength
|
||||||
|
bitlength = 0
|
||||||
|
-- bus will always let up eventually, don't bother with timeout
|
||||||
|
while (gpio_read(pin) == 0) do end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
---------------------------Check out the data--------------------------
|
||||||
|
----Auto Select the DHT11/DHT22 By check the byte[1] && byte[3] -------
|
||||||
|
---------------Which is empty when using DHT11-------------------------
|
||||||
|
function M.read(pin)
|
||||||
|
read(pin)
|
||||||
|
|
||||||
|
local byte_0 = 0
|
||||||
|
local byte_1 = 0
|
||||||
|
local byte_2 = 0
|
||||||
|
local byte_3 = 0
|
||||||
|
local byte_4 = 0
|
||||||
|
|
||||||
|
for i = 1, 8, 1 do -- Byte[0]
|
||||||
|
if (bitStream[i] > 3) then
|
||||||
|
byte_0 = byte_0 + 2 ^ (8 - i)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
for i = 1, 8, 1 do -- Byte[1]
|
||||||
|
if (bitStream[i+8] > 3) then
|
||||||
|
byte_1 = byte_1 + 2 ^ (8 - i)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
for i = 1, 8, 1 do -- Byte[2]
|
||||||
|
if (bitStream[i+16] > 3) then
|
||||||
|
byte_2 = byte_2 + 2 ^ (8 - i)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
for i = 1, 8, 1 do -- Byte[3]
|
||||||
|
if (bitStream[i+24] > 3) then
|
||||||
|
byte_2 = byte_2 + 2 ^ (8 - i)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
for i = 1, 8, 1 do -- Byte[4]
|
||||||
|
if (bitStream[i+32] > 3) then
|
||||||
|
byte_4 = byte_4 + 2 ^ (8 - i)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
if byte_1==0 and byte_3 == 0 then
|
||||||
|
---------------------------Convert the bitStream into Number through DHT11's Way--------------------------
|
||||||
|
--As for DHT11 40Bit is consisit of 5Bytes
|
||||||
|
--First byte->Humidity Data's Int part
|
||||||
|
--Sencond byte->Humidity Data's Float Part(Which should be empty)
|
||||||
|
--Third byte->Temp Data;s Intpart
|
||||||
|
--Forth byte->Temp Data's Float Part(Which should be empty)
|
||||||
|
--Fifth byte->SUM Byte, Humi+Temp
|
||||||
|
|
||||||
|
if(byte_4 ~= byte_0+byte_2) then
|
||||||
|
humidity = nil
|
||||||
|
temperature = nil
|
||||||
|
else
|
||||||
|
humidity = byte_0 *10 -- In order to universe with the DHT22
|
||||||
|
temperature = byte_2 *10
|
||||||
|
end
|
||||||
|
|
||||||
|
else ---------------------------Convert the bitStream into Number through DHT22's Way--------------------------
|
||||||
|
--As for DHT22 40Bit is consisit of 5Bytes
|
||||||
|
--First byte->Humidity Data's High Bit
|
||||||
|
--Sencond byte->Humidity Data's Low Bit(And if over 0x8000, use complement)
|
||||||
|
--Third byte->Temp Data's High Bit
|
||||||
|
--Forth byte->Temp Data's Low Bit
|
||||||
|
--Fifth byte->SUM Byte
|
||||||
|
|
||||||
|
humidity = byte_0 * 256 + byte_1
|
||||||
|
temperature = byte_2 * 256 + byte_3
|
||||||
|
checksum = byte_4
|
||||||
|
|
||||||
|
checksumTest = (bit.band(humidity, 0xFF) + bit.rshift(humidity, 8) + bit.band(temperature, 0xFF) + bit.rshift(temperature, 8))
|
||||||
|
checksumTest = bit.band(checksumTest, 0xFF)
|
||||||
|
|
||||||
|
if temperature > 0x8000 then
|
||||||
|
-- convert to negative format
|
||||||
|
temperature = -(temperature - 0x8000)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- conditions compatible con float point and integer
|
||||||
|
if (checksumTest - checksum >= 1) or (checksum - checksumTest >= 1) then
|
||||||
|
humidity = nil
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
byte_0 = nil
|
||||||
|
byte_1 = nil
|
||||||
|
byte_2 = nil
|
||||||
|
byte_3 = nil
|
||||||
|
byte_4 = nil
|
||||||
|
|
||||||
|
end
|
||||||
|
--------------API for geting the data out------------------
|
||||||
|
|
||||||
|
function M.getTemperature()
|
||||||
|
return temperature
|
||||||
|
end
|
||||||
|
|
||||||
|
function M.getHumidity()
|
||||||
|
return humidity
|
||||||
|
end
|
||||||
|
-------------Return Index------------------------------------
|
||||||
|
return M
|
|
@ -0,0 +1,25 @@
|
||||||
|
-- ***************************************************************************
|
||||||
|
-- Example for Yeelink Lib
|
||||||
|
--
|
||||||
|
-- Written by Martin
|
||||||
|
--
|
||||||
|
--
|
||||||
|
-- MIT license, http://opensource.org/licenses/MIT
|
||||||
|
-- ***************************************************************************
|
||||||
|
|
||||||
|
wifi.setmode(wifi.STATION) --Step1: Connect to Wifi
|
||||||
|
wifi.sta.config("SSID","Password")
|
||||||
|
|
||||||
|
dht = require("dht_lib") --Step2: "Require" the libs
|
||||||
|
yeelink = require("yeelink_lib")
|
||||||
|
|
||||||
|
yeelink.init(23333,23333,"You api-key",function() --Step3: Register the callback function
|
||||||
|
|
||||||
|
print("Yeelink Init OK...")
|
||||||
|
tmr.alarm(1,60000,1,function() --Step4: Have fun~ (Update your data)
|
||||||
|
|
||||||
|
dht.read(4)
|
||||||
|
yeelink.update(dht.getTemperature())
|
||||||
|
|
||||||
|
end)
|
||||||
|
end)
|
|
@ -0,0 +1,134 @@
|
||||||
|
|
||||||
|
-- ***************************************************************************
|
||||||
|
-- Yeelink Updata Libiary Version 0.1.2 r1
|
||||||
|
--
|
||||||
|
-- Written by Martin
|
||||||
|
-- but based on a script of zhouxu_o from bbs.nodemcu.com
|
||||||
|
--
|
||||||
|
-- MIT license, http://opensource.org/licenses/MIT
|
||||||
|
-- ***************************************************************************
|
||||||
|
--==========================Module Part======================
|
||||||
|
|
||||||
|
local moduleName = ...
|
||||||
|
local M = {}
|
||||||
|
_G[moduleName] = M
|
||||||
|
--=========================Local Args=======================
|
||||||
|
local dns = "0.0.0.0"
|
||||||
|
|
||||||
|
local device = ""
|
||||||
|
local sensor = ""
|
||||||
|
local apikey = ""
|
||||||
|
|
||||||
|
--================================
|
||||||
|
local debug = true --<<<<<<<<<<<<< Don't forget to "false" it before using
|
||||||
|
--================================
|
||||||
|
local sk=net.createConnection(net.TCP, 0)
|
||||||
|
|
||||||
|
local datapoint = 0
|
||||||
|
|
||||||
|
|
||||||
|
--====DNS the yeelink ip advance(in order to save RAM)=====
|
||||||
|
|
||||||
|
if wifi.sta.getip() == nil then
|
||||||
|
print("Please Connect WIFI First")
|
||||||
|
tmr.alarm(1,1000,1,function ()
|
||||||
|
if wifi.sta.getip() ~= nil then
|
||||||
|
tmr.stop(1)
|
||||||
|
sk:dns("api.yeelink.net",function(conn,ip)
|
||||||
|
dns=ip
|
||||||
|
print("DNS YEELINK OK... IP: "..dns)
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
sk:dns("api.yeelink.net",function(conn,ip)
|
||||||
|
|
||||||
|
dns=ip
|
||||||
|
|
||||||
|
print("DNS YEELINK OK... IP: "..dns)
|
||||||
|
|
||||||
|
end)
|
||||||
|
|
||||||
|
--========Set the init function===========
|
||||||
|
--device->number
|
||||||
|
--sensor->number
|
||||||
|
-- apikey must be -> string <-
|
||||||
|
-- e.g. xxx.init(00000,00000,"123j12b3jkb12k4b23bv54i2b5b3o4")
|
||||||
|
--========================================
|
||||||
|
function M.init(_device, _sensor, _apikey)
|
||||||
|
device = tostring(_device)
|
||||||
|
sensor = tostring(_sensor)
|
||||||
|
apikey = _apikey
|
||||||
|
if dns == "0.0.0.0" then
|
||||||
|
tmr.alarm(2,5000,1,function ()
|
||||||
|
if dns == "0.0.0.0" then
|
||||||
|
print("Waiting for DNS...")
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
return false
|
||||||
|
else
|
||||||
|
return dns
|
||||||
|
end
|
||||||
|
end
|
||||||
|
--========Check the DNS Status===========
|
||||||
|
--if DNS success, return the address(string)
|
||||||
|
--if DNS fail(or processing), return nil
|
||||||
|
--
|
||||||
|
--
|
||||||
|
--========================================
|
||||||
|
function M.getDNS()
|
||||||
|
|
||||||
|
if dns == "0.0.0.0" then
|
||||||
|
return nil
|
||||||
|
else
|
||||||
|
return dns
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
--=====Update to Yeelink Sever(At least 10s per sencods))=====
|
||||||
|
-- datapoint->number
|
||||||
|
--
|
||||||
|
--e.g. xxx.update(233.333)
|
||||||
|
--============================================================
|
||||||
|
function M.update(_datapoint)
|
||||||
|
|
||||||
|
datapoint = tostring(_datapoint)
|
||||||
|
|
||||||
|
sk:on("connection", function(conn)
|
||||||
|
|
||||||
|
print("connect OK...")
|
||||||
|
|
||||||
|
|
||||||
|
local a=[[{"value":]]
|
||||||
|
local b=[[}]]
|
||||||
|
|
||||||
|
local st=a..datapoint..b
|
||||||
|
|
||||||
|
sk:send("POST /v1.0/device/"..device.."/sensor/"..sensor.."/datapoints HTTP/1.1\r\n"
|
||||||
|
.."Host: www.yeelink.net\r\n"
|
||||||
|
.."Content-Length: "..string.len(st).."\r\n"--the length of json is important
|
||||||
|
.."Content-Type: application/x-www-form-urlencoded\r\n"
|
||||||
|
.."U-ApiKey:"..apikey.."\r\n"
|
||||||
|
.."Cache-Control: no-cache\r\n\r\n"
|
||||||
|
..st.."\r\n" )
|
||||||
|
|
||||||
|
end)
|
||||||
|
|
||||||
|
sk:on("receive", function(sck, content)
|
||||||
|
|
||||||
|
if debug then
|
||||||
|
print("\r\n"..content.."\r\n")
|
||||||
|
else
|
||||||
|
print("Date Receive")
|
||||||
|
end
|
||||||
|
|
||||||
|
end)
|
||||||
|
|
||||||
|
sk:connect(80,dns)
|
||||||
|
|
||||||
|
|
||||||
|
end
|
||||||
|
--================end==========================
|
||||||
|
return M
|
Loading…
Reference in New Issue