/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * Copyright by The HDF Group. * * All rights reserved. * * * * This file is part of HDF5. The full HDF5 copyright notice, including * * terms governing use, modification, and redistribution, is contained in * * the COPYING file, which can be found at the root of the source code * * distribution tree, or in https://www.hdfgroup.org/licenses. * * If you do not have access to either file, you may request a copy from * * help@hdfgroup.org. * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ /* * Purpose: The public header file for the Hadoop Distributed File System * (hdfs) virtual file driver (VFD) */ #ifndef H5FDhdfs_H #define H5FDhdfs_H #ifdef H5_HAVE_LIBHDFS /** Initializer for the hdfs VFD */ #define H5FD_HDFS (H5FDperform_init(H5FD_hdfs_init)) /** Identifier for the hdfs VFD */ #define H5FD_HDFS_VALUE H5_VFD_HDFS #else /** Initializer for the hdfs VFD (disabled) */ #define H5FD_HDFS (H5I_INVALID_HID) /** Identifier for the hdfs VFD (disabled) */ #define H5FD_HDFS_VALUE H5_VFD_INVALID #endif /* H5_HAVE_LIBHDFS */ #ifdef H5_HAVE_LIBHDFS #ifdef __cplusplus extern "C" { #endif /** * The version number of the H5FD_hdfs_fapl_t configuration * structure for the #H5FD_HDFS driver */ #define H5FD__CURR_HDFS_FAPL_T_VERSION 1 /** Max size of the node name */ #define H5FD__HDFS_NODE_NAME_SPACE 128 /** Max size of the user name */ #define H5FD__HDFS_USER_NAME_SPACE 128 /** Max size of the kerberos cache path */ #define H5FD__HDFS_KERB_CACHE_PATH_SPACE 128 /** *\struct H5FD_hdfs_fapl_t * \brief Configuration structure for H5Pset_fapl_hdfs() / H5Pget_fapl_hdfs() * * \details H5FD_hdfs_fapl_t is a public structure that is used to pass * configuration data to the #H5FD_HDFS driver via a File Access * Property List. A pointer to an instance of this structure is * a parameter to H5Pset_fapl_hdfs() and H5Pget_fapl_hdfs(). * * \var int32_t H5FD_hdfs_fapl_t::version * Version number of the H5FD_hdfs_fapl_t structure. Any instance passed * to H5Pset_fapl_hdfs() / H5Pget_fapl_hdfs() must have a recognized version * number or an error will be raised. Currently, this field should be set * to #H5FD__CURR_HDFS_FAPL_T_VERSION. * * \var char H5FD_hdfs_fapl_t::namenode_name[H5FD__HDFS_NODE_NAME_SPACE + 1] * Name of "Name Node" to access as the HDFS server * * \var int32_t H5FD_hdfs_fapl_t::namenode_port * Port number to use to connect with Name Node * * \var char H5FD_hdfs_fapl_t::user_name[H5FD__HDFS_USER_NAME_SPACE + 1] * Username to use when accessing file * * \var char H5FD_hdfs_fapl_t::kerberos_ticket_cache[H5FD__HDFS_KERB_CACHE_PATH_SPACE + 1] * Path to the location of the Kerberos authentication cache * * \var int32_t H5FD_hdfs_fapl_t::stream_buffer_size * Size (in bytes) of the file read stream buffer */ typedef struct H5FD_hdfs_fapl_t { int32_t version; char namenode_name[H5FD__HDFS_NODE_NAME_SPACE + 1]; int32_t namenode_port; char user_name[H5FD__HDFS_USER_NAME_SPACE + 1]; char kerberos_ticket_cache[H5FD__HDFS_KERB_CACHE_PATH_SPACE + 1]; int32_t stream_buffer_size; } H5FD_hdfs_fapl_t; /** @private * * \brief Private initializer for the hdfs VFD */ H5_DLL hid_t H5FD_hdfs_init(void); /** * \ingroup FAPL * * \brief Modifies the file access property list to use the #H5FD_HDFS driver * * \fapl_id * \param[in] fa Pointer to #H5FD_HDFS driver configuration structure * * \returns \herr_t * * \details H5Pset_fapl_hdfs() modifies the file access property list to use the * #H5FD_HDFS driver. * * \since 1.10.6 */ H5_DLL herr_t H5Pset_fapl_hdfs(hid_t fapl_id, H5FD_hdfs_fapl_t *fa); /** * \ingroup FAPL * * \brief Queries a File Access Property List for #H5FD_HDFS file driver properties * * \fapl_id * \param[out] fa_out Pointer to #H5FD_HDFS driver configuration structure * \returns \herr_t * * \details H5Pget_fapl_hdfs() queries the #H5FD_HDFS driver properties as set * by H5Pset_fapl_hdfs(). * * \since 1.10.6 */ H5_DLL herr_t H5Pget_fapl_hdfs(hid_t fapl_id, H5FD_hdfs_fapl_t *fa_out); #ifdef __cplusplus } #endif #endif /* H5_HAVE_LIBHDFS */ #endif /* ifndef H5FDhdfs_H */