/** number of concurrent notify packets in flight */
#define NOTIFY_CONCURRENT_MAX 16
/** notify packet info */
struct notify_pkt {
struct acl_options* dest; /* target, NULL if entry not in use */
uint8_t notify_retry; /* how manieth retry in sending to current */
uint16_t notify_query_id;
time_t send_time;
};
/**
* This struct keeps track of outbound notifies for a zone.
*/
struct notify_zone {
rbnode_type node;
/* name of the zone */
const dname_type* apex;
const char* apex_str;
tsig_record_type notify_tsig; /* tsig state for notify */
struct zone_options* options;
struct xfrd_soa *current_soa; /* current SOA in NSD */
/* notify sending handler */
/* Not saved on disk (i.e. kill of daemon stops notifies) */
int notify_send_enable;
struct event notify_send_handler;
int notify_send6_enable;
struct event notify_send6_handler;
struct timeval notify_timeout;
struct acl_options* notify_current; /* current slave to notify */
uint8_t notify_restart; /* restart notify after repattern */
struct notify_pkt pkts[NOTIFY_CONCURRENT_MAX];
int notify_pkt_count; /* number of entries nonNULL in pkts */
/* is this notify waiting for a socket? */
uint8_t is_waiting;
/* the double linked waiting list for the udp sockets */
struct notify_zone* waiting_next;
struct notify_zone* waiting_prev;
} ATTR_PACKED;
/* send notifications to all in the notify list */
void xfrd_send_notify(rbtree_type* tree, const struct dname* apex,
struct xfrd_soa* new_soa);
/* start notifications, if not started already (does not clobber SOA) */
void xfrd_notify_start(struct notify_zone* zone, struct xfrd_state* xfrd);
/* handle soa update notify for a master zone. newsoa can be NULL.
Makes sure that the soa (serial) has changed. Or drops notify. */
void notify_handle_master_zone_soainfo(rbtree_type* tree,
const dname_type* apex, struct xfrd_soa* new_soa);
/* close fds in use for notification sending */
void close_notify_fds(rbtree_type* tree);
/* stop send of notify */
void notify_disable(struct notify_zone* zone);