X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Ffilter_bounce.cpp;h=0eb0454d4ed3061c31c3a1e7ed0bb45f6366d06d;hb=586d78659d671683f33ec55f4a7d32b28e345ccd;hp=ab553b5ccc1d282db061f936a5fe8eec92d8ce2c;hpb=637a685d61a9ff0e3f398a59da426979815c4d68;p=metaproxy-moved-to-github.git diff --git a/src/filter_bounce.cpp b/src/filter_bounce.cpp index ab553b5..0eb0454 100644 --- a/src/filter_bounce.cpp +++ b/src/filter_bounce.cpp @@ -1,7 +1,5 @@ -/* $Id: filter_bounce.cpp,v 1.4 2007-05-09 21:23:09 adam Exp $ - Copyright (c) 2005-2007, Index Data. - -This file is part of Metaproxy. +/* This file is part of Metaproxy. + Copyright (C) Index Data Metaproxy is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free @@ -14,29 +12,25 @@ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License -along with Metaproxy; see the file LICENSE. If not, write to the -Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA -02111-1307, USA. - */ +along with this program; if not, write to the Free Software +Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA +*/ + +/* filter_bounce +A very simple filter that produces some response, in case no earlier +filter has done so, a kind of last resort fallback. Also supports dumping +the request in that response, for debugging and testing purposes +*/ #include "filter_bounce.hpp" -#include "package.hpp" -#include "util.hpp" +#include +#include #include "gduutil.hpp" #include #include -//#include "config.hpp" -//#include "filter.hpp" - -//#include - - - - - namespace mp = metaproxy_1; namespace yf = mp::filter; @@ -44,65 +38,113 @@ namespace metaproxy_1 { namespace filter { class Bounce::Rep { friend class Bounce; - bool bounce; + bool echo; // indicates that we wish to echo the request in the + // HTTP response }; } } yf::Bounce::Bounce() : m_p(new Rep) { - m_p->bounce = true; + m_p->echo = false; } yf::Bounce::~Bounce() -{ // must have a destructor because of boost::scoped_ptr +{ // must have a destructor because of boost::scoped_ptr to m_p } -void yf::Bounce::process(mp::Package &package) const + +// Dump the http request into the content of the http response +static void http_echo(mp::odr &odr, Z_GDU *zgdu, Z_GDU *zgdu_res) { - if (! m_p->bounce ) + int len; + ODR enc = odr_createmem(ODR_ENCODE); + //int r = + (void) z_GDU(enc, &zgdu, 0, 0); + char *buf = odr_getbuf(enc, &len, 0); + //h.db( "\n" + msg + "\n" + std::string(buf,len) ); + Z_HTTP_Response *hres = zgdu_res->u.HTTP_Response; + if (hres) { - package.move(); - return; + z_HTTP_header_set(odr, &hres->headers, + "Content-Type", "text/plain"); + + hres->content_buf = (char*) odr_malloc(odr, len); + memcpy(hres->content_buf, buf, len); + hres->content_len = len; } + odr_destroy(enc); + +} + + +void yf::Bounce::process(mp::Package &package) const +{ package.session().close(); Z_GDU *zgdu = package.request().get(); - + if (!zgdu) return; - + //std::string message("BOUNCE "); - std::ostringstream message; + std::ostringstream message; message << "BOUNCE " << *zgdu; - - metaproxy_1::odr odr; - + + metaproxy_1::odr odr; + if (zgdu->which == Z_GDU_Z3950) { Z_APDU *apdu_res = 0; apdu_res = odr.create_close(zgdu->u.z3950, Z_Close_systemProblem, message.str().c_str()); + // TODO - Some day we may want a dump of the request in some + // addinfo in the close response package.response() = apdu_res; } else if (zgdu->which == Z_GDU_HTTP_Request) { Z_GDU *zgdu_res = 0; - zgdu_res - = odr.create_HTTP_Response(package.session(), + zgdu_res + = odr.create_HTTP_Response(package.session(), zgdu->u.HTTP_Request, 400); - + if (m_p->echo) + { + http_echo(odr, zgdu, zgdu_res); + } package.response() = zgdu_res; } else if (zgdu->which == Z_GDU_HTTP_Response) { } - + return; } +void mp::filter::Bounce::configure(const xmlNode * ptr, bool test_only, + const char *path) +{ + for (ptr = ptr->children; ptr; ptr = ptr->next) + { + if (ptr->type != XML_ELEMENT_NODE) + continue; + else if (!strcmp((const char *) ptr->name, "echo")) + { + m_p->echo = mp::xml::get_bool(ptr, 0); + } + else + { + throw mp::filter::FilterException + ("Bad element '" + + std::string((const char *) ptr->name) + + "' in bounce filter"); + } + } + +} + static mp::filter::Base* filter_creator() { return new mp::filter::Bounce; @@ -120,8 +162,9 @@ extern "C" { /* * Local variables: * c-basic-offset: 4 + * c-file-style: "Stroustrup" * indent-tabs-mode: nil - * c-file-style: "stroustrup" * End: * vim: shiftwidth=4 tabstop=8 expandtab */ +