state machine top level should work, light not added yet

This commit is contained in:
2025-08-28 20:04:27 +02:00
parent 83d589a3ec
commit 936d1dba20
4 changed files with 30 additions and 7 deletions

View File

@@ -17,6 +17,12 @@ Network::Network(std::string_view hostname, std::string_view apSsid) : hostname(
webServer.begin(); webServer.begin();
} }
Network::~Network() {
webServer.end();
WifiManager.detachUI();
WifiManager.detachWebServer();
}
bool Network::isConnected() const { bool Network::isConnected() const {
return WiFi.status() == WL_CONNECTED; return WiFi.status() == WL_CONNECTED;
} }

View File

@@ -5,6 +5,7 @@
class Network { class Network {
public: public:
Network(std::string_view hostname, std::string_view apSsid = "Smart RGB"); Network(std::string_view hostname, std::string_view apSsid = "Smart RGB");
~Network();
bool isConnected() const; bool isConnected() const;
std::string getHostname() const; std::string getHostname() const;
bool setHostname(const std::string_view &hostname); bool setHostname(const std::string_view &hostname);

View File

@@ -56,10 +56,8 @@ void setup() {
stateMachine->addTransition(StateId::StartState, EventId::PinInitialized, StateId::NetworkInitializeState); stateMachine->addTransition(StateId::StartState, EventId::PinInitialized, StateId::NetworkInitializeState);
stateMachine->addStateRaw(runningState); stateMachine->addStateRaw(runningState);
stateMachine->addTransition(StateId::NetworkInitializeState, EventId::WifiConnected, StateId::RunningState); stateMachine->addTransition(StateId::NetworkInitializeState, EventId::WifiConnected, StateId::RunningState);
stateMachine->addTransition(StateId::RunningState, EventId::WifiDisconnected, StateId::NetworkInitializeState);
stateMachine->setInitialState(StateId::StartState); stateMachine->setInitialState(StateId::StartState);
// Mqtt::connect("10.238.75.81", 1883, "smart_rgb_client", "mqtt", "mqtt");
// delay(1000); // Wait for MQTT connection to stabilize
// light = new Light(pinR, pinG, pinB, pinCW, pinWW, mqttClient, "smart_rgb_light"); // light = new Light(pinR, pinG, pinB, pinCW, pinWW, mqttClient, "smart_rgb_light");
} }

View File

@@ -15,7 +15,8 @@ enum class StateId
enum class EventId enum class EventId
{ {
PinInitialized, PinInitialized,
WifiConnected WifiConnected,
WifiDisconnected
}; };
class StartState : public State class StartState : public State
@@ -50,7 +51,12 @@ public:
NetworkInitializeState(AppContext *appContext) : State("NetworkInitializeState", StateId::NetworkInitializeState), appContext(appContext) {} NetworkInitializeState(AppContext *appContext) : State("NetworkInitializeState", StateId::NetworkInitializeState), appContext(appContext) {}
void onEnter(StateMachineBase &stateMachine) override { void onEnter(StateMachineBase &stateMachine) override {
if (appContext) { Serial.println("Entering NetworkInitializeState");
if (appContext && appContext->network) {
delete appContext->network;
appContext->network = nullptr;
}
if (appContext && !appContext->network) {
appContext->network = new Network(hostName, friendlyName); appContext->network = new Network(hostName, friendlyName);
} }
} }
@@ -58,9 +64,11 @@ public:
void onExit(StateMachineBase &stateMachine) override { void onExit(StateMachineBase &stateMachine) override {
if (appContext && appContext->network) { if (appContext && appContext->network) {
appContext->network->registerMDNS(); appContext->network->registerMDNS();
appContext->otaHandler = new OTAHandler(hostName); if (!appContext->otaHandler) {
appContext->otaHandler = new OTAHandler(hostName);
}
} }
Mqtt::connect(mqttBroker.data(), 1883, "smart_rgb_dev", "mqtt", "mqtt"); Mqtt::connect(mqttBroker.data(), 1883, hostName.data(), "mqtt", "mqtt");
} }
void onUpdate(StateMachineBase &stateMachine) override { void onUpdate(StateMachineBase &stateMachine) override {
@@ -81,9 +89,11 @@ public:
lastOtaPollMs = millis(); lastOtaPollMs = millis();
lastMqttPollMs = millis(); lastMqttPollMs = millis();
lastMqttCheckConnectionPollSecond = millis() / 1000; lastMqttCheckConnectionPollSecond = millis() / 1000;
lastNetworkCheckPollMs = millis();
} }
void onExit(StateMachineBase &stateMachine) override { void onExit(StateMachineBase &stateMachine) override {
Serial.println("Exiting RunningState");
} }
void onUpdate(StateMachineBase &stateMachine) override { void onUpdate(StateMachineBase &stateMachine) override {
@@ -101,12 +111,20 @@ public:
lastMqttCheckConnectionPollSecond = millis() / 1000; lastMqttCheckConnectionPollSecond = millis() / 1000;
Mqtt::checkConnection(); Mqtt::checkConnection();
} }
if ((millis() - lastNetworkCheckPollMs) >= networkCheckPollInterval) {
lastNetworkCheckPollMs = millis();
if (appContext && appContext->network && !appContext->network->isConnected()) {
stateMachine.postEvent(EventId::WifiDisconnected);
}
}
} }
private: private:
AppContext *appContext = nullptr; AppContext *appContext = nullptr;
uint32_t lastOtaPollMs = 0; uint32_t lastOtaPollMs = 0;
static constexpr uint32_t otaPollInterval = 1000; // Poll every second static constexpr uint32_t otaPollInterval = 1000; // Poll every second
uint32_t lastNetworkCheckPollMs = 0;
static constexpr uint32_t networkCheckPollInterval = 5000; // Poll every 5 seconds
uint32_t lastMqttPollMs = 0; uint32_t lastMqttPollMs = 0;
static constexpr uint32_t mqttPollInterval = 100; // Poll every 100 milliseconds static constexpr uint32_t mqttPollInterval = 100; // Poll every 100 milliseconds
uint32_t lastMqttCheckConnectionPollSecond = 0; uint32_t lastMqttCheckConnectionPollSecond = 0;