18 #ifndef WIPPERSNAPPER_H 19 #define WIPPERSNAPPER_H 27 #include <nanopb/pb_common.h> 28 #include <nanopb/pb_decode.h> 29 #include <nanopb/pb_encode.h> 32 #include <wippersnapper/description/v1/description.pb.h> 33 #include <wippersnapper/signal/v1/signal.pb.h> 36 #include "Adafruit_MQTT.h" 37 #include "Adafruit_SleepyDog.h" 44 #include "provisioning/ConfigJson.h" 47 #define WS_PRINTER Serial 52 #ifdef ARDUINO_ARCH_ESP8266 57 #define WS_DEBUG_PRINT(x) \ 58 { WS_PRINTER.print(F(x)); } 59 #define WS_DEBUG_PRINTLN(x) \ 60 { WS_PRINTER.println(F(x)); } 63 #define WS_DEBUG_PRINT(...) \ 64 { WS_PRINTER.print(__VA_ARGS__); } 65 #define WS_DEBUG_PRINTLN(...) \ 66 { WS_PRINTER.println(__VA_ARGS__); } 70 #define WS_DEBUG_PRINTVAR(...) \ 71 { WS_PRINTER.print(__VA_ARGS__); } 72 #define WS_DEBUG_PRINTLNVAR(...) \ 73 { WS_PRINTER.println(__VA_ARGS__); } 74 #define WS_DEBUG_PRINTHEX(...) \ 75 { WS_PRINTER.print(__VA_ARGS__, HEX); } 78 #define WS_DEBUG_PRINT(...) \ 80 #define WS_DEBUG_PRINTLN(...) \ 82 #define WS_DEBUG_PRINTVAR(...) \ 84 #define WS_DEBUG_PRINTLNVAR(...) \ 86 #define WS_DEBUG_PRINTHEX(...) \ 88 #define WS_DEBUG_HEAP(label) \ 92 #define WS_DELAY_WITH_WDT(timeout) \ 94 unsigned long start = millis(); \ 95 while (millis() - start < timeout) { \ 99 if (millis() < start) { \ 124 #define RETRY_FUNCTION_UNTIL_TIMEOUT(func, result_type, result_var, condition, \ 125 timeout, interval, ...) \ 127 unsigned long startTime = millis(); \ 128 while (millis() - startTime < timeout) { \ 129 result_type result_var = func(__VA_ARGS__); \ 130 if (condition(result_var)) { \ 133 if (startTime > millis()) { \ 134 startTime = millis(); \ 136 WS_DELAY_WITH_WDT(interval); \ 141 #include <nanopb/ws_pb_helpers.h> 149 #ifdef ARDUINO_ARCH_ESP32 157 #include "components/pwm/ws_pwm.h" 161 #if defined(USE_TINYUSB) 162 #include "provisioning/tinyusb/Wippersnapper_FS.h" 165 #if defined(USE_LITTLEFS) 166 #include "provisioning/littlefs/WipperSnapper_LittleFS.h" 173 #define TOPIC_IO_THROTTLE "/throttle" 174 #define TOPIC_IO_ERRORS "/errors" 177 #define TOPIC_WS "/wprsnpr/" 178 #define TOPIC_INFO "/info/" 179 #define TOPIC_SIGNALS "/signals/" 180 #define TOPIC_I2C "/i2c" 181 #define TOPIC_DISPLAY "/display" 182 #define MQTT_TOPIC_PIXELS_DEVICE \ 183 "/signals/device/pixel" 184 #define MQTT_TOPIC_PIXELS_BROKER \ 185 "/signals/broker/pixel" 190 WS_NET_DISCONNECTED = 1,
192 WS_FINGERPRINT_UNKOWN = 3,
194 WS_NET_CONNECT_FAILED = 10,
195 WS_CONNECT_FAILED = 11,
196 WS_FINGERPRINT_INVALID = 12,
201 WS_NET_CONNECTED = 20,
203 WS_CONNECTED_INSECURE = 22,
204 WS_FINGERPRINT_UNSUPPORTED = 23,
205 WS_FINGERPRINT_VALID = 24,
206 WS_BOARD_DESC_INVALID = 25,
207 WS_BOARD_RESYNC_FAILED = 26
212 WS_MQTT_CONNECTED = 0,
213 WS_MQTT_INVALID_PROTOCOL = 1,
214 WS_MQTT_INVALID_CID = 2,
215 WS_MQTT_SERVICE_UNAVALIABLE = 3,
216 WS_MQTT_INVALID_USER_PASS = 4,
217 WS_MQTT_UNAUTHORIZED = 5,
218 WS_MQTT_THROTTLED = 6,
225 WS_BOARD_DEF_SEND_FAILED,
228 WS_BOARD_DEF_INVALID,
229 WS_BOARD_DEF_UNSPECIFIED
238 FSM_NET_CHECK_NETWORK,
239 FSM_NET_ESTABLISH_NETWORK,
240 FSM_NET_ESTABLISH_MQTT,
243 #ifdef ARDUINO_ARCH_RP2040 244 #define WS_WDT_TIMEOUT 8388 246 #define WS_WDT_TIMEOUT 60000 249 #define WS_MAX_ALT_WIFI_NETWORKS 3 251 #define WS_KEEPALIVE_INTERVAL_MS \ 254 #define WS_MQTT_MAX_PAYLOAD_SIZE \ 259 class Wippersnapper_FS;
260 class WipperSnapper_LittleFS;
261 #ifdef ARDUINO_ARCH_ESP32 293 virtual void set_ssid_pass(
const char *ssid,
const char *ssidPassword);
324 void publish(
const char *topic, uint8_t *payload, uint16_t bLen,
338 int seconds_until_reboot = 25);
344 wippersnapper_signal_v1_CreateSignalRequest *encodedSignalMsg);
348 encodePinEvent(wippersnapper_signal_v1_CreateSignalRequest *outgoingSignalMsg,
349 uint8_t pinName,
int pinVal);
356 std::vector<WipperSnapper_Component_I2C *>
382 WipperSnapper_LittleFS
433 wippersnapper_signal_v1_CreateSignalRequest
436 wippersnapper_signal_v1_I2CRequest_init_zero;
441 wippersnapper_signal_v1_Ds18x20Request_init_zero;
445 wippersnapper_signal_v1_ServoRequest
447 wippersnapper_signal_v1_PWMRequest
msgPWM =
448 wippersnapper_signal_v1_PWMRequest_init_zero;
452 wippersnapper_signal_v1_PixelsRequest
455 wippersnapper_signal_v1_UARTRequest
458 wippersnapper_signal_v1_DisplayRequest
468 #ifdef ARDUINO_ARCH_ESP32 509 Adafruit_MQTT_Subscribe
511 Adafruit_MQTT_Subscribe
513 Adafruit_MQTT_Subscribe
515 Adafruit_MQTT_Subscribe
517 Adafruit_MQTT_Subscribe
519 Adafruit_MQTT_Subscribe
524 Adafruit_MQTT_Subscribe
526 Adafruit_MQTT_Subscribe
529 wippersnapper_signal_v1_CreateSignalRequest
534 #endif // ADAFRUIT_WIPPERSNAPPER_H
Class that provides an interface with the I2C bus.
Definition: WipperSnapper_I2C.h:109
char * _topic_signal_pixels_brkr
Definition: Wippersnapper.h:454
wippersnapper_signal_v1_PWMRequest msgPWM
Definition: Wippersnapper.h:477
void disconnect()
Disconnects from Adafruit IO+ Wippersnapper.
Definition: Wippersnapper.cpp:132
char * _topic_signal_uart_brkr
Definition: Wippersnapper.h:456
virtual void setupMQTTClient(const char *clientID)
Sets up the MQTT client session.
Definition: Wippersnapper.cpp:182
const char * _boardId
Definition: Wippersnapper.h:426
ws_mqtt_status_t
Definition: Wippersnapper.h:241
Adafruit_MQTT_Subscribe * _throttle_sub
Definition: Wippersnapper.h:557
High-level interface for the ESP32/ESP32-Sx/ESP32-Cx LED Control (LEDC) peripheral. Instead of specifying a timer or channel, this class automatically allocates a channel and associates it with a pin. Underlying esp32-hal-ledc performs timer management and handles the low-level LEDC peripheral API calls.
Definition: ws_ledc.h:37
bool _isI2CPort1Init
True if I2C port 1 has been initialized, False otherwise.
Definition: Wippersnapper.h:394
ws_ledc * _ledc
Pointer to LEDC object.
Definition: Wippersnapper.h:499
bool generateWSErrorTopics()
Builds MQTT topics for handling errors returned from the Adafruit IO broker and subscribes to them...
Definition: Wippersnapper.cpp:1775
ws_pixels * _ws_pixelsComponent
ptr to instance of ws_pixels class
Definition: Wippersnapper.h:414
Class that provides functions for reading and interacting with digital inputs and outputs...
Definition: Wippersnapper_DigitalGPIO.h:38
DisplayController * _displayController
Instance of display controller class.
Definition: Wippersnapper.h:420
void publish(const char *topic, uint8_t *payload, uint16_t bLen, uint8_t qos=0)
Publishes a message to the Adafruit IO MQTT broker. Handles network connectivity. ...
Definition: Wippersnapper.cpp:2678
char * _topic_signal_pwm_brkr
Definition: Wippersnapper.h:446
void processPackets()
Process all incoming packets from the Adafruit IO MQTT broker. Handles network connectivity.
Definition: Wippersnapper.cpp:2656
const char * _deviceId
Definition: Wippersnapper.h:515
wippersnapper_signal_v1_DisplayRequest msgSignalDisplay
DisplayRequest wrapper message.
Definition: Wippersnapper.h:489
char * _device_uid
Definition: Wippersnapper.h:516
virtual ~Wippersnapper()
Wippersnapper destructor.
Definition: Wippersnapper.cpp:82
ws_led_status_t
Definition: Wippersnapper_StatusLED.h:34
#define WS_MQTT_MAX_PAYLOAD_SIZE
MAXIMUM expected payload size, in bytes.
Definition: Wippersnapper.h:284
void connect()
Connects to Adafruit IO+ Wippersnapper broker.
Definition: Wippersnapper.cpp:2792
uint8_t _buffer[512]
Definition: Wippersnapper.h:397
bool encodePinEvent(wippersnapper_signal_v1_CreateSignalRequest *outgoingSignalMsg, uint8_t pinName, int pinVal)
Handles MQTT messages on signal topic until timeout.
Definition: Wippersnapper.cpp:1663
char * _topic_description_status
Definition: Wippersnapper.h:519
bool generateWSTopics()
Generates device-specific Wippersnapper control topics and subscribes to them.
Definition: Wippersnapper.cpp:1874
Class that provides an interface for reading and controlling analog pins. Stores information about an...
Definition: Wippersnapper_AnalogIO.h:43
WipperSnapper_LittleFS * _littleFS
Instance of LittleFS Filesystem (non-native USB)
Definition: Wippersnapper.h:413
float status_pixel_brightness
(from 0.0 to 1.0)
Definition: Wippersnapper.h:318
void errorWriteHang(String error)
Writes an error message to the serial and the filesystem, blinks WS_LED_STATUS_ERROR_RUNTIME pattern ...
Definition: Wippersnapper.cpp:2390
Adafruit_MQTT_Subscribe * _topic_signal_ds18_sub
Definition: Wippersnapper.h:546
bool decodeSignalMsg(wippersnapper_signal_v1_CreateSignalRequest *encodedSignalMsg)
Decodes a signal buffer protobuf message. NOTE: Should be executed in-order after a new _buffer is re...
Definition: Wippersnapper.cpp:465
void provision()
Provisions a WipperSnapper device with its network configuration and Adafruit IO credentials.
Definition: Wippersnapper.cpp:97
Adafruit_MQTT_Subscribe * _topic_signal_i2c_sub
Definition: Wippersnapper.h:540
char * _topic_signal_device
Definition: Wippersnapper.h:437
secretsConfig _config
Definition: Wippersnapper.h:429
uint32_t _last_mqtt_connect
Definition: Wippersnapper.h:507
char * _topic_signal_i2c_device
Definition: Wippersnapper.h:440
char * _topic_signal_pixels_device
Definition: Wippersnapper.h:455
wippersnapper_signal_v1_I2CRequest msgSignalI2C
Definition: Wippersnapper.h:465
Wippersnapper_DigitalGPIO * _digitalGPIO
Instance of digital gpio class.
Definition: Wippersnapper.h:409
ws_status_t
Definition: Wippersnapper.h:218
WipperSnapper_Component_I2C * _i2cPort1
WipperSnapper I2C Component for I2C port #1.
Definition: Wippersnapper.h:390
void haltError(String error, ws_led_status_t ledStatusColor=WS_LED_STATUS_ERROR_RUNTIME, int seconds_until_reboot=25)
Prints an error to the serial and halts the hardware until the WDT bites.
Definition: Wippersnapper.cpp:2529
wippersnapper_signal_v1_CreateSignalRequest _incomingSignalMsg
Definition: Wippersnapper.h:464
virtual bool check_valid_ssid()
Performs a scan of local WiFi networks.
Definition: Wippersnapper.cpp:227
Class that provides storage and functions for the Adafruit IO Wippersnapper interface.
Definition: Wippersnapper.h:308
Interface for WipperSnapper servo control.
Definition: ws_servo.h:61
bool configureDigitalPinReq(wippersnapper_pin_v1_ConfigurePinRequest *pinMsg)
Configures a pin according to a wippersnapper_pin_v1_ConfigurePinRequest message. ...
Definition: Wippersnapper.cpp:291
friend class
Definition: ws_pixels.h:49
ws_status_t run()
Processes incoming commands and handles network connection.
Definition: Wippersnapper.cpp:2892
virtual void _connect()
Connects to wireless network.
Definition: Wippersnapper.cpp:141
const char * _airlift_version
Definition: Wippersnapper.h:425
wippersnapper_signal_v1_CreateSignalRequest _outgoingSignalMsg
Definition: Wippersnapper.h:560
char * _topic_signal_pwm_device
Definition: Wippersnapper.h:448
bool encodePubRegistrationReq()
Encodes hardware registration request message and publishes the message to the Adafruit IO broker...
Definition: Wippersnapper_Register.cpp:27
char * throttleMessage
Definition: Wippersnapper.h:491
uint32_t _prv_ping
Definition: Wippersnapper.h:509
virtual void getMacAddr()
Sets the network interface's unique identifier, typically the MAC address.
Definition: Wippersnapper.cpp:160
bool generateDeviceUID()
Attempts to generate unique device identifier.
Definition: Wippersnapper.cpp:1833
Adafruit_MQTT_Subscribe * _topic_description_sub
Definition: Wippersnapper.h:533
char sUID[13]
Definition: Wippersnapper.h:424
Wippersnapper WS
Global member variable for callbacks.
Definition: Wippersnapper.cpp:36
Forward declaration.
Definition: controller.h:30
virtual void set_ssid_pass()
Sets the device's wireless network credentials from the secrets.json configuration file...
Definition: Wippersnapper.cpp:217
char * _err_topic
Definition: Wippersnapper.h:530
void feedWDT()
Feeds the WDT to prevent hardware reset.
Definition: Wippersnapper.cpp:2630
uint32_t _prvKATBlink
Definition: Wippersnapper.h:511
char * _topic_signal_servo_device
Definition: Wippersnapper.h:444
bool _isWiFiMulti
Definition: Wippersnapper.h:431
Adafruit_MQTT_Subscribe * _topic_signal_pixels_sub
Definition: Wippersnapper.h:548
ws_ds18x20 * _ds18x20Component
Instance of DS18x20 class.
Definition: Wippersnapper.h:417
ws_board_status_t _boardStatus
Hardware's registration status.
Definition: Wippersnapper.h:404
wippersnapper_signal_v1_UARTRequest msgSignalUART
UARTReq wrapper message.
Definition: Wippersnapper.h:486
void runNetFSM()
Checks network and MQTT connectivity. Handles network re-connection and mqtt re-establishment.
Definition: Wippersnapper.cpp:2414
char * _topic_signal_display_device
Definition: Wippersnapper.h:460
networkConfig _multiNetworks[3]
Definition: Wippersnapper.h:430
bool pinCfgCompleted
Definition: Wippersnapper.h:495
char * _topic_signal_uart_device
Definition: Wippersnapper.h:457
void pingBroker()
Pings the MQTT broker within the keepalive interval to keep the connection alive. Blinks the keepaliv...
Definition: Wippersnapper.cpp:2601
wippersnapper_signal_v1_Ds18x20Request msgSignalDS
Definition: Wippersnapper.h:470
wippersnapper_signal_v1_PixelsRequest msgPixels
PixelsRequest wrapper message.
Definition: Wippersnapper.h:483
void enableWDT(int timeoutMS=0)
Enables the watchdog timer.
Definition: Wippersnapper.cpp:2640
Adafruit_MQTT_Subscribe * _topic_signal_pwm_sub
Definition: Wippersnapper.h:544
Class that provides an interface with DS18X20-compatible sensors.
Definition: ws_ds18x20.h:48
char * _topic_signal_ds18_brkr
Definition: Wippersnapper.h:450
void publishPinConfigComplete()
Publishes an ACK to the broker that the device has completed its hardware configuration.
Definition: Wippersnapper.cpp:2854
std::vector< WipperSnapper_Component_I2C * > i2cComponents
Vector containing all I2C components.
Definition: Wippersnapper.h:387
uint16_t bufSize
Definition: Wippersnapper.h:402
char * _topic_signal_i2c_brkr
Definition: Wippersnapper.h:438
Adafruit_MQTT_Subscribe * _topic_signal_brkr_sub
Definition: Wippersnapper.h:537
char * _topic_signal_brkr
Definition: Wippersnapper.h:529
int32_t totalDigitalPins
Definition: Wippersnapper.h:434
Interface for WipperSnapper PWM.
Definition: ws_pwm.h:34
char * _topic_signal_display_brkr
Definition: Wippersnapper.h:458
ws_status_t _status
Definition: Wippersnapper.h:506
ws_board_status_t
Definition: Wippersnapper.h:253
uint8_t _macAddr[6]
Definition: Wippersnapper.h:423
ws_pwm * _pwmComponent
Instance of pwm class.
Definition: Wippersnapper.h:415
fsm_net_t
Definition: Wippersnapper.h:263
bool lockStatusLED
True if status LED is using the built-in LED.
Definition: Wippersnapper.h:317
Wippersnapper_FS * _fileSystem
Instance of Filesystem (native USB)
Definition: Wippersnapper.h:411
Adafruit_MQTT_Subscribe * _topic_signal_uart_sub
Definition: Wippersnapper.h:550
Adafruit_MQTT * _mqtt
Definition: Wippersnapper.h:427
#define STATUS_PIXEL_BRIGHTNESS_DEFAULT
Default status pixel brightness.
Definition: Wippersnapper_StatusLED.h:59
virtual ws_status_t networkStatus()
Returns the network's connection status.
Definition: Wippersnapper.cpp:192
char * _topic_device_pin_config_complete
Definition: Wippersnapper.h:525
char * _topic_signal_servo_brkr
Definition: Wippersnapper.h:442
Wippersnapper_AnalogIO * _analogIO
Instance of analog io class.
Definition: Wippersnapper.h:410
char * _topic_description_status_complete
Definition: Wippersnapper.h:522
void pollRegistrationResp()
Polls the broker for the hardware registration response message.
Definition: Wippersnapper_Register.cpp:78
ws_board_status_t getBoardStatus()
Returns the board definition status.
Definition: Wippersnapper.cpp:2592
Adafruit_MQTT_Subscribe * _topic_signal_display_sub
Definition: Wippersnapper.h:551
bool configAnalogInPinReq(wippersnapper_pin_v1_ConfigurePinRequest *pinMsg)
Configures an analog input pin according to a wippersnapper_pin_v1_ConfigurePinRequest message...
Definition: Wippersnapper.cpp:254
bool lockStatusDotStar
True if status LED is using the status dotstar.
Definition: Wippersnapper.h:316
wippersnapper_signal_v1_ServoRequest msgServo
ServoRequest wrapper message.
Definition: Wippersnapper.h:476
uint8_t _buffer_outgoing[512]
Definition: Wippersnapper.h:400
char * _throttle_topic
Definition: Wippersnapper.h:531
void decodeRegistrationResp(char *data, uint16_t len)
Decodes hardware registration response message from the Adafruit IO MQTT broker and initializes hardw...
Definition: Wippersnapper_Register.cpp:98
bool lockStatusNeoPixel
True if status LED is using the status neopixel.
Definition: Wippersnapper.h:315
Adafruit_MQTT_Subscribe * _topic_signal_servo_sub
Definition: Wippersnapper.h:542
WipperSnapper_Component_I2C * _i2cPort0
WipperSnapper I2C Component for I2C port #0.
Definition: Wippersnapper.h:388
bool registerBoard()
Attempts to register hardware with Adafruit.io WipperSnapper.
Definition: Wippersnapper.cpp:2568
int throttleTime
Definition: Wippersnapper.h:492
Adafruit_MQTT_Subscribe * _err_sub
Definition: Wippersnapper.h:555
char * _topic_signal_ds18_device
Definition: Wippersnapper.h:452
bool _isI2CPort0Init
True if I2C port 0 has been initialized, False otherwise.
Definition: Wippersnapper.h:392
virtual int32_t getRSSI()
Gets the network's RSSI.
Definition: Wippersnapper.cpp:170
virtual void _disconnect()
Disconnect Wippersnapper MQTT session and network.
Definition: Wippersnapper.cpp:150
ws_servo * _servoComponent
Instance of servo class.
Definition: Wippersnapper.h:416
Adafruit_MQTT_Publish * _topic_signal_device_pub
Definition: Wippersnapper.h:535
ws_uart * _uartComponent
Instance of UART class.
Definition: Wippersnapper.h:418
char * _topic_description
Definition: Wippersnapper.h:436
Class that provides an interface between WipperSnapper's app and the device's UART bus...
Definition: ws_uart.h:29
virtual void set_user_key()
Configures the device's Adafruit IO credentials. This method should be used only if filesystem-backed...
Definition: Wippersnapper.cpp:239