diff options
author | Werner Koch <[email protected]> | 2015-10-24 14:27:47 +0000 |
---|---|---|
committer | Werner Koch <[email protected]> | 2015-10-25 15:47:11 +0000 |
commit | 816505958ac4308ee0dfe787d1b706982428b6cc (patch) | |
tree | 5e30e1463c53d988ba5b698d8d179628b5a5401d /dirmngr/dns-stuff.h | |
parent | gpg: Provide an interface to patch TOFU updates. (diff) | |
download | gnupg-816505958ac4308ee0dfe787d1b706982428b6cc.tar.gz gnupg-816505958ac4308ee0dfe787d1b706982428b6cc.zip |
dirmngr: Implement a getnameinfo wrapper.
* dirmngr/dns-stuff.h (DNS_NUMERICHOST): New.
(DNS_WITHBRACKET): New.
* dirmngr/dns-stuff.c (resolve_name_standard): Factor code out to...
(map_eai_to_gpg_error): new.
(resolve_addr_standard): New.
(resolve_dns_addr): New.
* dirmngr/ks-engine-hkp.c (is_ip_address): Move to ...
* dirmngr/dns-stuff.c (is_ip_address): here. Add support for non
bracketed v6 addresses.
* dirmngr/t-dns-stuff.c: Remove header netdb.h.
(main): Add option --bracket. Use resolve_dns_name instead of
getnameinfo.
Signed-off-by: Werner Koch <[email protected]>
Diffstat (limited to 'dirmngr/dns-stuff.h')
-rw-r--r-- | dirmngr/dns-stuff.h | 21 |
1 files changed, 20 insertions, 1 deletions
diff --git a/dirmngr/dns-stuff.h b/dirmngr/dns-stuff.h index 13c47df52..fd1c43acb 100644 --- a/dirmngr/dns-stuff.h +++ b/dirmngr/dns-stuff.h @@ -40,7 +40,16 @@ # include <sys/socket.h> #endif +/* + * Flags used with resolve_dns_addr. + */ +#define DNS_NUMERICHOST 1 /* Force numeric output format. */ +#define DNS_WITHBRACKET 2 /* Put brackets around numeric v6 + addresses. */ +/* + * Constants for use with get_dns_cert. + */ #define DNS_CERTTYPE_ANY 0 /* Internal catch all type. */ /* Certificate types according to RFC-4398: */ #define DNS_CERTTYPE_PKIX 1 /* X.509 as per PKIX. */ @@ -58,6 +67,8 @@ #define DNS_CERTTYPE_RRBASE 1024 /* Base of special constants. */ #define DNS_CERTTYPE_RR61 (DNS_CERTTYPE_RRBASE + 61) + + struct dns_addrinfo_s; typedef struct dns_addrinfo_s *dns_addrinfo_t; struct dns_addrinfo_s @@ -87,17 +98,25 @@ gpg_error_t enable_dns_tormode (void); void free_dns_addrinfo (dns_addrinfo_t ai); -/* Provide function similar to getaddrinfo. */ +/* Function similar to getaddrinfo. */ gpg_error_t resolve_dns_name (const char *name, unsigned short port, int want_family, int want_socktype, dns_addrinfo_t *r_dai, char **r_canonname); +/* Function similar to getnameinfo. */ +gpg_error_t resolve_dns_addr (const struct sockaddr *addr, int addrlen, + unsigned int flags, char **r_name); + +/* Return true if NAME is a numerical IP address. */ +int is_ip_address (const char *name); + /* Return a CERT record or an arbitray RR. */ gpg_error_t get_dns_cert (const char *name, int want_certtype, void **r_key, size_t *r_keylen, unsigned char **r_fpr, size_t *r_fprlen, char **r_url); + int getsrv (const char *name,struct srventry **list); |