aboutsummaryrefslogtreecommitdiff
path: root/plugins/check_ntp.c
diff options
context:
space:
mode:
authorGravatar Holger Weiss <holger@zedat.fu-berlin.de> 2014-12-01 01:07:53 +0100
committerGravatar Holger Weiss <holger@zedat.fu-berlin.de> 2014-12-01 01:07:53 +0100
commit99b3bfe488a856df059e933c796590eea0baae8d (patch)
tree1169ed8783ff0a6758bb765f8c9c18655e67a3f3 /plugins/check_ntp.c
parent5871123e0a5f520f810b2cfe03cef16c4c5a1aee (diff)
downloadmonitoring-plugins-99b3bfe488a856df059e933c796590eea0baae8d.tar.gz
check_ntp: Nul-terminate jitter data
Make sure the jitter response is nul-terminated before parsing the data using string functions.
Diffstat (limited to 'plugins/check_ntp.c')
-rw-r--r--plugins/check_ntp.c12
1 files changed, 11 insertions, 1 deletions
diff --git a/plugins/check_ntp.c b/plugins/check_ntp.c
index 0a7640a7..a7d278de 100644
--- a/plugins/check_ntp.c
+++ b/plugins/check_ntp.c
@@ -590,6 +590,9 @@ double jitter_request(const char *host, int *status){
for (i = 0; i < npeers; i++){
/* Only query this server if it is the current sync source */
if (PEER_SEL(peers[i].status) >= min_peer_sel){
+ char jitter_data[MAX_CM_SIZE+1];
+ size_t jitter_data_count;
+
num_selected++;
setup_control_request(&req, OP_READVAR, 2);
req.assoc = peers[i].assoc;
@@ -623,7 +626,14 @@ double jitter_request(const char *host, int *status){
if(verbose) {
printf("parsing jitter from peer %.2x: ", ntohs(peers[i].assoc));
}
- startofvalue = strchr(req.data, '=');
+ if((jitter_data_count = ntohs(req.count)) >= sizeof(jitter_data)){
+ die(STATE_UNKNOWN,
+ _("jitter response too large (%lu bytes)\n"),
+ (unsigned long)jitter_data_count);
+ }
+ memcpy(jitter_data, req.data, jitter_data_count);
+ jitter_data[jitter_data_count] = '\0';
+ startofvalue = strchr(jitter_data, '=');
if(startofvalue != NULL) {
startofvalue++;
jitter = strtod(startofvalue, &nptr);