Server : Apache System : Linux indy02.toastserver.com 3.10.0-962.3.2.lve1.5.85.el7.x86_64 #1 SMP Thu Apr 18 15:18:36 UTC 2024 x86_64 User : palandch ( 1163) PHP Version : 7.1.33 Disable Function : NONE Directory : /usr/include/yaz/ |
/* This file is part of the YAZ toolkit. * Copyright (C) Index Data. * All rights reserved. * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * Neither the name of Index Data nor the names of its contributors * may be used to endorse or promote products derived from this * software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL THE REGENTS AND CONTRIBUTORS BE LIABLE FOR ANY * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ /** * \file url.h * \brief Fetch URL utility */ #ifndef YAZ_URL_H #define YAZ_URL_H #include <yaz/zgdu.h> YAZ_BEGIN_CDECL /** \brief handle for our URL fetcher */ typedef struct yaz_url *yaz_url_t; /** \brief creates a URL fetcher handle \returns handle */ YAZ_EXPORT yaz_url_t yaz_url_create(void); /** \brief destroys a URL fetcher \param p handle Note: OK to pass NULL as p */ YAZ_EXPORT void yaz_url_destroy(yaz_url_t p); /** \brief sets proxy for URL fetcher \param p handle \param proxy proxy address , e.g "localhost:3128" Passing a proxy of NULL disables proxy use. */ YAZ_EXPORT void yaz_url_set_proxy(yaz_url_t p, const char *proxy); /** \brief sets maximum number of redirects \param p handle \param num maximum number of redirects */ YAZ_EXPORT void yaz_url_set_max_redirects(yaz_url_t p, int num); /** \brief sets verbose level 0=none, >0 verbose \param p handle \param num verbose level */ YAZ_EXPORT void yaz_url_set_verbose(yaz_url_t p, int num); /** \brief executes the actual HTTP request (including redirects, etc) \param p handle \param uri URL \param method HTTP method \param headers HTTP headers to be used (NULL for no custom headers) \param buf content buffer for HTTP request, NULL for empty content \param len content length for HTTP request \returns HTTP response; NULL on ERROR. Use yaz_url_get_error to get details if NULL is returned. */ YAZ_EXPORT Z_HTTP_Response *yaz_url_exec(yaz_url_t p, const char *uri, const char *method, Z_HTTP_Header *headers, const char *buf, size_t len); /** \brief get last error from yaz_url_exec \param p handle \returns message (possibly empty string no error occurred) */ YAZ_EXPORT const char *yaz_url_get_error(yaz_url_t p); YAZ_END_CDECL #endif /* * Local variables: * c-basic-offset: 4 * c-file-style: "Stroustrup" * indent-tabs-mode: nil * End: * vim: shiftwidth=4 tabstop=8 expandtab */