#include "utils_fbhash.h"
#include "utils_avltree.h"
#include "utils_cache.h"
+#include "utils_complain.h"
#include "network.h"
static int parse_part_sign_sha256 (sockent_t *se, /* {{{ */
void **ret_buffer, size_t *ret_buffer_len, int flags)
{
+ static c_complain_t complain_no_users = C_COMPLAIN_INIT_STATIC;
+
char *buffer;
size_t buffer_len;
size_t buffer_offset;
if (se->data.server.userdb == NULL)
{
- NOTICE ("network plugin: Received signed network packet but can't verify "
- "it because no user DB has been configured. Will accept it.");
+ c_complain (LOG_NOTICE, &complain_no_users,
+ "network plugin: Received signed network packet but can't verify it "
+ "because no user DB has been configured. Will accept it.");
return (0);
}
if (status == 0)
{
vl.time = TIME_T_TO_CDTIME_T (tmp);
- n.time = TIME_T_TO_CDTIME_T (tmp);
+ n.time = TIME_T_TO_CDTIME_T (tmp);
+ }
+ }
+ else if (pkg_type == TYPE_TIME_HR)
+ {
+ uint64_t tmp = 0;
+ status = parse_part_number (&buffer, &buffer_size,
+ &tmp);
+ if (status == 0)
+ {
+ vl.time = (cdtime_t) tmp;
+ n.time = (cdtime_t) tmp;
}
}
else if (pkg_type == TYPE_INTERVAL)
if (status == 0)
vl.interval = TIME_T_TO_CDTIME_T (tmp);
}
+ else if (pkg_type == TYPE_INTERVAL_HR)
+ {
+ uint64_t tmp = 0;
+ status = parse_part_number (&buffer, &buffer_size,
+ &tmp);
+ if (status == 0)
+ vl.interval = (cdtime_t) tmp;
+ }
else if (pkg_type == TYPE_HOST)
{
status = parse_part_string (&buffer, &buffer_size,
if (vl_def->time != vl->time)
{
- time_t tmp = CDTIME_T_TO_TIME_T (vl->time);
- if (write_part_number (&buffer, &buffer_size, TYPE_TIME,
- (uint64_t) tmp))
+ if (write_part_number (&buffer, &buffer_size, TYPE_TIME_HR,
+ (uint64_t) vl->time))
return (-1);
vl_def->time = vl->time;
}
if (vl_def->interval != vl->interval)
{
- /* TODO: Create a new type for sub-second intervals. */
- if (write_part_number (&buffer, &buffer_size, TYPE_INTERVAL,
- (uint64_t) CDTIME_T_TO_TIME_T (vl->interval)))
+ if (write_part_number (&buffer, &buffer_size, TYPE_INTERVAL_HR,
+ (uint64_t) vl->interval))
return (-1);
vl_def->interval = vl->interval;
}
char *buffer_ptr = buffer;
int buffer_free = sizeof (buffer);
int status;
- time_t tmp;
memset (buffer, '\0', sizeof (buffer));
-
- tmp = CDTIME_T_TO_TIME_T (n->time);
- status = write_part_number (&buffer_ptr, &buffer_free, TYPE_TIME,
- (uint64_t) tmp);
+ status = write_part_number (&buffer_ptr, &buffer_free, TYPE_TIME_HR,
+ (uint64_t) n->time);
if (status != 0)
return (-1);