root/usr.sbin/nsd/verify.h
/*
 * verify.h
 *
 * Copyright (c) 2020, NLnet Labs. All rights reserved.
 *
 * See LICENSE for the license.
 */
#ifndef VERIFY_H
#define VERIFY_H

#ifndef USE_MINI_EVENT
#  ifdef HAVE_EVENT_H
#    include <event.h>
#  else
#    include <event2/event.h>
#    include "event2/event_struct.h"
#    include "event2/event_compat.h"
#  endif
#else
#  include "mini_event.h"
#endif

/*
 * Track position in zone to feed verifier more data as the input descriptor
 * becomes available.
 */
struct verifier_zone_feed {
        FILE *fh;
        struct event event;
        zone_rr_iter_type rriter;
        struct state_pretty_rr *rrprinter;
        struct region *region;
        struct buffer *buffer;
};

/* 40 is (estimated) space already used on each logline.
 * (time, pid, priority, etc)
 */
#define LOGLINELEN (MAXSYSLOGMSGLEN-40)

#define LOGBUFSIZE (LOGLINELEN * 2)

/*
 * STDOUT and STDERR are logged per line. Lines that exceed LOGLINELEN, are
 * split over multiple entries. Line breaks are indicated with "..." in the log
 * before and after the break.
 */
struct verifier_stream {
        int fd;
        struct event event;
        int priority;
        int cut;
        char buf[LOGBUFSIZE+1];
        size_t cnt;
        size_t off;
};

struct verifier {
        struct nsd *nsd;
        struct zone *zone;
        pid_t pid;
        int was_ok;
        struct timeval timeout;
        struct event timeout_event;
        struct verifier_zone_feed zone_feed;
        struct verifier_stream output_stream;
        struct verifier_stream error_stream;
};

struct zone *verify_next_zone(struct nsd *nsd, struct zone *zone);

void verify_zone(struct nsd *nsd, struct zone *zone);

void verify_handle_signal(int sig, short event, void *arg);

void verify_handle_exit(int fd, short event, void *arg);

void verify_handle_command(int fd, short event, void *arg);

#endif /* VERIFY_H */