summaryrefslogtreecommitdiffstats
blob: 9315d2fd70320eb39171a639423e8b5d54b8ed30 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
/*
 * Copyright (c) 2010 Remko Tronçon
 * Licensed under the GNU General Public License v3.
 * See Documentation/Licenses/GPLv3.txt for more information.
 */

#pragma once

#include <iostream>

#include "Swiften/Session/Session.h"
#include "Swiften/Base/String.h"
#include "Swiften/Base/ByteArray.h"

namespace Swift {
	class SessionTracer {
		public:
			SessionTracer(boost::shared_ptr<Session> session) : session(session) {
				session->onDataRead.connect(boost::bind(&SessionTracer::printData, this, '<', _1));
				session->onDataWritten.connect(boost::bind(&SessionTracer::printData, this, '>', _1));
			}

		private:
			void printData(char direction, const ByteArray& data) {
				std::cerr << direction << direction << " " << session->getLocalJID() << " ";
				for (unsigned int i = 0; i < 72 - session->getLocalJID().toString().getUTF8Size() - session->getRemoteJID().toString().getUTF8Size(); ++i) {
					std::cerr << direction;
				}
				std::cerr << " " << session->getRemoteJID()<< " " << direction << direction << std::endl;
				std::cerr << String(data.getData(), data.getSize()) << std::endl;
			}

			boost::shared_ptr<Session> session;
	};
}