session.h 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. #ifndef SESSION_H
  2. #define SESSION_H
  3. #include <boost/asio.hpp>
  4. #include <boost/asio/ip/basic_resolver.hpp>
  5. #include <map>
  6. #include <string>
  7. #define MAX_BUFFER 256
  8. /*
  9. The Session:
  10. */
  11. class Session : public std::enable_shared_from_this<Session> {
  12. public:
  13. Session(boost::asio::ip::tcp::socket socket,
  14. boost::asio::io_service &io_service, std::string hostname,
  15. std::string port);
  16. void start(void);
  17. ~Session();
  18. void parse_auth(void);
  19. void on_connect(const boost::system::error_code error);
  20. void server_read(void);
  21. void on_resolve(const boost::system::error_code error,
  22. const boost::asio::ip::tcp::resolver::results_type results);
  23. void client_read(void);
  24. void to_client(std::string message);
  25. void to_server(std::string message);
  26. void on_shutdown(boost::system::error_code ec);
  27. void dispatch_line(std::string line);
  28. void process_lines(std::string &received);
  29. private:
  30. void set_timer(void);
  31. void reset_timer(void);
  32. void on_timer(const boost::system::error_code error);
  33. void stayin_alive(const boost::system::error_code error);
  34. int time_ms;
  35. int keepalive_secs;
  36. // FOR NOW: These will go into the director
  37. bool show_client = true;
  38. bool talk_direct = true;
  39. /**
  40. * The client's socket
  41. */
  42. boost::asio::ip::tcp::socket socket_;
  43. boost::asio::io_service &io_service_;
  44. boost::asio::ip::tcp::resolver resolver_;
  45. /**
  46. * The server's socket
  47. */
  48. boost::asio::ip::tcp::socket server_;
  49. /**
  50. * The time that we'll use to fire off the "prompt" event.
  51. *
  52. * The idea being that we'd receive chars, processing lines.
  53. * And if we have something in server_prompt start the timer.
  54. * If we receive more, process lines, if !server_prompt.empty()
  55. * reset the timer.
  56. *
  57. * If the timer fires (and isn't aborted), fire off the prompt.
  58. *
  59. * I'm not so sure about this -- because this adds delay to the
  60. * proxy. [It might be better to just fire off "some" text, and
  61. * have it ignored, rather then adding a delay.] Or, this might
  62. * not matter at all, I'm thinking milliseconds here!
  63. */
  64. boost::asio::high_resolution_timer timer_;
  65. boost::asio::high_resolution_timer keep_alive_;
  66. /**
  67. * What characters have been received from the server,
  68. * that weren't \n terminated?
  69. *
  70. * This needs to be reset/cleared if there's a \r (carriage return).
  71. */
  72. std::string server_prompt;
  73. /**
  74. * FAIL-WHALE: This was supposed to hold the number of characters
  75. * already sent to the user at this point in time, but I'm having
  76. * a hard time tracking those.
  77. *
  78. */
  79. // int server_sent;
  80. /**
  81. * The client read buffer.
  82. *
  83. * This is too big, we don't get that many characters from the client.
  84. *
  85. */
  86. char read_buffer[MAX_BUFFER + 1];
  87. /**
  88. * The server read buffer.
  89. * This is MAX_BUFFER + 1 (to store the \0 to terminate the string)
  90. */
  91. char server_buffer[MAX_BUFFER + 1];
  92. /**
  93. * The rlogin information received from the client.
  94. *
  95. * We check this, and if it isn't valid, we spoof some rlogin
  96. * connection.
  97. */
  98. std::string rlogin_auth;
  99. /**
  100. * The username passed in via rlogin. We need this so we know what
  101. * name we need to store the data under.
  102. */
  103. std::string rlogin_name;
  104. std::string host;
  105. std::string port;
  106. /**
  107. * Are we connected to the server?
  108. *
  109. * Don't shutdown the server socket if we aren't connected.
  110. */
  111. bool connected = false;
  112. };
  113. /*
  114. maybe move the resolver part to the server, so I don't need io_service?
  115. I'm not sure what the socket connection part is going to need just yet,
  116. so I probably won't move that just yet. [NNY!]
  117. */
  118. class Server {
  119. public:
  120. Server(boost::asio::io_service &io_service,
  121. const boost::asio::ip::tcp::endpoint &endpoint, std::string host,
  122. std::string port);
  123. private:
  124. void do_accept(void);
  125. boost::asio::io_service &io_service_;
  126. boost::asio::ip::tcp::acceptor acceptor_;
  127. /**
  128. * The host to connect to (from config)
  129. */
  130. std::string host_;
  131. /**
  132. * The port to connect to (from config)
  133. *
  134. */
  135. std::string port_;
  136. };
  137. // The simple way to get the boost logging to log file and line number
  138. // information. [Let the BUGZ_LOG macro do it!]
  139. #include <iomanip>
  140. #include <string.h>
  141. const char *trim_path(const char *filepath);
  142. #define BUGZ_LOG(severity) \
  143. BOOST_LOG_TRIVIAL(severity) \
  144. << "(" << std::setw(15) << trim_path(__FILE__) << ":" << std::setw(4) \
  145. << std::left << __LINE__ << ") "
  146. #endif