/*
This sketch shows the Ethernet event usage
*/
// Important to be defined BEFORE including ETH.h for ETH.begin() to work.
// Example RMII LAN8720 (Olimex, etc.)
#ifndef ETH_PHY_MDC
#define ETH_PHY_TYPE ETH_PHY_LAN8720
#if CONFIG_IDF_TARGET_ESP32
#define ETH_PHY_ADDR 0
#define ETH_PHY_MDC 23
#define ETH_PHY_MDIO 18
#define ETH_PHY_POWER -1
#define ETH_CLK_MODE ETH_CLOCK_GPIO0_IN
#elif CONFIG_IDF_TARGET_ESP32P4
#define ETH_PHY_ADDR 0
#define ETH_PHY_MDC 31
#define ETH_PHY_MDIO 52
#define ETH_PHY_POWER 51
#define ETH_CLK_MODE EMAC_CLK_EXT_IN
#endif
#endif
#define RELAY1 32
#define RELAY2 33
#define BUTTON 34
#include <ETH.h>
static bool eth_connected = false;
// WARNING: onEvent is called from a separate FreeRTOS task (thread)!
void onEvent(arduino_event_id_t event) {
switch (event) {
case ARDUINO_EVENT_ETH_START:
Serial.println("ETH Started");
// The hostname must be set after the interface is started, but needs
// to be set before DHCP, so set it from the event handler thread.
ETH.setHostname("esp32-ethernet");
break;
case ARDUINO_EVENT_ETH_CONNECTED: Serial.println("ETH Connected"); break;
case ARDUINO_EVENT_ETH_GOT_IP:
Serial.println("ETH Got IP");
Serial.println(ETH);
eth_connected = true;
break;
case ARDUINO_EVENT_ETH_LOST_IP:
Serial.println("ETH Lost IP");
eth_connected = false;
break;
case ARDUINO_EVENT_ETH_DISCONNECTED:
Serial.println("ETH Disconnected");
eth_connected = false;
break;
case ARDUINO_EVENT_ETH_STOP:
Serial.println("ETH Stopped");
eth_connected = false;
break;
default: break;
}
}
void testClient(const char *host, uint16_t port) {
Serial.print("\nconnecting to ");
Serial.println(host);
NetworkClient client;
if (!client.connect(host, port)) {
Serial.println("connection failed");
return;
}
client.printf("GET / HTTP/1.1\r\nHost: %s\r\n\r\n", host);
while (client.connected() && !client.available());
while (client.available()) {
Serial.write(client.read());
}
Serial.println("closing connection\n");
client.stop();
}
void setup() {
Serial.begin(115200);
Network.onEvent(onEvent);
ETH.begin();
pinMode (BUTTON, INPUT);
pinMode (RELAY1, OUTPUT);
pinMode (RELAY2, OUTPUT);
}
void loop() {
if (eth_connected) {
testClient("google.com", 80);
while (!digitalRead (BUTTON));
digitalWrite (RELAY1, HIGH);
digitalWrite (RELAY2, LOW);
delay (1000);
digitalWrite (RELAY1, LOW);
digitalWrite (RELAY2, HIGH);
delay (1000);
}
delay(1000);
}
[D][switch:012]: 'Solarsteuerung Schalter 2' Turning ON.
[D][switch:055]: 'Solarsteuerung Schalter 2': Sending state ON
[D][switch:016]: 'Solarsteuerung Schalter 2' Turning OFF.
[D][switch:055]: 'Solarsteuerung Schalter 2': Sending state OFF
[D][switch:012]: 'Solarsteuerung Schalter 1' Turning ON.
[D][switch:055]: 'Solarsteuerung Schalter 1': Sending state ON
[D][switch:016]: 'Solarsteuerung Schalter 1' Turning OFF.
[D][switch:055]: 'Solarsteuerung Schalter 1': Sending state OFF
[D][switch:012]: 'Solarsteuerung Schalter 2' Turning ON.
[D][switch:055]: 'Solarsteuerung Schalter 2': Sending state ON
[D][switch:012]: 'Solarsteuerung Schalter 1' Turning ON.
[D][switch:055]: 'Solarsteuerung Schalter 1': Sending state ON
[V][ethernet:411][sys_evt]: [Ethernet event] ETH disconnected (num=3)
[W][ethernet:274]: Connection via Ethernet lost! Re-connecting...
[W][component:157]: Component ethernet set Warning flag: waiting for IP configuration
[V][ethernet:472]: DHCP Client Status: 0
[W][api.connection:109]: Home Assistant 2025.4.4 (192.168.64.17): Network unavailable, disconnecting
[V][api:116]: Removing connection to Home Assistant 2025.4.4
[W][component:157]: Component api set Warning flag: unspecified
[W][ethernet:265]: Connecting via ethernet failed! Re-connecting...
[V][ethernet:472]: DHCP Client Status: 0
[W][ethernet:265]: Connecting via ethernet failed! Re-connecting...
[V][ethernet:472]: DHCP Client Status: 0