Training courses

Kernel and Embedded Linux

Bootlin training courses

Embedded Linux, kernel,
Yocto Project, Buildroot, real-time,
graphics, boot time, debugging...

Bootlin logo

Elixir Cross Referencer

/*
 * ixfrcreate.h -- generating IXFR differences from zonefiles.
 *
 * Copyright (c) 2021, NLnet Labs. All rights reserved.
 *
 * See LICENSE for the license.
 *
 */

#ifndef _IXFRCREATE_H_
#define _IXFRCREATE_H_
#include "dns.h"
struct zone;
struct nsd;

/* the ixfr create data structure while the ixfr difference from zone files
 * is created. */
struct ixfr_create {
	/* the old serial and new serial */
	uint32_t old_serial, new_serial;
	/* the file with the spooled old zone data */
	char* file_name;
	/* zone name in uncompressed wireformat */
	uint8_t* zone_name;
	/* length of zone name */
	size_t zone_name_len;
	/* max size of ixfr in bytes */
	size_t max_size;
	/* we are in checkzone, errors should go to the console, not to the
	 * serverlog */
	int errorcmdline;
};

/* start ixfr creation */
struct ixfr_create* ixfr_create_start(struct zone* zone, const char* zfile,
	uint64_t ixfr_size, int errorcmdline);

/* free ixfr create */
void ixfr_create_free(struct ixfr_create* ixfrcr);

/* create the IXFR from differences. The old zone is spooled to file
 * and the new zone is in memory now.
 * With append_mem it does not only write to file but sticks it into the
 * memory lookup structure for IXFRs used by the server. */
int ixfr_create_perform(struct ixfr_create* ixfrcr, struct zone* zone,
	int append_mem, struct nsd* nsd, const char* zfile,
	uint32_t ixfr_number);

/* cancel ixfrcreation, that was started, but not performed yet.
 * It removes the temporary file. */
void ixfr_create_cancel(struct ixfr_create* ixfrcr);

/* returns true if ixfr should be created by taking difference between
 * zone file contents. Also checks if ixfr is enabled for the zone. */
int ixfr_create_from_difference(struct zone* zone, const char* zfile,
	int* ixfr_create_already_done_flag);

/* readup existing file if it already exists */
void ixfr_readup_exist(struct zone* zone, struct nsd* nsd, const char* zfile);

/*
 * Structure to keep track of spool domain name iterator.
 * This reads from the spool file and steps over the domain name
 * elements one by one. It keeps track of: is the first one read yet,
 * are we at end nothing more, is the element processed yet that is
 * current read into the buffer?
 */
struct spool_dname_iterator {
	/* the domain name that has recently been read, but can be none
	 * if before first or after last. */
	uint8_t dname[MAXDOMAINLEN+1];
	/* length of the dname, if one is read, otherwise 0 */
	size_t dname_len;
	/* if we are before the first element, hence nothing is read yet */
	int read_first;
	/* if we are after the last element, nothing to read, end of file */
	int eof;
	/* is the element processed that is currently in dname? */
	int is_processed;
	/* the file to read from */
	FILE* spool;
	/* filename for error printout */
	char* file_name;
};

#endif /* _IXFRCREATE_H_ */