/* * This File is part of Davix, The IO library for HTTP based protocols * Copyright (C) CERN 2013 * Author: Adrien Devresse * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * */ #ifndef DAVIX_DAVPOSIX_HPP #define DAVIX_DAVPOSIX_HPP #include #include #include #include /** @file davposix.hpp @author Devresse Adrien @brief POSIX-like API of davix */ #ifndef __DAVIX_INSIDE__ #error "Only davix.hpp for the C++ API or davix.h for the C API should be included." #endif namespace Davix { class DavPosixInternal; /// /// @brief POSIX-like API of Davix. /// /// DavPosix offers a POSIX-like API for HTTP/WebDav file operations. /// /// POSIX API can be used for convenience when porting application. /// to a POSIX like interface. /// /// DavPosix and all associated method are Thread safe. class DAVIX_EXPORT DavPosix : NonCopyable { public: /// /// \brief default constructor /// \param handle /// /// /// @snippet example_code_snippets.cpp DavPosix DavPosix(Context* handle); virtual ~DavPosix(); /** @brief POSIX-like stat() call Behavior similar to the POSIX stat function, see man 3 stat. Supported by Webdav, Http and S3. Depending of the protocol, some struct stat field can be ignored. @param params request options, can be NULL @param str string url @param st stat struct to fill @param err Davix error report system @return 0 if success, negative value if error @snippet example_code_snippets.cpp stat */ int stat(const RequestParams* params, const std::string & str, struct stat * st, DavixError** err); /** @brief 64bits version of /ref Davix::DavPosix::stat. @snippet example_code_snippets.cpp stat */ int stat64(const RequestParams *params, const std::string & url, StatInfo* st, DavixError** err); /** @brief get_quota gives quota information on a directory */ int get_quota(const RequestParams *params, const std::string & url, QuotaInfo* st, DavixError** err); /** @brief open a directory for listing. behavior similar to the POSIX opendir function. Supported by Webdav. @param params request options, can be NULL @param url url of the directory to list @param err Davix error report system @return DAVIX_DIR davix readdir handle, NULL if error @snippet example_code_snippets.cpp opendir */ DAVIX_DIR* opendir(const RequestParams* params, const std::string & url, DavixError** err); /** @brief read an entry directory. Behavior similar to the POSIX readdir function. @param dir directory handle @param err Davix Error report @return dirent struct if success, or NULL if error @snippet example_code_snippets.cpp opendir */ struct dirent* readdir(DAVIX_DIR* dir, DavixError** err); /** @brief close a directory handle @param d directory handle to close @param err Davix error report system @return 0 if success else a negative value and err is set. @snippet example_code_snippets.cpp opendir */ int closedir(DAVIX_DIR* d, DavixError** err); /** @brief open a directory for listing with per entry meta-data information. Similar to \ref Davix::DavPosix::opendir but provide stat() information for each entry Supported by Webdav. @param params request options, can be NULL @param url url of the directory to list @param err Davix error report system @return DAVIX_DIR davix readdir handle or NULL if error, in this case err is set. @snippet example_code_snippets.cpp opendirpp */ DAVIX_DIR* opendirpp(const RequestParams* params, const std::string & url, DavixError** err); /** @brief execute an readdirpp function Similar to \ref Davix::DavPosix::readdir but provide stat() information for each entry. Supported by Webdav. @param dir directory handle @param st struct to fill @param err Davix Error report @return dirent struct if success, or NULL if error @snippet example_code_snippets.cpp opendirpp */ struct dirent* readdirpp(DAVIX_DIR* dir, struct stat * st, DavixError** err ); /** @brief close a directory handle @param d directory handle to close @param err Davix error report system @return 0 if success else a negative value and err is set. @snippet example_code_snippets.cpp opendirpp */ int closedirpp(DAVIX_DIR* d, DavixError** err ); /** @brief execute a mkdir function with Webdav. Behavior similar to the POSIX mkdir function. @warning dependening of the server, implementation, mode_t parameter can be ignored @param params request options, can be NULL @param url url of the directory to create @param right default mode of the directory ( ignored for now ) @param err Davix error report system @return 0 if success else a negative value and err is set. @snippet example_code_snippets.cpp mkdir */ int mkdir(const RequestParams* params, const std::string& url, mode_t right, DavixError** err); /** @brief rename a target file or collection. Behavior similar to the POSIX rename function. @param params request options, can be NULL @param source_url old url of the resource @param target_url new url of the resource @param err Davix error report system @return 0 if success else a negative value and err is set. @snippet example_code_snippets.cpp rename */ int rename(const RequestParams* params, const std::string& source_url, const std::string& target_url, DavixError** err); /** @brief execute a remove file operation. Behavior similar to the POSIX unlink function. @param params request options, can be NULL @param url file to delete @param err Davix error report system @return 0 if success else a negative value and err is set. @snippet example_code_snippets.cpp unlink */ int unlink(const RequestParams* params, const std::string& url, DavixError** err); /** @brief execute a remove directory operation. Behavior similar to the POSIX rmdir function @param params request options, can be NULL @param url directory to delete @param err Davix error report system @return 0 if success else a negative value and err is set. @snippet example_code_snippets.cpp rmdir */ int rmdir(const RequestParams* params, const std::string& url, DavixError** err); /** @brief open a file for read/write operation in a POSIX-like approach. Behavior similar to the POSIX open function This operation is supported on plain HTTP servers. @param params request options, can be NULL @param url url of the HTTP file to open @param flags open flags, similar to the POSIX function open @param err Davix Error report @return Davix file descriptor in case of success, or NULL if an error occures. @snippet example_code_snippets.cpp open */ DAVIX_FD* open(const RequestParams* params, const std::string & url, int flags, DavixError** err); /** @brief read a file in a POSIX-like approach with HTTP(S). Behavior similar to the POSIX read function @param fd davix file descriptor @param buffer buffer to fill @param count maximum number of bytes to read @param err Davix Error report @return the size of data or a negative value if an error occurred @snippet example_code_snippets.cpp read */ ssize_t read(DAVIX_FD* fd, void* buffer, size_t count, DavixError** err); /** @brief do a partial read of a file in a POSIX-like approach with HTTP(S). Behavior similar to the POSIX pread function. @param fd davix file descriptor @param buffer buffer to fill @param count maximum number of bytes to read @param offset offset to use @param err Davix Error report @return the size of data or a negative value if an error occurred @snippet example_code_snippets.cpp pread */ ssize_t pread(DAVIX_FD* fd, void* buffer, size_t count, off_t offset, DavixError** err); /** @brief 64bits version of /ref Davix::DavPosix::pread */ dav_ssize_t pread64(DAVIX_FD* fd, void* buffer, dav_size_t count, dav_off_t offset, DavixError ** err); /** @brief do a partial write of a file in a POSIX-like approach with HTTP(S). Behavior similar to the POSIX pwrite function @param fd davix file descriptor @param buffer buffer to fill @param count maximum number of bytes to write @param offset offset to use @param err Davix Error report @return the size of data written or a negative value if an error occurred @snippet example_code_snippets.cpp pwrite */ ssize_t pwrite(DAVIX_FD* fd, const void* buffer, size_t count, off_t offset, DavixError** err); /** @brief 64bits version of /ref Davix::DavPosix::pwrite */ dav_ssize_t pwrite64(DAVIX_FD* fd, const void* buffer, dav_size_t count, dav_off_t offset, DavixError** err); /** @brief pread_vec a file in a POSIX-like approach with HTTP(S). Vector read operation. Able to do several read operations in one single request. NOTE: The return code is the number of data bytes received from the server, not the total number of bytes written into the buffers. The two might not be equal if range coalescing is performed. Check diov_size of the output vector to make sure the buffers contain the expected number of bytes. @param fd davix file descriptor @param input_vec input vectors, parameters @param output_vec output vectors, results @param count_vec number of vector struct @param err Davix Error report @return total number of bytes read, or -1 if error occurs. @snippet example_code_snippets.cpp preadVec */ dav_ssize_t preadVec(DAVIX_FD* fd, const DavIOVecInput * input_vec, DavIOVecOuput * output_vec, dav_size_t count_vec, DavixError** err); /** @brief write a file in a POSIX-like approach with HTTP(S). Behavior similar to the POSIX write function. @param fd davix file descriptor @param buf buffer with the write content @param count number of bytes to write @param err Davix Error report @return the size of the written data or a negative value if an error occurred @snippet example_code_snippets.cpp write */ ssize_t write(DAVIX_FD* fd, const void* buf, size_t count, DavixError** err); /** @brief move the cursor a davix file with HTTP(S). Behavior similar to the POSIX lseek function. @param fd davix file descriptor @param offset offset in byte inside the file @param flags lseek flags, similar to the lseek function @param err Davix Error report @return the offset position or (off_t)-1 if error occurs @snippet example_code_snippets.cpp lseek */ off_t lseek(DAVIX_FD* fd, off_t offset, int flags, DavixError** err); /** @brief 64bits versions of /ref Davix::DavixPosix::lseek */ dav_off_t lseek64(DAVIX_FD* fd, dav_off_t, int flags, DavixError** err); /** @brief close a existing file descriptor. Note : all file descriptors MUST be closed before the destruction of the parent davix context @param fd davix file descriptor @param err Davix Error report @return 0 if success, negative value if error @snippet example_code_snippets.cpp close */ int close(DAVIX_FD* fd, DavixError** err); /** @brief give advise about next file operation similar to posix_fadvise, allow I/O optimizations non-blocking asynchronous function @param fd Davix file descriptor @param offset offset of the next chunk to read @param len size of the next chunk to read @param advise type of pattern for I/O : sequential, random */ void fadvise(DAVIX_FD* fd, dav_off_t offset, dav_size_t len, advise_t advise); private: DAVIX_DIR* internal_opendirpp(const RequestParams* params, const char * scope, const std::string & body, const std::string & url, DavixError** err); Context* context; long _timeout; long _s_buff; DavPosixInternal* d_ptr; }; } // namespace Davix #endif // DAVIX_DAVPOSIX_HPP