TraceIrcClient.h 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. /*\
  2. |*| Copyright 2015-2016 bill-auger <https://github.com/bill-auger/av-caster/issues>
  3. |*|
  4. |*| This file is part of the AvCaster program.
  5. |*|
  6. |*| AvCaster is free software: you can redistribute it and/or modify
  7. |*| it under the terms of the GNU General Public License version 3
  8. |*| as published by the Free Software Foundation.
  9. |*|
  10. |*| AvCaster is distributed in the hope that it will be useful,
  11. |*| but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. |*| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. |*| GNU General Public License for more details.
  14. |*|
  15. |*| You should have received a copy of the GNU General Public License
  16. |*| along with AvCaster. If not, see <http://www.gnu.org/licenses/>.
  17. \*/
  18. #ifndef _TRACEIRCCLIENT_H_
  19. #define _TRACEIRCCLIENT_H_
  20. #ifdef DEBUG_TRACE
  21. # include "Trace.h"
  22. // IRC event codes
  23. static HashMap<int , String> IRC_EVENT_CODES ;
  24. static void PopulateEventCodes()
  25. {
  26. IRC_EVENT_CODES.set(LIBIRC_RFC_RPL_WELCOME , "RPL_WELCOME" ) ; // 001
  27. IRC_EVENT_CODES.set(LIBIRC_RFC_RPL_YOURHOST , "RPL_YOURHOST" ) ; // 002
  28. IRC_EVENT_CODES.set(LIBIRC_RFC_RPL_CREATED , "RPL_CREATED" ) ; // 003
  29. IRC_EVENT_CODES.set(LIBIRC_RFC_RPL_MYINFO , "RPL_MYINFO" ) ; // 004
  30. IRC_EVENT_CODES.set(LIBIRC_RFC_RPL_BOUNCE , "RPL_BOUNCE" ) ; // 005
  31. IRC_EVENT_CODES.set(42 , "RPL_YOURID" ) ; // 042 non-RFC
  32. IRC_EVENT_CODES.set(250 , "RPL_STATSDLINE" ) ; // 250
  33. IRC_EVENT_CODES.set(LIBIRC_RFC_RPL_LUSERCLIENT , "RPL_LUSERCLIENT" ) ; // 251
  34. IRC_EVENT_CODES.set(LIBIRC_RFC_RPL_LUSEROP , "RPL_LUSEROP" ) ; // 252
  35. IRC_EVENT_CODES.set(LIBIRC_RFC_RPL_LUSERUNKNOWN , "RPL_LUSERUNKNOWN" ) ; // 253
  36. IRC_EVENT_CODES.set(LIBIRC_RFC_RPL_LUSERCHANNELS , "RPL_LUSERCHANNELS") ; // 254
  37. IRC_EVENT_CODES.set(LIBIRC_RFC_RPL_LUSERME , "RPL_LUSERME" ) ; // 255
  38. IRC_EVENT_CODES.set(256 , "RPL_ADMINME" ) ; // 256
  39. IRC_EVENT_CODES.set(265 , "RPL_LOCALUSERS" ) ; // 265 non-RFC
  40. IRC_EVENT_CODES.set(266 , "RPL_GLOBALUSERS" ) ; // 266 non-RFC
  41. IRC_EVENT_CODES.set(LIBIRC_RFC_RPL_NAMREPLY , "RPL_NAMREPLY" ) ; // 353
  42. IRC_EVENT_CODES.set(LIBIRC_RFC_RPL_ENDOFNAMES , "RPL_ENDOFNAMES" ) ; // 366
  43. IRC_EVENT_CODES.set(LIBIRC_RFC_RPL_MOTD , "RPL_MOTD" ) ; // 372
  44. IRC_EVENT_CODES.set(LIBIRC_RFC_RPL_MOTDSTART , "RPL_MOTDSTART" ) ; // 375
  45. IRC_EVENT_CODES.set(LIBIRC_RFC_RPL_ENDOFMOTD , "RPL_ENDOFMOTD" ) ; // 376
  46. }
  47. # define DUMP_SERVER_PARAMS String dbg = "" ; \
  48. for (int i = 0 ; i < count ; ++i) \
  49. dbg += "\tparams[" + String(i) + "]=" + String(params[i]) + "\n" ; \
  50. Trace::TraceChatVb(dbg) ;
  51. # define DEBUG_TRACE_CREATE_SESSION \
  52. String dbg = " session for network '" + String(network) + "'" ; \
  53. String err = (network.isEmpty()) ? String::empty : \
  54. String((is_valid_session) ? String::empty : " session invalid") + \
  55. String((is_valid_port ) ? String::empty : " port invalid" ) + \
  56. String((is_valid_nick ) ? String::empty : " nick invalid" ) + \
  57. String((is_valid_channel) ? String::empty : " channel invalid") ; \
  58. if (err.isNotEmpty()) Trace::TraceError("error creating" + dbg + " - " + err) ; \
  59. else if (is_valid_network) Trace::TraceChat("created" + dbg) ;
  60. # define DEBUG_TRACE_LOGIN_FAILED \
  61. if (n_retries == IRC::STATE_FAILED + 1) \
  62. Trace::TraceError("error connecting to '" + String(network) + \
  63. ":" + String(port ) + \
  64. "' as '" + String(nick ) + "'" ) ;
  65. # define DEBUG_TRACE_LOGIN \
  66. String err = String(irc_strerror(irc_errno(session))) ; \
  67. bool is_connect_error = err != String("Illegal operation for this state") ; \
  68. String dbg = "connecting to '" + String(network) + \
  69. ":" + String(port ) + \
  70. "' as '" + String(nick ) + "'" ; \
  71. if (!is_err ) Trace::TraceChat(dbg) ; \
  72. else if (is_connect_error) Trace::TraceError("error " + dbg + " - " + err) ;
  73. # define DEBUG_TRACE_CONNECTED \
  74. String network = STRING(NetworkStore[CONFIG::NETWORK_ID]) ; \
  75. Trace::TraceState("connected to '" + network + "' host (" + host + ")") ; \
  76. if (network != host) Trace::TraceConfig("updating '" + network + "' host (" + host + ")") ;
  77. # define DEBUG_TRACE_LOGOUT \
  78. String network = STRING(NetworkStore[CONFIG::NETWORK_ID]) ; \
  79. int port = int (NetworkStore[CONFIG::PORT_ID ]) ; \
  80. String nick = STRING(NetworkStore[CONFIG::NICK_ID ]) ; \
  81. Trace::TraceChat("disconnecting from '" + String(network) + \
  82. ":" + String(port ) + \
  83. "' as '" + String(nick ) + "'" ) ;
  84. # define DEBUG_TRACE_SERVER_EVENT \
  85. if (IRC_EVENT_CODES.size() == 0) PopulateEventCodes() ; \
  86. String code = (IRC_EVENT_CODES.contains(event)) ? IRC_EVENT_CODES[event] : \
  87. String("code: ") + String(event) ; \
  88. Trace::TraceChatVb(String("received ") + code) ; DUMP_SERVER_PARAMS
  89. # define DEBUG_TRACE_NICKS \
  90. StringArray newnicks = StringArray::fromTokens(nicks , false) ; \
  91. String nnewnicks = String(newnicks.size()) ; \
  92. String ntotalnicks = String(Nicks.size() ) ; \
  93. String newnicks_csv = newnicks.joinIntoString(",") ; \
  94. Trace::TraceChat("got (" + nnewnicks + "/" + ntotalnicks + \
  95. ") NAMES from '" + network + "' channel: " + channel + \
  96. ((DEBUG_TRACE_CHAT_VB) ? " [" + newnicks_csv + "]" : "") ) ;
  97. # define DEBUG_TRACE_CHAT_MSG_VB \
  98. if (count == 2) Trace::TraceChatVb("'" + String((!!origin) ? origin : "someone") + \
  99. "' said in channel " + String(params[0]) + \
  100. ": " + String(params[1]) + "") ;
  101. # define DEBUG_TRACE_CHAT_MSG \
  102. if (is_root_channel ) Trace::TraceChatVb("is_root_channel" ) ; \
  103. if (is_root_user ) Trace::TraceChatVb("is_root_user" ) ; \
  104. if (is_xmpp_channel ) Trace::TraceChatVb("is_my_channel" ) ; \
  105. if (is_login_blocked) Trace::TraceChatVb("is_login_blocked") ; \
  106. if (is_logged_in ) Trace::TraceChatVb("is_logged_in" ) ; \
  107. if (has_kicked_self ) Trace::TraceChatVb("has_kicked_self" ) ; \
  108. String dbg = ((is_root_user && is_root_channel ) ? \
  109. ((is_logged_in ) ? "logged into bitlbee" : \
  110. ((is_login_blocked ) ? "already logged into bitlbee" : "")) : \
  111. ((!is_root_user && !is_root_channel) ? nick + " said: '" + message + "'" : \
  112. ((DEBUG_TRACE_CHAT_VB ) ? "unhandled msg" : "") ) ) ; \
  113. if (dbg.isNotEmpty()) Trace::TraceChat(dbg) ;
  114. # define DEBUG_TRACE_ONJOIN Trace::TraceChat(nick + " just joined channel " + channel) ;
  115. # define DEBUG_TRACE_ONPART Trace::TraceChat(nick + " just parted channel " + channel) ;
  116. # define DEBUG_TRACE_NICK_CHANGE \
  117. IrcClient* client = static_cast<IrcClient*>(irc_get_ctx(session)) ; \
  118. Trace::TraceChat("'" + from_nick + "' changed nick to '" + to_nick + \
  119. "' on " + network + channel ) ;
  120. #else // DEBUG_TRACE
  121. # define DEBUG_TRACE_CREATE_SESSION ;
  122. # define DEBUG_TRACE_LOGIN ;
  123. # define DEBUG_TRACE_LOGIN_FAILED ;
  124. # define DEBUG_TRACE_CONNECTED ;
  125. # define DEBUG_TRACE_SERVER_EVENT ;
  126. # define DEBUG_TRACE_NICKS ;
  127. # define DEBUG_TRACE_CHAT_MSG_VB ;
  128. # define DEBUG_TRACE_CHAT_MSG ;
  129. # define DEBUG_TRACE_ONJOIN ;
  130. # define DEBUG_TRACE_ONPART ;
  131. # define DEBUG_TRACE_NICK_CHANGE ;
  132. #endif // DEBUG_TRACE
  133. #endif // _TRACEIRCCLIENT_H_