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