Go to the source code of this file.
Data Structures | |
struct | ldns_struct_dnssec_rrs |
struct | ldns_struct_dnssec_rrsets |
struct | ldns_struct_dnssec_name |
struct | ldns_struct_dnssec_zone |
Structure containing a dnssec zone. More... | |
Typedefs | |
typedef struct ldns_struct_dnssec_rrs | ldns_dnssec_rrs |
Singly linked list of rrs. | |
typedef struct ldns_struct_dnssec_rrsets | ldns_dnssec_rrsets |
Singly linked list of RRsets. | |
typedef struct ldns_struct_dnssec_name | ldns_dnssec_name |
Structure containing all resource records for a domain name Including the derived NSEC3, if present. | |
typedef struct ldns_struct_dnssec_zone | ldns_dnssec_zone |
Functions | |
ldns_dnssec_rrs * | ldns_dnssec_rrs_new (void) |
Creates a new entry for 1 pointer to an rr and 1 pointer to the next rrs. | |
void | ldns_dnssec_rrs_free (ldns_dnssec_rrs *rrs) |
Frees the list of rrs, but not the individual ldns_rr records contained in the list. | |
void | ldns_dnssec_rrs_deep_free (ldns_dnssec_rrs *rrs) |
Frees the list of rrs, and the individual ldns_rr records contained in the list. | |
ldns_status | ldns_dnssec_rrs_add_rr (ldns_dnssec_rrs *rrs, ldns_rr *rr) |
Adds an RR to the list of RRs. | |
void | ldns_dnssec_rrs_print (FILE *out, const ldns_dnssec_rrs *rrs) |
Prints the given rrs to the file descriptor. | |
void | ldns_dnssec_rrs_print_fmt (FILE *out, const ldns_output_format *fmt, const ldns_dnssec_rrs *rrs) |
Prints the given rrs to the file descriptor. | |
ldns_dnssec_rrsets * | ldns_dnssec_rrsets_new (void) |
Creates a new list (entry) of RRsets. | |
void | ldns_dnssec_rrsets_free (ldns_dnssec_rrsets *rrsets) |
Frees the list of rrsets and their rrs, but not the ldns_rr records in the sets. | |
void | ldns_dnssec_rrsets_deep_free (ldns_dnssec_rrsets *rrsets) |
Frees the list of rrsets and their rrs, and the ldns_rr records in the sets. | |
ldns_rr_type | ldns_dnssec_rrsets_type (const ldns_dnssec_rrsets *rrsets) |
Returns the rr type of the rrset (that is head of the given list) | |
ldns_status | ldns_dnssec_rrsets_set_type (ldns_dnssec_rrsets *rrsets, ldns_rr_type type) |
Sets the RR type of the rrset (that is head of the given list) | |
ldns_status | ldns_dnssec_rrsets_add_rr (ldns_dnssec_rrsets *rrsets, ldns_rr *rr) |
Add an ldns_rr to the corresponding RRset in the given list of RRsets. | |
void | ldns_dnssec_rrsets_print (FILE *out, const ldns_dnssec_rrsets *rrsets, signed char follow) |
Print the given list of rrsets to the given file descriptor. | |
void | ldns_dnssec_rrsets_print_fmt (FILE *out, const ldns_output_format *fmt, const ldns_dnssec_rrsets *rrsets, signed char follow) |
Print the given list of rrsets to the given file descriptor. | |
ldns_dnssec_name * | ldns_dnssec_name_new (void) |
Create a new data structure for a dnssec name. | |
ldns_dnssec_name * | ldns_dnssec_name_new_frm_rr (ldns_rr *rr) |
Create a new data structure for a dnssec name for the given RR. | |
void | ldns_dnssec_name_free (ldns_dnssec_name *name) |
Frees the name structure and its rrs and rrsets. | |
void | ldns_dnssec_name_deep_free (ldns_dnssec_name *name) |
Frees the name structure and its rrs and rrsets. | |
ldns_rdf * | ldns_dnssec_name_name (const ldns_dnssec_name *name) |
Returns the domain name of the given dnssec_name structure. | |
void | ldns_dnssec_name_set_name (ldns_dnssec_name *name, ldns_rdf *dname) |
Sets the domain name of the given dnssec_name structure. | |
signed char | ldns_dnssec_name_is_glue (const ldns_dnssec_name *name) |
Returns if dnssec_name structure is marked as glue. | |
void | ldns_dnssec_name_set_nsec (ldns_dnssec_name *name, ldns_rr *nsec) |
Sets the NSEC(3) RR of the given dnssec_name structure. | |
int | ldns_dnssec_name_cmp (const void *a, const void *b) |
Compares the domain names of the two arguments in their canonical ordering. | |
ldns_status | ldns_dnssec_name_add_rr (ldns_dnssec_name *name, ldns_rr *rr) |
Inserts the given rr at the right place in the current dnssec_name No checking is done whether the name matches. | |
ldns_dnssec_rrsets * | ldns_dnssec_name_find_rrset (const ldns_dnssec_name *name, ldns_rr_type type) |
Find the RRset with the given type in within this name structure. | |
ldns_dnssec_rrsets * | ldns_dnssec_zone_find_rrset (const ldns_dnssec_zone *zone, const ldns_rdf *dname, ldns_rr_type type) |
Find the RRset with the given name and type in the zone. | |
void | ldns_dnssec_name_print (FILE *out, const ldns_dnssec_name *name) |
Prints the RRs in the dnssec name structure to the given file descriptor. | |
void | ldns_dnssec_name_print_fmt (FILE *out, const ldns_output_format *fmt, const ldns_dnssec_name *name) |
Prints the RRs in the dnssec name structure to the given file descriptor. | |
ldns_dnssec_zone * | ldns_dnssec_zone_new (void) |
Creates a new dnssec_zone structure. | |
ldns_status | ldns_dnssec_zone_new_frm_fp (ldns_dnssec_zone **z, FILE *fp, const ldns_rdf *origin, uint32_t ttl, ldns_rr_class c) |
Create a new dnssec zone from a file. | |
ldns_status | ldns_dnssec_zone_new_frm_fp_l (ldns_dnssec_zone **z, FILE *fp, const ldns_rdf *origin, uint32_t ttl, ldns_rr_class c, int *line_nr) |
Create a new dnssec zone from a file, keep track of the line numbering. | |
void | ldns_dnssec_zone_free (ldns_dnssec_zone *zone) |
Frees the given zone structure, and its rbtree of dnssec_names Individual ldns_rr RRs within those names are not freed. | |
void | ldns_dnssec_zone_deep_free (ldns_dnssec_zone *zone) |
Frees the given zone structure, and its rbtree of dnssec_names Individual ldns_rr RRs within those names are also freed. | |
ldns_status | ldns_dnssec_zone_add_rr (ldns_dnssec_zone *zone, ldns_rr *rr) |
Adds the given RR to the zone. | |
void | ldns_dnssec_zone_names_print (FILE *out, const ldns_rbtree_t *tree, signed char print_soa) |
Prints the rbtree of ldns_dnssec_name structures to the file descriptor. | |
void | ldns_dnssec_zone_names_print_fmt (FILE *out, const ldns_output_format *fmt, const ldns_rbtree_t *tree, signed char print_soa) |
Prints the rbtree of ldns_dnssec_name structures to the file descriptor. | |
void | ldns_dnssec_zone_print (FILE *out, const ldns_dnssec_zone *zone) |
Prints the complete zone to the given file descriptor. | |
void | ldns_dnssec_zone_print_fmt (FILE *out, const ldns_output_format *fmt, const ldns_dnssec_zone *zone) |
Prints the complete zone to the given file descriptor. | |
ldns_status | ldns_dnssec_zone_add_empty_nonterminals (ldns_dnssec_zone *zone) |
Adds explicit dnssec_name structures for the empty nonterminals in this zone. | |
signed char | ldns_dnssec_zone_is_nsec3_optout (const ldns_dnssec_zone *zone) |
If a NSEC3PARAM is available in the apex, walks the zone and returns true on the first optout nsec3. | |
ldns_status | ldns_dnssec_zone_verify_zonemd (ldns_dnssec_zone *zone) |
typedef struct ldns_struct_dnssec_rrs ldns_dnssec_rrs |
Singly linked list of rrs.
Definition at line 21 of file dnssec_zone.h.
typedef struct ldns_struct_dnssec_rrsets ldns_dnssec_rrsets |
Singly linked list of RRsets.
Definition at line 31 of file dnssec_zone.h.
typedef struct ldns_struct_dnssec_name ldns_dnssec_name |
Structure containing all resource records for a domain name Including the derived NSEC3, if present.
Definition at line 44 of file dnssec_zone.h.
typedef struct ldns_struct_dnssec_zone ldns_dnssec_zone |
Definition at line 104 of file dnssec_zone.h.
ldns_dnssec_rrs * ldns_dnssec_rrs_new | ( | void | ) |
Creates a new entry for 1 pointer to an rr and 1 pointer to the next rrs.
Definition at line 10 of file dnssec_zone.c.
References LDNS_MALLOC, ldns_struct_dnssec_rrs::next, and ldns_struct_dnssec_rrs::rr.
void ldns_dnssec_rrs_free | ( | ldns_dnssec_rrs * | rrs | ) |
Frees the list of rrs, but not the individual ldns_rr records contained in the list.
[in] | rrs | the data structure to free |
Definition at line 35 of file dnssec_zone.c.
void ldns_dnssec_rrs_deep_free | ( | ldns_dnssec_rrs * | rrs | ) |
Frees the list of rrs, and the individual ldns_rr records contained in the list.
[in] | rrs | the data structure to free |
Definition at line 41 of file dnssec_zone.c.
ldns_status ldns_dnssec_rrs_add_rr | ( | ldns_dnssec_rrs * | rrs, |
ldns_rr * | rr | ||
) |
Adds an RR to the list of RRs.
The list will remain ordered. If an equal RR already exists, this RR will not be added.
[in] | rrs | the list to add to |
[in] | rr | the RR to add |
Definition at line 47 of file dnssec_zone.c.
References ldns_dnssec_rrs_add_rr(), ldns_dnssec_rrs_new(), ldns_rr_compare(), LDNS_STATUS_ERR, LDNS_STATUS_OK, ldns_struct_dnssec_rrs::next, and ldns_struct_dnssec_rrs::rr.
void ldns_dnssec_rrs_print | ( | FILE * | out, |
const ldns_dnssec_rrs * | rrs | ||
) |
Prints the given rrs to the file descriptor.
[in] | out | the file descriptor to print to |
[in] | rrs | the list of RRs to print |
Definition at line 97 of file dnssec_zone.c.
References ldns_dnssec_rrs_print_fmt(), and ldns_output_format_default.
void ldns_dnssec_rrs_print_fmt | ( | FILE * | out, |
const ldns_output_format * | fmt, | ||
const ldns_dnssec_rrs * | rrs | ||
) |
Prints the given rrs to the file descriptor.
[in] | out | the file descriptor to print to |
[in] | fmt | the format of the textual representation |
[in] | rrs | the list of RRs to print |
Definition at line 80 of file dnssec_zone.c.
References ldns_struct_output_format::flags, LDNS_COMMENT_LAYOUT, ldns_dnssec_rrs_print_fmt(), ldns_rr_print_fmt(), ldns_struct_dnssec_rrs::next, and ldns_struct_dnssec_rrs::rr.
ldns_dnssec_rrsets * ldns_dnssec_rrsets_new | ( | void | ) |
Creates a new list (entry) of RRsets.
Definition at line 104 of file dnssec_zone.c.
References LDNS_MALLOC, ldns_struct_dnssec_rrsets::next, ldns_struct_dnssec_rrsets::rrs, ldns_struct_dnssec_rrsets::signatures, and ldns_struct_dnssec_rrsets::type.
void ldns_dnssec_rrsets_free | ( | ldns_dnssec_rrsets * | rrsets | ) |
Frees the list of rrsets and their rrs, but not the ldns_rr records in the sets.
[in] | rrsets | the data structure to free |
Definition at line 134 of file dnssec_zone.c.
void ldns_dnssec_rrsets_deep_free | ( | ldns_dnssec_rrsets * | rrsets | ) |
Frees the list of rrsets and their rrs, and the ldns_rr records in the sets.
[in] | rrsets | the data structure to free |
Definition at line 140 of file dnssec_zone.c.
ldns_rr_type ldns_dnssec_rrsets_type | ( | const ldns_dnssec_rrsets * | rrsets | ) |
Returns the rr type of the rrset (that is head of the given list)
[in] | rrsets | the rrset to get the type of |
Definition at line 146 of file dnssec_zone.c.
References ldns_struct_dnssec_rrsets::type.
ldns_status ldns_dnssec_rrsets_set_type | ( | ldns_dnssec_rrsets * | rrsets, |
ldns_rr_type | type | ||
) |
Sets the RR type of the rrset (that is head of the given list)
[in] | rrsets | the rrset to set the type of |
[in] | type | the type to set |
Definition at line 156 of file dnssec_zone.c.
References LDNS_STATUS_ERR, LDNS_STATUS_OK, and ldns_struct_dnssec_rrsets::type.
ldns_status ldns_dnssec_rrsets_add_rr | ( | ldns_dnssec_rrsets * | rrsets, |
ldns_rr * | rr | ||
) |
Add an ldns_rr to the corresponding RRset in the given list of RRsets.
If it is not present, add it as a new RRset with 1 record.
[in] | rrsets | the list of rrsets to add the RR to |
[in] | rr | the rr to add to the list of rrsets |
Definition at line 193 of file dnssec_zone.c.
References ldns_dnssec_rrs_add_rr(), ldns_dnssec_rrs_new(), ldns_dnssec_rrsets_add_rr(), ldns_dnssec_rrsets_new(), ldns_dnssec_rrsets_type(), ldns_rdf2rr_type(), ldns_rr_get_type(), ldns_rr_rrsig_typecovered(), LDNS_RR_TYPE_RRSIG, LDNS_STATUS_ERR, LDNS_STATUS_OK, ldns_struct_dnssec_rrsets::next, ldns_struct_dnssec_rrs::rr, ldns_struct_dnssec_rrsets::rrs, ldns_struct_dnssec_rrsets::signatures, and ldns_struct_dnssec_rrsets::type.
void ldns_dnssec_rrsets_print | ( | FILE * | out, |
const ldns_dnssec_rrsets * | rrsets, | ||
signed char | follow | ||
) |
Print the given list of rrsets to the given file descriptor.
[in] | out | the file descriptor to print to |
[in] | rrsets | the list of RRsets to print |
[in] | follow | if set to false, only print the first RRset |
Definition at line 310 of file dnssec_zone.c.
References ldns_dnssec_rrsets_print_fmt(), and ldns_output_format_default.
void ldns_dnssec_rrsets_print_fmt | ( | FILE * | out, |
const ldns_output_format * | fmt, | ||
const ldns_dnssec_rrsets * | rrsets, | ||
signed char | follow | ||
) |
Print the given list of rrsets to the given file descriptor.
[in] | out | the file descriptor to print to |
[in] | fmt | the format of the textual representation |
[in] | rrsets | the list of RRsets to print |
[in] | follow | if set to false, only print the first RRset |
Definition at line 302 of file dnssec_zone.c.
ldns_dnssec_name * ldns_dnssec_name_new | ( | void | ) |
Create a new data structure for a dnssec name.
Definition at line 317 of file dnssec_zone.c.
References LDNS_CALLOC.
ldns_dnssec_name * ldns_dnssec_name_new_frm_rr | ( | ldns_rr * | rr | ) |
Create a new data structure for a dnssec name for the given RR.
[in] | rr | the RR to derive properties from, and to add to the name |
Definition at line 342 of file dnssec_zone.c.
References ldns_dnssec_name_add_rr(), ldns_dnssec_name_free(), ldns_dnssec_name_new(), ldns_rr_owner(), LDNS_STATUS_OK, and ldns_struct_dnssec_name::name.
void ldns_dnssec_name_free | ( | ldns_dnssec_name * | name | ) |
Frees the name structure and its rrs and rrsets.
Individual ldns_rr records therein are not freed
[in] | name | the structure to free |
Definition at line 383 of file dnssec_zone.c.
void ldns_dnssec_name_deep_free | ( | ldns_dnssec_name * | name | ) |
Frees the name structure and its rrs and rrsets.
Individual ldns_rr records contained in the name are also freed
[in] | name | the structure to free |
Definition at line 389 of file dnssec_zone.c.
ldns_rdf * ldns_dnssec_name_name | ( | const ldns_dnssec_name * | name | ) |
Returns the domain name of the given dnssec_name structure.
[in] | name | the dnssec name to get the domain name from |
Definition at line 395 of file dnssec_zone.c.
References ldns_struct_dnssec_name::name.
void ldns_dnssec_name_set_name | ( | ldns_dnssec_name * | name, |
ldns_rdf * | dname | ||
) |
Sets the domain name of the given dnssec_name structure.
[in] | name | the dnssec name to set the domain name of |
[in] | dname | the domain name to set it to. This data is not copied. |
Definition at line 413 of file dnssec_zone.c.
References ldns_struct_dnssec_name::name.
signed char ldns_dnssec_name_is_glue | ( | const ldns_dnssec_name * | name | ) |
Returns if dnssec_name structure is marked as glue.
The ldns_dnssec_zone_mark_glue() function has to be called on a zone before using this function. Only names that have only glue rrsets will be marked. Names that have other occluded rrsets and names containing glue on the delegation point will NOT be marked!
[in] | name | the dnssec name to get the domain name from |
Definition at line 404 of file dnssec_zone.c.
References ldns_struct_dnssec_name::is_glue.
void ldns_dnssec_name_set_nsec | ( | ldns_dnssec_name * | name, |
ldns_rr * | nsec | ||
) |
Sets the NSEC(3) RR of the given dnssec_name structure.
[in] | name | the dnssec name to set the domain name of |
[in] | nsec | the nsec rr to set it to. This data is not copied. |
Definition at line 423 of file dnssec_zone.c.
References ldns_struct_dnssec_name::nsec.
int ldns_dnssec_name_cmp | ( | const void * | a, |
const void * | b | ||
) |
Compares the domain names of the two arguments in their canonical ordering.
[in] | a | The first dnssec_name to compare |
[in] | b | The second dnssec_name to compare |
Definition at line 431 of file dnssec_zone.c.
References ldns_dname_compare(), and ldns_dnssec_name_name().
ldns_status ldns_dnssec_name_add_rr | ( | ldns_dnssec_name * | name, |
ldns_rr * | rr | ||
) |
Inserts the given rr at the right place in the current dnssec_name No checking is done whether the name matches.
[in] | name | The ldns_dnssec_name to add the RR to |
[in] | rr | The RR to add |
Definition at line 449 of file dnssec_zone.c.
References ldns_dnssec_rrs_add_rr(), ldns_dnssec_rrs_new(), ldns_dnssec_rrsets_add_rr(), ldns_dnssec_rrsets_new(), ldns_rdf2rr_type(), ldns_rr_get_type(), ldns_rr_rrsig_typecovered(), LDNS_RR_TYPE_NSEC, LDNS_RR_TYPE_NSEC3, LDNS_RR_TYPE_RRSIG, LDNS_STATUS_ERR, LDNS_STATUS_OK, ldns_struct_dnssec_name::nsec, ldns_struct_dnssec_name::nsec_signatures, ldns_struct_dnssec_rrs::rr, and ldns_struct_dnssec_name::rrsets.
ldns_dnssec_rrsets * ldns_dnssec_name_find_rrset | ( | const ldns_dnssec_name * | name, |
ldns_rr_type | type | ||
) |
Find the RRset with the given type in within this name structure.
[in] | name | the name to find the RRset in |
[in] | type | the type of the RRset to find |
Definition at line 493 of file dnssec_zone.c.
References ldns_struct_dnssec_rrsets::next, ldns_struct_dnssec_name::rrsets, and ldns_struct_dnssec_rrsets::type.
ldns_dnssec_rrsets * ldns_dnssec_zone_find_rrset | ( | const ldns_dnssec_zone * | zone, |
const ldns_rdf * | dname, | ||
ldns_rr_type | type | ||
) |
Find the RRset with the given name and type in the zone.
[in] | zone | the zone structure to find the RRset in |
[in] | dname | the domain name of the RRset to find |
[in] | type | the type of the RRset to find |
Definition at line 509 of file dnssec_zone.c.
References ldns_rbnode_t::data, ldns_dnssec_name_find_rrset(), ldns_rbtree_search(), and ldns_struct_dnssec_zone::names.
void ldns_dnssec_name_print | ( | FILE * | out, |
const ldns_dnssec_name * | name | ||
) |
Prints the RRs in the dnssec name structure to the given file descriptor.
[in] | out | the file descriptor to print to |
[in] | name | the name structure to print the contents of |
Definition at line 563 of file dnssec_zone.c.
References ldns_dnssec_name_print_fmt(), and ldns_output_format_default.
void ldns_dnssec_name_print_fmt | ( | FILE * | out, |
const ldns_output_format * | fmt, | ||
const ldns_dnssec_name * | name | ||
) |
Prints the RRs in the dnssec name structure to the given file descriptor.
[in] | out | the file descriptor to print to |
[in] | fmt | the format of the textual representation |
[in] | name | the name structure to print the contents of |
Definition at line 556 of file dnssec_zone.c.
ldns_dnssec_zone * ldns_dnssec_zone_new | ( | void | ) |
Creates a new dnssec_zone structure.
Definition at line 570 of file dnssec_zone.c.
References ldns_struct_dnssec_zone::_nsec3params, ldns_struct_dnssec_zone::hashed_names, LDNS_MALLOC, ldns_struct_dnssec_zone::names, and ldns_struct_dnssec_zone::soa.
ldns_status ldns_dnssec_zone_new_frm_fp | ( | ldns_dnssec_zone ** | z, |
FILE * | fp, | ||
const ldns_rdf * | origin, | ||
uint32_t | ttl, | ||
ldns_rr_class | c | ||
) |
Create a new dnssec zone from a file.
[out] | z | the new zone |
[in] | *fp | the filepointer to use |
[in] | *origin | the zones' origin |
[in] | c | default class to use (IN) |
[in] | ttl | default ttl to use |
ldns_status ldns_dnssec_zone_new_frm_fp_l | ( | ldns_dnssec_zone ** | z, |
FILE * | fp, | ||
const ldns_rdf * | origin, | ||
uint32_t | ttl, | ||
ldns_rr_class | c, | ||
int * | line_nr | ||
) |
Create a new dnssec zone from a file, keep track of the line numbering.
[out] | z | the new zone |
[in] | *fp | the filepointer to use |
[in] | *origin | the zones' origin |
[in] | ttl | default ttl to use |
[in] | c | default class to use (IN) |
[out] | line_nr | used for error msg, to get to the line number |
void ldns_dnssec_zone_free | ( | ldns_dnssec_zone * | zone | ) |
Frees the given zone structure, and its rbtree of dnssec_names Individual ldns_rr RRs within those names are not freed.
[in] | *zone | the zone to free |
Definition at line 865 of file dnssec_zone.c.
References ldns_struct_dnssec_zone::hashed_names, LDNS_FREE, ldns_traverse_postorder(), and ldns_struct_dnssec_zone::names.
void ldns_dnssec_zone_deep_free | ( | ldns_dnssec_zone * | zone | ) |
Frees the given zone structure, and its rbtree of dnssec_names Individual ldns_rr RRs within those names are also freed.
[in] | *zone | the zone to free |
Definition at line 885 of file dnssec_zone.c.
References ldns_struct_dnssec_zone::hashed_names, LDNS_FREE, ldns_traverse_postorder(), and ldns_struct_dnssec_zone::names.
ldns_status ldns_dnssec_zone_add_rr | ( | ldns_dnssec_zone * | zone, |
ldns_rr * | rr | ||
) |
Adds the given RR to the zone.
It find whether there is a dnssec_name with that name present. If so, add it to that, if not create a new one. Special handling of NSEC and RRSIG provided
[in] | zone | the zone to add the RR to |
[in] | rr | The RR to add |
Definition at line 1002 of file dnssec_zone.c.
References ldns_rbnode_t::data, ldns_rbnode_t::key, ldns_dname_compare_v(), ldns_dnssec_name_add_rr(), ldns_dnssec_name_free(), ldns_dnssec_name_new_frm_rr(), LDNS_MALLOC, ldns_rbtree_create(), ldns_rbtree_insert(), ldns_rbtree_search(), ldns_rdf2rr_type(), ldns_rr_get_type(), ldns_rr_owner(), ldns_rr_rrsig_typecovered(), LDNS_RR_TYPE_NSEC3, LDNS_RR_TYPE_RRSIG, LDNS_RR_TYPE_SOA, LDNS_STATUS_DNSSEC_NSEC3_ORIGINAL_NOT_FOUND, LDNS_STATUS_ERR, LDNS_STATUS_MEM_ERR, LDNS_STATUS_OK, ldns_struct_dnssec_zone::names, and ldns_struct_dnssec_zone::soa.
void ldns_dnssec_zone_names_print | ( | FILE * | out, |
const ldns_rbtree_t * | tree, | ||
signed char | print_soa | ||
) |
Prints the rbtree of ldns_dnssec_name structures to the file descriptor.
[in] | out | the file descriptor to print the names to |
[in] | tree | the tree of ldns_dnssec_name structures to print |
[in] | print_soa | if true, print SOA records, if false, skip them |
Definition at line 1074 of file dnssec_zone.c.
References ldns_dnssec_zone_names_print_fmt(), and ldns_output_format_default.
void ldns_dnssec_zone_names_print_fmt | ( | FILE * | out, |
const ldns_output_format * | fmt, | ||
const ldns_rbtree_t * | tree, | ||
signed char | print_soa | ||
) |
Prints the rbtree of ldns_dnssec_name structures to the file descriptor.
[in] | out | the file descriptor to print the names to |
[in] | fmt | the format of the textual representation |
[in] | tree | the tree of ldns_dnssec_name structures to print |
[in] | print_soa | if true, print SOA records, if false, skip them |
Definition at line 1056 of file dnssec_zone.c.
References ldns_rbnode_t::data, ldns_struct_output_format::flags, LDNS_COMMENT_LAYOUT, ldns_rbtree_first(), ldns_rbtree_next(), and LDNS_RBTREE_NULL.
void ldns_dnssec_zone_print | ( | FILE * | out, |
const ldns_dnssec_zone * | zone | ||
) |
Prints the complete zone to the given file descriptor.
[in] | out | the file descriptor to print to |
[in] | zone | the dnssec_zone to print |
Definition at line 1109 of file dnssec_zone.c.
References ldns_dnssec_zone_print_fmt(), and ldns_output_format_default.
void ldns_dnssec_zone_print_fmt | ( | FILE * | out, |
const ldns_output_format * | fmt, | ||
const ldns_dnssec_zone * | zone | ||
) |
Prints the complete zone to the given file descriptor.
[in] | out | the file descriptor to print to |
[in] | fmt | the format of the textual representation |
[in] | zone | the dnssec_zone to print |
Definition at line 1081 of file dnssec_zone.c.
References ldns_struct_output_format::flags, LDNS_COMMENT_LAYOUT, ldns_dnssec_name_find_rrset(), ldns_dnssec_name_name(), ldns_dnssec_rrsets_print_fmt(), ldns_dnssec_zone_names_print_fmt(), ldns_rdf_print(), LDNS_RR_TYPE_SOA, ldns_struct_dnssec_zone::names, and ldns_struct_dnssec_zone::soa.
ldns_status ldns_dnssec_zone_add_empty_nonterminals | ( | ldns_dnssec_zone * | zone | ) |
Adds explicit dnssec_name structures for the empty nonterminals in this zone.
(this is needed for NSEC3 generation)
[in] | zone | the zone to check for empty nonterminals return LDNS_STATUS_OK on success. |
Definition at line 1254 of file dnssec_zone.c.
signed char ldns_dnssec_zone_is_nsec3_optout | ( | const ldns_dnssec_zone * | zone | ) |
If a NSEC3PARAM is available in the apex, walks the zone and returns true on the first optout nsec3.
[in] | zone | the zone to check for nsec3 optout records return true when the zone has at least one nsec3 optout record. |
Definition at line 1260 of file dnssec_zone.c.
References ldns_rbnode_t::data, ldns_dnssec_name_find_rrset(), ldns_nsec3_optout(), ldns_rbtree_first(), ldns_rbtree_next(), LDNS_RBTREE_NULL, ldns_rr_get_type(), LDNS_RR_TYPE_NSEC3, LDNS_RR_TYPE_NSEC3PARAM, ldns_struct_dnssec_zone::names, and ldns_struct_dnssec_zone::soa.
ldns_status ldns_dnssec_zone_verify_zonemd | ( | ldns_dnssec_zone * | zone | ) |
Definition at line 1759 of file dnssec_zone.c.
References ldns_rbnode_t::data, ldns_struct_dnssec_name::hashed_name, ldns_struct_dnssec_zone::hashed_names, ldns_dnssec_zone_find_rrset(), ldns_nsec_bitmap_covers_type(), ldns_nsec_get_bitmap(), LDNS_RBTREE_NULL, ldns_rbtree_search(), ldns_rdf2native_int32(), ldns_rdf2native_int8(), ldns_rdf_data(), ldns_rdf_size(), ldns_rr_get_type(), ldns_rr_rd_count(), ldns_rr_rdf(), LDNS_RR_TYPE_SOA, LDNS_RR_TYPE_ZONEMD, LDNS_SHA384_DIGEST_LENGTH, ldns_sha384_final(), LDNS_SHA512_DIGEST_LENGTH, ldns_sha512_final(), LDNS_STATUS_NO_VALID_ZONEMD, LDNS_STATUS_NO_ZONEMD, LDNS_STATUS_NULL, LDNS_STATUS_OK, LDNS_STATUS_ZONEMD_INVALID_SOA, ldns_struct_dnssec_name::name, ldns_struct_dnssec_rrs::next, ldns_struct_dnssec_name::nsec, ldns_struct_dnssec_rrs::rr, ldns_struct_dnssec_rrsets::rrs, struct_zone_digester::sha384_CTX, struct_zone_digester::sha512_CTX, struct_zone_digester::simple_sha384, struct_zone_digester::simple_sha512, ldns_struct_dnssec_zone::soa, ZONEMD_HASH_SHA384, ZONEMD_HASH_SHA512, and ZONEMD_SCHEME_SIMPLE.