HDLCd-Tools
main-hdlcd-dissector.cpp
Go to the documentation of this file.
1 
22 #include "Config.h"
23 #include <iostream>
24 #include <boost/asio.hpp>
25 #include <boost/program_options.hpp>
26 #include <boost/regex.hpp>
27 #include "HdlcdClient.h"
28 #include "FramePrinter.h"
29 
30 int main(int argc, char* argv[]) {
31  try {
32  // Declare the supported options.
33  boost::program_options::options_description l_Description("Allowed options");
34  l_Description.add_options()
35  ("help,h", "produce this help message")
36  ("version,v", "show version information")
37  ("connect,c", boost::program_options::value<std::string>(),
38  "syntax: SerialPort@IPAddess:PortNbr\n"
39  " linux: /dev/ttyUSB0@localhost:5001\n"
40  " windows: //./COM1@example.com:5001")
41  ;
42 
43  // Parse the command line
44  boost::program_options::variables_map l_VariablesMap;
45  boost::program_options::store(boost::program_options::parse_command_line(argc, argv, l_Description), l_VariablesMap);
46  boost::program_options::notify(l_VariablesMap);
47  if (l_VariablesMap.count("version")) {
48  std::cerr << "HDLCd dissector version " << HDLCD_TOOLS_VERSION_MAJOR << "." << HDLCD_TOOLS_VERSION_MINOR
49  << " built with hdlcd-devel version " << HDLCD_DEVEL_VERSION_MAJOR << "." << HDLCD_DEVEL_VERSION_MINOR << std::endl;
50  } // if
51 
52  if (l_VariablesMap.count("help")) {
53  std::cout << l_Description << std::endl;
54  std::cout << "The HDLC dissector is Copyright (C) 2016, and GNU GPL'd, by Florian Evers." << std::endl;
55  std::cout << "Bug reports, feedback, admiration, abuse, etc, to: https://github.com/Strunzdesign/hdlcd-tools" << std::endl;
56  return 1;
57  } // if
58 
59  if (!l_VariablesMap.count("connect")) {
60  std::cout << "hdlcd-dissector: you have to specify one device to connect to" << std::endl;
61  std::cout << "hdlcd-dissector: Use --help for more information." << std::endl;
62  return 1;
63  } // if
64 
65  // Install signal handlers
66  boost::asio::io_service l_IoService;
67  boost::asio::signal_set l_Signals(l_IoService);
68  l_Signals.add(SIGINT);
69  l_Signals.add(SIGTERM);
70  l_Signals.async_wait([&l_IoService](boost::system::error_code, int){ l_IoService.stop(); });
71 
72  // Parse the destination specifier
73  static boost::regex s_RegEx("^(.*?)@(.*?):(.*?)$");
74  boost::smatch l_Match;
75  if (boost::regex_match(l_VariablesMap["connect"].as<std::string>(), l_Match, s_RegEx)) {
76  // Resolve destination
77  boost::asio::ip::tcp::resolver l_Resolver(l_IoService);
78  auto l_EndpointIterator = l_Resolver.resolve({ l_Match[2], l_Match[3] });
79 
80  // Prepare the HDLCd client entity
82  l_HdlcdClient.SetOnClosedCallback([&l_IoService](){ l_IoService.stop(); });
83  l_HdlcdClient.SetOnDataCallback([](const HdlcdPacketData& a_PacketData){ PrintDissectedFrame(a_PacketData.GetWasSent(), a_PacketData.GetData()); });
84  l_HdlcdClient.AsyncConnect(l_EndpointIterator, [&l_Signals](bool a_bSuccess) {
85  if (!a_bSuccess) {
86  std::cout << "Failed to connect to the HDLC Daemon!" << std::endl;
87  l_Signals.cancel();
88  } // if
89  }); // AsyncConnect
90 
91  // Start event processing
92  l_IoService.run();
93  } else {
94  throw boost::program_options::validation_error(boost::program_options::validation_error::invalid_option_value);
95  } // else
96  } catch (std::exception& a_Error) {
97  std::cerr << "Exception: " << a_Error.what() << "\n";
98  } // catch
99 
100  return 0;
101 }
#define HDLCD_DEVEL_VERSION_MINOR
Definition: HdlcdConfig.h:3
void AsyncConnect(boost::asio::ip::tcp::resolver::iterator a_EndpointIterator, std::function< void(bool a_bSuccess)> a_OnConnectedCallback)
Perform an asynchronous connect procedure regarding both TCP sockets.
Definition: HdlcdClient.h:82
#define HDLCD_DEVEL_VERSION_MAJOR
Definition: HdlcdConfig.h:2
Class HdlcdClient.
Definition: HdlcdClient.h:54
void SetOnClosedCallback(std::function< void()> a_OnClosedCallback)
Provide a callback method to be called if this client entity is closing.
Definition: HdlcdClient.h:192
void SetOnDataCallback(std::function< void(const HdlcdPacketData &a_PacketData)> a_OnDataCallback)
Provide a callback method to be called for received data packets.
Definition: HdlcdClient.h:172
const std::vector< unsigned char > & GetData() const
int main(int argc, char *argv[])
bool GetWasSent() const
void PrintDissectedFrame(bool a_bWasSent, const std::vector< unsigned char > &a_Buffer)
Definition: FramePrinter.h:28
Copyright (c) 2016, Florian Evers, florian-evers@gmx.de All rights reserved.
Additional tools to be used together with the HDLC Daemon. Copyright (C) 2016 Florian Evers...