GNUnet 0.27.0-17-g14611e095
 
Loading...
Searching...
No Matches
DNS parser library

Helper library to parse DNS packets. More...

Collaboration diagram for DNS parser library:

Data Structures

struct  GNUNET_DNSPARSER_Query
 A DNS query. More...
 
struct  GNUNET_DNSPARSER_MxRecord
 Information from MX records (RFC 1035). More...
 
struct  GNUNET_DNSPARSER_SrvRecord
 Information from SRV records (RFC 2782). More...
 
struct  GNUNET_DNSPARSER_UriRecord
 Information from URI records (RFC 7553). More...
 
struct  GNUNET_DNSPARSER_CertRecord
 Information from CERT records (RFC 4034). More...
 
struct  GNUNET_DNSPARSER_SoaRecord
 Information from SOA records (RFC 1035). More...
 
struct  GNUNET_DNSPARSER_CaaRecord
 Information from CAA records (RFC 6844). More...
 
struct  GNUNET_DNSPARSER_RawRecord
 Binary record information (unparsed). More...
 
struct  GNUNET_DNSPARSER_Record
 A DNS response record. More...
 
struct  GNUNET_DNSPARSER_Packet
 Easy-to-process, parsed version of a DNS packet. More...
 

Macros

#define GNUNET_DNSPARSER_MAX_LABEL_LENGTH   63
 Maximum length of a label in DNS.
 
#define GNUNET_DNSPARSER_MAX_NAME_LENGTH   253
 Maximum length of a name in DNS.
 
#define GNUNET_DNSPARSER_TYPE_ANY   0
 A few common DNS types.
 
#define GNUNET_DNSPARSER_TYPE_A   1
 
#define GNUNET_DNSPARSER_TYPE_NS   2
 
#define GNUNET_DNSPARSER_TYPE_CNAME   5
 
#define GNUNET_DNSPARSER_TYPE_SOA   6
 
#define GNUNET_DNSPARSER_TYPE_PTR   12
 
#define GNUNET_DNSPARSER_TYPE_MX   15
 
#define GNUNET_DNSPARSER_TYPE_TXT   16
 
#define GNUNET_DNSPARSER_TYPE_RP   17
 
#define GNUNET_DNSPARSER_TYPE_AFSDB   18
 
#define GNUNET_DNSPARSER_TYPE_SIG   24
 
#define GNUNET_DNSPARSER_TYPE_KEY   25
 
#define GNUNET_DNSPARSER_TYPE_AAAA   28
 
#define GNUNET_DNSPARSER_TYPE_LOC   29
 
#define GNUNET_DNSPARSER_TYPE_SRV   33
 
#define GNUNET_DNSPARSER_TYPE_NAPTR   35
 
#define GNUNET_DNSPARSER_TYPE_KX   36
 
#define GNUNET_DNSPARSER_TYPE_CERT   37
 
#define GNUNET_DNSPARSER_TYPE_DNAME   39
 
#define GNUNET_DNSPARSER_TYPE_APL   42
 
#define GNUNET_DNSPARSER_TYPE_DS   43
 
#define GNUNET_DNSPARSER_TYPE_SSHFP   44
 
#define GNUNET_DNSPARSER_TYPE_IPSECKEY   45
 
#define GNUNET_DNSPARSER_TYPE_RRSIG   46
 
#define GNUNET_DNSPARSER_TYPE_NSEC   47
 
#define GNUNET_DNSPARSER_TYPE_DNSKEY   48
 
#define GNUNET_DNSPARSER_TYPE_DHCID   49
 
#define GNUNET_DNSPARSER_TYPE_NSEC3   50
 
#define GNUNET_DNSPARSER_TYPE_NSEC3PARAM   51
 
#define GNUNET_DNSPARSER_TYPE_TLSA   52
 
#define GNUNET_DNSPARSER_TYPE_SMIMEA   53
 
#define GNUNET_DNSPARSER_TYPE_HIP   55
 
#define GNUNET_DNSPARSER_TYPE_CDS   59
 
#define GNUNET_DNSPARSER_TYPE_CDNSKEY   60
 
#define GNUNET_DNSPARSER_TYPE_OPENPGPKEY   61
 
#define GNUNET_DNSPARSER_TYPE_TKEY   249
 
#define GNUNET_DNSPARSER_TYPE_TSIG   250
 
#define GNUNET_DNSPARSER_TYPE_ALL   255
 
#define GNUNET_DNSPARSER_TYPE_URI   256
 
#define GNUNET_DNSPARSER_TYPE_CAA   257
 
#define GNUNET_DNSPARSER_TYPE_TA   32768
 

Enumerations

enum  GNUNET_DNSPARSER_CertType {
  GNUNET_DNSPARSER_CERTTYPE_RESERVED = 0 , GNUNET_DNSPARSER_CERTTYPE_PKIX = 1 , GNUNET_DNSPARSER_CERTTYPE_SKPI = 2 , GNUNET_DNSPARSER_CERTTYPE_PGP = 3 ,
  GNUNET_DNSPARSER_CERTTYPE_IPKIX = 4 , GNUNET_DNSPARSER_CERTTYPE_ISKPI = 5 , GNUNET_DNSPARSER_CERTTYPE_IPGP = 6 , GNUNET_DNSPARSER_CERTTYPE_ACPKIX = 7 ,
  GNUNET_DNSPARSER_CERTTYPE_IACKPIX = 8
}
 DNS CERT types as defined in RFC 4398. More...
 
enum  GNUNET_DNSPARSER_CertAlgorithm {
  GNUNET_DNSPARSER_CERTALGO_UNDEFINED = 0 , GNUNET_DNSPARSER_CERTALGO_RSAMD5 = 1 , GNUNET_DNSPARSER_CERTALGO_DH = 2 , GNUNET_DNSPARSER_CERTALGO_DSASHA = 3 ,
  GNUNET_DNSPARSER_CERTALGO_RSRVD4 = 4 , GNUNET_DNSPARSER_CERTALGO_RSASHA = 5 , GNUNET_DNSPARSER_CERTALGO_DSANSEC3 = 6 , GNUNET_DNSPARSER_CERTALGO_RSANSEC3 = 7 ,
  GNUNET_DNSPARSER_CERTALGO_RSASHA256 = 8 , GNUNET_DNSPARSER_CERTALGO_RSRVD9 = 9 , GNUNET_DNSPARSER_CERTALGO_RSASHA512 = 10 , GNUNET_DNSPARSER_CERTALGO_GOST_R34 = 12 ,
  GNUNET_DNSPARSER_CERTALGO_ECDSA_P256SHA256 = 13 , GNUNET_DNSPARSER_CERTALGO_ECDSA_P384SHA384 = 14
}
 DNSCERT algorithms as defined in http://www.iana.org/assignments/ dns-sec-alg-numbers/dns-sec-alg-numbers.xhtml, under dns-sec-alg-numbers-1. More...
 

Functions

enum GNUNET_GenericReturnValue GNUNET_DNSPARSER_check_label (const char *label)
 Check if a label in UTF-8 format can be coded into valid IDNA.
 
enum GNUNET_GenericReturnValue GNUNET_DNSPARSER_check_name (const char *name)
 Check if a hostname in UTF-8 format can be coded into valid IDNA.
 
struct GNUNET_DNSPARSER_PacketGNUNET_DNSPARSER_parse (const char *udp_payload, size_t udp_payload_length)
 Parse a UDP payload of a DNS packet in to a nice struct for further processing and manipulation.
 
void GNUNET_DNSPARSER_free_packet (struct GNUNET_DNSPARSER_Packet *p)
 Free memory taken by a packet.
 
int GNUNET_DNSPARSER_pack (const struct GNUNET_DNSPARSER_Packet *p, uint16_t max, char **buf, size_t *buf_length)
 Given a DNS packet p, generate the corresponding UDP payload.
 
int GNUNET_DNSPARSER_builder_add_name (char *dst, size_t dst_len, size_t *off, const char *name)
 Add a DNS name to the UDP packet at the given location, converting the name to IDNA notation as necessary.
 
int GNUNET_DNSPARSER_builder_add_query (char *dst, size_t dst_len, size_t *off, const struct GNUNET_DNSPARSER_Query *query)
 Add a DNS query to the UDP packet at the given location.
 
int GNUNET_DNSPARSER_builder_add_mx (char *dst, size_t dst_len, size_t *off, const struct GNUNET_DNSPARSER_MxRecord *mx)
 Add an MX record to the UDP packet at the given location.
 
int GNUNET_DNSPARSER_builder_add_soa (char *dst, size_t dst_len, size_t *off, const struct GNUNET_DNSPARSER_SoaRecord *soa)
 Add an SOA record to the UDP packet at the given location.
 
int GNUNET_DNSPARSER_builder_add_cert (char *dst, size_t dst_len, size_t *off, const struct GNUNET_DNSPARSER_CertRecord *cert)
 Add CERT record to the UDP packet at the given location.
 
int GNUNET_DNSPARSER_builder_add_srv (char *dst, size_t dst_len, size_t *off, const struct GNUNET_DNSPARSER_SrvRecord *srv)
 Add an SRV record to the UDP packet at the given location.
 
int GNUNET_DNSPARSER_builder_add_uri (char *dst, size_t dst_len, size_t *off, const struct GNUNET_DNSPARSER_UriRecord *uri)
 Add an URI record to the UDP packet at the given location.
 
int GNUNET_DNSPARSER_parse_record (const char *udp_payload, size_t udp_payload_length, size_t *off, struct GNUNET_DNSPARSER_Record *r)
 Parse a DNS record entry.
 
char * GNUNET_DNSPARSER_parse_name (const char *udp_payload, size_t udp_payload_length, size_t *off)
 Parse name inside of a DNS query or record.
 
int GNUNET_DNSPARSER_parse_query (const char *udp_payload, size_t udp_payload_length, size_t *off, struct GNUNET_DNSPARSER_Query *q)
 Parse a DNS query entry.
 
struct GNUNET_DNSPARSER_SoaRecordGNUNET_DNSPARSER_parse_soa (const char *udp_payload, size_t udp_payload_length, size_t *off)
 Parse a DNS SOA record.
 
struct GNUNET_DNSPARSER_CertRecordGNUNET_DNSPARSER_parse_cert (const char *udp_payload, size_t udp_payload_length, size_t *off)
 Parse a DNS CERT record.
 
struct GNUNET_DNSPARSER_MxRecordGNUNET_DNSPARSER_parse_mx (const char *udp_payload, size_t udp_payload_length, size_t *off)
 Parse a DNS MX record.
 
struct GNUNET_DNSPARSER_SrvRecordGNUNET_DNSPARSER_parse_srv (const char *udp_payload, size_t udp_payload_length, size_t *off)
 Parse a DNS SRV record.
 
struct GNUNET_DNSPARSER_UriRecordGNUNET_DNSPARSER_parse_uri (const char *udp_payload, size_t udp_payload_length, size_t *off)
 Parse a DNS URI record.
 
struct GNUNET_DNSPARSER_RecordGNUNET_DNSPARSER_duplicate_record (const struct GNUNET_DNSPARSER_Record *r)
 Duplicate (deep-copy) the given DNS record.
 
struct GNUNET_DNSPARSER_SoaRecordGNUNET_DNSPARSER_duplicate_soa_record (const struct GNUNET_DNSPARSER_SoaRecord *r)
 Duplicate (deep-copy) the given DNS record.
 
struct GNUNET_DNSPARSER_CertRecordGNUNET_DNSPARSER_duplicate_cert_record (const struct GNUNET_DNSPARSER_CertRecord *r)
 Duplicate (deep-copy) the given DNS record.
 
struct GNUNET_DNSPARSER_MxRecordGNUNET_DNSPARSER_duplicate_mx_record (const struct GNUNET_DNSPARSER_MxRecord *r)
 Duplicate (deep-copy) the given DNS record.
 
struct GNUNET_DNSPARSER_SrvRecordGNUNET_DNSPARSER_duplicate_srv_record (const struct GNUNET_DNSPARSER_SrvRecord *r)
 Duplicate (deep-copy) the given DNS record.
 
struct GNUNET_DNSPARSER_UriRecordGNUNET_DNSPARSER_duplicate_uri_record (const struct GNUNET_DNSPARSER_UriRecord *r)
 Duplicate (deep-copy) the given DNS record.
 
void GNUNET_DNSPARSER_free_record (struct GNUNET_DNSPARSER_Record *r)
 Free the given DNS record.
 
void GNUNET_DNSPARSER_free_mx (struct GNUNET_DNSPARSER_MxRecord *mx)
 Free MX information record.
 
void GNUNET_DNSPARSER_free_srv (struct GNUNET_DNSPARSER_SrvRecord *srv)
 Free SRV information record.
 
void GNUNET_DNSPARSER_free_uri (struct GNUNET_DNSPARSER_UriRecord *uri)
 Free URI information record.
 
void GNUNET_DNSPARSER_free_soa (struct GNUNET_DNSPARSER_SoaRecord *soa)
 Free SOA information record.
 
void GNUNET_DNSPARSER_free_cert (struct GNUNET_DNSPARSER_CertRecord *cert)
 Free CERT information record.
 
char * GNUNET_DNSPARSER_bin_to_hex (const void *data, size_t data_size)
 Convert a block of binary data to HEX.
 
size_t GNUNET_DNSPARSER_hex_to_bin (const char *hex, void *data)
 Convert a HEX string to block of binary data.
 

Detailed Description

Helper library to parse DNS packets.

Macro Definition Documentation

◆ GNUNET_DNSPARSER_MAX_LABEL_LENGTH

#define GNUNET_DNSPARSER_MAX_LABEL_LENGTH   63

Maximum length of a label in DNS.

Definition at line 46 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_MAX_NAME_LENGTH

#define GNUNET_DNSPARSER_MAX_NAME_LENGTH   253

Maximum length of a name in DNS.

Definition at line 51 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_ANY

#define GNUNET_DNSPARSER_TYPE_ANY   0

A few common DNS types.

Definition at line 57 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_A

#define GNUNET_DNSPARSER_TYPE_A   1

Definition at line 58 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_NS

#define GNUNET_DNSPARSER_TYPE_NS   2

Definition at line 59 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_CNAME

#define GNUNET_DNSPARSER_TYPE_CNAME   5

Definition at line 60 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_SOA

#define GNUNET_DNSPARSER_TYPE_SOA   6

Definition at line 61 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_PTR

#define GNUNET_DNSPARSER_TYPE_PTR   12

Definition at line 62 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_MX

#define GNUNET_DNSPARSER_TYPE_MX   15

Definition at line 63 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_TXT

#define GNUNET_DNSPARSER_TYPE_TXT   16

Definition at line 64 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_RP

#define GNUNET_DNSPARSER_TYPE_RP   17

Definition at line 65 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_AFSDB

#define GNUNET_DNSPARSER_TYPE_AFSDB   18

Definition at line 66 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_SIG

#define GNUNET_DNSPARSER_TYPE_SIG   24

Definition at line 67 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_KEY

#define GNUNET_DNSPARSER_TYPE_KEY   25

Definition at line 68 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_AAAA

#define GNUNET_DNSPARSER_TYPE_AAAA   28

Definition at line 69 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_LOC

#define GNUNET_DNSPARSER_TYPE_LOC   29

Definition at line 70 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_SRV

#define GNUNET_DNSPARSER_TYPE_SRV   33

Definition at line 71 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_NAPTR

#define GNUNET_DNSPARSER_TYPE_NAPTR   35

Definition at line 72 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_KX

#define GNUNET_DNSPARSER_TYPE_KX   36

Definition at line 73 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_CERT

#define GNUNET_DNSPARSER_TYPE_CERT   37

Definition at line 74 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_DNAME

#define GNUNET_DNSPARSER_TYPE_DNAME   39

Definition at line 75 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_APL

#define GNUNET_DNSPARSER_TYPE_APL   42

Definition at line 76 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_DS

#define GNUNET_DNSPARSER_TYPE_DS   43

Definition at line 77 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_SSHFP

#define GNUNET_DNSPARSER_TYPE_SSHFP   44

Definition at line 78 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_IPSECKEY

#define GNUNET_DNSPARSER_TYPE_IPSECKEY   45

Definition at line 79 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_RRSIG

#define GNUNET_DNSPARSER_TYPE_RRSIG   46

Definition at line 80 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_NSEC

#define GNUNET_DNSPARSER_TYPE_NSEC   47

Definition at line 81 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_DNSKEY

#define GNUNET_DNSPARSER_TYPE_DNSKEY   48

Definition at line 82 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_DHCID

#define GNUNET_DNSPARSER_TYPE_DHCID   49

Definition at line 83 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_NSEC3

#define GNUNET_DNSPARSER_TYPE_NSEC3   50

Definition at line 84 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_NSEC3PARAM

#define GNUNET_DNSPARSER_TYPE_NSEC3PARAM   51

Definition at line 85 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_TLSA

#define GNUNET_DNSPARSER_TYPE_TLSA   52

Definition at line 86 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_SMIMEA

#define GNUNET_DNSPARSER_TYPE_SMIMEA   53

Definition at line 87 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_HIP

#define GNUNET_DNSPARSER_TYPE_HIP   55

Definition at line 88 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_CDS

#define GNUNET_DNSPARSER_TYPE_CDS   59

Definition at line 89 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_CDNSKEY

#define GNUNET_DNSPARSER_TYPE_CDNSKEY   60

Definition at line 90 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_OPENPGPKEY

#define GNUNET_DNSPARSER_TYPE_OPENPGPKEY   61

Definition at line 91 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_TKEY

#define GNUNET_DNSPARSER_TYPE_TKEY   249

Definition at line 92 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_TSIG

#define GNUNET_DNSPARSER_TYPE_TSIG   250

Definition at line 93 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_ALL

#define GNUNET_DNSPARSER_TYPE_ALL   255

Definition at line 94 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_URI

#define GNUNET_DNSPARSER_TYPE_URI   256

Definition at line 95 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_CAA

#define GNUNET_DNSPARSER_TYPE_CAA   257

Definition at line 96 of file gnunet_dnsparser_lib.h.

◆ GNUNET_DNSPARSER_TYPE_TA

#define GNUNET_DNSPARSER_TYPE_TA   32768

Definition at line 97 of file gnunet_dnsparser_lib.h.

Enumeration Type Documentation

◆ GNUNET_DNSPARSER_CertType

DNS CERT types as defined in RFC 4398.

Enumerator
GNUNET_DNSPARSER_CERTTYPE_RESERVED 

Reserved value.

GNUNET_DNSPARSER_CERTTYPE_PKIX 

An x509 PKIX certificate.

GNUNET_DNSPARSER_CERTTYPE_SKPI 

A SKPI certificate.

GNUNET_DNSPARSER_CERTTYPE_PGP 

A PGP certificate.

GNUNET_DNSPARSER_CERTTYPE_IPKIX 

An x509 PKIX cert URL.

GNUNET_DNSPARSER_CERTTYPE_ISKPI 

A SKPI cert URL.

GNUNET_DNSPARSER_CERTTYPE_IPGP 

A PGP cert fingerprint and URL.

GNUNET_DNSPARSER_CERTTYPE_ACPKIX 

An attribute Certificate.

GNUNET_DNSPARSER_CERTTYPE_IACKPIX 

An attribute cert URL.

Definition at line 211 of file gnunet_dnsparser_lib.h.

212{
217
222
227
232
237
242
247
252
257};
@ GNUNET_DNSPARSER_CERTTYPE_SKPI
A SKPI certificate.
@ GNUNET_DNSPARSER_CERTTYPE_ISKPI
A SKPI cert URL.
@ GNUNET_DNSPARSER_CERTTYPE_IPGP
A PGP cert fingerprint and URL.
@ GNUNET_DNSPARSER_CERTTYPE_IACKPIX
An attribute cert URL.
@ GNUNET_DNSPARSER_CERTTYPE_PGP
A PGP certificate.
@ GNUNET_DNSPARSER_CERTTYPE_ACPKIX
An attribute Certificate.
@ GNUNET_DNSPARSER_CERTTYPE_RESERVED
Reserved value.
@ GNUNET_DNSPARSER_CERTTYPE_PKIX
An x509 PKIX certificate.
@ GNUNET_DNSPARSER_CERTTYPE_IPKIX
An x509 PKIX cert URL.

◆ GNUNET_DNSPARSER_CertAlgorithm

DNSCERT algorithms as defined in http://www.iana.org/assignments/ dns-sec-alg-numbers/dns-sec-alg-numbers.xhtml, under dns-sec-alg-numbers-1.

Enumerator
GNUNET_DNSPARSER_CERTALGO_UNDEFINED 

No defined.

GNUNET_DNSPARSER_CERTALGO_RSAMD5 

RSA/MD5.

GNUNET_DNSPARSER_CERTALGO_DH 

Diffie-Hellman.

GNUNET_DNSPARSER_CERTALGO_DSASHA 

DSA/SHA1.

GNUNET_DNSPARSER_CERTALGO_RSRVD4 

Reserved.

GNUNET_DNSPARSER_CERTALGO_RSASHA 

RSA/SHA1.

GNUNET_DNSPARSER_CERTALGO_DSANSEC3 

DSA/NSEC3/SHA.

GNUNET_DNSPARSER_CERTALGO_RSANSEC3 

RSA/NSEC3/SHA.

GNUNET_DNSPARSER_CERTALGO_RSASHA256 

RSA/SHA256.

GNUNET_DNSPARSER_CERTALGO_RSRVD9 

Reserved.

GNUNET_DNSPARSER_CERTALGO_RSASHA512 

RSA/SHA512.

GNUNET_DNSPARSER_CERTALGO_GOST_R34 

GHOST R 34.10-2001.

GNUNET_DNSPARSER_CERTALGO_ECDSA_P256SHA256 

ECDSA Curve P-256/SHA256.

GNUNET_DNSPARSER_CERTALGO_ECDSA_P384SHA384 

ECDSA Curve P-384/SHA384.

Definition at line 264 of file gnunet_dnsparser_lib.h.

265{
270
275
280
285
290
295
300
305
310
315
320
325
330
335};
@ GNUNET_DNSPARSER_CERTALGO_RSAMD5
RSA/MD5.
@ GNUNET_DNSPARSER_CERTALGO_RSASHA
RSA/SHA1.
@ GNUNET_DNSPARSER_CERTALGO_RSRVD9
Reserved.
@ GNUNET_DNSPARSER_CERTALGO_GOST_R34
GHOST R 34.10-2001.
@ GNUNET_DNSPARSER_CERTALGO_RSASHA256
RSA/SHA256.
@ GNUNET_DNSPARSER_CERTALGO_RSRVD4
Reserved.
@ GNUNET_DNSPARSER_CERTALGO_DSANSEC3
DSA/NSEC3/SHA.
@ GNUNET_DNSPARSER_CERTALGO_ECDSA_P256SHA256
ECDSA Curve P-256/SHA256.
@ GNUNET_DNSPARSER_CERTALGO_RSASHA512
RSA/SHA512.
@ GNUNET_DNSPARSER_CERTALGO_DH
Diffie-Hellman.
@ GNUNET_DNSPARSER_CERTALGO_ECDSA_P384SHA384
ECDSA Curve P-384/SHA384.
@ GNUNET_DNSPARSER_CERTALGO_RSANSEC3
RSA/NSEC3/SHA.
@ GNUNET_DNSPARSER_CERTALGO_DSASHA
DSA/SHA1.
@ GNUNET_DNSPARSER_CERTALGO_UNDEFINED
No defined.

Function Documentation

◆ GNUNET_DNSPARSER_check_label()

enum GNUNET_GenericReturnValue GNUNET_DNSPARSER_check_label ( const char *  label)

Check if a label in UTF-8 format can be coded into valid IDNA.

This can fail if the ASCII-conversion becomes longer than 63 characters.

Parameters
labellabel to check (UTF-8 string)
Returns
GNUNET_OK if the label can be converted to IDNA, GNUNET_SYSERR if the label is not valid for DNS names

Definition at line 53 of file dnsparser.c.

54{
55 char *output;
56 size_t slen;
57
58 if (NULL != strchr (label, '.'))
59 return GNUNET_SYSERR; /* not a label! Did you mean GNUNET_DNSPARSER_check_name? */
60 if (0 == strcmp (label, "@")) /* '@' is reserved for the empty label, see #GNUNET_GNS_EMPTY_LABEL_AT */
61 return GNUNET_SYSERR;
62 if (IDNA_SUCCESS != idna_to_ascii_8z (label, &output, IDNA_ALLOW_UNASSIGNED))
63 return GNUNET_SYSERR;
64 slen = strlen (output);
65 free (output);
66 return (slen > 63) ? GNUNET_SYSERR : GNUNET_OK;
67}
@ GNUNET_OK
@ GNUNET_SYSERR

References GNUNET_OK, and GNUNET_SYSERR.

Referenced by GNUNET_DNSPARSER_check_name().

Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_check_name()

enum GNUNET_GenericReturnValue GNUNET_DNSPARSER_check_name ( const char *  name)

Check if a hostname in UTF-8 format can be coded into valid IDNA.

This can fail if a label becomes longer than 63 characters or if the entire name exceeds 253 characters.

Parameters
namename to check (UTF-8 string)
Returns
GNUNET_OK if the label can be converted to IDNA, GNUNET_SYSERR if the label is not valid for DNS names

Check if a hostname in UTF-8 format can be coded into valid IDNA.

This can fail if the ASCII-conversion becomes longer than 253 characters.

Parameters
namename to check (UTF-8 string)
Returns
GNUNET_OK if the label can be converted to IDNA, GNUNET_SYSERR if the label is not valid for DNS names

Definition at line 79 of file dnsparser.c.

80{
81 {
82 char *ldup;
83 char *saveptr;
84
85 ldup = GNUNET_strdup (name);
86 for (const char *tok = strtok_r (ldup,
87 ".",
88 &saveptr);
89 NULL != tok;
90 tok = strtok_r (NULL,
91 ".",
92 &saveptr))
93 {
94 if (GNUNET_OK !=
96 {
97 GNUNET_free (ldup);
98 return GNUNET_SYSERR;
99 }
100 }
101 GNUNET_free (ldup);
102 }
103 {
104 char *output;
105 size_t slen;
106
107 if (IDNA_SUCCESS !=
108 idna_to_ascii_8z (name,
109 &output,
110 IDNA_ALLOW_UNASSIGNED))
111 return GNUNET_SYSERR;
112 slen = strlen (output);
113 free (output);
114 return (slen > 253) ? GNUNET_SYSERR : GNUNET_OK;
115 }
116}
static char * name
Name (label) of the records to list.
enum GNUNET_GenericReturnValue GNUNET_DNSPARSER_check_label(const char *label)
Check if a label in UTF-8 format can be coded into valid IDNA.
Definition dnsparser.c:53
#define GNUNET_strdup(a)
Wrapper around GNUNET_xstrdup_.
#define GNUNET_free(ptr)
Wrapper around free.

References GNUNET_DNSPARSER_check_label(), GNUNET_free, GNUNET_OK, GNUNET_strdup, GNUNET_SYSERR, and name.

Referenced by queue(), queue(), and run().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_parse()

struct GNUNET_DNSPARSER_Packet * GNUNET_DNSPARSER_parse ( const char *  udp_payload,
size_t  udp_payload_length 
)

Parse a UDP payload of a DNS packet in to a nice struct for further processing and manipulation.

Parameters
udp_payloadwire-format of the DNS packet
udp_payload_lengthnumber of bytes in udp_payload
Returns
NULL on error, otherwise the parsed packet

Definition at line 746 of file dnsparser.c.

747{
749 const struct GNUNET_TUN_DnsHeader *dns;
750 size_t off;
751 unsigned int n;
752
753 if (udp_payload_length < sizeof(struct GNUNET_TUN_DnsHeader))
754 return NULL;
755 dns = (const struct GNUNET_TUN_DnsHeader *) udp_payload;
756 off = sizeof(struct GNUNET_TUN_DnsHeader);
758 p->flags = dns->flags;
759 p->id = dns->id;
760 n = ntohs (dns->query_count);
761 if (n > 0)
762 {
763 p->queries = GNUNET_new_array (n, struct GNUNET_DNSPARSER_Query);
764 p->num_queries = n;
765 for (unsigned int i = 0; i < n; i++)
766 if (GNUNET_OK != GNUNET_DNSPARSER_parse_query (udp_payload,
767 udp_payload_length,
768 &off,
769 &p->queries[i]))
770 goto error;
771 }
772 n = ntohs (dns->answer_rcount);
773 if (n > 0)
774 {
775 p->answers = GNUNET_new_array (n, struct GNUNET_DNSPARSER_Record);
776 p->num_answers = n;
777 for (unsigned int i = 0; i < n; i++)
778 if (GNUNET_OK != GNUNET_DNSPARSER_parse_record (udp_payload,
779 udp_payload_length,
780 &off,
781 &p->answers[i]))
782 goto error;
783 }
784 n = ntohs (dns->authority_rcount);
785 if (n > 0)
786 {
787 p->authority_records = GNUNET_new_array (n, struct GNUNET_DNSPARSER_Record);
788 p->num_authority_records = n;
789 for (unsigned int i = 0; i < n; i++)
790 if (GNUNET_OK != GNUNET_DNSPARSER_parse_record (udp_payload,
791 udp_payload_length,
792 &off,
793 &p->authority_records[i]))
794 goto error;
795 }
796 n = ntohs (dns->additional_rcount);
797 if (n > 0)
798 {
799 p->additional_records =
801 p->num_additional_records = n;
802 for (unsigned int i = 0; i < n; i++)
803 {
804 if (GNUNET_OK !=
806 udp_payload_length,
807 &off,
808 &p->additional_records[i]))
809 goto error;
810 }
811 }
812 return p;
813error:
814 GNUNET_break_op (0);
816 return NULL;
817}
static struct GNUNET_Process * p
Helper process we started.
Definition gnunet-uri.c:38
void GNUNET_DNSPARSER_free_packet(struct GNUNET_DNSPARSER_Packet *p)
Free memory taken by a packet.
Definition dnsparser.c:967
int GNUNET_DNSPARSER_parse_query(const char *udp_payload, size_t udp_payload_length, size_t *off, struct GNUNET_DNSPARSER_Query *q)
Parse a DNS query entry.
Definition dnsparser.c:389
int GNUNET_DNSPARSER_parse_record(const char *udp_payload, size_t udp_payload_length, size_t *off, struct GNUNET_DNSPARSER_Record *r)
Parse a DNS record entry.
Definition dnsparser.c:639
#define GNUNET_break_op(cond)
Use this for assertion violations caused by other peers (i.e.
#define GNUNET_new(type)
Allocate a struct or union of the given type.
#define GNUNET_new_array(n, type)
Allocate a size n array with structs or unions of the given type.
Easy-to-process, parsed version of a DNS packet.
A DNS response record.
struct GNUNET_TUN_DnsFlags flags
Flags.
uint16_t query_count
Number of queries.
uint16_t authority_rcount
Number of authoritative answers.
uint16_t id
Unique identifier for the request/response.
uint16_t additional_rcount
Number of additional records.
uint16_t answer_rcount
Number of answers.

References GNUNET_TUN_DnsHeader::additional_rcount, GNUNET_TUN_DnsHeader::answer_rcount, GNUNET_TUN_DnsHeader::authority_rcount, GNUNET_TUN_DnsHeader::flags, GNUNET_break_op, GNUNET_DNSPARSER_free_packet(), GNUNET_DNSPARSER_parse_query(), GNUNET_DNSPARSER_parse_record(), GNUNET_new, GNUNET_new_array, GNUNET_OK, GNUNET_TUN_DnsHeader::id, p, and GNUNET_TUN_DnsHeader::query_count.

Referenced by display_request(), dns_post_request_handler(), dns_result_parser(), dns_result_processor(), handle_dns_request(), handle_request(), handle_resolve_result(), modify_request(), process_result(), and process_result().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_free_packet()

void GNUNET_DNSPARSER_free_packet ( struct GNUNET_DNSPARSER_Packet p)

Free memory taken by a packet.

Parameters
ppacket to free

Definition at line 967 of file dnsparser.c.

968{
969 for (unsigned int i = 0; i < p->num_queries; i++)
970 GNUNET_free (p->queries[i].name);
971 GNUNET_free (p->queries);
972 for (unsigned int i = 0; i < p->num_answers; i++)
973 GNUNET_DNSPARSER_free_record (&p->answers[i]);
974 GNUNET_free (p->answers);
975 for (unsigned int i = 0; i < p->num_authority_records; i++)
976 GNUNET_DNSPARSER_free_record (&p->authority_records[i]);
977 GNUNET_free (p->authority_records);
978 for (unsigned int i = 0; i < p->num_additional_records; i++)
979 GNUNET_DNSPARSER_free_record (&p->additional_records[i]);
980 GNUNET_free (p->additional_records);
981 GNUNET_free (p);
982}
void GNUNET_DNSPARSER_free_record(struct GNUNET_DNSPARSER_Record *r)
Free the given DNS record.
Definition dnsparser.c:201

References GNUNET_DNSPARSER_free_record(), GNUNET_free, and p.

Referenced by display_request(), dns_post_request_handler(), dns_result_parser(), do_timeout(), finish_request(), GNS_interceptor_done(), GNUNET_DNSPARSER_parse(), handle_dns_request(), handle_request(), handle_resolve_result(), modify_request(), process_result(), process_result(), recursive_dns_resolution(), reply_to_dns(), result_processor(), send_response(), and vpn_allocation_callback().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_pack()

int GNUNET_DNSPARSER_pack ( const struct GNUNET_DNSPARSER_Packet p,
uint16_t  max,
char **  buf,
size_t *  buf_length 
)

Given a DNS packet p, generate the corresponding UDP payload.

Note that we do not attempt to pack the strings with pointers as this would complicate the code and this is about being simple and secure, not fast, fancy and broken like bind.

Parameters
ppacket to pack
maxmaximum allowed size for the resulting UDP payload
bufset to a buffer with the packed message
buf_lengthset to the length of buf
Returns
GNUNET_SYSERR if p is invalid GNUNET_NO if p was truncated (but there is still a result in buf) GNUNET_OK if p was packed completely into buf

Definition at line 1417 of file dnsparser.c.

1421{
1422 struct GNUNET_TUN_DnsHeader dns;
1423 size_t off;
1424 char tmp[max];
1425 int ret;
1426 int trc;
1427
1428 if ((p->num_queries > UINT16_MAX) || (p->num_answers > UINT16_MAX) ||
1429 (p->num_authority_records > UINT16_MAX) ||
1430 (p->num_additional_records > UINT16_MAX))
1431 return GNUNET_SYSERR;
1432 dns.id = p->id;
1433 dns.flags = p->flags;
1434 dns.query_count = htons (p->num_queries);
1435 dns.answer_rcount = htons (p->num_answers);
1436 dns.authority_rcount = htons (p->num_authority_records);
1437 dns.additional_rcount = htons (p->num_additional_records);
1438
1439 off = sizeof(struct GNUNET_TUN_DnsHeader);
1440 trc = GNUNET_NO;
1441 for (unsigned int i = 0; i < p->num_queries; i++)
1442 {
1444 sizeof(tmp),
1445 &off,
1446 &p->queries[i]);
1447 if (GNUNET_SYSERR == ret)
1448 return GNUNET_SYSERR;
1449 if (GNUNET_NO == ret)
1450 {
1451 dns.query_count = htons ((uint16_t) (i - 1));
1452 trc = GNUNET_YES;
1453 break;
1454 }
1455 }
1456 for (unsigned int i = 0; i < p->num_answers; i++)
1457 {
1458 ret = add_record (tmp, sizeof(tmp), &off, &p->answers[i]);
1459 if (GNUNET_SYSERR == ret)
1460 return GNUNET_SYSERR;
1461 if (GNUNET_NO == ret)
1462 {
1463 dns.answer_rcount = htons ((uint16_t) (i - 1));
1464 trc = GNUNET_YES;
1465 break;
1466 }
1467 }
1468 for (unsigned int i = 0; i < p->num_authority_records; i++)
1469 {
1470 ret = add_record (tmp, sizeof(tmp), &off, &p->authority_records[i]);
1471 if (GNUNET_SYSERR == ret)
1472 return GNUNET_SYSERR;
1473 if (GNUNET_NO == ret)
1474 {
1475 dns.authority_rcount = htons ((uint16_t) (i - 1));
1476 trc = GNUNET_YES;
1477 break;
1478 }
1479 }
1480 for (unsigned int i = 0; i < p->num_additional_records; i++)
1481 {
1482 ret = add_record (tmp, sizeof(tmp), &off, &p->additional_records[i]);
1483 if (GNUNET_SYSERR == ret)
1484 return GNUNET_SYSERR;
1485 if (GNUNET_NO == ret)
1486 {
1487 dns.additional_rcount = htons (i - 1);
1488 trc = GNUNET_YES;
1489 break;
1490 }
1491 }
1492
1493 if (GNUNET_YES == trc)
1494 dns.flags.message_truncated = 1;
1495 GNUNET_memcpy (tmp, &dns, sizeof(struct GNUNET_TUN_DnsHeader));
1496
1497 *buf = GNUNET_malloc (off);
1498 *buf_length = off;
1499 GNUNET_memcpy (*buf, tmp, off);
1500 if (GNUNET_YES == trc)
1501 return GNUNET_NO;
1502 return GNUNET_OK;
1503}
static int add_record(char *dst, size_t dst_len, size_t *off, const struct GNUNET_DNSPARSER_Record *record)
Add a DNS record to the UDP packet at the given location.
Definition dnsparser.c:1310
static int ret
Final status code.
Definition gnunet-arm.c:93
int GNUNET_DNSPARSER_builder_add_query(char *dst, size_t dst_len, size_t *off, const struct GNUNET_DNSPARSER_Query *query)
Add a DNS query to the UDP packet at the given location.
Definition dnsparser.c:1080
#define GNUNET_memcpy(dst, src, n)
Call memcpy() but check for n being 0 first.
@ GNUNET_YES
@ GNUNET_NO
#define GNUNET_malloc(size)
Wrapper around malloc.
#define max(x, y)

References add_record(), GNUNET_TUN_DnsHeader::additional_rcount, GNUNET_TUN_DnsHeader::answer_rcount, GNUNET_TUN_DnsHeader::authority_rcount, GNUNET_TUN_DnsHeader::flags, GNUNET_DNSPARSER_builder_add_query(), GNUNET_malloc, GNUNET_memcpy, GNUNET_NO, GNUNET_OK, GNUNET_SYSERR, GNUNET_YES, GNUNET_TUN_DnsHeader::id, max, GNUNET_TUN_DnsFlags::message_truncated, p, GNUNET_TUN_DnsHeader::query_count, and ret.

Referenced by build_dns_query(), finish_request(), modify_request(), pack(), queue(), recursive_dns_resolution(), reply_to_dns(), and send_response().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_builder_add_name()

int GNUNET_DNSPARSER_builder_add_name ( char *  dst,
size_t  dst_len,
size_t *  off,
const char *  name 
)

Add a DNS name to the UDP packet at the given location, converting the name to IDNA notation as necessary.

Parameters
dstwhere to write the name (UDP packet)
dst_lennumber of bytes in dst
offpointer to offset where to write the name (increment by bytes used) must not be changed if there is an error
namename to write
Returns
GNUNET_SYSERR if name is invalid GNUNET_NO if name did not fit GNUNET_OK if name was added to dst

Definition at line 1002 of file dnsparser.c.

1006{
1007 const char *dot;
1008 const char *idna_name;
1009 char *idna_start;
1010 size_t start;
1011 size_t pos;
1012 size_t len;
1013 Idna_rc rc;
1014
1015 if (NULL == name)
1016 return GNUNET_SYSERR;
1017
1018 if (IDNA_SUCCESS !=
1019 (rc = idna_to_ascii_8z (name, &idna_start, IDNA_ALLOW_UNASSIGNED)))
1020 {
1022 _ (
1023 "Failed to convert UTF-8 name `%s' to DNS IDNA format: %s\n"),
1024 name,
1025 idna_strerror (rc));
1026 return GNUNET_NO;
1027 }
1028 idna_name = idna_start;
1029 GNUNET_assert (*off <= SIZE_MAX - strlen (idna_name) - 2);
1030 start = *off;
1031 if (start + strlen (idna_name) + 2 > dst_len)
1032 goto fail;
1033 pos = start;
1034 do
1035 {
1036 dot = strchr (idna_name, '.');
1037 if (NULL == dot)
1038 len = strlen (idna_name);
1039 else
1040 len = dot - idna_name;
1041 if (len == 0)
1042 break;
1043 if (len >= 64)
1044 {
1046 "Invalid DNS name `%s': label with %u characters encountered\n",
1047 name,
1048 (unsigned int) len);
1049 goto fail; /* label too long or empty */
1050 }
1051 dst[pos++] = (char) (uint8_t) len;
1052 GNUNET_memcpy (&dst[pos], idna_name, len);
1053 pos += len;
1054 idna_name += len + 1; /* also skip dot */
1055 }
1056 while (NULL != dot);
1057 dst[pos++] = '\0'; /* terminator */
1058 *off = pos;
1059 free (idna_start);
1060 return GNUNET_OK;
1061fail:
1062 free (idna_start);
1063 return GNUNET_NO;
1064}
static int start
Set if we are to start default services (including ARM).
Definition gnunet-arm.c:38
char * idna_name
DNS IDNA name to lookup.
Definition gnunet-gns.c:63
#define GNUNET_log(kind,...)
#define GNUNET_assert(cond)
Use this for fatal errors that cannot be handled.
@ GNUNET_ERROR_TYPE_WARNING
@ GNUNET_ERROR_TYPE_ERROR
#define _(String)
GNU gettext support macro.
Definition platform.h:179
#define SIZE_MAX
Definition platform.h:209

References _, GNUNET_assert, GNUNET_ERROR_TYPE_ERROR, GNUNET_ERROR_TYPE_WARNING, GNUNET_log, GNUNET_memcpy, GNUNET_NO, GNUNET_OK, GNUNET_SYSERR, idna_name, name, SIZE_MAX, and start.

Referenced by add_record(), dns_result_parser(), dns_string_to_value(), GNUNET_DNSPARSER_builder_add_mx(), GNUNET_DNSPARSER_builder_add_query(), GNUNET_DNSPARSER_builder_add_soa(), GNUNET_DNSPARSER_builder_add_srv(), handle_gns_resolution_result(), and process_record().

Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_builder_add_query()

int GNUNET_DNSPARSER_builder_add_query ( char *  dst,
size_t  dst_len,
size_t *  off,
const struct GNUNET_DNSPARSER_Query query 
)

Add a DNS query to the UDP packet at the given location.

Parameters
dstwhere to write the query
dst_lennumber of bytes in dst
offpointer to offset where to write the query (increment by bytes used) must not be changed if there is an error
queryquery to write
Returns
GNUNET_SYSERR if query is invalid GNUNET_NO if query did not fit GNUNET_OK if query was added to dst

Definition at line 1080 of file dnsparser.c.

1084{
1085 int ret;
1086 struct GNUNET_TUN_DnsQueryLine ql;
1087
1088 GNUNET_assert (dst_len >= sizeof (ql));
1090 dst_len - sizeof(ql),
1091 off,
1092 query->name);
1093 if (ret != GNUNET_OK)
1094 return ret;
1095 ql.type = htons (query->type);
1096 ql.dns_traffic_class = htons (query->dns_traffic_class);
1097 GNUNET_memcpy (&dst[*off], &ql, sizeof(ql));
1098 (*off) += sizeof(ql);
1099 return GNUNET_OK;
1100}
int GNUNET_DNSPARSER_builder_add_name(char *dst, size_t dst_len, size_t *off, const char *name)
Add a DNS name to the UDP packet at the given location, converting the name to IDNA notation as neces...
Definition dnsparser.c:1002
uint16_t dns_traffic_class
See GNUNET_TUN_DNS_CLASS_*.
uint16_t type
See GNUNET_DNSPARSER_TYPE_*.
char * name
Name of the record that the query is for (0-terminated).

References GNUNET_DNSPARSER_Query::dns_traffic_class, GNUNET_TUN_DnsQueryLine::dns_traffic_class, GNUNET_assert, GNUNET_DNSPARSER_builder_add_name(), GNUNET_memcpy, GNUNET_OK, GNUNET_DNSPARSER_Query::name, ret, GNUNET_DNSPARSER_Query::type, and GNUNET_TUN_DnsQueryLine::type.

Referenced by GNUNET_DNSPARSER_pack().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_builder_add_mx()

int GNUNET_DNSPARSER_builder_add_mx ( char *  dst,
size_t  dst_len,
size_t *  off,
const struct GNUNET_DNSPARSER_MxRecord mx 
)

Add an MX record to the UDP packet at the given location.

Parameters
dstwhere to write the mx record
dst_lennumber of bytes in dst
offpointer to offset where to write the mx information (increment by bytes used); can also change if there was an error
mxmx information to write
Returns
GNUNET_SYSERR if mx is invalid GNUNET_NO if mx did not fit GNUNET_OK if mx was added to dst

Definition at line 1116 of file dnsparser.c.

1120{
1121 uint16_t mxpref;
1122
1123 GNUNET_assert (*off <= SIZE_MAX - sizeof (uint16_t));
1124 if (*off + sizeof(uint16_t) > dst_len)
1125 return GNUNET_NO;
1126 mxpref = htons (mx->preference);
1127 GNUNET_memcpy (&dst[*off], &mxpref, sizeof(mxpref));
1128 (*off) += sizeof(mxpref);
1129 return GNUNET_DNSPARSER_builder_add_name (dst, dst_len, off, mx->mxhost);
1130}
char * mxhost
Name of the mail server.
uint16_t preference
Preference for this entry (lower value is higher preference).

References GNUNET_assert, GNUNET_DNSPARSER_builder_add_name(), GNUNET_memcpy, GNUNET_NO, GNUNET_DNSPARSER_MxRecord::mxhost, GNUNET_DNSPARSER_MxRecord::preference, and SIZE_MAX.

Referenced by add_record(), dns_result_parser(), dns_string_to_value(), handle_gns_resolution_result(), and process_record().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_builder_add_soa()

int GNUNET_DNSPARSER_builder_add_soa ( char *  dst,
size_t  dst_len,
size_t *  off,
const struct GNUNET_DNSPARSER_SoaRecord soa 
)

Add an SOA record to the UDP packet at the given location.

Parameters
dstwhere to write the SOA record
dst_lennumber of bytes in dst
offpointer to offset where to write the SOA information (increment by bytes used) can also change if there was an error
soaSOA information to write
Returns
GNUNET_SYSERR if soa is invalid GNUNET_NO if soa did not fit GNUNET_OK if soa was added to dst

Definition at line 1194 of file dnsparser.c.

1198{
1199 struct GNUNET_TUN_DnsSoaRecord sd;
1200 int ret;
1201
1202 if ((GNUNET_OK !=
1203 (ret =
1204 GNUNET_DNSPARSER_builder_add_name (dst, dst_len, off, soa->mname))) ||
1205 (GNUNET_OK !=
1206 (ret =
1207 GNUNET_DNSPARSER_builder_add_name (dst, dst_len, off, soa->rname))))
1208 return ret;
1209 if (*off + sizeof(struct GNUNET_TUN_DnsSoaRecord) > dst_len)
1210 return GNUNET_NO;
1211 sd.serial = htonl (soa->serial);
1212 sd.refresh = htonl (soa->refresh);
1213 sd.retry = htonl (soa->retry);
1214 sd.expire = htonl (soa->expire);
1215 sd.minimum = htonl (soa->minimum_ttl);
1216 GNUNET_memcpy (&dst[*off], &sd, sizeof(sd));
1217 (*off) += sizeof(sd);
1218 return GNUNET_OK;
1219}
uint32_t retry
Time interval that should elapse before a failed refresh should be retried.
char * mname
The domainname of the name server that was the original or primary source of data for this zone.
uint32_t refresh
Time interval before the zone should be refreshed.
uint32_t minimum_ttl
The bit minimum TTL field that should be exported with any RR from this zone.
char * rname
A domainname which specifies the mailbox of the person responsible for this zone.
uint32_t expire
Time value that specifies the upper limit on the time interval that can elapse before the zone is no ...
uint32_t serial
The version number of the original copy of the zone.
Payload of DNS SOA record (header).
uint32_t serial
The version number of the original copy of the zone.

References GNUNET_DNSPARSER_SoaRecord::expire, GNUNET_TUN_DnsSoaRecord::expire, GNUNET_DNSPARSER_builder_add_name(), GNUNET_memcpy, GNUNET_NO, GNUNET_OK, GNUNET_TUN_DnsSoaRecord::minimum, GNUNET_DNSPARSER_SoaRecord::minimum_ttl, GNUNET_DNSPARSER_SoaRecord::mname, GNUNET_DNSPARSER_SoaRecord::refresh, GNUNET_TUN_DnsSoaRecord::refresh, ret, GNUNET_DNSPARSER_SoaRecord::retry, GNUNET_TUN_DnsSoaRecord::retry, GNUNET_DNSPARSER_SoaRecord::rname, GNUNET_DNSPARSER_SoaRecord::serial, and GNUNET_TUN_DnsSoaRecord::serial.

Referenced by add_record(), dns_result_parser(), dns_string_to_value(), handle_gns_resolution_result(), and process_record().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_builder_add_cert()

int GNUNET_DNSPARSER_builder_add_cert ( char *  dst,
size_t  dst_len,
size_t *  off,
const struct GNUNET_DNSPARSER_CertRecord cert 
)

Add CERT record to the UDP packet at the given location.

Parameters
dstwhere to write the CERT record
dst_lennumber of bytes in dst
offpointer to offset where to write the CERT information (increment by bytes used) can also change if there was an error
certCERT information to write
Returns
GNUNET_SYSERR if soa is invalid GNUNET_NO if soa did not fit GNUNET_OK if soa was added to dst

Add CERT record to the UDP packet at the given location.

Parameters
dstwhere to write the CERT record
dst_lennumber of bytes in dst
offpointer to offset where to write the CERT information (increment by bytes used); can also change if there was an error
certCERT information to write
Returns
GNUNET_SYSERR if cert is invalid GNUNET_NO if cert did not fit GNUNET_OK if cert was added to dst

Definition at line 1146 of file dnsparser.c.

1151{
1152 struct GNUNET_TUN_DnsCertRecord dcert;
1153
1154#ifdef __clang__
1155#pragma clang diagnostic push
1156#pragma clang diagnostic ignored "-Wtautological-constant-out-of-range-compare"
1157#endif
1158 if ((cert->cert_type > UINT16_MAX) || (cert->algorithm > UINT8_MAX))
1159 {
1160 GNUNET_break (0);
1161 return GNUNET_SYSERR;
1162 }
1163#ifdef __clang__
1164#pragma clang diagnostic pop
1165#endif
1166 GNUNET_assert (*off <= SIZE_MAX - sizeof (dcert));
1167 GNUNET_assert (cert->certificate_size <= SIZE_MAX - *off - sizeof (dcert));
1168 if (*off + sizeof(dcert) + cert->certificate_size > dst_len)
1169 return GNUNET_NO;
1170 dcert.cert_type = htons ((uint16_t) cert->cert_type);
1171 dcert.cert_tag = htons ((uint16_t) cert->cert_tag);
1172 dcert.algorithm = (uint8_t) cert->algorithm;
1173 GNUNET_memcpy (&dst[*off], &dcert, sizeof(dcert));
1174 (*off) += sizeof(dcert);
1175 GNUNET_memcpy (&dst[*off], cert->certificate_data, cert->certificate_size);
1176 (*off) += cert->certificate_size;
1177 return GNUNET_OK;
1178}
#define GNUNET_break(cond)
Use this for internal assertion violations that are not fatal (can be handled) but should not occur.
enum GNUNET_DNSPARSER_CertType cert_type
Certificate type.
char * certificate_data
Data of the certificate.
enum GNUNET_DNSPARSER_CertAlgorithm algorithm
Algorithm.
size_t certificate_size
Number of bytes in certificate_data.
uint16_t cert_tag
Certificate KeyTag.
Payload of DNS CERT record.

References GNUNET_DNSPARSER_CertRecord::algorithm, GNUNET_TUN_DnsCertRecord::algorithm, GNUNET_DNSPARSER_CertRecord::cert_tag, GNUNET_TUN_DnsCertRecord::cert_tag, GNUNET_DNSPARSER_CertRecord::cert_type, GNUNET_TUN_DnsCertRecord::cert_type, GNUNET_DNSPARSER_CertRecord::certificate_data, GNUNET_DNSPARSER_CertRecord::certificate_size, GNUNET_assert, GNUNET_break, GNUNET_memcpy, GNUNET_NO, GNUNET_OK, GNUNET_SYSERR, and SIZE_MAX.

Referenced by add_record(), dns_string_to_value(), and process_record().

Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_builder_add_srv()

int GNUNET_DNSPARSER_builder_add_srv ( char *  dst,
size_t  dst_len,
size_t *  off,
const struct GNUNET_DNSPARSER_SrvRecord srv 
)

Add an SRV record to the UDP packet at the given location.

Parameters
dstwhere to write the SRV record
dst_lennumber of bytes in dst
offpointer to offset where to write the SRV information (increment by bytes used) can also change if there was an error
srvSRV information to write
Returns
GNUNET_SYSERR if srv is invalid GNUNET_NO if srv did not fit GNUNET_OK if srv was added to dst

Definition at line 1235 of file dnsparser.c.

1239{
1240 struct GNUNET_TUN_DnsSrvRecord sd;
1241 int ret;
1242
1243 GNUNET_assert (*off <= SIZE_MAX - sizeof (sd));
1244 if (*off + sizeof(sd) > dst_len)
1245 return GNUNET_NO;
1246 sd.prio = htons (srv->priority);
1247 sd.weight = htons (srv->weight);
1248 sd.port = htons (srv->port);
1249 GNUNET_memcpy (&dst[*off], &sd, sizeof(sd));
1250 (*off) += sizeof(sd);
1251 if (GNUNET_OK !=
1252 (ret =
1253 GNUNET_DNSPARSER_builder_add_name (dst, dst_len, off, srv->target)))
1254 return ret;
1255 return GNUNET_OK;
1256}
uint16_t port
TCP or UDP port of the service.
uint16_t weight
Relative weight for records with the same priority.
uint16_t priority
Preference for this entry (lower value is higher preference).
char * target
Hostname offering the service.
Payload of DNS SRV record (header).

References GNUNET_assert, GNUNET_DNSPARSER_builder_add_name(), GNUNET_memcpy, GNUNET_NO, GNUNET_OK, GNUNET_DNSPARSER_SrvRecord::port, GNUNET_TUN_DnsSrvRecord::port, GNUNET_TUN_DnsSrvRecord::prio, GNUNET_DNSPARSER_SrvRecord::priority, ret, SIZE_MAX, GNUNET_DNSPARSER_SrvRecord::target, GNUNET_DNSPARSER_SrvRecord::weight, and GNUNET_TUN_DnsSrvRecord::weight.

Referenced by add_record(), dns_result_parser(), dns_string_to_value(), handle_gns_resolution_result(), and process_record().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_builder_add_uri()

int GNUNET_DNSPARSER_builder_add_uri ( char *  dst,
size_t  dst_len,
size_t *  off,
const struct GNUNET_DNSPARSER_UriRecord uri 
)

Add an URI record to the UDP packet at the given location.

Parameters
dstwhere to write the URI record
dst_lennumber of bytes in dst
offpointer to offset where to write the URI information (increment by bytes used) can also change if there was an error
uriURI information to write
Returns
GNUNET_SYSERR if uri is invalid GNUNET_NO if uri did not fit GNUNET_OK if uri was added to dst

Definition at line 1272 of file dnsparser.c.

1276{
1277 struct GNUNET_TUN_DnsUriRecord sd;
1278 int written;
1279 size_t max_target_len;
1280
1281 GNUNET_assert (dst_len > sizeof (sd));
1282 GNUNET_assert (*off <= SIZE_MAX - sizeof (sd));
1283 max_target_len = dst_len - sizeof (sd) - 1;
1284 if (*off + sizeof(sd) > dst_len)
1285 return GNUNET_NO;
1286 sd.prio = htons (uri->priority);
1287 sd.weight = htons (uri->weight);
1288 GNUNET_memcpy (&dst[*off], &sd, sizeof(sd));
1289 (*off) += sizeof(sd);
1290 written = GNUNET_snprintf (&dst[*off], max_target_len, "%s", uri->target);
1291 (*off) += written;
1292 dst[*off] = '\0';
1293 return GNUNET_OK;
1294}
static struct GNUNET_FS_Uri * uri
Value of URI provided on command-line (when not publishing a file but just creating UBlocks to refer ...
int GNUNET_snprintf(char *buf, size_t size, const char *format,...) __attribute__((format(printf
Like snprintf, just aborts if the buffer is of insufficient size.
Payload of DNS URI record (header).

References GNUNET_assert, GNUNET_memcpy, GNUNET_NO, GNUNET_OK, GNUNET_snprintf(), GNUNET_TUN_DnsUriRecord::prio, SIZE_MAX, uri, and GNUNET_TUN_DnsUriRecord::weight.

Referenced by add_record(), dns_result_parser(), dns_string_to_value(), handle_gns_resolution_result(), and process_record().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_parse_record()

int GNUNET_DNSPARSER_parse_record ( const char *  udp_payload,
size_t  udp_payload_length,
size_t *  off,
struct GNUNET_DNSPARSER_Record r 
)

Parse a DNS record entry.

Parameters
udp_payloadentire UDP payload
udp_payload_lengthlength of udp_payload
offpointer to the offset of the record to parse in the udp_payload (to be incremented by the size of the record)
rwhere to write the record information
Returns
GNUNET_OK on success, GNUNET_SYSERR if the record is malformed

Definition at line 639 of file dnsparser.c.

643{
644 char *name;
645 struct GNUNET_TUN_DnsRecordLine rl;
646 size_t old_off;
647 uint16_t data_len;
648
649 name = GNUNET_DNSPARSER_parse_name (udp_payload, udp_payload_length, off);
650 if (NULL == name)
651 {
652 GNUNET_break_op (0);
653 return GNUNET_SYSERR;
654 }
655 r->name = name;
656 if (*off + sizeof(struct GNUNET_TUN_DnsRecordLine) > udp_payload_length)
657 {
658 GNUNET_break_op (0);
659 return GNUNET_SYSERR;
660 }
661 GNUNET_memcpy (&rl, &udp_payload[*off], sizeof(rl));
662 (*off) += sizeof(rl);
663 r->type = ntohs (rl.type);
664 r->dns_traffic_class = ntohs (rl.dns_traffic_class);
667 data_len = ntohs (rl.data_len);
668 if (*off + data_len > udp_payload_length)
669 {
670 GNUNET_break_op (0);
671 return GNUNET_SYSERR;
672 }
673 old_off = *off;
674 switch (r->type)
675 {
680 r->data.hostname =
681 GNUNET_DNSPARSER_parse_name (udp_payload, udp_payload_length, off);
682 if ((NULL == r->data.hostname) || (old_off + data_len != *off))
683 return GNUNET_SYSERR;
684 return GNUNET_OK;
685
687 r->data.soa =
688 GNUNET_DNSPARSER_parse_soa (udp_payload, udp_payload_length, off);
689 if ((NULL == r->data.soa) || (old_off + data_len != *off))
690 {
691 GNUNET_break_op (0);
692 return GNUNET_SYSERR;
693 }
694 return GNUNET_OK;
695
697 r->data.mx =
698 GNUNET_DNSPARSER_parse_mx (udp_payload, udp_payload_length, off);
699 if ((NULL == r->data.mx) || (old_off + data_len != *off))
700 {
701 GNUNET_break_op (0);
702 return GNUNET_SYSERR;
703 }
704 return GNUNET_OK;
705
707 r->data.srv =
708 GNUNET_DNSPARSER_parse_srv (udp_payload, udp_payload_length, off);
709 if ((NULL == r->data.srv) || (old_off + data_len != *off))
710 {
711 GNUNET_break_op (0);
712 return GNUNET_SYSERR;
713 }
714 return GNUNET_OK;
715
717 r->data.uri =
718 GNUNET_DNSPARSER_parse_uri (udp_payload, udp_payload_length, off);
719 if ((NULL == r->data.uri) || (old_off + data_len != *off))
720 {
721 GNUNET_break_op (0);
722 return GNUNET_SYSERR;
723 }
724 return GNUNET_OK;
725
726 default:
729 GNUNET_memcpy (r->data.raw.data, &udp_payload[*off], data_len);
730 break;
731 }
732 (*off) += data_len;
733 return GNUNET_OK;
734}
#define GNUNET_DNSPARSER_TYPE_URI
struct GNUNET_DNSPARSER_MxRecord * GNUNET_DNSPARSER_parse_mx(const char *udp_payload, size_t udp_payload_length, size_t *off)
Parse a DNS MX record.
Definition dnsparser.c:472
#define GNUNET_DNSPARSER_TYPE_SRV
#define GNUNET_DNSPARSER_TYPE_SOA
#define GNUNET_DNSPARSER_TYPE_PTR
struct GNUNET_DNSPARSER_SoaRecord * GNUNET_DNSPARSER_parse_soa(const char *udp_payload, size_t udp_payload_length, size_t *off)
Parse a DNS SOA record.
Definition dnsparser.c:427
#define GNUNET_DNSPARSER_TYPE_NS
#define GNUNET_DNSPARSER_TYPE_CNAME
#define GNUNET_DNSPARSER_TYPE_DNAME
struct GNUNET_DNSPARSER_UriRecord * GNUNET_DNSPARSER_parse_uri(const char *udp_payload, size_t udp_payload_length, size_t *off)
Parse a DNS URI record.
Definition dnsparser.c:554
struct GNUNET_DNSPARSER_SrvRecord * GNUNET_DNSPARSER_parse_srv(const char *udp_payload, size_t udp_payload_length, size_t *off)
Parse a DNS SRV record.
Definition dnsparser.c:513
char * GNUNET_DNSPARSER_parse_name(const char *udp_payload, size_t udp_payload_length, size_t *off)
Parse name inside of a DNS query or record.
Definition dnsparser.c:370
#define GNUNET_DNSPARSER_TYPE_MX
#define GNUNET_TIME_UNIT_SECONDS
One second.
struct GNUNET_TIME_Absolute GNUNET_TIME_relative_to_absolute(struct GNUNET_TIME_Relative rel)
Convert relative time to an absolute time in the future.
Definition time.c:316
struct GNUNET_TIME_Relative GNUNET_TIME_relative_multiply(struct GNUNET_TIME_Relative rel, unsigned long long factor)
Multiply relative time by a given factor.
Definition time.c:486
void * data
Binary record data.
size_t data_len
Number of bytes in data.
uint16_t dns_traffic_class
See GNUNET_TUN_DNS_CLASS_*.
struct GNUNET_DNSPARSER_SoaRecord * soa
SOA data for SOA records.
struct GNUNET_DNSPARSER_SrvRecord * srv
SRV data for SRV records.
struct GNUNET_DNSPARSER_MxRecord * mx
MX data for MX records.
char * hostname
For NS, CNAME and PTR records, this is the uncompressed 0-terminated hostname.
uint16_t type
See GNUNET_DNSPARSER_TYPE_*.
struct GNUNET_TIME_Absolute expiration_time
When does the record expire?
union GNUNET_DNSPARSER_Record::@24 data
Payload of the record (which one of these is valid depends on the 'type').
char * name
Name of the record that the query is for (0-terminated).
struct GNUNET_DNSPARSER_RawRecord raw
Raw data for all other types.
struct GNUNET_DNSPARSER_UriRecord * uri
URI data for URI records.
General DNS record prefix.
uint16_t data_len
Number of bytes of data that follow.

References GNUNET_DNSPARSER_RawRecord::data, GNUNET_DNSPARSER_Record::data, GNUNET_DNSPARSER_RawRecord::data_len, GNUNET_TUN_DnsRecordLine::data_len, GNUNET_DNSPARSER_Record::dns_traffic_class, GNUNET_TUN_DnsRecordLine::dns_traffic_class, GNUNET_DNSPARSER_Record::expiration_time, GNUNET_break_op, GNUNET_DNSPARSER_parse_mx(), GNUNET_DNSPARSER_parse_name(), GNUNET_DNSPARSER_parse_soa(), GNUNET_DNSPARSER_parse_srv(), GNUNET_DNSPARSER_parse_uri(), GNUNET_DNSPARSER_TYPE_CNAME, GNUNET_DNSPARSER_TYPE_DNAME, GNUNET_DNSPARSER_TYPE_MX, GNUNET_DNSPARSER_TYPE_NS, GNUNET_DNSPARSER_TYPE_PTR, GNUNET_DNSPARSER_TYPE_SOA, GNUNET_DNSPARSER_TYPE_SRV, GNUNET_DNSPARSER_TYPE_URI, GNUNET_malloc, GNUNET_memcpy, GNUNET_OK, GNUNET_SYSERR, GNUNET_TIME_relative_multiply(), GNUNET_TIME_relative_to_absolute(), GNUNET_TIME_UNIT_SECONDS, GNUNET_DNSPARSER_Record::hostname, GNUNET_DNSPARSER_Record::mx, name, GNUNET_DNSPARSER_Record::name, GNUNET_DNSPARSER_Record::raw, GNUNET_DNSPARSER_Record::soa, GNUNET_DNSPARSER_Record::srv, GNUNET_TUN_DnsRecordLine::ttl, GNUNET_DNSPARSER_Record::type, GNUNET_TUN_DnsRecordLine::type, and GNUNET_DNSPARSER_Record::uri.

Referenced by GNUNET_DNSPARSER_parse().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_parse_name()

char * GNUNET_DNSPARSER_parse_name ( const char *  udp_payload,
size_t  udp_payload_length,
size_t *  off 
)

Parse name inside of a DNS query or record.

Parameters
udp_payloadentire UDP payload
udp_payload_lengthlength of udp_payload
offpointer to the offset of the name to parse in the udp_payload (to be incremented by the size of the name)
Returns
name as 0-terminated C string on success, NULL if the payload is malformed

Definition at line 370 of file dnsparser.c.

373{
374 return parse_name (udp_payload, udp_payload_length, off, 0);
375}
static char * parse_name(const char *udp_payload, size_t udp_payload_length, size_t *off, unsigned int depth)
Parse name inside of a DNS query or record.
Definition dnsparser.c:250

References parse_name().

Referenced by dns_value_to_string(), GNUNET_DNSPARSER_parse_mx(), GNUNET_DNSPARSER_parse_query(), GNUNET_DNSPARSER_parse_record(), GNUNET_DNSPARSER_parse_soa(), GNUNET_DNSPARSER_parse_srv(), handle_gns_resolution_result(), recursive_cname_resolution(), and reply_to_dns().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_parse_query()

int GNUNET_DNSPARSER_parse_query ( const char *  udp_payload,
size_t  udp_payload_length,
size_t *  off,
struct GNUNET_DNSPARSER_Query q 
)

Parse a DNS query entry.

Parameters
udp_payloadentire UDP payload
udp_payload_lengthlength of udp_payload
offpointer to the offset of the query to parse in the udp_payload (to be incremented by the size of the query)
qwhere to write the query information
Returns
GNUNET_OK on success, GNUNET_SYSERR if the query is malformed

Definition at line 389 of file dnsparser.c.

393{
394 char *name;
395 struct GNUNET_TUN_DnsQueryLine ql;
396
397 name = GNUNET_DNSPARSER_parse_name (udp_payload, udp_payload_length, off);
398 if (NULL == name)
399 {
400 GNUNET_break_op (0);
401 return GNUNET_SYSERR;
402 }
403 q->name = name;
404 if (*off + sizeof(struct GNUNET_TUN_DnsQueryLine) > udp_payload_length)
405 {
406 GNUNET_break_op (0);
407 return GNUNET_SYSERR;
408 }
409 GNUNET_memcpy (&ql, &udp_payload[*off], sizeof(ql));
410 *off += sizeof(ql);
411 q->type = ntohs (ql.type);
412 q->dns_traffic_class = ntohs (ql.dns_traffic_class);
413 return GNUNET_OK;
414}
static struct GNUNET_REVOCATION_Query * q
Handle for revocation query.

References GNUNET_TUN_DnsQueryLine::dns_traffic_class, GNUNET_break_op, GNUNET_DNSPARSER_parse_name(), GNUNET_memcpy, GNUNET_OK, GNUNET_SYSERR, name, q, and GNUNET_TUN_DnsQueryLine::type.

Referenced by GNUNET_DNSPARSER_parse().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_parse_soa()

struct GNUNET_DNSPARSER_SoaRecord * GNUNET_DNSPARSER_parse_soa ( const char *  udp_payload,
size_t  udp_payload_length,
size_t *  off 
)

Parse a DNS SOA record.

Parameters
udp_payloadreference to UDP packet
udp_payload_lengthlength of udp_payload
offpointer to the offset of the query to parse in the SOA record (to be incremented by the size of the record), unchanged on error
Returns
the parsed SOA record, NULL on error

Definition at line 427 of file dnsparser.c.

430{
431 struct GNUNET_DNSPARSER_SoaRecord *soa;
432 struct GNUNET_TUN_DnsSoaRecord soa_bin;
433 size_t old_off;
434
435 old_off = *off;
437 soa->mname =
438 GNUNET_DNSPARSER_parse_name (udp_payload, udp_payload_length, off);
439 soa->rname =
440 GNUNET_DNSPARSER_parse_name (udp_payload, udp_payload_length, off);
441 if ((NULL == soa->mname) || (NULL == soa->rname) ||
442 (*off + sizeof(struct GNUNET_TUN_DnsSoaRecord) > udp_payload_length))
443 {
444 GNUNET_break_op (0);
446 *off = old_off;
447 return NULL;
448 }
449 GNUNET_memcpy (&soa_bin,
450 &udp_payload[*off],
451 sizeof(struct GNUNET_TUN_DnsSoaRecord));
452 soa->serial = ntohl (soa_bin.serial);
453 soa->refresh = ntohl (soa_bin.refresh);
454 soa->retry = ntohl (soa_bin.retry);
455 soa->expire = ntohl (soa_bin.expire);
456 soa->minimum_ttl = ntohl (soa_bin.minimum);
457 (*off) += sizeof(struct GNUNET_TUN_DnsSoaRecord);
458 return soa;
459}
void GNUNET_DNSPARSER_free_soa(struct GNUNET_DNSPARSER_SoaRecord *soa)
Free SOA information record.
Definition dnsparser.c:125
Information from SOA records (RFC 1035).

References GNUNET_DNSPARSER_SoaRecord::expire, GNUNET_TUN_DnsSoaRecord::expire, GNUNET_break_op, GNUNET_DNSPARSER_free_soa(), GNUNET_DNSPARSER_parse_name(), GNUNET_memcpy, GNUNET_new, GNUNET_TUN_DnsSoaRecord::minimum, GNUNET_DNSPARSER_SoaRecord::minimum_ttl, GNUNET_DNSPARSER_SoaRecord::mname, GNUNET_DNSPARSER_SoaRecord::refresh, GNUNET_TUN_DnsSoaRecord::refresh, GNUNET_DNSPARSER_SoaRecord::retry, GNUNET_TUN_DnsSoaRecord::retry, GNUNET_DNSPARSER_SoaRecord::rname, GNUNET_DNSPARSER_SoaRecord::serial, and GNUNET_TUN_DnsSoaRecord::serial.

Referenced by dns_value_to_string(), GNUNET_DNSPARSER_parse_record(), handle_gns_resolution_result(), and reply_to_dns().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_parse_cert()

struct GNUNET_DNSPARSER_CertRecord * GNUNET_DNSPARSER_parse_cert ( const char *  udp_payload,
size_t  udp_payload_length,
size_t *  off 
)

Parse a DNS CERT record.

Parameters
udp_payloadreference to UDP packet
udp_payload_lengthlength of udp_payload
offpointer to the offset of the query to parse in the CERT record (to be incremented by the size of the record), unchanged on error
Returns
the parsed CERT record, NULL on error

Definition at line 598 of file dnsparser.c.

601{
602 struct GNUNET_DNSPARSER_CertRecord *cert;
603 struct GNUNET_TUN_DnsCertRecord dcert;
604
605 if (*off + sizeof(struct GNUNET_TUN_DnsCertRecord) >= udp_payload_length)
606 {
607 GNUNET_break_op (0);
608 return NULL;
609 }
610 GNUNET_memcpy (&dcert,
611 &udp_payload[*off],
612 sizeof(struct GNUNET_TUN_DnsCertRecord));
613 (*off) += sizeof(struct GNUNET_TUN_DnsCertRecord);
615 cert->cert_type = ntohs (dcert.cert_type);
616 cert->cert_tag = ntohs (dcert.cert_tag);
617 cert->algorithm = dcert.algorithm;
618 cert->certificate_size = udp_payload_length - (*off);
621 &udp_payload[*off],
622 cert->certificate_size);
623 (*off) += cert->certificate_size;
624 return cert;
625}
Information from CERT records (RFC 4034).

References GNUNET_DNSPARSER_CertRecord::algorithm, GNUNET_TUN_DnsCertRecord::algorithm, GNUNET_DNSPARSER_CertRecord::cert_tag, GNUNET_TUN_DnsCertRecord::cert_tag, GNUNET_DNSPARSER_CertRecord::cert_type, GNUNET_TUN_DnsCertRecord::cert_type, GNUNET_DNSPARSER_CertRecord::certificate_data, GNUNET_DNSPARSER_CertRecord::certificate_size, GNUNET_break_op, GNUNET_malloc, GNUNET_memcpy, and GNUNET_new.

Referenced by dns_value_to_string().

Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_parse_mx()

struct GNUNET_DNSPARSER_MxRecord * GNUNET_DNSPARSER_parse_mx ( const char *  udp_payload,
size_t  udp_payload_length,
size_t *  off 
)

Parse a DNS MX record.

Parameters
udp_payloadreference to UDP packet
udp_payload_lengthlength of udp_payload
offpointer to the offset of the query to parse in the MX record (to be incremented by the size of the record), unchanged on error
Returns
the parsed MX record, NULL on error

Definition at line 472 of file dnsparser.c.

475{
476 struct GNUNET_DNSPARSER_MxRecord *mx;
477 uint16_t mxpref;
478 size_t old_off;
479
480 old_off = *off;
481 if (*off + sizeof(uint16_t) > udp_payload_length)
482 {
483 GNUNET_break_op (0);
484 return NULL;
485 }
486 GNUNET_memcpy (&mxpref, &udp_payload[*off], sizeof(uint16_t));
487 (*off) += sizeof(uint16_t);
489 mx->preference = ntohs (mxpref);
490 mx->mxhost =
491 GNUNET_DNSPARSER_parse_name (udp_payload, udp_payload_length, off);
492 if (NULL == mx->mxhost)
493 {
494 GNUNET_break_op (0);
496 *off = old_off;
497 return NULL;
498 }
499 return mx;
500}
void GNUNET_DNSPARSER_free_mx(struct GNUNET_DNSPARSER_MxRecord *mx)
Free MX information record.
Definition dnsparser.c:186
Information from MX records (RFC 1035).

References GNUNET_break_op, GNUNET_DNSPARSER_free_mx(), GNUNET_DNSPARSER_parse_name(), GNUNET_memcpy, GNUNET_new, GNUNET_DNSPARSER_MxRecord::mxhost, and GNUNET_DNSPARSER_MxRecord::preference.

Referenced by dns_value_to_string(), GNUNET_DNSPARSER_parse_record(), handle_gns_resolution_result(), and reply_to_dns().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_parse_srv()

struct GNUNET_DNSPARSER_SrvRecord * GNUNET_DNSPARSER_parse_srv ( const char *  udp_payload,
size_t  udp_payload_length,
size_t *  off 
)

Parse a DNS SRV record.

Parameters
udp_payloadreference to UDP packet
udp_payload_lengthlength of udp_payload
offpointer to the offset of the query to parse in the SRV record (to be incremented by the size of the record), unchanged on error
Returns
the parsed SRV record, NULL on error

Definition at line 513 of file dnsparser.c.

516{
517 struct GNUNET_DNSPARSER_SrvRecord *srv;
518 struct GNUNET_TUN_DnsSrvRecord srv_bin;
519 size_t old_off;
520
521 old_off = *off;
522 if (*off + sizeof(struct GNUNET_TUN_DnsSrvRecord) > udp_payload_length)
523 return NULL;
524 GNUNET_memcpy (&srv_bin,
525 &udp_payload[*off],
526 sizeof(struct GNUNET_TUN_DnsSrvRecord));
527 (*off) += sizeof(struct GNUNET_TUN_DnsSrvRecord);
529 srv->priority = ntohs (srv_bin.prio);
530 srv->weight = ntohs (srv_bin.weight);
531 srv->port = ntohs (srv_bin.port);
532 srv->target =
533 GNUNET_DNSPARSER_parse_name (udp_payload, udp_payload_length, off);
534 if (NULL == srv->target)
535 {
537 *off = old_off;
538 return NULL;
539 }
540 return srv;
541}
void GNUNET_DNSPARSER_free_srv(struct GNUNET_DNSPARSER_SrvRecord *srv)
Free SRV information record.
Definition dnsparser.c:156
Information from SRV records (RFC 2782).

References GNUNET_DNSPARSER_free_srv(), GNUNET_DNSPARSER_parse_name(), GNUNET_memcpy, GNUNET_new, GNUNET_DNSPARSER_SrvRecord::port, GNUNET_TUN_DnsSrvRecord::port, GNUNET_TUN_DnsSrvRecord::prio, GNUNET_DNSPARSER_SrvRecord::priority, GNUNET_DNSPARSER_SrvRecord::target, GNUNET_DNSPARSER_SrvRecord::weight, and GNUNET_TUN_DnsSrvRecord::weight.

Referenced by dns_value_to_string(), GNUNET_DNSPARSER_parse_record(), and handle_gns_resolution_result().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_parse_uri()

struct GNUNET_DNSPARSER_UriRecord * GNUNET_DNSPARSER_parse_uri ( const char *  udp_payload,
size_t  udp_payload_length,
size_t *  off 
)

Parse a DNS URI record.

Parameters
udp_payloadreference to UDP packet
udp_payload_lengthlength of udp_payload
offpointer to the offset of the query to parse in the URI record (to be incremented by the size of the record), unchanged on error
Returns
the parsed URI record, NULL on error

Definition at line 554 of file dnsparser.c.

557{
559 struct GNUNET_TUN_DnsUriRecord uri_bin;
560 size_t old_off;
561 int max_len;
562 int len;
563
564 old_off = *off;
565 if (*off + sizeof(struct GNUNET_TUN_DnsUriRecord) > udp_payload_length)
566 return NULL;
567 GNUNET_memcpy (&uri_bin,
568 &udp_payload[*off],
569 sizeof(struct GNUNET_TUN_DnsUriRecord));
570 (*off) += sizeof(struct GNUNET_TUN_DnsUriRecord);
572 uri->priority = ntohs (uri_bin.prio);
573 uri->weight = ntohs (uri_bin.weight);
574 max_len = udp_payload_length - sizeof(struct GNUNET_TUN_DnsUriRecord);
575 len = GNUNET_asprintf (&(uri->target), "%.*s", max_len,
576 &udp_payload[*off]);
577 (*off) += len;
578 if (NULL == uri->target)
579 {
581 *off = old_off;
582 return NULL;
583 }
584 return uri;
585}
void GNUNET_DNSPARSER_free_uri(struct GNUNET_DNSPARSER_UriRecord *uri)
Free URI information record.
Definition dnsparser.c:171
int int GNUNET_asprintf(char **buf, const char *format,...) __attribute__((format(printf
Like asprintf, just portable.
Information from URI records (RFC 7553).

References GNUNET_asprintf(), GNUNET_DNSPARSER_free_uri(), GNUNET_memcpy, GNUNET_new, GNUNET_TUN_DnsUriRecord::prio, uri, and GNUNET_TUN_DnsUriRecord::weight.

Referenced by dns_value_to_string(), GNUNET_DNSPARSER_parse_record(), handle_gns_resolution_result(), and reply_to_dns().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_duplicate_record()

struct GNUNET_DNSPARSER_Record * GNUNET_DNSPARSER_duplicate_record ( const struct GNUNET_DNSPARSER_Record r)

Duplicate (deep-copy) the given DNS record.

Parameters
rthe record
Returns
the newly allocated record

Definition at line 827 of file dnsparser.c.

828{
829 struct GNUNET_DNSPARSER_Record *dup = GNUNET_memdup (r, sizeof(*r));
830
831 dup->name = GNUNET_strdup (r->name);
832 switch (r->type)
833 {
838 break;
839 }
840
843 break;
844 }
845
848 break;
849 }
850
853 break;
854 }
855
858 break;
859 }
860
863 break;
864 }
865
866 default: {
868 r->data.raw.data_len);
869 }
870 }
871 return dup;
872}
struct GNUNET_DNSPARSER_MxRecord * GNUNET_DNSPARSER_duplicate_mx_record(const struct GNUNET_DNSPARSER_MxRecord *r)
Duplicate (deep-copy) the given DNS record.
Definition dnsparser.c:918
struct GNUNET_DNSPARSER_SoaRecord * GNUNET_DNSPARSER_duplicate_soa_record(const struct GNUNET_DNSPARSER_SoaRecord *r)
Duplicate (deep-copy) the given DNS record.
Definition dnsparser.c:882
#define GNUNET_DNSPARSER_TYPE_CERT
struct GNUNET_DNSPARSER_SrvRecord * GNUNET_DNSPARSER_duplicate_srv_record(const struct GNUNET_DNSPARSER_SrvRecord *r)
Duplicate (deep-copy) the given DNS record.
Definition dnsparser.c:934
struct GNUNET_DNSPARSER_CertRecord * GNUNET_DNSPARSER_duplicate_cert_record(const struct GNUNET_DNSPARSER_CertRecord *r)
Duplicate (deep-copy) the given DNS record.
Definition dnsparser.c:900
struct GNUNET_DNSPARSER_UriRecord * GNUNET_DNSPARSER_duplicate_uri_record(const struct GNUNET_DNSPARSER_UriRecord *r)
Duplicate (deep-copy) the given DNS record.
Definition dnsparser.c:951
#define GNUNET_memdup(buf, size)
Allocate and initialize a block of memory.
struct GNUNET_DNSPARSER_CertRecord * cert
CERT data for CERT records.

References GNUNET_DNSPARSER_Record::cert, GNUNET_DNSPARSER_RawRecord::data, GNUNET_DNSPARSER_Record::data, GNUNET_DNSPARSER_RawRecord::data_len, GNUNET_DNSPARSER_duplicate_cert_record(), GNUNET_DNSPARSER_duplicate_mx_record(), GNUNET_DNSPARSER_duplicate_soa_record(), GNUNET_DNSPARSER_duplicate_srv_record(), GNUNET_DNSPARSER_duplicate_uri_record(), GNUNET_DNSPARSER_TYPE_CERT, GNUNET_DNSPARSER_TYPE_CNAME, GNUNET_DNSPARSER_TYPE_MX, GNUNET_DNSPARSER_TYPE_NS, GNUNET_DNSPARSER_TYPE_PTR, GNUNET_DNSPARSER_TYPE_SOA, GNUNET_DNSPARSER_TYPE_SRV, GNUNET_DNSPARSER_TYPE_URI, GNUNET_memdup, GNUNET_strdup, GNUNET_DNSPARSER_Record::hostname, GNUNET_DNSPARSER_Record::mx, GNUNET_DNSPARSER_Record::name, GNUNET_DNSPARSER_Record::raw, GNUNET_DNSPARSER_Record::soa, GNUNET_DNSPARSER_Record::srv, GNUNET_DNSPARSER_Record::type, and GNUNET_DNSPARSER_Record::uri.

Referenced by cache_answers().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_duplicate_soa_record()

struct GNUNET_DNSPARSER_SoaRecord * GNUNET_DNSPARSER_duplicate_soa_record ( const struct GNUNET_DNSPARSER_SoaRecord r)

Duplicate (deep-copy) the given DNS record.

Parameters
rthe record
Returns
the newly allocated record

Definition at line 882 of file dnsparser.c.

884{
885 struct GNUNET_DNSPARSER_SoaRecord *dup = GNUNET_memdup (r, sizeof(*r));
886
887 dup->mname = GNUNET_strdup (r->mname);
888 dup->rname = GNUNET_strdup (r->rname);
889 return dup;
890}

References GNUNET_memdup, GNUNET_strdup, GNUNET_DNSPARSER_SoaRecord::mname, and GNUNET_DNSPARSER_SoaRecord::rname.

Referenced by GNUNET_DNSPARSER_duplicate_record().

Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_duplicate_cert_record()

struct GNUNET_DNSPARSER_CertRecord * GNUNET_DNSPARSER_duplicate_cert_record ( const struct GNUNET_DNSPARSER_CertRecord r)

Duplicate (deep-copy) the given DNS record.

Parameters
rthe record
Returns
the newly allocated record

Definition at line 900 of file dnsparser.c.

902{
903 struct GNUNET_DNSPARSER_CertRecord *dup = GNUNET_memdup (r, sizeof(*r));
904
907 return dup;
908}

References GNUNET_DNSPARSER_CertRecord::certificate_data, GNUNET_DNSPARSER_CertRecord::certificate_size, and GNUNET_memdup.

Referenced by GNUNET_DNSPARSER_duplicate_record().

Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_duplicate_mx_record()

struct GNUNET_DNSPARSER_MxRecord * GNUNET_DNSPARSER_duplicate_mx_record ( const struct GNUNET_DNSPARSER_MxRecord r)

Duplicate (deep-copy) the given DNS record.

Parameters
rthe record
Returns
the newly allocated record

Definition at line 918 of file dnsparser.c.

919{
920 struct GNUNET_DNSPARSER_MxRecord *dup = GNUNET_memdup (r, sizeof(*r));
921
922 dup->mxhost = GNUNET_strdup (r->mxhost);
923 return dup;
924}

References GNUNET_memdup, GNUNET_strdup, and GNUNET_DNSPARSER_MxRecord::mxhost.

Referenced by GNUNET_DNSPARSER_duplicate_record().

Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_duplicate_srv_record()

struct GNUNET_DNSPARSER_SrvRecord * GNUNET_DNSPARSER_duplicate_srv_record ( const struct GNUNET_DNSPARSER_SrvRecord r)

Duplicate (deep-copy) the given DNS record.

Parameters
rthe record
Returns
the newly allocated record

Definition at line 934 of file dnsparser.c.

936{
937 struct GNUNET_DNSPARSER_SrvRecord *dup = GNUNET_memdup (r, sizeof(*r));
938
939 dup->target = GNUNET_strdup (r->target);
940 return dup;
941}

References GNUNET_memdup, GNUNET_strdup, and GNUNET_DNSPARSER_SrvRecord::target.

Referenced by GNUNET_DNSPARSER_duplicate_record().

Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_duplicate_uri_record()

struct GNUNET_DNSPARSER_UriRecord * GNUNET_DNSPARSER_duplicate_uri_record ( const struct GNUNET_DNSPARSER_UriRecord r)

Duplicate (deep-copy) the given DNS record.

Parameters
rthe record
Returns
the newly allocated record

Definition at line 951 of file dnsparser.c.

953{
954 struct GNUNET_DNSPARSER_UriRecord *dup = GNUNET_memdup (r, sizeof(*r));
955
956 dup->target = GNUNET_strdup (r->target);
957 return dup;
958}
char * target
URI of the target, where the URI is as specified in RFC 3986.

References GNUNET_memdup, GNUNET_strdup, and GNUNET_DNSPARSER_UriRecord::target.

Referenced by GNUNET_DNSPARSER_duplicate_record().

Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_free_record()

void GNUNET_DNSPARSER_free_record ( struct GNUNET_DNSPARSER_Record r)

Free the given DNS record.

Parameters
rrecord to free

Definition at line 201 of file dnsparser.c.

202{
203 GNUNET_free (r->name);
204 switch (r->type)
205 {
208 break;
209
212 break;
213
216 break;
217
220 break;
221
224 break;
225
230 break;
231
232 default:
234 break;
235 }
236}
void GNUNET_DNSPARSER_free_cert(struct GNUNET_DNSPARSER_CertRecord *cert)
Free CERT information record.
Definition dnsparser.c:141

References GNUNET_DNSPARSER_Record::cert, GNUNET_DNSPARSER_RawRecord::data, GNUNET_DNSPARSER_Record::data, GNUNET_DNSPARSER_free_cert(), GNUNET_DNSPARSER_free_mx(), GNUNET_DNSPARSER_free_soa(), GNUNET_DNSPARSER_free_srv(), GNUNET_DNSPARSER_free_uri(), GNUNET_DNSPARSER_TYPE_CERT, GNUNET_DNSPARSER_TYPE_CNAME, GNUNET_DNSPARSER_TYPE_MX, GNUNET_DNSPARSER_TYPE_NS, GNUNET_DNSPARSER_TYPE_PTR, GNUNET_DNSPARSER_TYPE_SOA, GNUNET_DNSPARSER_TYPE_SRV, GNUNET_DNSPARSER_TYPE_URI, GNUNET_free, GNUNET_DNSPARSER_Record::hostname, GNUNET_DNSPARSER_Record::mx, GNUNET_DNSPARSER_Record::name, GNUNET_DNSPARSER_Record::raw, GNUNET_DNSPARSER_Record::soa, GNUNET_DNSPARSER_Record::srv, GNUNET_DNSPARSER_Record::type, and GNUNET_DNSPARSER_Record::uri.

Referenced by free_cache_entry(), free_hosts_entry(), GNUNET_DNSPARSER_free_packet(), and remove_expired().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_free_mx()

void GNUNET_DNSPARSER_free_mx ( struct GNUNET_DNSPARSER_MxRecord mx)

Free MX information record.

Parameters
mxrecord to free

Definition at line 186 of file dnsparser.c.

187{
188 if (NULL == mx)
189 return;
190 GNUNET_free (mx->mxhost);
191 GNUNET_free (mx);
192}

References GNUNET_free, and GNUNET_DNSPARSER_MxRecord::mxhost.

Referenced by dns_value_to_string(), GNUNET_DNSPARSER_free_record(), GNUNET_DNSPARSER_parse_mx(), and handle_gns_resolution_result().

Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_free_srv()

void GNUNET_DNSPARSER_free_srv ( struct GNUNET_DNSPARSER_SrvRecord srv)

Free SRV information record.

Parameters
srvrecord to free

Definition at line 156 of file dnsparser.c.

157{
158 if (NULL == srv)
159 return;
160 GNUNET_free (srv->target);
161 GNUNET_free (srv);
162}

References GNUNET_free, and GNUNET_DNSPARSER_SrvRecord::target.

Referenced by dns_value_to_string(), GNUNET_DNSPARSER_free_record(), GNUNET_DNSPARSER_parse_srv(), and handle_gns_resolution_result().

Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_free_uri()

void GNUNET_DNSPARSER_free_uri ( struct GNUNET_DNSPARSER_UriRecord uri)

Free URI information record.

Parameters
urirecord to free

Definition at line 171 of file dnsparser.c.

172{
173 if (NULL == uri)
174 return;
175 GNUNET_free (uri->target);
177}

References GNUNET_free, and uri.

Referenced by dns_value_to_string(), GNUNET_DNSPARSER_free_record(), GNUNET_DNSPARSER_parse_uri(), and handle_gns_resolution_result().

Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_free_soa()

void GNUNET_DNSPARSER_free_soa ( struct GNUNET_DNSPARSER_SoaRecord soa)

Free SOA information record.

Parameters
soarecord to free

Definition at line 125 of file dnsparser.c.

126{
127 if (NULL == soa)
128 return;
129 GNUNET_free (soa->mname);
130 GNUNET_free (soa->rname);
131 GNUNET_free (soa);
132}

References GNUNET_free, GNUNET_DNSPARSER_SoaRecord::mname, and GNUNET_DNSPARSER_SoaRecord::rname.

Referenced by dns_value_to_string(), GNUNET_DNSPARSER_free_record(), GNUNET_DNSPARSER_parse_soa(), and handle_gns_resolution_result().

Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_free_cert()

void GNUNET_DNSPARSER_free_cert ( struct GNUNET_DNSPARSER_CertRecord cert)

Free CERT information record.

Parameters
certrecord to free

Definition at line 141 of file dnsparser.c.

142{
143 if (NULL == cert)
144 return;
146 GNUNET_free (cert);
147}

References GNUNET_DNSPARSER_CertRecord::certificate_data, and GNUNET_free.

Referenced by dns_value_to_string(), and GNUNET_DNSPARSER_free_record().

Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_bin_to_hex()

char * GNUNET_DNSPARSER_bin_to_hex ( const void *  data,
size_t  data_size 
)

Convert a block of binary data to HEX.

Parameters
databinary data to convert
data_sizenumber of bytes in data
Returns
HEX string (lower case)

Definition at line 1514 of file dnsparser.c.

1515{
1516 char *ret;
1517 size_t off;
1518 const uint8_t *idata;
1519
1520 idata = data;
1521 ret = GNUNET_malloc (data_size * 2 + 1);
1522 for (off = 0; off < data_size; off++)
1523 sprintf (&ret[off * 2], "%02x", idata[off]);
1524 return ret;
1525}
static char * data
The data to insert into the dht.
static size_t data_size
Number of bytes in data.

References data, data_size, GNUNET_malloc, and ret.

Referenced by dns_value_to_string().

Here is the caller graph for this function:

◆ GNUNET_DNSPARSER_hex_to_bin()

size_t GNUNET_DNSPARSER_hex_to_bin ( const char *  hex,
void *  data 
)

Convert a HEX string to block of binary data.

Parameters
hexHEX string to convert (may contain mixed case)
datawhere to write result, must be at least strlen(hex)/2 bytes long
Returns
number of bytes written to data

Definition at line 1537 of file dnsparser.c.

1538{
1539 size_t data_size;
1540 size_t off;
1541 uint8_t *idata;
1542 unsigned int h;
1543 char in[3];
1544
1545 data_size = strlen (hex) / 2;
1546 idata = data;
1547 in[2] = '\0';
1548 for (off = 0; off < data_size; off++)
1549 {
1550 in[0] = tolower ((unsigned char) hex[off * 2]);
1551 in[1] = tolower ((unsigned char) hex[off * 2 + 1]);
1552 if (1 != sscanf (in, "%x", &h))
1553 return off;
1554 idata[off] = (uint8_t) h;
1555 }
1556 return off;
1557}
static struct GNUNET_ARM_Handle * h
Connection with ARM.
Definition gnunet-arm.c:98

References data, data_size, and h.

Referenced by dns_string_to_value().

Here is the caller graph for this function: