1 /*
2  * Copyright (c) 2009 NLNet Labs. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
14  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
15  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16  * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
17  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
18  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
19  * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
21  * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
22  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
23  * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24  *
25  */
26 
27 /**
28  * Parsing DNS Adapter.
29  *
30  */
31 
32 #ifndef PARSER_ADDNSPARSER_H
33 #define PARSER_ADDNSPARSER_H
34 
35 #include "wire/acl.h"
36 #include "wire/tsig.h"
37 
38 #include <libxml/xpath.h>
39 #include <libxml/xmlreader.h>
40 
41 /**
42  * Parse <RequestTransfer/>.
43  * \param[in] allocator memory allocator
44  * \param[in] filename filename
45  * \param[in] tsig list of TSIGs
46  * \return acl_type* ACL
47  *
48  */
49 extern acl_type* parse_addns_request_xfr(const char* filename, tsig_type* tsig);
50 
51 /**
52  * Parse <AllowNotify/>.
53  * \param[in] allocator memory allocator
54  * \param[in] filename filename
55  * \param[in] tsig list of TSIGs
56  * \return acl_type* ACL
57  *
58  */
59 extern acl_type* parse_addns_allow_notify(const char* filename, tsig_type* tsig);
60 
61 /**
62  * Parse <ProvideTransfer/>.
63  * \param[in] allocator memory allocator
64  * \param[in] filename filename
65  * \param[in] tsig list of TSIGs
66  * \return acl_type* ACL
67  *
68  */
69 extern acl_type* parse_addns_provide_xfr(const char* filename, tsig_type* tsig);
70 
71 /**
72  * Parse <Notify/>.
73  * \param[in] allocator memory allocator
74  * \param[in] filename filename
75  * \param[in] tsig list of TSIGs
76  * \return acl_type* ACL
77  *
78  */
79 extern acl_type* parse_addns_do_notify(const char* filename, tsig_type* tsig);
80 
81 /**
82  * Parse <TSIG/>.
83  * \param[in] allocator memory allocator
84  * \param[in] filename filename
85  * \return tsig_type* TSIG
86  *
87  */
88 extern tsig_type* parse_addns_tsig(const char* filename);
89 
90 #endif /* PARSER_ADDNSPARSER_H */
91