#ifndef _DNS_H_INCLUDED_ #define _DNS_H_INCLUDED_ /*++ /* NAME /* dns 3h /* SUMMARY /* domain name service lookup /* SYNOPSIS /* #include /* DESCRIPTION /* .nf /* * System library. */ #include #include #ifdef RESOLVE_H_NEEDS_STDIO_H #include #endif #include /* * Name server compatibility. These undocumented macros appear in the file * , but since they are undocumented we should not count on * their presence, and so they are included here just in case. */ #ifndef GETSHORT #define GETSHORT(s, cp) { \ unsigned char *t_cp = (u_char *)(cp); \ (s) = ((unsigned)t_cp[0] << 8) \ | ((unsigned)t_cp[1]) \ ; \ (cp) += 2; \ } #define GETLONG(l, cp) { \ unsigned char *t_cp = (u_char *)(cp); \ (l) = ((unsigned)t_cp[0] << 24) \ | ((unsigned)t_cp[1] << 16) \ | ((unsigned)t_cp[2] << 8) \ | ((unsigned)t_cp[3]) \ ; \ (cp) += 4; \ } #endif /* * SunOS 4 needs this. */ #ifndef T_TXT #define T_TXT 16 #endif /* * Utility library. */ #include /* * Structure for fixed resource record data. */ typedef struct DNS_FIXED { unsigned short type; /* T_A, T_CNAME, etc. */ unsigned short class; /* C_IN, etc. */ unsigned int ttl; /* always */ unsigned length; /* record length */ } DNS_FIXED; /* * Structure of a DNS resource record after expansion. The components are * named after the things one can expect to find in a DNS resource record. */ typedef struct DNS_RR { char *name; /* name, mystrdup()ed */ unsigned short type; /* T_A, T_CNAME, etc. */ unsigned short class; /* C_IN, etc. */ unsigned int ttl; /* always */ unsigned short pref; /* T_MX only */ struct DNS_RR *next; /* linkage */ unsigned data_len; /* actual data size */ char data[1]; /* actually a bunch of data */ } DNS_RR; /* * dns_strerror.c */ extern const char *dns_strerror(unsigned); /* * dns_strtype.c */ extern const char *dns_strtype(unsigned); extern unsigned dns_type(const char *); /* * dns_rr.c */ extern DNS_RR *dns_rr_create(const char *, DNS_FIXED *, unsigned, const char *, unsigned); extern void dns_rr_free(DNS_RR *); extern DNS_RR *dns_rr_copy(DNS_RR *); extern DNS_RR *dns_rr_append(DNS_RR *, DNS_RR *); extern DNS_RR *dns_rr_sort(DNS_RR *, int (*) (DNS_RR *, DNS_RR *)); /* * dns_lookup.c */ extern int dns_lookup(const char *, unsigned, unsigned, DNS_RR **, VSTRING *, VSTRING *); extern int dns_lookup_types(const char *, unsigned, DNS_RR **, VSTRING *, VSTRING *,...); /* * Status codes. Failures must have negative codes so they will not collide * with valid counts of answer records etc. */ #define DNS_FAIL (-4) /* query failed, don't retry */ #define DNS_NOTFOUND (-3) /* query ok, data not found */ #define DNS_RETRY (-2) /* query failed, try again */ #define DNS_RECURSE (-1) /* recursion needed */ #define DNS_OK 0 /* query succeeded */ /* * How long can a DNS name be? */ #define DNS_NAME_LEN 1024 /* LICENSE /* .ad /* .fi /* The Secure Mailer license must be distributed with this software. /* AUTHOR(S) /* Wietse Venema /* IBM T.J. Watson Research /* P.O. Box 704 /* Yorktown Heights, NY 10598, USA /*--*/ #endif