Compare commits
25 Commits
AsyncAndWi
...
0.7.6
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
fab242e212 | ||
|
|
56a2be621f | ||
|
|
c4cf39ab68 | ||
|
|
90dea36ab0 | ||
|
|
25a721e06a | ||
|
|
b228d35ab0 | ||
|
|
c70716a595 | ||
|
|
8d5cad5fec | ||
|
|
d5430228e5 | ||
|
|
91c1f96146 | ||
|
|
f04a2a07c0 | ||
|
|
38f306c170 | ||
|
|
024e80c9dc | ||
|
|
2249ddef7f | ||
|
|
e193929f8f | ||
|
|
e00e31de33 | ||
|
|
20292b7b7b | ||
|
|
26de3befa8 | ||
|
|
1098466055 | ||
|
|
2d3663e78c | ||
|
|
5e16282ad0 | ||
|
|
e35a43c4a4 | ||
|
|
087a203ba0 | ||
|
|
5d313bbf5e | ||
|
|
ce896f02c4 |
8
.github/workflows/aunit.yml
vendored
8
.github/workflows/aunit.yml
vendored
@@ -24,5 +24,11 @@ jobs:
|
|||||||
git clone https://github.com/hsaturn/EspMock
|
git clone https://github.com/hsaturn/EspMock
|
||||||
- name: Verify tests
|
- name: Verify tests
|
||||||
run: |
|
run: |
|
||||||
make -C tests
|
# Run tests for ESP8266
|
||||||
|
make -C tests ESP_LIBS="ESP8266WiFi ESPAsyncTCP" tests
|
||||||
make -C tests runtests
|
make -C tests runtests
|
||||||
|
make -C tests clean
|
||||||
|
# Run tests for ESP32
|
||||||
|
#make -C tests ESP_LIBS="ESP8266WiFi ESPAsyncTCP" tests
|
||||||
|
#make -C tests runtests
|
||||||
|
#make -C tests clean
|
||||||
|
|||||||
18
.github/workflows/ci.yml
vendored
Normal file
18
.github/workflows/ci.yml
vendored
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
name: "CI"
|
||||||
|
on:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
ci:
|
||||||
|
runs-on: ubuntu-20.04
|
||||||
|
steps:
|
||||||
|
- name: Checkout this repository
|
||||||
|
uses: actions/checkout@v2.3.4
|
||||||
|
- name: Cache for arduino-ci
|
||||||
|
uses: actions/cache@v2.1.3
|
||||||
|
with:
|
||||||
|
path: |
|
||||||
|
~/.arduino15
|
||||||
|
key: ${{ runner.os }}-arduino
|
||||||
|
- name: Install nix
|
||||||
|
uses: cachix/install-nix-action@v12
|
||||||
|
- run: nix-shell -I nixpkgs=channel:nixpkgs-unstable -p arduino-ci --run "arduino-ci"
|
||||||
15
README.md
15
README.md
@@ -1,18 +1,19 @@
|
|||||||
# TinyMqtt
|
# TinyMqtt
|
||||||
|
|
||||||

|
[](https://github.com/hsaturn/TinyMqtt/releases)
|
||||||
[](https://github.com/hsaturn/TinyMqtt/actions/workflows/aunit.yml)
|
[](https://github.com/hsaturn/TinyMqtt/actions/workflows/aunit.yml)
|
||||||

|
[](https://github.com/hsaturn/TinyMqtt/issues)
|
||||||

|
[](https://www.espressif.com/en/products/socs/esp8266)
|
||||||

|
[](https://www.espressif.com/en/products/socs/esp32)
|
||||||

|
[](https://www.gnu.org/licenses/gpl-3.0.fr.html)
|
||||||
|
[](https://docs.oasis-open.org/mqtt/mqtt/v3.1.1/errata01/os/mqtt-v3.1.1-errata01-os-complete.html#_Toc442180822)
|
||||||
|
|
||||||
ESP 8266 is a small, fast and capable Mqtt Broker and Client
|
TinyMqtt is a small, fast and capable Mqtt Broker and Client for Esp8266 / Esp32 / Esp WROOM
|
||||||
|
|
||||||
## Features
|
## Features
|
||||||
|
|
||||||
- Very (very !!) fast broker I saw it re-sent 1000 topics per second for two
|
- Very (very !!) fast broker I saw it re-sent 1000 topics per second for two
|
||||||
clients that had subscribed (payload ~15 bytes). No topic lost.
|
clients that had subscribed (payload ~15 bytes ESP8266). No topic lost.
|
||||||
The max I've seen was 2k msg/s (1 client 1 subscription)
|
The max I've seen was 2k msg/s (1 client 1 subscription)
|
||||||
- Act as as a mqtt broker and/or a mqtt client
|
- Act as as a mqtt broker and/or a mqtt client
|
||||||
- Mqtt 3.1.1 / Qos 0 supported
|
- Mqtt 3.1.1 / Qos 0 supported
|
||||||
|
|||||||
@@ -1,6 +1,8 @@
|
|||||||
#include <TinyMqtt.h> // https://github.com/hsaturn/TinyMqtt
|
#include <TinyMqtt.h> // https://github.com/hsaturn/TinyMqtt
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* Local broker that accept connections and two local clients
|
||||||
|
*
|
||||||
*
|
*
|
||||||
* +-----------------------------+
|
* +-----------------------------+
|
||||||
* | ESP |
|
* | ESP |
|
||||||
@@ -9,11 +11,12 @@
|
|||||||
* | | +--------+ |
|
* | | +--------+ |
|
||||||
* | | ^ |
|
* | | ^ |
|
||||||
* | | | |
|
* | | | |
|
||||||
* | v v |
|
* | | | | -----
|
||||||
* | +----------+ +----------+ |
|
* | v v | ---
|
||||||
* | | internal | | internal | |
|
* | +----------+ +----------+ | -
|
||||||
* | | client | | client | |
|
* | | internal | | internal | +-------* Wifi
|
||||||
* | +----------+ +----------+ |
|
* | | client | | client | |
|
||||||
|
* | +----------+ +----------+ |
|
||||||
* | |
|
* | |
|
||||||
* +-----------------------------+
|
* +-----------------------------+
|
||||||
*
|
*
|
||||||
@@ -28,7 +31,8 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <my_credentials.h>
|
const char *ssid = "";
|
||||||
|
const char *password = "";
|
||||||
|
|
||||||
std::string topic="sensor/temperature";
|
std::string topic="sensor/temperature";
|
||||||
|
|
||||||
@@ -37,11 +41,11 @@ MqttBroker broker(1883);
|
|||||||
MqttClient mqtt_a(&broker);
|
MqttClient mqtt_a(&broker);
|
||||||
MqttClient mqtt_b(&broker);
|
MqttClient mqtt_b(&broker);
|
||||||
|
|
||||||
void onPublishA(const MqttClient* source, const Topic& topic, const char* payload, size_t length)
|
void onPublishA(const MqttClient* /* source */, const Topic& topic, const char* payload, size_t /* length */)
|
||||||
{ Serial << endl << "---------> A Received " << topic.c_str() << endl; }
|
{ Serial << "--> client A received " << topic.c_str() << ", " << payload << endl; }
|
||||||
|
|
||||||
void onPublishB(const MqttClient* source, const Topic& topic, const char* payload, size_t length)
|
void onPublishB(const MqttClient* /* source */, const Topic& topic, const char* payload, size_t /* length */)
|
||||||
{ Serial << endl << "---------> B Received " << topic.c_str() << endl; }
|
{ Serial << "--> client B Received " << topic.c_str() << ", " << payload << endl; }
|
||||||
|
|
||||||
void setup()
|
void setup()
|
||||||
{
|
{
|
||||||
@@ -49,6 +53,9 @@ void setup()
|
|||||||
delay(500);
|
delay(500);
|
||||||
Serial << "Clients with wifi " << endl;
|
Serial << "Clients with wifi " << endl;
|
||||||
|
|
||||||
|
if (strlen(ssid)==0)
|
||||||
|
Serial << "****** PLEASE EDIT THE EXAMPLE AND MODIFY ssid/password *************" << endl;
|
||||||
|
|
||||||
WiFi.mode(WIFI_STA);
|
WiFi.mode(WIFI_STA);
|
||||||
WiFi.begin(ssid, password);
|
WiFi.begin(ssid, password);
|
||||||
|
|
||||||
@@ -73,14 +80,14 @@ void loop()
|
|||||||
mqtt_b.loop();
|
mqtt_b.loop();
|
||||||
|
|
||||||
// ============= client A publish ================
|
// ============= client A publish ================
|
||||||
static const int intervalA = 5000; // publishes every 5s
|
static const int intervalA = 5000; // publishes every 5s (please avoid usage of delay())
|
||||||
static uint32_t timerA = millis() + intervalA;
|
static uint32_t timerA = millis() + intervalA;
|
||||||
|
|
||||||
if (millis() > timerA)
|
if (millis() > timerA)
|
||||||
{
|
{
|
||||||
Serial << "A is publishing " << topic.c_str() << endl;
|
Serial << "A is publishing " << topic.c_str() << endl;
|
||||||
timerA += intervalA;
|
timerA += intervalA;
|
||||||
mqtt_a.publish(topic);
|
mqtt_a.publish(topic, " sent by A");
|
||||||
}
|
}
|
||||||
|
|
||||||
// ============= client B publish ================
|
// ============= client B publish ================
|
||||||
@@ -89,8 +96,9 @@ void loop()
|
|||||||
|
|
||||||
if (millis() > timerB)
|
if (millis() > timerB)
|
||||||
{
|
{
|
||||||
|
static int temperature;
|
||||||
Serial << "B is publishing " << topic.c_str() << endl;
|
Serial << "B is publishing " << topic.c_str() << endl;
|
||||||
timerB += intervalB;
|
timerB += intervalB;
|
||||||
mqtt_b.publish(topic, std::string(String(15+millis()%10).c_str()));
|
mqtt_b.publish(topic, " sent by B: "+std::string(String(16+temperature++%6).c_str()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,12 +1,30 @@
|
|||||||
#include <TinyMqtt.h> // https://github.com/hsaturn/TinyMqtt
|
#include <TinyMqtt.h> // https://github.com/hsaturn/TinyMqtt
|
||||||
|
|
||||||
/** TinyMQTT allows a disconnected mode:
|
/** TinyMQTT allows a disconnected mode:
|
||||||
*
|
*
|
||||||
* In this example, local clients A and B are talking together, no need to be connected.
|
* +-----------------------------+
|
||||||
* A single ESP can use this to be able to comunicate with itself with the power
|
* | ESP |
|
||||||
* of MQTT, and once connected still continue to work with others.
|
* | +--------+ |
|
||||||
*
|
* | +-------->| broker | |
|
||||||
*/
|
* | | +--------+ |
|
||||||
|
* | | ^ |
|
||||||
|
* | | | |
|
||||||
|
* | v v |
|
||||||
|
* | +----------+ +----------+ |
|
||||||
|
* | | internal | | internal | |
|
||||||
|
* | | client | | client | |
|
||||||
|
* | +----------+ +----------+ |
|
||||||
|
* | |
|
||||||
|
* +-----------------------------+
|
||||||
|
*
|
||||||
|
* In this example, local clients A and B are talking together, no need to be connected.
|
||||||
|
*
|
||||||
|
* A single ESP can use this to be able to comunicate with itself with the power
|
||||||
|
* of MQTT, and once connected still continue to work with others.
|
||||||
|
*
|
||||||
|
* The broker may still be conected if wifi is on.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
std::string topic="sensor/temperature";
|
std::string topic="sensor/temperature";
|
||||||
|
|
||||||
@@ -14,11 +32,11 @@ MqttBroker broker(1883);
|
|||||||
MqttClient mqtt_a(&broker);
|
MqttClient mqtt_a(&broker);
|
||||||
MqttClient mqtt_b(&broker);
|
MqttClient mqtt_b(&broker);
|
||||||
|
|
||||||
void onPublishA(const MqttClient* srce, const Topic& topic, const char* payload, size_t length)
|
void onPublishA(const MqttClient* /* srce */, const Topic& topic, const char* payload, size_t /* length */)
|
||||||
{ Serial << "--> A Received " << topic.c_str() << endl; }
|
{ Serial << "--> Client A received msg on topic " << topic.c_str() << ", " << payload << endl; }
|
||||||
|
|
||||||
void onPublishB(const MqttClient* srce, const Topic& topic, const char* payload, size_t length)
|
void onPublishB(const MqttClient* /* srce */, const Topic& topic, const char* payload, size_t /* length */)
|
||||||
{ Serial << "--> B Received " << topic.c_str() << endl; }
|
{ Serial << "--> Client B received msg on topic " << topic.c_str() << ", " << payload << endl; }
|
||||||
|
|
||||||
void setup()
|
void setup()
|
||||||
{
|
{
|
||||||
@@ -35,7 +53,7 @@ void setup()
|
|||||||
|
|
||||||
void loop()
|
void loop()
|
||||||
{
|
{
|
||||||
broker.loop();
|
broker.loop(); // Don't forget to call loop() for all brokers and clients
|
||||||
mqtt_a.loop();
|
mqtt_a.loop();
|
||||||
mqtt_b.loop();
|
mqtt_b.loop();
|
||||||
|
|
||||||
@@ -47,7 +65,7 @@ void loop()
|
|||||||
{
|
{
|
||||||
Serial << "A is publishing " << topic.c_str() << endl;
|
Serial << "A is publishing " << topic.c_str() << endl;
|
||||||
timerA += intervalA;
|
timerA += intervalA;
|
||||||
mqtt_a.publish(topic);
|
mqtt_a.publish(topic, "sent by A");
|
||||||
}
|
}
|
||||||
|
|
||||||
// ============= client B publish ================
|
// ============= client B publish ================
|
||||||
@@ -58,6 +76,6 @@ void loop()
|
|||||||
{
|
{
|
||||||
Serial << "B is publishing " << topic.c_str() << endl;
|
Serial << "B is publishing " << topic.c_str() << endl;
|
||||||
timerB += intervalB;
|
timerB += intervalB;
|
||||||
mqtt_b.publish(topic);
|
mqtt_b.publish(topic, "sent by B");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,14 +1,33 @@
|
|||||||
#include "TinyMqtt.h" // https://github.com/hsaturn/TinyMqtt
|
#include "TinyMqtt.h" // https://github.com/hsaturn/TinyMqtt
|
||||||
|
|
||||||
#include <my_credentials.h>
|
|
||||||
|
|
||||||
#define PORT 1883
|
#define PORT 1883
|
||||||
MqttBroker broker(PORT);
|
MqttBroker broker(PORT);
|
||||||
|
|
||||||
|
/** Basic Mqtt Broker
|
||||||
|
*
|
||||||
|
* +-----------------------------+
|
||||||
|
* | ESP |
|
||||||
|
* | +--------+ |
|
||||||
|
* | | broker | | 1883 <--- External client/s
|
||||||
|
* | +--------+ |
|
||||||
|
* | |
|
||||||
|
* +-----------------------------+
|
||||||
|
*
|
||||||
|
* Your ESP will become a MqttBroker.
|
||||||
|
* You can test it with any client such as mqtt-spy for example
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
const char* ssid = "";
|
||||||
|
const char* password = "";
|
||||||
|
|
||||||
void setup()
|
void setup()
|
||||||
{
|
{
|
||||||
Serial.begin(115200);
|
Serial.begin(115200);
|
||||||
|
|
||||||
|
if (strlen(ssid)==0)
|
||||||
|
Serial << "****** PLEASE MODIFY ssid/password *************" << endl;
|
||||||
|
|
||||||
WiFi.mode(WIFI_STA);
|
WiFi.mode(WIFI_STA);
|
||||||
WiFi.begin(ssid, password);
|
WiFi.begin(ssid, password);
|
||||||
|
|
||||||
|
|||||||
@@ -1,11 +1,25 @@
|
|||||||
#include "TinyMqtt.h" // https://github.com/hsaturn/TinyMqtt
|
#include "TinyMqtt.h" // https://github.com/hsaturn/TinyMqtt
|
||||||
|
|
||||||
/** Simple Client
|
/** Simple Client (The simplest configuration)
|
||||||
*
|
*
|
||||||
* This is the simplest Mqtt client configuration
|
*
|
||||||
*
|
* +--------+
|
||||||
* 1 - edit my_credentials.h to setup wifi essid/password
|
* +------>| broker |<--- < Other client
|
||||||
|
* | +--------+
|
||||||
|
* |
|
||||||
|
* +-----------------+
|
||||||
|
* | ESP | |
|
||||||
|
* | +----------+ |
|
||||||
|
* | | internal | |
|
||||||
|
* | | client | |
|
||||||
|
* | +----------+ |
|
||||||
|
* | |
|
||||||
|
* +-----------------+
|
||||||
|
*
|
||||||
|
* 1 - change the ssid/password
|
||||||
* 2 - change BROKER values (or keep emqx.io test broker)
|
* 2 - change BROKER values (or keep emqx.io test broker)
|
||||||
|
* 3 - you can use mqtt-spy to connect to the same broker and
|
||||||
|
* see the sensor/temperature updated by the client.
|
||||||
*
|
*
|
||||||
* pro - small memory footprint (both ram and flash)
|
* pro - small memory footprint (both ram and flash)
|
||||||
* - very simple to setup and use
|
* - very simple to setup and use
|
||||||
@@ -18,7 +32,8 @@
|
|||||||
const char* BROKER = "broker.emqx.io";
|
const char* BROKER = "broker.emqx.io";
|
||||||
const uint16_t BROKER_PORT = 1883;
|
const uint16_t BROKER_PORT = 1883;
|
||||||
|
|
||||||
#include <my_credentials.h>
|
const char* ssid = "";
|
||||||
|
const char* password = "";
|
||||||
|
|
||||||
static float temp=19;
|
static float temp=19;
|
||||||
static MqttClient client;
|
static MqttClient client;
|
||||||
@@ -27,7 +42,10 @@ void setup()
|
|||||||
{
|
{
|
||||||
Serial.begin(115200);
|
Serial.begin(115200);
|
||||||
delay(500);
|
delay(500);
|
||||||
|
|
||||||
Serial << "Simple clients with wifi " << endl;
|
Serial << "Simple clients with wifi " << endl;
|
||||||
|
if (strlen(ssid)==0)
|
||||||
|
Serial << "****** PLEASE MODIFY ssid/password *************" << endl;
|
||||||
|
|
||||||
WiFi.mode(WIFI_STA);
|
WiFi.mode(WIFI_STA);
|
||||||
WiFi.begin(ssid, password);
|
WiFi.begin(ssid, password);
|
||||||
@@ -42,15 +60,28 @@ void setup()
|
|||||||
|
|
||||||
void loop()
|
void loop()
|
||||||
{
|
{
|
||||||
client.loop();
|
client.loop(); // Don't forget to call loop() for each broker and client
|
||||||
|
|
||||||
delay(1000);
|
// delay(1000); please avoid usage of delay (see below how this done using next_send and millis())
|
||||||
|
static auto next_send = millis();
|
||||||
|
|
||||||
|
if (millis() > next_send)
|
||||||
|
{
|
||||||
|
next_send += 1000;
|
||||||
|
|
||||||
auto rnd=random(100);
|
if (not client.connected())
|
||||||
|
{
|
||||||
|
Serial << millis() << ": Not connected to broker" << endl;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (rnd > 66) temp += 0.1;
|
auto rnd=random(100);
|
||||||
else if (rnd < 33) temp -= 0.1;
|
|
||||||
|
|
||||||
client.publish("sensor/temperature", String(temp));
|
if (rnd > 66) temp += 0.1;
|
||||||
|
else if (rnd < 33) temp -= 0.1;
|
||||||
|
|
||||||
|
Serial << "--> Publishing a new sensor/temperature value: " << temp << endl;
|
||||||
|
|
||||||
|
client.publish("sensor/temperature", String(temp));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,25 +1,32 @@
|
|||||||
#include <TinyMqtt.h> // https://github.com/hsaturn/TinyMqtt
|
#include <TinyMqtt.h> // https://github.com/hsaturn/TinyMqtt
|
||||||
#include <MqttStreaming.h>
|
#include <MqttStreaming.h>
|
||||||
#include <ESP8266mDNS.h>
|
#if defined(ESP8266)
|
||||||
|
#include <ESP8266mDNS.h>
|
||||||
|
#elif defined(ESP32)
|
||||||
|
#include <WiFi.h>
|
||||||
|
#include <ESPmDNS.h>
|
||||||
|
#else
|
||||||
|
#error Unsupported platform
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
#include <map>
|
#include <map>
|
||||||
|
|
||||||
/**
|
bool echo_on = true;
|
||||||
* Console allowing to make any kind of test.
|
|
||||||
|
/** Very complex example
|
||||||
|
* Console allowing to make any kind of test,
|
||||||
|
* even some stress tests.
|
||||||
*
|
*
|
||||||
* pros - Reduces internal latency (when publish is received by the same ESP)
|
* Upload the sketch, the use the terminal.
|
||||||
* - Reduces wifi traffic
|
* Press H for mini help.
|
||||||
* - No need to have an external broker
|
|
||||||
* - can still report to a 'main' broker (TODO see documentation that have to be written)
|
|
||||||
* - accepts external clients
|
|
||||||
*
|
|
||||||
* cons - Takes more memory
|
|
||||||
* - a bit hard to understand
|
|
||||||
*
|
*
|
||||||
|
* tested with mqtt-spy-0.5.4
|
||||||
|
* TODO examples of scripts
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <my_credentials.h>
|
const char* ssid = "";
|
||||||
|
const char* password = "";
|
||||||
|
|
||||||
std::string topic="sensor/temperature";
|
std::string topic="sensor/temperature";
|
||||||
|
|
||||||
@@ -44,17 +51,32 @@ void setup()
|
|||||||
WiFi.persistent(false); // https://github.com/esp8266/Arduino/issues/1054
|
WiFi.persistent(false); // https://github.com/esp8266/Arduino/issues/1054
|
||||||
Serial.begin(115200);
|
Serial.begin(115200);
|
||||||
delay(500);
|
delay(500);
|
||||||
Serial << endl << endl << endl
|
|
||||||
<< "Connecting to '" << ssid << "' ";
|
|
||||||
|
|
||||||
|
Serial << endl << endl;
|
||||||
|
Serial << "***************************************************************" << endl;
|
||||||
|
Serial << "* Welcome to the TinyMqtt console" << endl;
|
||||||
|
Serial << endl;
|
||||||
|
Serial << "* The console allows to test all features of the libraries." << endl;
|
||||||
|
Serial << endl;
|
||||||
|
if (strlen(ssid)==0)
|
||||||
|
Serial << "* WARNING: You may want to modify ssid/password in order" << endl
|
||||||
|
<< " to reflect your Wifi configuration." << endl;
|
||||||
|
Serial << endl;
|
||||||
|
Serial << "* Enter help to view the list of commands." << endl;
|
||||||
|
Serial << "***************************************************************" << endl;
|
||||||
|
Serial << endl;
|
||||||
|
|
||||||
|
Serial << "Connecting to '" << ssid << "' ";
|
||||||
|
|
||||||
|
WiFi.mode(WIFI_STA);
|
||||||
|
WiFi.begin(ssid, password);
|
||||||
WiFi.mode(WIFI_STA);
|
WiFi.mode(WIFI_STA);
|
||||||
WiFi.begin(ssid, password);
|
WiFi.begin(ssid, password);
|
||||||
|
|
||||||
while (WiFi.status() != WL_CONNECTED)
|
while (WiFi.status() != WL_CONNECTED)
|
||||||
{ Serial << '-'; delay(500); }
|
{ Serial << '-'; delay(500); }
|
||||||
|
|
||||||
Serial << "Connected to " << ssid << "IP address: " << WiFi.localIP() << endl;
|
Serial << endl << "Connected to " << ssid << "IP address: " << WiFi.localIP() << endl;
|
||||||
Serial << "Type help for more..." << endl;
|
|
||||||
|
|
||||||
const char* name="tinytest";
|
const char* name="tinytest";
|
||||||
Serial << "Starting MDNS, name= " << name;
|
Serial << "Starting MDNS, name= " << name;
|
||||||
@@ -69,27 +91,67 @@ void setup()
|
|||||||
brokers["broker"] = broker;
|
brokers["broker"] = broker;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::string getword(std::string& str, const char* if_empty=nullptr, char sep=' ');
|
||||||
|
|
||||||
int getint(std::string& str, const int if_empty=0)
|
int getint(std::string& str, const int if_empty=0)
|
||||||
{
|
{
|
||||||
std::string sword;
|
std::string str2=str;
|
||||||
while(str.length() && str[0]>='0' && str[0]<='9')
|
std::string sword = getword(str);
|
||||||
|
if (sword[0] and isdigit(sword[0]))
|
||||||
{
|
{
|
||||||
sword += str[0]; str.erase(0,1);
|
int ret=atoi(sword.c_str());
|
||||||
|
while(isdigit(sword[0]) or sword[0]==' ') sword.erase(0,1);
|
||||||
|
if (sword.length()) str = sword+' '+str;
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
while(str[0]==' ') str.erase(0,1);
|
str=str2;
|
||||||
if (if_empty and sword.length()==0) return if_empty;
|
return if_empty;
|
||||||
return atoi(sword.c_str());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string getword(std::string& str, const char* if_empty=nullptr, char sep=' ')
|
std::string getword(std::string& str, const char* if_empty/*=nullptr*/, char sep/*=' '*/)
|
||||||
{
|
{
|
||||||
|
char quote=(str[0]=='"' or str[0]=='\'' ? str[0] : 0);
|
||||||
|
if (quote) str.erase(0,1);
|
||||||
std::string sword;
|
std::string sword;
|
||||||
while(str.length() && str[0]!=sep)
|
while(str.length() and (str[0]!=sep or quote))
|
||||||
{
|
{
|
||||||
sword += str[0]; str.erase(0,1);
|
if (str[0]==quote)
|
||||||
|
{
|
||||||
|
str.erase(0,1);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
sword += str[0];
|
||||||
|
str.erase(0,1);
|
||||||
}
|
}
|
||||||
while(str[0]==sep) str.erase(0,1);
|
while(str[0]==sep) str.erase(0,1);
|
||||||
if (if_empty and sword.length()==0) return if_empty;
|
if (if_empty and sword.length()==0) return if_empty;
|
||||||
|
if (quote==false and sword.length()>=4 and sword.substr(0,3)=="rnd")
|
||||||
|
{
|
||||||
|
sword.erase(0,3);
|
||||||
|
if (sword[0]=='(')
|
||||||
|
{
|
||||||
|
int to = 100;
|
||||||
|
sword.erase(0,1);
|
||||||
|
int from=getint(sword);
|
||||||
|
if (sword[0]==',')
|
||||||
|
{
|
||||||
|
sword.erase(0,1);
|
||||||
|
to = getint(sword);
|
||||||
|
if (sword[0]!=')') Serial << "Missing ')'" << endl;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
to=from;
|
||||||
|
from=0;
|
||||||
|
}
|
||||||
|
return String(random(from,to)).c_str();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Serial << "Missing '('" << endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while(str[0]==' ') str.erase(0,1);
|
||||||
return sword;
|
return sword;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -117,7 +179,7 @@ std::string getip(std::string& str, const char* if_empty=nullptr, char sep=' ')
|
|||||||
return addr;
|
return addr;
|
||||||
}
|
}
|
||||||
IPAddress local=WiFi.localIP();
|
IPAddress local=WiFi.localIP();
|
||||||
addr="";
|
addr.clear();
|
||||||
while(build.size()!=4)
|
while(build.size()!=4)
|
||||||
{
|
{
|
||||||
std::stringstream b;
|
std::stringstream b;
|
||||||
@@ -138,10 +200,10 @@ std::set<std::string> commands = {
|
|||||||
"auto", "broker", "blink", "client", "connect",
|
"auto", "broker", "blink", "client", "connect",
|
||||||
"create", "delete", "help", "interval",
|
"create", "delete", "help", "interval",
|
||||||
"ls", "ip", "off", "on", "set",
|
"ls", "ip", "off", "on", "set",
|
||||||
"publish", "reset", "subscribe", "unsubscribe", "view", "every"
|
"publish", "reset", "subscribe", "unsubscribe", "view", "echo", "every"
|
||||||
};
|
};
|
||||||
|
|
||||||
void getCommand(std::string& search)
|
void convertToCommand(std::string& search)
|
||||||
{
|
{
|
||||||
while(search[0]==' ') search.erase(0,1);
|
while(search[0]==' ') search.erase(0,1);
|
||||||
if (search.length()==0) return;
|
if (search.length()==0) return;
|
||||||
@@ -161,7 +223,7 @@ void getCommand(std::string& search)
|
|||||||
else if (count>1)
|
else if (count>1)
|
||||||
{
|
{
|
||||||
Serial << "Ambiguous command: " << matches << endl;
|
Serial << "Ambiguous command: " << matches << endl;
|
||||||
search="";
|
search.clear();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -177,7 +239,7 @@ void replace(const char* d, std::string& str, std::string srch, std::string to)
|
|||||||
{
|
{
|
||||||
str.erase(pos, srch.length());
|
str.erase(pos, srch.length());
|
||||||
str.insert(pos, to);
|
str.insert(pos, to);
|
||||||
pos += to.length();
|
pos += to.length()-1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -195,6 +257,7 @@ void replaceVars(std::string& cmd)
|
|||||||
}
|
}
|
||||||
cmd.erase(0, cmd.find_first_not_of(" "));
|
cmd.erase(0, cmd.find_first_not_of(" "));
|
||||||
cmd.erase(cmd.find_last_not_of(" ")+1);
|
cmd.erase(cmd.find_last_not_of(" ")+1);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// publish at regular interval
|
// publish at regular interval
|
||||||
@@ -332,9 +395,12 @@ struct Every
|
|||||||
std::string cmd;
|
std::string cmd;
|
||||||
uint32_t ms;
|
uint32_t ms;
|
||||||
uint32_t next;
|
uint32_t next;
|
||||||
|
uint32_t underrun=0;
|
||||||
|
bool active=true;
|
||||||
|
|
||||||
void dump()
|
void dump()
|
||||||
{
|
{
|
||||||
|
Serial << (active ? "enabled " : "disabled ");
|
||||||
auto mill=millis();
|
auto mill=millis();
|
||||||
Serial << ms << "ms [" << cmd << "] next in ";
|
Serial << ms << "ms [" << cmd << "] next in ";
|
||||||
if (mill > next)
|
if (mill > next)
|
||||||
@@ -363,7 +429,6 @@ void eval(std::string& cmd)
|
|||||||
MqttClient* client = nullptr;
|
MqttClient* client = nullptr;
|
||||||
|
|
||||||
// client.function notation
|
// client.function notation
|
||||||
// ("a.fun " becomes "fun a ")
|
|
||||||
if (cmd.find('.') != std::string::npos &&
|
if (cmd.find('.') != std::string::npos &&
|
||||||
cmd.find('.') < cmd.find(' '))
|
cmd.find('.') < cmd.find(' '))
|
||||||
{
|
{
|
||||||
@@ -382,13 +447,13 @@ void eval(std::string& cmd)
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
Serial << "Unknown class (" << s.c_str() << ")" << endl;
|
Serial << "Unknown class (" << s.c_str() << ")" << endl;
|
||||||
cmd="";
|
cmd.clear();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
s = getword(cmd);
|
s = getword(cmd);
|
||||||
if (s.length()) getCommand(s);
|
if (s.length()) convertToCommand(s);
|
||||||
if (s.length()==0)
|
if (s.length()==0)
|
||||||
{}
|
{}
|
||||||
else if (compare(s, "delete"))
|
else if (compare(s, "delete"))
|
||||||
@@ -444,6 +509,11 @@ void eval(std::string& cmd)
|
|||||||
{
|
{
|
||||||
broker->dump();
|
broker->dump();
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Serial << "Unknown broker command (" << s << ")" << endl;
|
||||||
|
s.clear();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (client)
|
else if (client)
|
||||||
{
|
{
|
||||||
@@ -454,9 +524,7 @@ void eval(std::string& cmd)
|
|||||||
}
|
}
|
||||||
else if (compare(s,"publish"))
|
else if (compare(s,"publish"))
|
||||||
{
|
{
|
||||||
while (cmd[0]==' ') cmd.erase(0,1);
|
retval = client->publish(getword(cmd, topic.c_str()), getword(cmd));
|
||||||
retval = client->publish(getword(cmd, topic.c_str()), cmd.c_str(), cmd.length());
|
|
||||||
cmd=""; // remove payload
|
|
||||||
}
|
}
|
||||||
else if (compare(s,"subscribe"))
|
else if (compare(s,"subscribe"))
|
||||||
{
|
{
|
||||||
@@ -470,6 +538,11 @@ void eval(std::string& cmd)
|
|||||||
{
|
{
|
||||||
client->dump();
|
client->dump();
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Serial << "Unknown client command (" << s << ")" << endl;
|
||||||
|
s.clear();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (compare(s, "on"))
|
else if (compare(s, "on"))
|
||||||
{
|
{
|
||||||
@@ -483,21 +556,59 @@ void eval(std::string& cmd)
|
|||||||
pinMode(pin, OUTPUT);
|
pinMode(pin, OUTPUT);
|
||||||
digitalWrite(pin, LOW);
|
digitalWrite(pin, LOW);
|
||||||
}
|
}
|
||||||
|
else if (compare(s, "echo"))
|
||||||
|
{
|
||||||
|
s=getword(cmd);
|
||||||
|
if (s=="on")
|
||||||
|
echo_on = true;
|
||||||
|
else if (s=="off")
|
||||||
|
echo_on = false;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Serial << s << ' ';
|
||||||
|
while(cmd.length())
|
||||||
|
{
|
||||||
|
Serial << getword(cmd) << ' ';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
else if (compare(s, "every"))
|
else if (compare(s, "every"))
|
||||||
{
|
{
|
||||||
uint32_t ms = getint(cmd, 0);
|
uint32_t ms = getint(cmd, 0);
|
||||||
if (ms and cmd.length())
|
if (ms)
|
||||||
{
|
{
|
||||||
Every every;
|
if (cmd.length())
|
||||||
every.ms=ms;
|
{
|
||||||
every.cmd=cmd;
|
Every every;
|
||||||
every.next=millis()+ms;
|
every.ms=ms;
|
||||||
everies.push_back(every);
|
every.cmd=cmd;
|
||||||
every.dump();
|
every.next=millis()+ms;
|
||||||
Serial << endl;
|
everies.push_back(every);
|
||||||
cmd="";
|
every.dump();
|
||||||
|
Serial << endl;
|
||||||
|
cmd.clear();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (ms==0 and compare(cmd, "list"))
|
else if (compare(cmd, "off") or compare(cmd, "on"))
|
||||||
|
{
|
||||||
|
bool active=getword(cmd)=="on";
|
||||||
|
uint8_t ever=getint(cmd, 100);
|
||||||
|
uint8_t count=0;
|
||||||
|
for(auto& every: everies)
|
||||||
|
{
|
||||||
|
if (count==ever or (ever==100))
|
||||||
|
{
|
||||||
|
if (every.active != active)
|
||||||
|
{
|
||||||
|
Serial << "every #" << count << (active ? " on" :" off") << endl;
|
||||||
|
every.active = active;
|
||||||
|
every.underrun = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
count++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (compare(cmd, "list") or cmd.length()==0)
|
||||||
{
|
{
|
||||||
getword(cmd);
|
getword(cmd);
|
||||||
Serial << "List of everies (ms=" << millis() << ")" << endl;
|
Serial << "List of everies (ms=" << millis() << ")" << endl;
|
||||||
@@ -510,11 +621,17 @@ void eval(std::string& cmd)
|
|||||||
count++;
|
count++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (ms==0 and compare(cmd, "remove"))
|
else if (compare(cmd, "remove"))
|
||||||
{
|
{
|
||||||
|
Serial << "Removing..." << endl;
|
||||||
getword(cmd);
|
getword(cmd);
|
||||||
int8_t every=getint(cmd, -1);
|
int8_t every=getint(cmd, -1);
|
||||||
if (every==-1 and compare(cmd, "all"))
|
if (every==-1 and compare(cmd, "last") and everies.size())
|
||||||
|
{
|
||||||
|
getword(cmd);
|
||||||
|
everies.erase(everies.begin()+everies.size()-1);
|
||||||
|
}
|
||||||
|
else if (every==-1 and compare(cmd, "all"))
|
||||||
{
|
{
|
||||||
getword(cmd);
|
getword(cmd);
|
||||||
everies.clear();
|
everies.clear();
|
||||||
@@ -523,7 +640,11 @@ void eval(std::string& cmd)
|
|||||||
{
|
{
|
||||||
everies.erase(everies.begin()+every);
|
everies.erase(everies.begin()+every);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
Serial << "Bad colmmand" << endl;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
Serial << "Bad command" << endl;
|
||||||
}
|
}
|
||||||
else if (compare(s, "blink"))
|
else if (compare(s, "blink"))
|
||||||
{
|
{
|
||||||
@@ -627,14 +748,14 @@ void eval(std::string& cmd)
|
|||||||
Serial << "--< " << clients.size() << " client/s. >--" << endl;
|
Serial << "--< " << clients.size() << " client/s. >--" << endl;
|
||||||
for(auto it: clients)
|
for(auto it: clients)
|
||||||
{
|
{
|
||||||
Serial << " "; it.second->dump();
|
it.second->dump(" ");
|
||||||
}
|
}
|
||||||
|
|
||||||
Serial << "--< " << brokers.size() << " brokers/s. >--" << endl;
|
Serial << "--< " << brokers.size() << " brokers/s. >--" << endl;
|
||||||
for(auto it: brokers)
|
for(auto it: brokers)
|
||||||
{
|
{
|
||||||
Serial << " ==[ Broker: " << it.first.c_str() << " ]== ";
|
Serial << " +-- '" << it.first.c_str() << "' " << it.second->clientsCount() << " client/s."<< endl;
|
||||||
it.second->dump();
|
it.second->dump(" ");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (compare(s, "reset"))
|
else if (compare(s, "reset"))
|
||||||
@@ -663,9 +784,11 @@ void eval(std::string& cmd)
|
|||||||
Serial << " set [name][value]" << endl;
|
Serial << " set [name][value]" << endl;
|
||||||
Serial << " ! repeat last command" << endl;
|
Serial << " ! repeat last command" << endl;
|
||||||
Serial << endl;
|
Serial << endl;
|
||||||
Serial << " every ms [command]; every list; every remove [nr|all]" << endl;
|
Serial << " echo [on|off] or strings" << endl;
|
||||||
|
Serial << " every ms [command]; every list; every remove [nr|all], every (on|off) [#]" << endl;
|
||||||
Serial << " on {output}; off {output}" << endl;
|
Serial << " on {output}; off {output}" << endl;
|
||||||
Serial << " $id : name of the client." << endl;
|
Serial << " $id : name of the client." << endl;
|
||||||
|
Serial << " rnd[(min[,max])] random number." << endl;
|
||||||
Serial << " default topic is '" << topic.c_str() << "'" << endl;
|
Serial << " default topic is '" << topic.c_str() << "'" << endl;
|
||||||
Serial << endl;
|
Serial << endl;
|
||||||
}
|
}
|
||||||
@@ -678,7 +801,7 @@ void eval(std::string& cmd)
|
|||||||
|
|
||||||
if (retval != MqttOk)
|
if (retval != MqttOk)
|
||||||
{
|
{
|
||||||
Serial << "## ERROR " << retval << endl;
|
Serial << "# MQTT ERROR " << retval << endl;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -688,15 +811,23 @@ void loop()
|
|||||||
auto ms=millis();
|
auto ms=millis();
|
||||||
int8_t out=0;
|
int8_t out=0;
|
||||||
int16_t blink_bits = blink;
|
int16_t blink_bits = blink;
|
||||||
|
uint8_t e=0;
|
||||||
|
|
||||||
for(auto& every: everies)
|
for(auto& every: everies)
|
||||||
{
|
{
|
||||||
|
if (not every.active) continue;
|
||||||
if (every.ms && every.cmd.length() && ms > every.next)
|
if (every.ms && every.cmd.length() && ms > every.next)
|
||||||
{
|
{
|
||||||
std::string cmd(every.cmd);
|
std::string cmd(every.cmd);
|
||||||
eval(cmd);
|
eval(cmd);
|
||||||
every.next += every.ms;
|
every.next += every.ms;
|
||||||
|
if (ms > every.next and ms > every.underrun)
|
||||||
|
{
|
||||||
|
Serial << "Underrun every #" << e << ", " << (ms - every.next) << "ms late" << endl;
|
||||||
|
every.underrun = ms+5000;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
e++;
|
||||||
}
|
}
|
||||||
|
|
||||||
while(blink_bits)
|
while(blink_bits)
|
||||||
@@ -720,7 +851,9 @@ void loop()
|
|||||||
}
|
}
|
||||||
|
|
||||||
static long count;
|
static long count;
|
||||||
|
#if defined(ESP9266)
|
||||||
MDNS.update();
|
MDNS.update();
|
||||||
|
#endif
|
||||||
|
|
||||||
if (MqttClient::counter != count)
|
if (MqttClient::counter != count)
|
||||||
{
|
{
|
||||||
@@ -739,8 +872,10 @@ void loop()
|
|||||||
{
|
{
|
||||||
static std::string cmd;
|
static std::string cmd;
|
||||||
char c=Serial.read();
|
char c=Serial.read();
|
||||||
|
if (echo_on)
|
||||||
|
Serial << c;
|
||||||
|
|
||||||
if (c==10 or c==14)
|
if (c==10 or c==13)
|
||||||
{
|
{
|
||||||
Serial << "----------------[ " << cmd.c_str() << " ]--------------" << endl;
|
Serial << "----------------[ " << cmd.c_str() << " ]--------------" << endl;
|
||||||
static std::string last_cmd;
|
static std::string last_cmd;
|
||||||
|
|||||||
@@ -1,12 +1,12 @@
|
|||||||
{
|
{
|
||||||
"name": "TinyMqtt",
|
"name": "TinyMqtt",
|
||||||
"keywords": "ethernet, mqtt, m2m, iot",
|
"keywords": "ethernet, mqtt, m2m, iot",
|
||||||
"description": "MQTT is a lightweight messaging protocol ideal for small devices. This library allows to send and receive MQTT messages. It does support MQTT 3.1.1 with QOS=0.",
|
"description": "MQTT is a lightweight messaging protocol ideal for small devices. This library allows to send and receive and host a broker for MQTT. It does support MQTT 3.1.1 with QOS=0 on ESP8266 and ESP32 WROOM platfrms.",
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/hsaturn/TinyMqtt.git"
|
"url": "https://github.com/hsaturn/TinyMqtt.git"
|
||||||
},
|
},
|
||||||
"version": "0.7.3",
|
"version": "0.7.6",
|
||||||
"exclude": "",
|
"exclude": "",
|
||||||
"examples": "examples/*/*.ino",
|
"examples": "examples/*/*.ino",
|
||||||
"frameworks": "arduino",
|
"frameworks": "arduino",
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
name=TinyMqtt
|
name=TinyMqtt
|
||||||
version=0.7.3
|
version=0.7.6
|
||||||
author=Francois BIOT, HSaturn, <hsaturn@gmail.com>
|
author=Francois BIOT, HSaturn, <hsaturn@gmail.com>
|
||||||
maintainer=Francois BIOT, HSaturn, <hsaturn@gmail.com>
|
maintainer=Francois BIOT, HSaturn, <hsaturn@gmail.com>
|
||||||
sentence=A tiny broker and client library for MQTT messaging.
|
sentence=A tiny broker and client library for MQTT messaging.
|
||||||
paragraph=MQTT is a lightweight messaging protocol ideal for small devices. This library allows to send and receive MQTT messages and to host a broker in your ESP. It does support MQTT 3.1.1 with QoS=0.
|
paragraph=MQTT is a lightweight messaging protocol ideal for small devices. This library allows to send and receive MQTT messages and to host a broker in your ESP 8266 and 32 WROOM. It does support MQTT 3.1.1 with QoS=0.
|
||||||
category=Communication
|
category=Communication
|
||||||
url=https://github.com/hsaturn/TinyMqtt
|
url=https://github.com/hsaturn/TinyMqtt
|
||||||
architectures=*
|
architectures=*
|
||||||
|
|||||||
@@ -665,7 +665,7 @@ void MqttMessage::incoming(char in_byte)
|
|||||||
state = Length;
|
state = Length;
|
||||||
break;
|
break;
|
||||||
case Length:
|
case Length:
|
||||||
size = (size<<7) + (in_byte & 0x3F);
|
size = (size<<7) + (in_byte & 0x7F);
|
||||||
if (size > MaxBufferLength)
|
if (size > MaxBufferLength)
|
||||||
{
|
{
|
||||||
state = Error;
|
state = Error;
|
||||||
|
|||||||
@@ -10,13 +10,10 @@
|
|||||||
#include <ESP8266WiFi.h>
|
#include <ESP8266WiFi.h>
|
||||||
#endif
|
#endif
|
||||||
#elif defined(ESP32)
|
#elif defined(ESP32)
|
||||||
|
#include <WiFi.h>
|
||||||
#ifdef TCP_ASYNC
|
#ifdef TCP_ASYNC
|
||||||
#include <AsyncTCP.h> // https://github.com/me-no-dev/AsyncTCP
|
#include <AsyncTCP.h> // https://github.com/me-no-dev/AsyncTCP
|
||||||
#else
|
#endif
|
||||||
#include <WiFi.h>
|
|
||||||
#endif
|
|
||||||
#else
|
|
||||||
#error "Unsupported platform"
|
|
||||||
#endif
|
#endif
|
||||||
#ifdef EPOXY_DUINO
|
#ifdef EPOXY_DUINO
|
||||||
#define dbg_ptr uint64_t
|
#define dbg_ptr uint64_t
|
||||||
@@ -179,6 +176,7 @@ class MqttClient
|
|||||||
|
|
||||||
// Publish from client to the world
|
// Publish from client to the world
|
||||||
MqttError publish(const Topic&, const char* payload, size_t pay_length);
|
MqttError publish(const Topic&, const char* payload, size_t pay_length);
|
||||||
|
MqttError publish(const Topic& t, const char* payload) { return publish(t, payload, strlen(payload)); }
|
||||||
MqttError publish(const Topic& t, const String& s) { return publish(t, s.c_str(), s.length()); }
|
MqttError publish(const Topic& t, const String& s) { return publish(t, s.c_str(), s.length()); }
|
||||||
MqttError publish(const Topic& t, const std::string& s) { return publish(t,s.c_str(),s.length());}
|
MqttError publish(const Topic& t, const std::string& s) { return publish(t,s.c_str(),s.length());}
|
||||||
MqttError publish(const Topic& t) { return publish(t, nullptr, 0);};
|
MqttError publish(const Topic& t) { return publish(t, nullptr, 0);};
|
||||||
@@ -191,23 +189,25 @@ class MqttClient
|
|||||||
// TODO seems to be useless
|
// TODO seems to be useless
|
||||||
bool isLocal() const { return client == nullptr; }
|
bool isLocal() const { return client == nullptr; }
|
||||||
|
|
||||||
void dump()
|
void dump(std::string indent="")
|
||||||
{
|
{
|
||||||
uint32_t ms=millis();
|
uint32_t ms=millis();
|
||||||
Serial << "MqttClient (" << clientId.c_str() << ") " << (connected() ? " ON " : " OFF");
|
Serial << indent << "+-- " << '\'' << clientId.c_str() << "' " << (connected() ? " ON " : " OFF");
|
||||||
Serial << ", alive=" << alive << '/' << ms << ", ka=" << keep_alive;
|
Serial << ", alive=" << alive << '/' << ms << ", ka=" << keep_alive << ' ';
|
||||||
Serial << (client && client->connected() ? "" : "dis") << "connected";
|
Serial << (client && client->connected() ? "" : "dis") << "connected";
|
||||||
message.hexdump("entrant msg");
|
if (subscriptions.size())
|
||||||
bool c=false;
|
|
||||||
Serial << " [";
|
|
||||||
for(auto s: subscriptions)
|
|
||||||
{
|
{
|
||||||
Serial << (c?", ": "")<< s.str().c_str();
|
bool c = false;
|
||||||
c=true;
|
Serial << " [";
|
||||||
|
for(auto s: subscriptions)
|
||||||
|
{
|
||||||
|
if (c) Serial << ", ";
|
||||||
|
Serial << s.str().c_str();
|
||||||
|
c=true;
|
||||||
|
}
|
||||||
|
Serial << ']';
|
||||||
}
|
}
|
||||||
|
Serial << endl;
|
||||||
|
|
||||||
Serial << "]" << endl;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Count the number of messages that have been sent **/
|
/** Count the number of messages that have been sent **/
|
||||||
@@ -267,14 +267,10 @@ class MqttBroker
|
|||||||
|
|
||||||
size_t clientsCount() const { return clients.size(); }
|
size_t clientsCount() const { return clients.size(); }
|
||||||
|
|
||||||
void dump()
|
void dump(std::string indent="")
|
||||||
{
|
{
|
||||||
Serial << clients.size() << " client/s" << endl;
|
|
||||||
for(auto client: clients)
|
for(auto client: clients)
|
||||||
{
|
client->dump(indent);
|
||||||
Serial << " ";
|
|
||||||
client->dump();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
# Makefile to compile and run Arduino programs natively on Linux or MacOS.
|
# Makefile to compile and run Arduino programs natively on Linux or MacOS.
|
||||||
|
|
||||||
APP_NAME := local-tests
|
APP_NAME := local-tests
|
||||||
ARDUINO_LIBS := AUnit AceCommon AceTime TinyMqtt EspMock
|
ARDUINO_LIBS := AUnit AceCommon AceTime TinyMqtt EspMock ESP8266WiFi ESPAsyncTCP
|
||||||
ESP_LIBS = ESP8266WiFi ESPAsyncTCP
|
ARDUINO_LIB_DIRS := ../../../EspMock/libraries
|
||||||
include ../../../EspMock/EspMock.mk
|
EPOXY_CORE := EPOXY_CORE_ESP8266
|
||||||
|
include ../../../EpoxyDuino/EpoxyDuino.mk
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
# Makefile to compile and run Arduino programs natively on Linux or MacOS.
|
# Makefile to compile and run Arduino programs natively on Linux or MacOS.
|
||||||
|
|
||||||
APP_NAME := nowifi-tests
|
APP_NAME := nowifi-tests
|
||||||
ARDUINO_LIBS := AUnit AceCommon AceTime TinyMqtt EspMock
|
ARDUINO_LIBS := AUnit AceCommon AceTime TinyMqtt EspMock ESP8266WiFi ESPAsyncTCP
|
||||||
ESP_LIBS = ESP8266WiFi ESPAsyncTCP
|
ARDUINO_LIB_DIRS := ../../../EspMock/libraries
|
||||||
include ../../../EspMock/EspMock.mk
|
EPOXY_CORE := EPOXY_CORE_ESP8266
|
||||||
|
include ../../../EpoxyDuino/EpoxyDuino.mk
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
# Makefile to compile and run Arduino programs natively on Linux or MacOS.
|
# Makefile to compile and run Arduino programs natively on Linux or MacOS.
|
||||||
|
|
||||||
APP_NAME := string-indexer-tests
|
APP_NAME := string-indexer-tests
|
||||||
ARDUINO_LIBS := AUnit AceCommon AceTime TinyMqtt EspMock
|
ARDUINO_LIBS := AUnit AceCommon AceTime TinyMqtt EspMock ESP8266WiFi ESPAsync
|
||||||
ESP_LIBS = ESP8266WiFi ESPAsyncTCP
|
ARDUINO_LIB_DIRS := ../../../EspMock/libraries
|
||||||
include ../../../EspMock/EspMock.mk
|
EPOXY_CORE := EPOXY_CORE_ESP8266
|
||||||
|
include ../../../EpoxyDuino/EpoxyDuino.mk
|
||||||
|
|||||||
@@ -105,5 +105,5 @@ void setup() {
|
|||||||
void loop() {
|
void loop() {
|
||||||
aunit::TestRunner::run();
|
aunit::TestRunner::run();
|
||||||
|
|
||||||
if (Serial.available()) ESP.reset();
|
// if (Serial.available()) ESP.reset();
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user