X-Git-Url: http://lists.indexdata.com/cgi-bin?a=blobdiff_plain;f=src%2Ffilter_frontend_net.cpp;h=385494b249d7209913b928d81c1422714a9c0fac;hb=1186f052158a6c1e85d51bacc0d73264bb1fc45a;hp=66d4cfce4662c079e2bfd5d60cf8a35695e2f361;hpb=53fa483f7ee74290fa3a34530a9826160c1a8a4c;p=metaproxy-moved-to-github.git diff --git a/src/filter_frontend_net.cpp b/src/filter_frontend_net.cpp index 66d4cfc..385494b 100644 --- a/src/filter_frontend_net.cpp +++ b/src/filter_frontend_net.cpp @@ -1,11 +1,12 @@ -/* $Id: filter_frontend_net.cpp,v 1.17 2006-03-29 13:44:45 adam Exp $ +/* $Id: filter_frontend_net.cpp,v 1.21 2006-08-30 10:48:52 adam Exp $ Copyright (c) 2005-2006, Index Data. -%LICENSE% + See the LICENSE file for details */ #include "config.hpp" +#include "util.hpp" #include "pipe.hpp" #include "filter.hpp" #include "package.hpp" @@ -106,11 +107,32 @@ void mp::ThreadPoolPackage::result() m_session->m_no_requests--; yazpp_1::GDU *gdu = &m_package->response(); + if (gdu->get()) { int len; m_session->send_GDU(gdu->get(), &len); } + else if (!m_package->session().is_closed()) + { + // no response package and yet the session is still open.. + // means that request is unhandled.. + yazpp_1::GDU *gdu_req = &m_package->request(); + Z_GDU *z_gdu = gdu_req->get(); + if (z_gdu && z_gdu->which == Z_GDU_Z3950) + { + // For Z39.50, response with a Close and shutdown + mp::odr odr; + int len; + Z_APDU *apdu_response = odr.create_close( + z_gdu->u.z3950, Z_Close_systemProblem, + "unhandled Z39.50 request"); + + m_session->send_Z_PDU(apdu_response, &len); + m_package->session().close(); + } + } + if (m_session->m_no_requests == 0 && m_package->session().is_closed()) delete m_session; delete this; @@ -132,6 +154,10 @@ mp::ZAssocChild::ZAssocChild(yazpp_1::IPDU_Observable *PDU_Observable, m_no_requests = 0; m_delete_flag = false; m_package = package; + const char *peername = PDU_Observable->getpeername(); + if (!peername) + peername = "unknown"; + m_origin.set_tcpip_address(std::string(peername), m_session.id()); }