vmime/examples/example6_tracer.hpp

60 lines
1.3 KiB
C++
Raw Normal View History

2014-03-16 21:52:40 +00:00
/** Tracer used to demonstrate logging communication between client and server.
*/
2018-09-05 21:54:48 +00:00
class myTracer : public vmime::net::tracer {
2014-03-16 21:52:40 +00:00
public:
2018-09-05 21:54:48 +00:00
myTracer(
const vmime::shared_ptr <std::ostringstream>& stream,
const vmime::shared_ptr <vmime::net::service>& serv,
const int connectionId
)
: m_stream(stream),
m_service(serv),
m_connectionId(connectionId) {
2014-03-16 21:52:40 +00:00
}
2018-09-05 21:54:48 +00:00
void traceSend(const vmime::string& line) {
2014-03-16 21:52:40 +00:00
*m_stream << "[" << m_service->getProtocolName() << ":" << m_connectionId
<< "] C: " << line << std::endl;
}
2018-09-05 21:54:48 +00:00
void traceReceive(const vmime::string& line) {
2014-03-16 21:52:40 +00:00
*m_stream << "[" << m_service->getProtocolName() << ":" << m_connectionId
<< "] S: " << line << std::endl;
}
private:
vmime::shared_ptr <std::ostringstream> m_stream;
vmime::shared_ptr <vmime::net::service> m_service;
const int m_connectionId;
};
2018-09-05 21:54:48 +00:00
class myTracerFactory : public vmime::net::tracerFactory {
2014-03-16 21:52:40 +00:00
public:
myTracerFactory(const vmime::shared_ptr <std::ostringstream>& stream)
2018-09-05 21:54:48 +00:00
: m_stream(stream) {
2014-03-16 21:52:40 +00:00
}
2018-09-05 21:54:48 +00:00
vmime::shared_ptr <vmime::net::tracer> create(
const vmime::shared_ptr <vmime::net::service>& serv,
const int connectionId
) {
2014-03-16 21:52:40 +00:00
return vmime::make_shared <myTracer>(m_stream, serv, connectionId);
}
private:
vmime::shared_ptr <std::ostringstream> m_stream;
};