getdns/src/types-internal.h

128 lines
3.5 KiB
C
Raw Normal View History

2013-08-15 11:33:05 -05:00
/**
*
* /brief getdns contect management functions
*
* This is the meat of the API
* Originally taken from the getdns API description pseudo implementation.
*
*/
/* The MIT License (MIT)
* Copyright (c) 2013 Verisign, Inc.
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*/
#ifndef TYPES_INTERNAL_H_
#define TYPES_INTERNAL_H_
#include "context.h"
#include <ldns/ldns.h>
/* declarations */
struct getdns_dns_req;
struct getdns_network_req;
struct ub_ctx;
2013-08-15 11:33:05 -05:00
typedef enum network_req_state_enum {
NET_REQ_NOT_SENT,
NET_REQ_IN_FLIGHT,
NET_REQ_FINISHED
} network_req_state;
/**
* Request data for unbound
**/
2013-08-15 11:33:05 -05:00
typedef struct getdns_network_req {
/* the async_id from unbound */
int unbound_id;
/* state var */
network_req_state state;
/* owner request (contains name) */
struct getdns_dns_req* owner;
/* request type */
uint16_t request_type;
/* request class */
uint16_t request_class;
/* result */
ldns_pkt* result;
/* next request to issue after this one */
struct getdns_network_req* next;
2013-08-15 11:33:05 -05:00
} getdns_network_req;
/* dns request - manages a number of network requests and
* the initial data passed to getdns_general
*/
2013-08-15 11:33:05 -05:00
typedef struct getdns_dns_req {
/* name */
char *name;
/* current network request */
2013-08-15 11:33:05 -05:00
struct getdns_network_req *current_req;
/* first request in list */
struct getdns_network_req *first_req;
/* context that owns the request */
2013-08-15 11:33:05 -05:00
getdns_context_t context;
/* ub_ctx issuing the request */
struct ub_ctx* unbound;
/* request extensions */
getdns_dict *extensions;
2013-08-15 11:33:05 -05:00
/* callback data */
getdns_callback_t user_callback;
void *user_pointer;
2013-08-15 16:51:26 -05:00
getdns_transaction_t trans_id; /* the transaction id */
2013-08-15 11:33:05 -05:00
} getdns_dns_req;
/* utility methods */
/* network request utilities */
2013-08-15 11:42:35 -05:00
void network_req_free(getdns_network_req* net_req);
2013-08-15 11:33:05 -05:00
getdns_network_req* network_req_new(getdns_dns_req* owner,
2013-08-15 11:33:05 -05:00
uint16_t request_type,
uint16_t request_class,
2013-08-15 16:51:26 -05:00
struct getdns_dict* extensions);
2013-08-15 11:33:05 -05:00
/* dns request utils */
getdns_dns_req* dns_req_new(getdns_context_t context,
struct ub_ctx* unbound,
2013-08-15 11:33:05 -05:00
const char* name,
uint16_t request_type,
struct getdns_dict *extensions);
2013-08-15 11:33:05 -05:00
2013-08-15 11:42:35 -05:00
void dns_req_free(getdns_dns_req* req);
/* cancel the request */
getdns_return_t dns_req_cancel(getdns_dns_req* req);
2013-08-15 11:33:05 -05:00
#endif