X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Ffilter_bounce.cpp;h=4a6e099ea100fadc9e489d5886986c2c24f6303b;hb=100c5228470dc9e35d400d7ab641d5064d2079b1;hp=ac50f00f8525cf1133453989f6840299e4a43db3;hpb=9f255f52501e9429f643772a186cc7a72a5e8893;p=metaproxy-moved-to-github.git diff --git a/src/filter_bounce.cpp b/src/filter_bounce.cpp index ac50f00..4a6e099 100644 --- a/src/filter_bounce.cpp +++ b/src/filter_bounce.cpp @@ -1,27 +1,30 @@ -/* $Id: filter_bounce.cpp,v 1.1 2006-08-31 13:01:09 marc Exp $ - Copyright (c) 2005-2006, Index Data. +/* This file is part of Metaproxy. + Copyright (C) 2005-2013 Index Data - See the LICENSE file for details - */ +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 +Software Foundation; either version 2, or (at your option) any later +version. + +Metaproxy 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 General Public License +for more details. + +You should have received a copy of the GNU General Public License +along with this program; if not, write to the Free Software +Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA +*/ #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; @@ -45,13 +48,11 @@ yf::Bounce::~Bounce() void yf::Bounce::process(mp::Package &package) const { - - if (! m_p->bounce ){ + if (! m_p->bounce ) + { package.move(); return; } - - package.session().close(); Z_GDU *zgdu = package.request().get(); @@ -60,42 +61,42 @@ void yf::Bounce::process(mp::Package &package) const 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; + 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()); 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->u.HTTP_Request, 400); - - //zgdu_res->u.HTTP_Response->content_len = message.str().size(); - //zgdu_res->u.HTTP_Response->content_buf - // = (char*) odr_malloc(odr, zgdu_res->u.HTTP_Response->content_len); - - //strncpy(zgdu_res->u.HTTP_Response->content_buf, - // message.str().c_str(), zgdu_res->u.HTTP_Response->content_len); - - // z_HTTP_header_add(o, &hres->headers, - // "Content-Type", content_type.c_str()); - package.response() = zgdu_res; + else if (zgdu->which == Z_GDU_HTTP_Request) + { + Z_GDU *zgdu_res = 0; + zgdu_res + = odr.create_HTTP_Response(package.session(), + zgdu->u.HTTP_Request, 400); + + package.response() = zgdu_res; } - else if (zgdu->which == Z_GDU_HTTP_Response){ + else if (zgdu->which == Z_GDU_HTTP_Response) + { } return; } +void mp::filter::Bounce::configure(const xmlNode * ptr, bool test_only, + const char *path) +{ + mp::xml::check_empty(ptr); +} + static mp::filter::Base* filter_creator() { return new mp::filter::Bounce; @@ -113,8 +114,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 */ +