xref: /titanic_44/usr/src/lib/libpool/common/pool_xml_impl.h (revision 7c478bd95313f5f23a4c958a745db2134aa03244)
1*7c478bd9Sstevel@tonic-gate /*
2*7c478bd9Sstevel@tonic-gate  * CDDL HEADER START
3*7c478bd9Sstevel@tonic-gate  *
4*7c478bd9Sstevel@tonic-gate  * The contents of this file are subject to the terms of the
5*7c478bd9Sstevel@tonic-gate  * Common Development and Distribution License, Version 1.0 only
6*7c478bd9Sstevel@tonic-gate  * (the "License").  You may not use this file except in compliance
7*7c478bd9Sstevel@tonic-gate  * with the License.
8*7c478bd9Sstevel@tonic-gate  *
9*7c478bd9Sstevel@tonic-gate  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10*7c478bd9Sstevel@tonic-gate  * or http://www.opensolaris.org/os/licensing.
11*7c478bd9Sstevel@tonic-gate  * See the License for the specific language governing permissions
12*7c478bd9Sstevel@tonic-gate  * and limitations under the License.
13*7c478bd9Sstevel@tonic-gate  *
14*7c478bd9Sstevel@tonic-gate  * When distributing Covered Code, include this CDDL HEADER in each
15*7c478bd9Sstevel@tonic-gate  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16*7c478bd9Sstevel@tonic-gate  * If applicable, add the following below this CDDL HEADER, with the
17*7c478bd9Sstevel@tonic-gate  * fields enclosed by brackets "[]" replaced with your own identifying
18*7c478bd9Sstevel@tonic-gate  * information: Portions Copyright [yyyy] [name of copyright owner]
19*7c478bd9Sstevel@tonic-gate  *
20*7c478bd9Sstevel@tonic-gate  * CDDL HEADER END
21*7c478bd9Sstevel@tonic-gate  */
22*7c478bd9Sstevel@tonic-gate /*
23*7c478bd9Sstevel@tonic-gate  * Copyright 2003 Sun Microsystems, Inc.  All rights reserved.
24*7c478bd9Sstevel@tonic-gate  * Use is subject to license terms.
25*7c478bd9Sstevel@tonic-gate  */
26*7c478bd9Sstevel@tonic-gate 
27*7c478bd9Sstevel@tonic-gate #ifndef	_POOL_XML_IMPL_H
28*7c478bd9Sstevel@tonic-gate #define	_POOL_XML_IMPL_H
29*7c478bd9Sstevel@tonic-gate 
30*7c478bd9Sstevel@tonic-gate #pragma ident	"%Z%%M%	%I%	%E% SMI"
31*7c478bd9Sstevel@tonic-gate 
32*7c478bd9Sstevel@tonic-gate #ifdef	__cplusplus
33*7c478bd9Sstevel@tonic-gate extern "C" {
34*7c478bd9Sstevel@tonic-gate #endif
35*7c478bd9Sstevel@tonic-gate 
36*7c478bd9Sstevel@tonic-gate /*
37*7c478bd9Sstevel@tonic-gate  * This file contains the definitions of types and supporting
38*7c478bd9Sstevel@tonic-gate  * functions to implement the libpool XML specific data manipulation
39*7c478bd9Sstevel@tonic-gate  * facility.
40*7c478bd9Sstevel@tonic-gate  *
41*7c478bd9Sstevel@tonic-gate  * For more information on the libpool generic data manipulation
42*7c478bd9Sstevel@tonic-gate  * facility, look at pool_impl.h.
43*7c478bd9Sstevel@tonic-gate  *
44*7c478bd9Sstevel@tonic-gate  * The central types for the generic data representation/storage
45*7c478bd9Sstevel@tonic-gate  * facility are here enhanced to provide additional XML specific
46*7c478bd9Sstevel@tonic-gate  * information.
47*7c478bd9Sstevel@tonic-gate  */
48*7c478bd9Sstevel@tonic-gate 
49*7c478bd9Sstevel@tonic-gate /*
50*7c478bd9Sstevel@tonic-gate  * pool_xml_elem_t is the XML (to be precise, libxml - although this
51*7c478bd9Sstevel@tonic-gate  * could be easily ported to an alternative C-API xml library)
52*7c478bd9Sstevel@tonic-gate  * specific representation of the pool_elem_t structure.
53*7c478bd9Sstevel@tonic-gate  *
54*7c478bd9Sstevel@tonic-gate  * The pxe_node pointer is a pointer to an XML element which
55*7c478bd9Sstevel@tonic-gate  * represents the element in the XML document
56*7c478bd9Sstevel@tonic-gate  */
57*7c478bd9Sstevel@tonic-gate typedef struct pool_xml_elem {
58*7c478bd9Sstevel@tonic-gate 	/*
59*7c478bd9Sstevel@tonic-gate 	 * Common to pool_elem_t
60*7c478bd9Sstevel@tonic-gate 	 */
61*7c478bd9Sstevel@tonic-gate 	pool_elem_t pxe_elem;
62*7c478bd9Sstevel@tonic-gate 	void *pxe_pad1;
63*7c478bd9Sstevel@tonic-gate 	void *pxe_pad2;
64*7c478bd9Sstevel@tonic-gate 	/*
65*7c478bd9Sstevel@tonic-gate 	 * Common to pool_xml_elem_t
66*7c478bd9Sstevel@tonic-gate 	 */
67*7c478bd9Sstevel@tonic-gate 	xmlNodePtr pxe_node;				/* XML Element */
68*7c478bd9Sstevel@tonic-gate } pool_xml_elem_t;
69*7c478bd9Sstevel@tonic-gate 
70*7c478bd9Sstevel@tonic-gate typedef pool_xml_elem_t pool_xml_system_t;
71*7c478bd9Sstevel@tonic-gate 
72*7c478bd9Sstevel@tonic-gate typedef struct pool_xml_resource  {
73*7c478bd9Sstevel@tonic-gate 	/*
74*7c478bd9Sstevel@tonic-gate 	 * Common to pool_elem_t
75*7c478bd9Sstevel@tonic-gate 	 */
76*7c478bd9Sstevel@tonic-gate 	pool_elem_t pxe_elem;
77*7c478bd9Sstevel@tonic-gate 	/*
78*7c478bd9Sstevel@tonic-gate 	 * Specific to pool_resource_t
79*7c478bd9Sstevel@tonic-gate 	 */
80*7c478bd9Sstevel@tonic-gate 	int (*pr_is_system)(const pool_resource_t *);
81*7c478bd9Sstevel@tonic-gate 	int (*pr_can_associate)(const pool_resource_t *);
82*7c478bd9Sstevel@tonic-gate 	/*
83*7c478bd9Sstevel@tonic-gate 	 * Common to pool_xml_elem_t
84*7c478bd9Sstevel@tonic-gate 	 */
85*7c478bd9Sstevel@tonic-gate 	xmlNodePtr pxe_node;				/* XML Element */
86*7c478bd9Sstevel@tonic-gate } pool_xml_resource_t;
87*7c478bd9Sstevel@tonic-gate 
88*7c478bd9Sstevel@tonic-gate typedef struct pool_xml_pool {
89*7c478bd9Sstevel@tonic-gate 	/*
90*7c478bd9Sstevel@tonic-gate 	 * Common to pool_elem_t
91*7c478bd9Sstevel@tonic-gate 	 */
92*7c478bd9Sstevel@tonic-gate 	pool_elem_t pxe_elem;
93*7c478bd9Sstevel@tonic-gate 	/*
94*7c478bd9Sstevel@tonic-gate 	 * Specific to pool_t
95*7c478bd9Sstevel@tonic-gate 	 */
96*7c478bd9Sstevel@tonic-gate 	int (*pp_associate)(pool_t *, const pool_resource_t *);
97*7c478bd9Sstevel@tonic-gate 	int (*pp_dissociate)(pool_t *, const pool_resource_t *);
98*7c478bd9Sstevel@tonic-gate 	/*
99*7c478bd9Sstevel@tonic-gate 	 * Common to pool_xml_elem_t
100*7c478bd9Sstevel@tonic-gate 	 */
101*7c478bd9Sstevel@tonic-gate 	xmlNodePtr pxe_node;				/* XML Element */
102*7c478bd9Sstevel@tonic-gate } pool_xml_pool_t;
103*7c478bd9Sstevel@tonic-gate 
104*7c478bd9Sstevel@tonic-gate typedef pool_xml_elem_t pool_xml_component_t;
105*7c478bd9Sstevel@tonic-gate 
106*7c478bd9Sstevel@tonic-gate /*
107*7c478bd9Sstevel@tonic-gate  * pool_xml_result_set_t is the XML (to be precise, libxml - although
108*7c478bd9Sstevel@tonic-gate  * this could be easily ported to an alternative C-API xml library)
109*7c478bd9Sstevel@tonic-gate  * specific representation of the pool_result_set_t structure.
110*7c478bd9Sstevel@tonic-gate  *
111*7c478bd9Sstevel@tonic-gate  * The pxr_ctx member is a pointer to an XML XPath Context which
112*7c478bd9Sstevel@tonic-gate  * represents the context in which this result set is valid. AN
113*7c478bd9Sstevel@tonic-gate  * alternative way of thinking about this is to envisage the context
114*7c478bd9Sstevel@tonic-gate  * as the root of the search which is used to build the result set.
115*7c478bd9Sstevel@tonic-gate  *
116*7c478bd9Sstevel@tonic-gate  * The pxr_path member is a pointer to the compiled XPath statement
117*7c478bd9Sstevel@tonic-gate  * used to generate this result set.
118*7c478bd9Sstevel@tonic-gate  *
119*7c478bd9Sstevel@tonic-gate  * The prs_index member is a cursor into the result set and is used by
120*7c478bd9Sstevel@tonic-gate  * the various result set functions to determine which result set
121*7c478bd9Sstevel@tonic-gate  * member to access.
122*7c478bd9Sstevel@tonic-gate  *
123*7c478bd9Sstevel@tonic-gate  */
124*7c478bd9Sstevel@tonic-gate typedef struct pool_xml_result_set {
125*7c478bd9Sstevel@tonic-gate 	const pool_conf_t *prs_conf;			/* Configuration */
126*7c478bd9Sstevel@tonic-gate 	int prs_active;					/* Query active? */
127*7c478bd9Sstevel@tonic-gate 	int prs_index;					/* Result Index */
128*7c478bd9Sstevel@tonic-gate 	pool_elem_t *(*prs_next)(pool_result_set_t *);
129*7c478bd9Sstevel@tonic-gate 	pool_elem_t *(*prs_prev)(pool_result_set_t *);
130*7c478bd9Sstevel@tonic-gate 	pool_elem_t *(*prs_first)(pool_result_set_t *);
131*7c478bd9Sstevel@tonic-gate 	pool_elem_t *(*prs_last)(pool_result_set_t *);
132*7c478bd9Sstevel@tonic-gate 	int (*prs_set_index)(pool_result_set_t *, int);
133*7c478bd9Sstevel@tonic-gate 	int (*prs_get_index)(pool_result_set_t *);
134*7c478bd9Sstevel@tonic-gate 	int (*prs_close)(pool_result_set_t *);
135*7c478bd9Sstevel@tonic-gate 	int (*prs_count)(pool_result_set_t *);
136*7c478bd9Sstevel@tonic-gate 	/*
137*7c478bd9Sstevel@tonic-gate 	 * End of common part
138*7c478bd9Sstevel@tonic-gate 	 */
139*7c478bd9Sstevel@tonic-gate 	xmlXPathContextPtr pxr_ctx;			/* Result Context */
140*7c478bd9Sstevel@tonic-gate 	xmlXPathObjectPtr pxr_path;			/* Result Path Object */
141*7c478bd9Sstevel@tonic-gate } pool_xml_result_set_t;
142*7c478bd9Sstevel@tonic-gate 
143*7c478bd9Sstevel@tonic-gate /*
144*7c478bd9Sstevel@tonic-gate  * pool_xml_connection_t is the XML (to be precise, libxml - although
145*7c478bd9Sstevel@tonic-gate  * this could be easily ported to an alternative C-API xml library)
146*7c478bd9Sstevel@tonic-gate  * specific representation of the pool_result_set_t structure.
147*7c478bd9Sstevel@tonic-gate  *
148*7c478bd9Sstevel@tonic-gate  * The pxc_doc member is a pointer to an XML document structure which
149*7c478bd9Sstevel@tonic-gate  * contains information about the XML document which acts as the data
150*7c478bd9Sstevel@tonic-gate  * store for this connection.
151*7c478bd9Sstevel@tonic-gate  *
152*7c478bd9Sstevel@tonic-gate  * The pxc_file member is a FILE pointer to the data file used to
153*7c478bd9Sstevel@tonic-gate  * store the XML document.
154*7c478bd9Sstevel@tonic-gate  *
155*7c478bd9Sstevel@tonic-gate  * The pxc_oflags member is the OR'd list of options specified when
156*7c478bd9Sstevel@tonic-gate  * opening this connection.
157*7c478bd9Sstevel@tonic-gate  *
158*7c478bd9Sstevel@tonic-gate  * The pxc_cleanup member is a boolean flag indicating whether a
159*7c478bd9Sstevel@tonic-gate  * configuration has a backup which needs to be cleaned up. This is
160*7c478bd9Sstevel@tonic-gate  * used as a means of providing resilient configuration changes in the
161*7c478bd9Sstevel@tonic-gate  * face of potential failure.
162*7c478bd9Sstevel@tonic-gate  *
163*7c478bd9Sstevel@tonic-gate  */
164*7c478bd9Sstevel@tonic-gate typedef struct pool_xml_connection {
165*7c478bd9Sstevel@tonic-gate 	const char *pc_name;				/* Provider name */
166*7c478bd9Sstevel@tonic-gate 	int pc_store_type;				/* Datastore type */
167*7c478bd9Sstevel@tonic-gate 	int pc_oflags;					/* Open flags */
168*7c478bd9Sstevel@tonic-gate 	int (*pc_close)(pool_conf_t *);
169*7c478bd9Sstevel@tonic-gate 	int (*pc_validate)(const pool_conf_t *, pool_valid_level_t);
170*7c478bd9Sstevel@tonic-gate 	int (*pc_commit)(pool_conf_t *);
171*7c478bd9Sstevel@tonic-gate 	int (*pc_export)(const pool_conf_t *, const char *,
172*7c478bd9Sstevel@tonic-gate 	    pool_export_format_t);
173*7c478bd9Sstevel@tonic-gate 	int (*pc_rollback)(pool_conf_t *);
174*7c478bd9Sstevel@tonic-gate 	pool_result_set_t *(*pc_exec_query)(const pool_conf_t *,
175*7c478bd9Sstevel@tonic-gate 	    const pool_elem_t *, const char *,
176*7c478bd9Sstevel@tonic-gate 	    pool_elem_class_t, pool_value_t **);
177*7c478bd9Sstevel@tonic-gate 	pool_elem_t *(*pc_elem_create)(pool_conf_t *, pool_elem_class_t,
178*7c478bd9Sstevel@tonic-gate 	    pool_resource_elem_class_t, pool_component_elem_class_t);
179*7c478bd9Sstevel@tonic-gate 	int (*pc_remove)(pool_conf_t *);
180*7c478bd9Sstevel@tonic-gate 	int (*pc_res_xfer)(pool_resource_t *, pool_resource_t *, uint64_t);
181*7c478bd9Sstevel@tonic-gate 	int (*pc_res_xxfer)(pool_resource_t *, pool_resource_t *,
182*7c478bd9Sstevel@tonic-gate 	    pool_component_t **);
183*7c478bd9Sstevel@tonic-gate 	char *(*pc_get_binding)(pool_conf_t *, pid_t);
184*7c478bd9Sstevel@tonic-gate 	int (*pc_set_binding)(pool_conf_t *, const char *, idtype_t, id_t);
185*7c478bd9Sstevel@tonic-gate 	char *(*pc_get_resource_binding)(pool_conf_t *,
186*7c478bd9Sstevel@tonic-gate 	    pool_resource_elem_class_t, pid_t);
187*7c478bd9Sstevel@tonic-gate 	/*
188*7c478bd9Sstevel@tonic-gate 	 * End of common part
189*7c478bd9Sstevel@tonic-gate 	 */
190*7c478bd9Sstevel@tonic-gate 	xmlDocPtr pxc_doc;				/* XML document */
191*7c478bd9Sstevel@tonic-gate 	FILE *pxc_file;					/* XML File */
192*7c478bd9Sstevel@tonic-gate } pool_xml_connection_t;
193*7c478bd9Sstevel@tonic-gate 
194*7c478bd9Sstevel@tonic-gate #ifdef	__cplusplus
195*7c478bd9Sstevel@tonic-gate }
196*7c478bd9Sstevel@tonic-gate #endif
197*7c478bd9Sstevel@tonic-gate 
198*7c478bd9Sstevel@tonic-gate #endif	/* _POOL_XML_IMPL_H */
199