blob: afe653e1c569ae50c2ad6010c2e7a2f7030702f6 [file] [log] [blame]
Vince Lehmanc57c64b2015-08-10 12:21:31 -05001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Davide Pesaventoe3c741d2019-01-29 20:28:15 -05002/*
3 * Copyright (c) 2014-2019, 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"
Ashlesh Gawande85998a12017-12-07 22:22:13 -060026#include "conf-parameter.hpp"
Vince Lehmanc57c64b2015-08-10 12:21:31 -050027
28#include <ndn-cxx/face.hpp>
29#include <ndn-cxx/util/scheduler.hpp>
30
Vince Lehmanc57c64b2015-08-10 12:21:31 -050031namespace nlsr {
32
Nick Gordond0a7df32017-05-30 16:44:34 -050033/*! \brief A wrapper class to instantiate and configure an NLSR object.
34 *
35 * As its name suggests, this class is responsible for running
36 * NLSR. It creates an nlsr::ConfFileProcessor to read a configuration
dmcoomescf8d0ed2017-02-21 11:39:01 -060037 * file and uses that to configure and then start an NLSR process.
38 * This class only exists to provide this functionality, and there is
39 * no special reliance of NLSR on this class.
Nick Gordond0a7df32017-05-30 16:44:34 -050040 */
Vince Lehmanc57c64b2015-08-10 12:21:31 -050041class NlsrRunner
42{
43public:
dmcoomescf8d0ed2017-02-21 11:39:01 -060044 explicit
Ashlesh Gawande85998a12017-12-07 22:22:13 -060045 NlsrRunner(ndn::Face& face, ConfParameter& confParam);
Vince Lehmanc57c64b2015-08-10 12:21:31 -050046
Nick Gordond0a7df32017-05-30 16:44:34 -050047 /*! \brief Instantiate, configure, and start the NLSR process.
48 *
49 * Each NlsrRunner is uniquely paired to the Face it's instantiated
50 * with. This is *not* a factory-type class, but a one-to-one
51 * relationship. If one wants to create multiple NLSR classes,
52 * multiple NLSR runners need to be created, too.
53 *
Davide Pesaventoe3c741d2019-01-29 20:28:15 -050054 * \throws ConfFileError The configuration file cannot be processed.
55 * NLSR is not started.
Nick Gordond0a7df32017-05-30 16:44:34 -050056 * \sa Nlsr::canonizeNeighborUris
57 */
Vince Lehmanc57c64b2015-08-10 12:21:31 -050058 void
59 run();
60
Vince Lehmanc57c64b2015-08-10 12:21:31 -050061private:
Ashlesh Gawande85998a12017-12-07 22:22:13 -060062 ndn::Face& m_face;
Laqin Fana4cf4022017-01-03 18:57:35 +000063 ndn::KeyChain m_keyChain;
Ashlesh Gawande85998a12017-12-07 22:22:13 -060064 ConfParameter& m_confParam;
Vince Lehmanc57c64b2015-08-10 12:21:31 -050065 Nlsr m_nlsr;
66};
67
68} // namespace nlsr
69
70#endif // NLSR_NLSR_RUNNER_HPP