Source code pulled from OpenBSD for OpenNTPD. The place to contribute to this code is via the OpenBSD CVS tree.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

88 lines
3.2 KiB

  1. /* $OpenBSD: asr.h,v 1.1 2014/03/26 18:13:15 eric Exp $ */
  2. /*
  3. * Copyright (c) 2012-2014 Eric Faurot <eric@openbsd.org>
  4. *
  5. * Permission to use, copy, modify, and distribute this software for any
  6. * purpose with or without fee is hereby granted, provided that the above
  7. * copyright notice and this permission notice appear in all copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
  10. * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
  11. * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
  12. * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  13. * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
  14. * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
  15. * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  16. */
  17. /*
  18. * Expected fd conditions
  19. */
  20. #define ASR_WANT_READ 1
  21. #define ASR_WANT_WRITE 2
  22. /*
  23. * Structure through which asynchronous query results are returned when
  24. * calling asr_run().
  25. */
  26. struct asr_result {
  27. /* Fields set if the query is not done yet (asr_run returns 0) */
  28. int ar_cond; /* ASR_WANT_READ or ASR_WANT_WRITE */
  29. int ar_fd; /* the fd waiting for io condition */
  30. int ar_timeout; /* time to wait for in milliseconds */
  31. /* Error fields. Depends on the query type. */
  32. int ar_errno;
  33. int ar_h_errno;
  34. int ar_gai_errno;
  35. int ar_rrset_errno;
  36. /* Result for res_*_async() calls */
  37. int ar_count; /* number of answers in the dns reply */
  38. int ar_rcode; /* response code in the dns reply */
  39. void *ar_data; /* raw reply packet (must be freed) */
  40. int ar_datalen; /* reply packet length */
  41. struct sockaddr_storage ar_ns; /* nameserver that responded */
  42. /* Result for other calls. Must be freed properly. */
  43. struct addrinfo *ar_addrinfo;
  44. struct rrsetinfo *ar_rrsetinfo;
  45. struct hostent *ar_hostent;
  46. struct netent *ar_netent;
  47. };
  48. /*
  49. * Asynchronous query management.
  50. */
  51. /* Forward declaration. The API uses opaque pointers as query handles. */
  52. struct asr_query;
  53. int asr_run(struct asr_query *, struct asr_result *);
  54. int asr_run_sync(struct asr_query *, struct asr_result *);
  55. void asr_abort(struct asr_query *);
  56. /*
  57. * Asynchronous version of the resolver functions. Similar prototypes, with
  58. * an extra context parameter at the end which must currently be set to NULL.
  59. * All functions return a handle suitable for use with the management functions
  60. * above.
  61. */
  62. struct asr_query *res_send_async(const unsigned char *, int, void *);
  63. struct asr_query *res_query_async(const char *, int, int, void *);
  64. struct asr_query *res_search_async(const char *, int, int, void *);
  65. struct asr_query *getrrsetbyname_async(const char *, unsigned int, unsigned int,
  66. unsigned int, void *);
  67. struct asr_query *gethostbyname_async(const char *, void *);
  68. struct asr_query *gethostbyname2_async(const char *, int, void *);
  69. struct asr_query *gethostbyaddr_async(const void *, socklen_t, int, void *);
  70. struct asr_query *getnetbyname_async(const char *, void *);
  71. struct asr_query *getnetbyaddr_async(in_addr_t, int, void *);
  72. struct asr_query *getaddrinfo_async(const char *, const char *,
  73. const struct addrinfo *, void *);
  74. struct asr_query *getnameinfo_async(const struct sockaddr *, socklen_t, char *,
  75. size_t, char *, size_t, int, void *);