blob: 7d4505e52961365f60207b4c6ee0f5f189a9adb5 [file] [log] [blame]
Vince Lehmanc57c64b2015-08-10 12:21:31 -05001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
Nick Gordonc6a85222017-01-03 16:54:34 -06003 * Copyright (c) 2014-2017, The University of Memphis,
Vince Lehmanc57c64b2015-08-10 12:21:31 -05004 * Regents of the University of California,
5 * Arizona Board of Regents.
6 *
7 * This file is part of NLSR (Named-data Link State Routing).
8 * See AUTHORS.md for complete list of NLSR authors and contributors.
9 *
10 * NLSR is free software: you can redistribute it and/or modify it under the terms
11 * of the GNU General Public License as published by the Free Software Foundation,
12 * either version 3 of the License, or (at your option) any later version.
13 *
14 * NLSR is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
15 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
16 * PURPOSE. See the GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License along with
19 * NLSR, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
20 **/
21
22#ifndef NLSR_NLSR_RUNNER_HPP
23#define NLSR_NLSR_RUNNER_HPP
24
25#include "nlsr.hpp"
26
27#include <ndn-cxx/face.hpp>
28#include <ndn-cxx/util/scheduler.hpp>
29
30// boost needs to be included after ndn-cxx, otherwise there will be conflict with _1, _2, ...
31#include <boost/asio.hpp>
32
33namespace nlsr {
34
Nick Gordond0a7df32017-05-30 16:44:34 -050035/*! \brief A wrapper class to instantiate and configure an NLSR object.
36 *
37 * As its name suggests, this class is responsible for running
38 * NLSR. It creates an nlsr::ConfFileProcessor to read a configuration
39 * file and uses that to configure and then start an NLSR process. It
40 * also initializes loggers and optionally daemonizes the NLSR
41 * process. This class only exists to provide this functionality, and
42 * there is no special reliance of NLSR on this class.
43 */
Vince Lehmanc57c64b2015-08-10 12:21:31 -050044class NlsrRunner
45{
46public:
47 class Error : public std::runtime_error
48 {
49 public:
50 explicit
51 Error(const std::string& what)
52 : std::runtime_error(what)
53 {
54 }
55 };
56
57 NlsrRunner(std::string& configFileName, bool isDaemonProcess);
58
Nick Gordond0a7df32017-05-30 16:44:34 -050059 /*! \brief Instantiate, configure, and start the NLSR process.
60 *
61 * Each NlsrRunner is uniquely paired to the Face it's instantiated
62 * with. This is *not* a factory-type class, but a one-to-one
63 * relationship. If one wants to create multiple NLSR classes,
64 * multiple NLSR runners need to be created, too.
65 *
66 * \throws Error If the configuration file cannot be processed. NLSR
67 * is not started.
68 *
69 * \sa Nlsr::canonizeNeighborUris
70 */
Vince Lehmanc57c64b2015-08-10 12:21:31 -050071 void
72 run();
73
74 static void
75 printUsage(const std::string& programName);
76
77private:
78 boost::asio::io_service m_ioService;
79 ndn::Scheduler m_scheduler;
80 ndn::Face m_face;
Laqin Fana4cf4022017-01-03 18:57:35 +000081 ndn::KeyChain m_keyChain;
Vince Lehmanc57c64b2015-08-10 12:21:31 -050082 Nlsr m_nlsr;
83};
84
85} // namespace nlsr
86
87#endif // NLSR_NLSR_RUNNER_HPP