NTPClient/NTPClient.h

136 lines
3.5 KiB
C
Raw Normal View History

2015-12-08 17:21:16 +01:00
#pragma once
#include "Arduino.h"
#include <Udp.h>
2015-12-08 17:21:16 +01:00
#define SEVENZYYEARS 2208988800UL
#define FRACTIONSPERMILLI (4294967UL)
2015-12-08 17:21:16 +01:00
#define NTP_PACKET_SIZE 48
#define NTP_DEFAULT_LOCAL_PORT 1337
2015-12-08 17:21:16 +01:00
class NTPClient;
typedef void (*NTPUpdateCallbackFunction)(NTPClient* c);
2015-12-08 17:21:16 +01:00
class NTPClient {
private:
UDP* _udp;
bool _udpSetup = false;
2015-12-08 17:21:16 +01:00
const char* _poolServerName = "pool.ntp.org"; // Default time server
IPAddress _poolServerIP;
int _port = NTP_DEFAULT_LOCAL_PORT;
long _timeOffset = 0;
2015-12-08 17:21:16 +01:00
2016-10-11 23:37:32 +02:00
unsigned int _retryInterval = 1000; // In ms
unsigned long _updateInterval = 60000; // In ms
2015-12-08 17:21:16 +01:00
unsigned long _currentEpoc = 0; // In s
unsigned long _currentFraction = 0; // In 1/(2^32) s
2015-12-08 17:21:16 +01:00
unsigned long _lastUpdate = 0; // In ms
2016-10-11 23:37:32 +02:00
unsigned long _lastRequest = 0; // IN ms
2015-12-08 17:21:16 +01:00
byte _packetBuffer[NTP_PACKET_SIZE];
NTPUpdateCallbackFunction _updateCallback = NULL;
void sendNTPPacket();
2016-10-11 23:37:32 +02:00
bool checkResponse();
2015-12-08 17:21:16 +01:00
public:
NTPClient(UDP& udp);
NTPClient(UDP& udp, long timeOffset);
NTPClient(UDP& udp, const char* poolServerName);
NTPClient(UDP& udp, const char* poolServerName, long timeOffset);
NTPClient(UDP& udp, const char* poolServerName, long timeOffset, unsigned long updateInterval);
NTPClient(UDP& udp, IPAddress poolServerIP);
NTPClient(UDP& udp, IPAddress poolServerIP, long timeOffset);
NTPClient(UDP& udp, IPAddress poolServerIP, long timeOffset, unsigned long updateInterval);
2015-12-08 17:21:16 +01:00
2017-10-31 10:01:47 +01:00
/**
* Set time server name
*
* @param poolServerName
*/
void setPoolServerName(const char* poolServerName);
2015-12-08 17:21:16 +01:00
/**
* Starts the underlying UDP client with the default local port
*/
void begin();
/**
* Starts the underlying UDP client with the specified local port
*/
void begin(int port);
2015-12-08 17:21:16 +01:00
/**
* This should be called in the main loop of your application. By default an update from the NTP Server is only
* made every 60 seconds. This can be configured in the NTPClient constructor.
*
* @return true on success, false on failure
2015-12-08 17:21:16 +01:00
*/
bool update();
2015-12-08 17:21:16 +01:00
/**
* Has the time ever been sucessfully updated
*
*/
bool updated();
/**
* Register a callback function for when the time gets updated
*
*/
void setUpdateCallback(NTPUpdateCallbackFunction f);
2015-12-08 17:21:16 +01:00
/**
* This will force the update from the NTP Server.
2016-10-11 23:37:32 +02:00
* This can block for a full second
* @return true on success, false on failure
2015-12-08 17:21:16 +01:00
*/
bool forceUpdate();
2015-12-08 17:21:16 +01:00
2018-02-20 21:32:17 +01:00
int getDay() const;
int getHours() const;
int getMinutes() const;
int getSeconds() const;
2015-12-08 17:21:16 +01:00
/**
* Changes the time offset. Useful for changing timezones dynamically
*/
void setTimeOffset(int timeOffset);
/**
* Set the update interval to another frequency. E.g. useful when the
* timeOffset should not be set in the constructor
*/
void setUpdateInterval(unsigned long updateInterval);
2018-10-20 19:41:27 +02:00
/**
* Set the retry interval to another frequency in ms
*/
void setRetryInterval(int retryInterval);
2015-12-08 17:21:16 +01:00
/**
* @return time formatted like `hh:mm:ss`
*/
2018-02-20 21:32:17 +01:00
String getFormattedTime() const;
2015-12-08 17:21:16 +01:00
/**
2016-04-13 15:41:16 +02:00
* @return time in seconds since Jan. 1, 1970
2015-12-08 17:21:16 +01:00
*/
2018-02-20 21:32:17 +01:00
unsigned long getEpochTime() const;
2016-04-12 16:45:21 +02:00
/**
* @return time in milliseconds since Jan. 1, 1970
*/
unsigned long long getEpochMillis();
2016-04-12 16:45:21 +02:00
/**
* Stops the underlying UDP client
*/
void end();
2015-12-08 17:21:16 +01:00
};