Also known as ISC bind. This import adds utilities such as host(1), dig(1), and nslookup(1), as well as many other tools and libraries. Change-Id: I035ca46e64f1965d57019e773f4ff0ef035e4aa3
162 lines
3.9 KiB
C
162 lines
3.9 KiB
C
/* $NetBSD: context.h,v 1.4 2014/12/10 04:37:59 christos Exp $ */
|
|
|
|
/*
|
|
* Copyright (C) 2009 Internet Systems Consortium, Inc. ("ISC")
|
|
*
|
|
* Permission to use, copy, modify, and/or distribute this software for any
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
* copyright notice and this permission notice appear in all copies.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
|
|
* REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
|
|
* AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
|
|
* INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
|
* LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
|
|
* OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
* PERFORMANCE OF THIS SOFTWARE.
|
|
*/
|
|
|
|
/* Id: context.h,v 1.3 2009/09/02 23:48:02 tbox Exp */
|
|
|
|
#ifndef IRS_CONTEXT_H
|
|
#define IRS_CONTEXT_H 1
|
|
|
|
/*! \file
|
|
*
|
|
* \brief
|
|
* The IRS context module provides an abstract interface to the DNS library
|
|
* with an application. An IRS context object initializes and holds various
|
|
* resources used in the DNS library.
|
|
*/
|
|
|
|
#include <dns/types.h>
|
|
#include <irs/types.h>
|
|
|
|
ISC_LANG_BEGINDECLS
|
|
|
|
isc_result_t
|
|
irs_context_create(irs_context_t **contextp);
|
|
/*%<
|
|
* Create an IRS context. It internally initializes the ISC and DNS libraries
|
|
* (if not yet), creates a DNS client object and initializes the client using
|
|
* the configuration files parsed via the 'resconf' and 'dnsconf' IRS modules.
|
|
* Some of the internally initialized objects can be used by the application
|
|
* via irs_context_getxxx() functions (see below).
|
|
*
|
|
* Requires:
|
|
*
|
|
*\li contextp != NULL && *contextp == NULL.
|
|
*/
|
|
|
|
isc_result_t
|
|
irs_context_get(irs_context_t **contextp);
|
|
/*%<
|
|
* Return an IRS context for the calling thread. If no IRS context is
|
|
* associated to the thread, this function creates a new one by calling
|
|
* irs_context_create(), and associates it with the thread as a thread specific
|
|
* data value. This function is provided for standard libraries that are
|
|
* expected to be thread-safe but do not accept an appropriate IRS context
|
|
* as a library parameter, e.g., getaddrinfo().
|
|
*
|
|
* Requires:
|
|
*
|
|
*\li contextp != NULL && *contextp == NULL.
|
|
*/
|
|
|
|
void
|
|
irs_context_destroy(irs_context_t **contextp);
|
|
/*%<
|
|
* Destroy an IRS context.
|
|
*
|
|
* Requires:
|
|
*
|
|
*\li '*contextp' is a valid IRS context.
|
|
*
|
|
* Ensures:
|
|
*\li '*contextp' == NULL.
|
|
*/
|
|
|
|
isc_mem_t *
|
|
irs_context_getmctx(irs_context_t *context);
|
|
/*%<
|
|
* Return the memory context held in the context.
|
|
*
|
|
* Requires:
|
|
*
|
|
*\li 'context' is a valid IRS context.
|
|
*/
|
|
|
|
isc_appctx_t *
|
|
irs_context_getappctx(irs_context_t *context);
|
|
/*%<
|
|
* Return the application context held in the context.
|
|
*
|
|
* Requires:
|
|
*
|
|
*\li 'context' is a valid IRS context.
|
|
*/
|
|
|
|
isc_taskmgr_t *
|
|
irs_context_gettaskmgr(irs_context_t *context);
|
|
/*%<
|
|
* Return the task manager held in the context.
|
|
*
|
|
* Requires:
|
|
*
|
|
*\li 'context' is a valid IRS context.
|
|
*/
|
|
|
|
isc_timermgr_t *
|
|
irs_context_gettimermgr(irs_context_t *context);
|
|
/*%<
|
|
* Return the timer manager held in the context.
|
|
*
|
|
* Requires:
|
|
*
|
|
*\li 'context' is a valid IRS context.
|
|
*/
|
|
|
|
isc_task_t *
|
|
irs_context_gettask(irs_context_t *context);
|
|
/*%<
|
|
* Return the task object held in the context.
|
|
*
|
|
* Requires:
|
|
*
|
|
*\li 'context' is a valid IRS context.
|
|
*/
|
|
|
|
dns_client_t *
|
|
irs_context_getdnsclient(irs_context_t *context);
|
|
/*%<
|
|
* Return the DNS client object held in the context.
|
|
*
|
|
* Requires:
|
|
*
|
|
*\li 'context' is a valid IRS context.
|
|
*/
|
|
|
|
irs_resconf_t *
|
|
irs_context_getresconf(irs_context_t *context);
|
|
/*%<
|
|
* Return the resolver configuration object held in the context.
|
|
*
|
|
* Requires:
|
|
*
|
|
*\li 'context' is a valid IRS context.
|
|
*/
|
|
|
|
irs_dnsconf_t *
|
|
irs_context_getdnsconf(irs_context_t *context);
|
|
/*%<
|
|
* Return the advanced DNS configuration object held in the context.
|
|
*
|
|
* Requires:
|
|
*
|
|
*\li 'context' is a valid IRS context.
|
|
*/
|
|
|
|
ISC_LANG_ENDDECLS
|
|
|
|
#endif /* IRS_CONTEXT_H */
|