X-Git-Url: http://lists.indexdata.com/cgi-bin?a=blobdiff_plain;f=src%2Futil.hpp;h=ad2b7e468c72bb196d2c3ca44966cd905471ae73;hb=1615e9726fe4457ef6efea73f0d1bed70b18342d;hp=3a32cc9466a81ae1cf5cf3bd759468583f364616;hpb=9dec54edaf1536d72030e95123c77040fc951185;p=metaproxy-moved-to-github.git diff --git a/src/util.hpp b/src/util.hpp index 3a32cc9..ad2b7e4 100644 --- a/src/util.hpp +++ b/src/util.hpp @@ -1,23 +1,48 @@ -/* $Id: util.hpp,v 1.15 2006-06-09 14:12:13 adam Exp $ +/* $Id: util.hpp,v 1.21 2006-10-03 07:57:40 marc Exp $ Copyright (c) 2005-2006, Index Data. -%LICENSE% + See the LICENSE file for details */ #ifndef YP2_UTIL_HPP #define YP2_UTIL_HPP +#include "package.hpp" + #include -#include -#include -#include #include #include -#include "package.hpp" + +#include +#include +#include +#include + namespace metaproxy_1 { namespace util { + + + template + std::string to_string(const T& t) + { + std::ostringstream o; + if(o << t) + return o.str(); + return std::string(); + }; + + std::string http_header_value(const Z_HTTP_Header* header, + const std::string name); + + std::string http_headers_debug(const Z_HTTP_Request &http_req); + + void http_response(metaproxy_1::Package &package, + const std::string &content, + int http_code = 200); + + int memcmp2(const void *buf1, int len1, const void *buf2, int len2); std::string database_name_normalize(const std::string &s); @@ -26,24 +51,33 @@ namespace metaproxy_1 { std::string zQueryToString(Z_Query *query); - Z_ReferenceId **get_referenceId(Z_APDU *apdu); + Z_ReferenceId **get_referenceId(const Z_APDU *apdu); + + void transfer_referenceId(ODR odr, const Z_APDU *src, Z_APDU *dst); - Z_APDU *create_APDU(ODR odr, int type, Z_APDU *in_apdu); + Z_APDU *create_APDU(ODR odr, int type, const Z_APDU *in_apdu); bool set_databases_from_zurl(ODR odr, std::string zurl, int *db_num, char ***db_strings); void split_zurl(std::string zurl, std::string &host, std::list &db); - - int get_vhost_otherinfo(Z_OtherInformation **otherInformation, - bool remove_flag, - std::list &vhosts); + + void get_vhost_otherinfo(Z_OtherInformation *otherInformation, + std::list &vhosts); + + int remove_vhost_otherinfo(Z_OtherInformation **otherInformation, + std::list &vhosts); void set_vhost_otherinfo(Z_OtherInformation **otherInformation, ODR odr, const std::list &vhosts); + int get_or_remove_vhost_otherinfo( + Z_OtherInformation **otherInformation, + bool remove_flag, + std::list &vhosts); + void get_init_diagnostics(Z_InitResponse *res, int &error_code, std::string &addinfo); @@ -63,17 +97,18 @@ namespace metaproxy_1 { odr(); ~odr(); operator ODR() const; - Z_APDU *create_close(Z_APDU *in_apdu, + Z_APDU *create_close(const Z_APDU *in_apdu, int reason, const char *addinfo); - Z_APDU *create_initResponse(Z_APDU *in_apdu, + Z_APDU *create_initResponse(const Z_APDU *in_apdu, int error, const char *addinfo); - Z_APDU *create_searchResponse(Z_APDU *in_apdu, + Z_APDU *create_searchResponse(const Z_APDU *in_apdu, int error, const char *addinfo); - Z_APDU *create_presentResponse(Z_APDU *in_apdu, + Z_APDU *create_presentResponse(const Z_APDU *in_apdu, int error, const char *addinfo); - Z_APDU *create_scanResponse(Z_APDU *in_apdu, + Z_APDU *create_scanResponse(const Z_APDU *in_apdu, int error, const char *addinfo); - Z_APDU *create_APDU(int type, Z_APDU *in_apdu); + Z_APDU *create_APDU(int type, const Z_APDU *in_apdu); + Z_GDU *create_HTTP_Response(metaproxy_1::Session &session, Z_HTTP_Request *req, int code); private: