--- /dev/null
+// $Id$
+//
+// Copyright (C) 2007
+// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS)
+// Kompetenzzentrum fuer Satelitenkommunikation (SatCom)
+//
+// This program 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 of the License, or
+// (at your option) any later version.
+//
+// This program 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.,
+// 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+// Definition of non-inline non-template functions
+
+//#include "Sniffer.hh"
+//#include "Sniffer.ih"
+
+// Custom includes
+#include <string>
+#include <fstream>
+
+#include <sys/socket.h>
+#include <netinet/in.h>
+#include <netinet/tcp.h>
+#include <sys/ioctl.h>
+#include <linux/sockios.h> //
+
+#include <string>
+#include <iostream>
+#include <iomanip>
+#include "Socket/UDPSocketHandle.hh"
+#include "Scheduler/Scheduler.hh"
+#include "Utils/membind.hh"
+
+#include "Packets/EthernetPacket.hh"
+
+
+
+
+//#include "Sniffer.mpp"
+#define prefix_
+///////////////////////////////cc.p////////////////////////////////////////
+
+namespace {
+
+ static const unsigned BLOCK_SIZE = 16;
+
+ template <class Iterator>
+ void hexdump(Iterator i, Iterator const & i_end, std::ostream& stream)
+ {
+ unsigned offset (0);
+ std::string ascii;
+ for (; i != i_end; ++i, ++offset) {
+ switch (offset % BLOCK_SIZE) {
+ case 0:
+ if (!ascii.empty()) {
+ stream << " " << ascii << "\n";
+ ascii = "";
+ }
+ stream << " "
+ << std::hex << std::setw(4) << std::setfill('0')
+ << offset << ' ';
+ break;
+ case BLOCK_SIZE/2:
+ stream << " ";
+ ascii += ' ';
+ break;
+ }
+ stream << ' ' << std::hex << std::setw(2) << std::setfill('0')
+ << unsigned(*i);
+ ascii += (*i >= ' ' && *i < 126) ? *i : '.';
+ }
+ if (!ascii.empty()) {
+ for (; (offset % BLOCK_SIZE) != 0; ++offset) {
+ if ((offset % BLOCK_SIZE) == BLOCK_SIZE/2)
+ stream << " ";
+ stream << " ";
+ }
+ stream << " " << ascii << "\n";
+ }
+ stream << std::dec;
+ }
+}
+
+
+class MSniffer
+{
+ senf::UDPv4ClientSocketHandle sock;
+ std::ostream& stream;
+
+public:
+ MSniffer(senf::INet4Address addr, std::ostream& s)
+ : stream(s)
+ {
+ sock.protocol().bind(addr);
+ sock.protocol().mcLoop(true);
+ sock.protocol().mcAddMembership(addr);
+ senf::Scheduler::instance().add(
+ sock, senf::membind(&MSniffer::dumpPacket, this));
+ }
+
+private:
+ void dumpPacket(senf::FileHandle /* ignored */, senf::Scheduler::EventId event)
+ {
+ std::string data (sock.read());
+ senf::EthernetPacket::ptr packet (
+ senf::Packet::create<senf::EthernetPacket>(
+ data.begin(), data.end()));
+ packet->dump(stream);
+ hexdump(packet->last()->begin(),
+ packet->last()->end(),
+ stream);
+ stream << "\n\n";
+ }
+};
+
+
+int main(int argc, char const * argv[])
+{
+ try {
+ std::ofstream f1 ("233.132.152.1.txt");
+ std::ofstream f2 ("233.132.152.2.txt");
+
+ MSniffer sniffer1 (
+ senf::INet4Address::INet4Address("233.132.152.1:22344"), f1);
+ MSniffer sniffer2 (
+ senf::INet4Address::INet4Address("233.132.152.2:22344"), f2);
+
+ senf::Scheduler::instance().process();
+ }
+ catch (std::exception const & ex) {
+ std::cerr << senf::prettyName(typeid(ex)) << ": " << ex.what() << "\n";
+ }
+ return 0;
+}
+
+
+///////////////////////////////cc.e////////////////////////////////////////
+#undef prefix_
+//#include "Sniffer.mpp"
+
+\f
+// Local Variables:
+// mode: c++
+// fill-column: 100
+// c-file-style: "senf"
+// indent-tabs-mode: nil
+// ispell-local-dictionary: "american"
+// End: