OpenDTU-old/include/NetworkSettings.h
helgeerbe 2eeb5f1d19 Revert "Merge remote-tracking branch 'tbnobody/OpenDTU/master' into development"
This reverts commit eb1c2dbd8c, reversing
changes made to 0cb42a6424.

merge of v23.9.11 broke the system
2023-09-12 20:18:10 +02:00

81 lines
1.9 KiB
C++

// SPDX-License-Identifier: GPL-2.0-or-later
#pragma once
#include <DNSServer.h>
#include <WiFi.h>
#include <vector>
enum class network_mode {
WiFi,
Ethernet,
Undefined
};
enum class network_event {
NETWORK_UNKNOWN,
NETWORK_START,
NETWORK_STOP,
NETWORK_CONNECTED,
NETWORK_DISCONNECTED,
NETWORK_GOT_IP,
NETWORK_LOST_IP,
NETWORK_EVENT_MAX
};
typedef std::function<void(network_event event)> NetworkEventCb;
typedef struct NetworkEventCbList {
NetworkEventCb cb;
network_event event;
NetworkEventCbList()
: cb(NULL)
, event(network_event::NETWORK_UNKNOWN)
{
}
} NetworkEventCbList_t;
class NetworkSettingsClass {
public:
NetworkSettingsClass();
void init();
void loop();
void applyConfig();
void enableAdminMode();
String getApName();
IPAddress localIP();
IPAddress subnetMask();
IPAddress gatewayIP();
IPAddress dnsIP(uint8_t dns_no = 0);
String macAddress();
static String getHostname();
bool isConnected();
network_mode NetworkMode();
bool onEvent(NetworkEventCb cbEvent, network_event event = network_event::NETWORK_EVENT_MAX);
void raiseEvent(network_event event);
private:
void setHostname();
void setStaticIp();
void setupMode();
void NetworkEvent(WiFiEvent_t event);
bool adminEnabled = true;
bool forceDisconnection = false;
int adminTimeoutCounter = 0;
int adminTimeoutCounterMax = 0;
int connectTimeoutTimer = 0;
int connectRedoTimer = 0;
uint32_t lastTimerCall = 0;
const byte DNS_PORT = 53;
IPAddress apIp;
IPAddress apNetmask;
std::unique_ptr<DNSServer> dnsServer;
bool dnsServerStatus = false;
network_mode _networkMode = network_mode::Undefined;
bool _ethConnected = false;
std::vector<NetworkEventCbList_t> _cbEventList;
};
extern NetworkSettingsClass NetworkSettings;