| PcapPlusPlus
    Next
    | 
The NTP packet consists of an integral number of 32-bit (4 octet) words in network byte order. The packet format consists of three components: the header itself, one or more optional extension fields (for v4), and an optional message authentication code (MAC). Currently the extension fields are not supported. The NTP header is: More...
#include <NtpLayer.h>
 
  
| Public Types | |
| enum | LeapIndicator { NoWarning = 0 , Last61Secs , Last59Secs , Unknown } | 
| Warning of an impending leap second to be inserted or deleted in the last minute of the current month.  More... | |
| enum | Mode { Reserved = 0 , SymActive , SymPassive , Client , Server , Broadcast , Control , PrivateUse } | 
| Representing the NTP association modes.  More... | |
| enum class | ClockSource : uint32_t { GOES = ('G') | ('O' << 8) | ('E' << 16) | ('S' << 24) , GPS = ('G') | ('P' << 8) | ('S' << 16) , GAL = ('G') | ('A' << 8) | ('L' << 16) , PPS = ('P') | ('P' << 8) | ('S' << 16) , IRIG = ('I') | ('R' << 8) | ('I' << 16) | ('G' << 24) , WWVB = ('W') | ('W' << 8) | ('V' << 16) | ('B' << 24) , DCF = ('D') | ('C' << 8) | ('F' << 16) , HBG = ('H') | ('B' << 8) | ('G' << 16) , MSF = ('M') | ('S' << 8) | ('F' << 16) , JJY = ('J') | ('J' << 8) | ('Y' << 16) , LORC = ('L') | ('O' << 8) | ('R' << 16) | ('C' << 24) , TDF = ('T') | ('D' << 8) | ('F' << 16) , CHU = ('C') | ('H' << 8) | ('U' << 16) , WWV = ('W') | ('W' << 8) | ('V' << 16) , WWVH = ('W') | ('W' << 8) | ('V' << 16) | ('H' << 24) , NIST = ('N') | ('I' << 8) | ('S' << 16) | ('T' << 24) , ACTS = ('A') | ('C' << 8) | ('T' << 16) | ('S' << 24) , USNO = ('U') | ('S' << 8) | ('N' << 16) | ('O' << 24) , PTB = ('P') | ('T' << 8) | ('B' << 16) , MRS = ('M') | ('R' << 8) | ('S' << 16) , XFAC = ('X') | ('F' << 8) | ('A' << 16) | ('C' << 24) , STEP = ('S') | ('T' << 8) | ('E' << 16) | ('P' << 24) , GOOG = ('G') | ('O' << 8) | ('O' << 16) | ('G' << 24) , DCFa = ('D') | ('C' << 8) | ('F' << 16) | ('a' << 24) , DCFp = ('D') | ('C' << 8) | ('F' << 16) | ('p' << 24) , GPSs = ('G') | ('P' << 8) | ('S' << 16) | ('s' << 24) , GPSi = ('G') | ('P' << 8) | ('S' << 16) | ('i' << 24) , GLNs = ('G') | ('L' << 8) | ('N' << 16) | ('s' << 24) , GLNi = ('G') | ('L' << 8) | ('N' << 16) | ('i' << 24) , LCL = ('L') | ('C' << 8) | ('L' << 16) , LOCL = ('L') | ('O' << 8) | ('C' << 16) | ('L' << 24) , DCN = ('D') | ('C' << 8) | ('N' << 16) , TSP = ('T') | ('S' << 8) | ('P' << 16) , DTS = ('D') | ('T' << 8) | ('S' << 16) , ATOM = ('A') | ('T' << 8) | ('O' << 16) | ('M' << 24) , VLF = ('V') | ('L' << 8) | ('F' << 16) } | 
| enum class | KissODeath : uint32_t { ACST = ('A') | ('C' << 8) | ('S' << 16) | ('T' << 24) , AUTH = ('A') | ('U' << 8) | ('T' << 16) | ('H' << 24) , AUTO = ('A') | ('U' << 8) | ('T' << 16) | ('O' << 24) , BCST = ('B') | ('C' << 8) | ('S' << 16) | ('T' << 24) , CRYP = ('C') | ('R' << 8) | ('Y' << 16) | ('P' << 24) , DENY = ('D') | ('E' << 8) | ('N' << 16) | ('Y' << 24) , DROP = ('D') | ('R' << 8) | ('O' << 16) | ('P' << 24) , RSTR = ('R') | ('S' << 8) | ('T' << 16) | ('R' << 24) , INIT = ('I') | ('N' << 8) | ('I' << 16) | ('T' << 24) , MCST = ('M') | ('C' << 8) | ('S' << 16) | ('T' << 24) , NKEY = ('N') | ('K' << 8) | ('E' << 16) | ('Y' << 24) , RATE = ('R') | ('A' << 8) | ('T' << 16) | ('E' << 24) , RMOT = ('R') | ('M' << 8) | ('O' << 16) | ('T' << 24) , STEP = ('S') | ('T' << 8) | ('E' << 16) | ('P' << 24) } | 
| 32-bit Kiss of Death (KoD) codes  More... | |
| Public Member Functions | |
| NtpLayer (uint8_t *data, size_t dataLen, Layer *prevLayer, Packet *packet) | |
| NtpLayer () | |
| Empty c'tor. | |
| LeapIndicator | getLeapIndicator () const | 
| void | setLeapIndicator (LeapIndicator val) | 
| Set the leap indicator. | |
| uint8_t | getVersion () const | 
| void | setVersion (uint8_t val) | 
| Set the version of NTP. | |
| Mode | getMode () const | 
| std::string | getModeString () const | 
| void | setMode (Mode val) | 
| Set the mode. | |
| uint8_t | getStratum () const | 
| void | setStratum (uint8_t val) | 
| Set the value of stratum. | |
| int8_t | getPollInterval () const | 
| void | setPollInterval (int8_t val) | 
| double | getPollIntervalInSecs () const | 
| int8_t | getPrecision () const | 
| void | setPrecision (int8_t val) | 
| double | getPrecisionInSecs () const | 
| uint32_t | getRootDelay () const | 
| void | setRootDelay (uint32_t val) | 
| double | getRootDelayInSecs () const | 
| void | setRootDelayInSecs (double val) | 
| uint32_t | getRootDispersion () const | 
| void | setRootDispersion (uint32_t val) | 
| double | getRootDispersionInSecs () const | 
| void | setRootDispersionInSecs (double val) | 
| uint32_t | getReferenceIdentifier () const | 
| void | setReferenceIdentifier (IPv4Address val) | 
| void | setReferenceIdentifier (ClockSource val) | 
| void | setReferenceIdentifier (KissODeath val) | 
| std::string | getReferenceIdentifierString () const | 
| uint64_t | getReferenceTimestamp () const | 
| void | setReferenceTimestamp (uint64_t val) | 
| double | getReferenceTimestampInSecs () const | 
| void | setReferenceTimestampInSecs (double val) | 
| std::string | getReferenceTimestampAsString () | 
| uint64_t | getOriginTimestamp () const | 
| void | setOriginTimestamp (uint64_t val) | 
| double | getOriginTimestampInSecs () const | 
| void | setOriginTimestampInSecs (double val) | 
| std::string | getOriginTimestampAsString () | 
| uint64_t | getReceiveTimestamp () const | 
| void | setReceiveTimestamp (uint64_t val) | 
| double | getReceiveTimestampInSecs () const | 
| void | setReceiveTimestampInSecs (double val) | 
| std::string | getReceiveTimestampAsString () | 
| uint64_t | getTransmitTimestamp () const | 
| void | setTransmitTimestamp (uint64_t val) | 
| double | getTransmitTimestampInSecs () const | 
| void | setTransmitTimestampInSecs (double val) | 
| std::string | getTransmitTimestampAsString () | 
| uint32_t | getKeyID () const | 
| std::string | getDigest () const | 
| void | parseNextLayer () override | 
| Parses the next layer. NTP is the always last so does nothing for this layer. | |
| size_t | getHeaderLen () const override | 
| void | computeCalculateFields () override | 
| Does nothing for this layer. | |
| OsiModelLayer | getOsiModelLayer () const override | 
| std::string | toString () const override | 
|  Public Member Functions inherited from pcpp::Layer | |
| ~Layer () override | |
| Layer * | getNextLayer () const | 
| Layer * | getPrevLayer () const | 
| ProtocolType | getProtocol () const | 
| bool | isMemberOfProtocolFamily (ProtocolTypeFamily protocolTypeFamily) const | 
| uint8_t * | getData () const | 
| size_t | getDataLen () const | 
| uint8_t * | getLayerPayload () const | 
| size_t | getLayerPayloadSize () const | 
| bool | isAllocatedToPacket () const | 
| void | copyData (uint8_t *toArr) const | 
| uint8_t * | getDataPtr (size_t offset=0) const override | 
| Static Public Member Functions | |
| static double | convertFromShortFormat (const uint32_t val) | 
| static double | convertFromTimestampFormat (const uint64_t val) | 
| static uint32_t | convertToShortFormat (const double val) | 
| static uint64_t | convertToTimestampFormat (const double val) | 
| static std::string | convertToIsoFormat (const double timestamp) | 
| static std::string | convertToIsoFormat (const uint64_t timestampInNTPformat) | 
| static bool | isDataValid (const uint8_t *data, size_t dataSize) | 
| static bool | isNTPPort (uint16_t port) | 
| Additional Inherited Members | |
|  Protected Member Functions inherited from pcpp::Layer | |
| template<typename T , typename... Args> | |
| Layer * | constructNextLayer (uint8_t *data, size_t dataLen, Packet *packet, Args &&... extraArgs) | 
| template<typename T , typename TFallback , typename... Args> | |
| Layer * | tryConstructNextLayerWithFallback (uint8_t *data, size_t dataLen, Packet *packet, Args &&... extraArgs) | 
|  Static Protected Member Functions inherited from pcpp::Layer | |
| template<typename T > | |
| static bool | canReinterpretAs (const uint8_t *data, size_t dataLen) | 
| Check if the data is large enough to reinterpret as a type.  More... | |
The NTP packet consists of an integral number of 32-bit (4 octet) words in network byte order. The packet format consists of three components: the header itself, one or more optional extension fields (for v4), and an optional message authentication code (MAC). Currently the extension fields are not supported. The NTP header is:
Represents a NTP (Network Time Protocol) layer
| 
 | strong | 
32-bit code identifying the particular server or reference clock. The interpretation depends on the value in the stratum field.
| Enumerator | |
|---|---|
| GOES | Geosynchronous Orbit Environment Satellite. | 
| GPS | Global Position System. | 
| GAL | Galileo Positioning System. | 
| PPS | Generic pulse-per-second. | 
| IRIG | Inter-Range Instrumentation Group. | 
| WWVB | LF Radio WWVB Ft. Collins, CO 60 kHz. | 
| DCF | LF Radio DCF77 Mainflingen, DE 77.5 kHz. | 
| HBG | LF Radio HBG Prangins, HB 75 kHz. | 
| MSF | LF Radio MSF Anthorn, UK 60 kHz. | 
| JJY | LF Radio JJY Fukushima, JP 40 kHz, Saga, JP 60 kHz. | 
| LORC | MF Radio LORAN C station, 100 kHz. | 
| TDF | MF Radio Allouis, FR 162 kHz. | 
| CHU | HF Radio CHU Ottawa, Ontario. | 
| WWV | HF Radio WWV Ft. Collins, CO. | 
| WWVH | HF Radio WWVH Kauai, HI. | 
| NIST | NIST telephone modem. | 
| ACTS | NIST telephone modem. | 
| USNO | USNO telephone modem. | 
| PTB | European telephone modem. | 
| MRS | Multi Reference Sources. | 
| XFAC | Inter Face Association Changed. | 
| STEP | Step time change. | 
| GOOG | Google Refid used by Google NTP servers as time4.google.com. | 
| DCFa | Meinberg DCF77 with amplitude modulation (Ref: https://www.meinbergglobal.com/english/info/ntp-refid.htm) | 
| DCFp | Meinberg DCF77 with phase modulation)/pseudo random phase modulation (Ref: https://www.meinbergglobal.com/english/info/ntp-refid.htm) | 
| GPSs | Meinberg GPS (with shared memory access) (Ref: https://www.meinbergglobal.com/english/info/ntp-refid.htm) | 
| GPSi | Meinberg GPS (with interrupt based access) (Ref: https://www.meinbergglobal.com/english/info/ntp-refid.htm) | 
| GLNs | Meinberg GPS/GLONASS (with shared memory access) (Ref: https://www.meinbergglobal.com/english/info/ntp-refid.htm) | 
| GLNi | Meinberg GPS/GLONASS (with interrupt based access) (Ref: https://www.meinbergglobal.com/english/info/ntp-refid.htm) | 
| LCL | Meinberg Undisciplined local clock (Ref: https://www.meinbergglobal.com/english/info/ntp-refid.htm) | 
| LOCL | Meinberg Undisciplined local clock (Ref: https://www.meinbergglobal.com/english/info/ntp-refid.htm) | 
| DCN | DCN routing protocol. | 
| TSP | TSP time protocol. | 
| DTS | Digital Time Service. | 
| ATOM | Atomic clock (calibrated) | 
| VLF | VLF radio (OMEGA, etc.) | 
| 
 | strong | 
32-bit Kiss of Death (KoD) codes
| enum pcpp::NtpLayer::Mode | 
| 
 | inline | 
A constructor that creates the layer from an existing packet raw data
| [in] | data | A pointer to the raw data | 
| [in] | dataLen | Size of the data in bytes | 
| [in] | prevLayer | A pointer to the previous layer | 
| [in] | packet | A pointer to the Packet instance where layer will be stored in | 
| 
 | static | 
Convert NTP short format to seconds from the Unix Epoch
| [in] | val | Value in NTP short format | 
| 
 | static | 
Convert NTP timestamp format to seconds from the Unix Epoch
| [in] | val | Value in NTP timestamp format | 
| 
 | static | 
A static method to convert timestamp value to ISO8601 date time format
| [in] | timestamp | Value in seconds from the Unix Epoch | 
| 
 | static | 
A static method to convert timestamp value to ISO8601 date time format
| [in] | timestampInNTPformat | Value in NTP timestamp format | 
| 
 | static | 
Convert seconds from the Unix Epoch to NTP short format
| [in] | val | Value in seconds from Unix Epoch (1 Jan 1970) | 
| 
 | static | 
Convert seconds from the Unix Epoch to NTP timestamp format
| [in] | val | Value in seconds from Unix Epoch (1 Jan 1970) | 
| std::string pcpp::NtpLayer::getDigest | ( | ) | const | 
| 
 | inlineoverridevirtual | 
Implements pcpp::Layer.
| uint32_t pcpp::NtpLayer::getKeyID | ( | ) | const | 
| LeapIndicator pcpp::NtpLayer::getLeapIndicator | ( | ) | const | 
| Mode pcpp::NtpLayer::getMode | ( | ) | const | 
| std::string pcpp::NtpLayer::getModeString | ( | ) | const | 
| uint64_t pcpp::NtpLayer::getOriginTimestamp | ( | ) | const | 
| std::string pcpp::NtpLayer::getOriginTimestampAsString | ( | ) | 
| double pcpp::NtpLayer::getOriginTimestampInSecs | ( | ) | const | 
| 
 | inlineoverridevirtual | 
Implements pcpp::Layer.
| int8_t pcpp::NtpLayer::getPollInterval | ( | ) | const | 
| double pcpp::NtpLayer::getPollIntervalInSecs | ( | ) | const | 
| int8_t pcpp::NtpLayer::getPrecision | ( | ) | const | 
| double pcpp::NtpLayer::getPrecisionInSecs | ( | ) | const | 
| uint64_t pcpp::NtpLayer::getReceiveTimestamp | ( | ) | const | 
| std::string pcpp::NtpLayer::getReceiveTimestampAsString | ( | ) | 
| double pcpp::NtpLayer::getReceiveTimestampInSecs | ( | ) | const | 
| uint32_t pcpp::NtpLayer::getReferenceIdentifier | ( | ) | const | 
| std::string pcpp::NtpLayer::getReferenceIdentifierString | ( | ) | const | 
| uint64_t pcpp::NtpLayer::getReferenceTimestamp | ( | ) | const | 
| std::string pcpp::NtpLayer::getReferenceTimestampAsString | ( | ) | 
| double pcpp::NtpLayer::getReferenceTimestampInSecs | ( | ) | const | 
| uint32_t pcpp::NtpLayer::getRootDelay | ( | ) | const | 
| double pcpp::NtpLayer::getRootDelayInSecs | ( | ) | const | 
| uint32_t pcpp::NtpLayer::getRootDispersion | ( | ) | const | 
| double pcpp::NtpLayer::getRootDispersionInSecs | ( | ) | const | 
| uint8_t pcpp::NtpLayer::getStratum | ( | ) | const | 
| uint64_t pcpp::NtpLayer::getTransmitTimestamp | ( | ) | const | 
| std::string pcpp::NtpLayer::getTransmitTimestampAsString | ( | ) | 
| double pcpp::NtpLayer::getTransmitTimestampInSecs | ( | ) | const | 
| uint8_t pcpp::NtpLayer::getVersion | ( | ) | const | 
| 
 | static | 
A static method that takes a byte array and detects whether it is a NTP message
| [in] | data | A byte array | 
| [in] | dataSize | The byte array size (in bytes) | 
| 
 | inlinestatic | 
A static method that checks whether the port is considered as NTP
| [in] | port | The port number to be checked | 
| void pcpp::NtpLayer::setOriginTimestamp | ( | uint64_t | val | ) | 
Set the value of origin timestamp
| [in] | val | Value in NTP timestamp format | 
| void pcpp::NtpLayer::setOriginTimestampInSecs | ( | double | val | ) | 
Set the value of origin timestamp
| [in] | val | Value in seconds from Unix Epoch (1 Jan 1970) | 
| void pcpp::NtpLayer::setPollInterval | ( | int8_t | val | ) | 
Set the value of poll interval
| [in] | val | Poll interval in log2 seconds | 
| void pcpp::NtpLayer::setPrecision | ( | int8_t | val | ) | 
Set the value of precision
| [in] | val | Precision in log2 seconds | 
| void pcpp::NtpLayer::setReceiveTimestamp | ( | uint64_t | val | ) | 
Set the value of receive timestamp
| [in] | val | Value in NTP timestamp format | 
| void pcpp::NtpLayer::setReceiveTimestampInSecs | ( | double | val | ) | 
Set the value of receive timestamp
| [in] | val | Value in seconds from Unix Epoch (1 Jan 1970) | 
| void pcpp::NtpLayer::setReferenceIdentifier | ( | ClockSource | val | ) | 
Set the value of reference identifier
| [in] | val | Value of the reference identifier as ClockSource | 
| void pcpp::NtpLayer::setReferenceIdentifier | ( | IPv4Address | val | ) | 
Set the value of reference identifier
| [in] | val | Value of the reference identifier as IPv4 address | 
| void pcpp::NtpLayer::setReferenceIdentifier | ( | KissODeath | val | ) | 
Set the value of reference identifier
| [in] | val | Value of the reference identifier as Kiss-O-Death code | 
| void pcpp::NtpLayer::setReferenceTimestamp | ( | uint64_t | val | ) | 
Set the value of reference timestamp
| [in] | val | Timestamp in NTP timestamp format | 
| void pcpp::NtpLayer::setReferenceTimestampInSecs | ( | double | val | ) | 
Set the value of reference timestamp
| [in] | val | Value in seconds from Unix Epoch (1 Jan 1970) | 
| void pcpp::NtpLayer::setRootDelay | ( | uint32_t | val | ) | 
Set the value of root delay
| [in] | val | Root delay in NTP short format | 
| void pcpp::NtpLayer::setRootDelayInSecs | ( | double | val | ) | 
Set the value of root delay
| [in] | val | Root delay in seconds | 
| void pcpp::NtpLayer::setRootDispersion | ( | uint32_t | val | ) | 
Set the value of root delay
| [in] | val | Root dispersion in NTP short format | 
| void pcpp::NtpLayer::setRootDispersionInSecs | ( | double | val | ) | 
Set the value of root dispersion
| [in] | val | Root dispersion in seconds | 
| void pcpp::NtpLayer::setTransmitTimestamp | ( | uint64_t | val | ) | 
Set the value of transmit timestamp
| [in] | val | Value in NTP timestamp format | 
| void pcpp::NtpLayer::setTransmitTimestampInSecs | ( | double | val | ) | 
Set the value of transmit timestamp
| [in] | val | Value in seconds from Unix Epoch (1 Jan 1970) | 
| 
 | overridevirtual | 
Implements pcpp::Layer.