blob: 92f7212d590ac113dbba2b0c96743390aa75fe57 [file] [log] [blame]
Junxiao Shi38f4ce92016-08-04 10:01:52 +00001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Davide Pesavento87fc0f82018-04-11 23:43:51 -04002/*
Davide Pesaventoe422f9e2022-06-03 01:30:23 -04003 * Copyright (c) 2014-2022, Regents of the University of California,
Junxiao Shi38f4ce92016-08-04 10:01:52 +00004 * Arizona Board of Regents,
5 * Colorado State University,
6 * University Pierre & Marie Curie, Sorbonne University,
7 * Washington University in St. Louis,
8 * Beijing Institute of Technology,
9 * The University of Memphis.
10 *
11 * This file is part of NFD (Named Data Networking Forwarding Daemon).
12 * See AUTHORS.md for complete list of NFD authors and contributors.
13 *
14 * NFD is free software: you can redistribute it and/or modify it under the terms
15 * of the GNU General Public License as published by the Free Software Foundation,
16 * either version 3 of the License, or (at your option) any later version.
17 *
18 * NFD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
19 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
20 * PURPOSE. See the GNU General Public License for more details.
21 *
22 * You should have received a copy of the GNU General Public License along with
23 * NFD, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
24 */
25
26#include "fib-module.hpp"
27#include "format-helpers.hpp"
28
Davide Pesaventoe422f9e2022-06-03 01:30:23 -040029namespace nfd::tools::nfdc {
Junxiao Shi38f4ce92016-08-04 10:01:52 +000030
31void
32FibModule::fetchStatus(Controller& controller,
Davide Pesavento87fc0f82018-04-11 23:43:51 -040033 const std::function<void()>& onSuccess,
Junxiao Shi29b41282016-08-22 03:47:02 +000034 const Controller::DatasetFailCallback& onFailure,
Junxiao Shi38f4ce92016-08-04 10:01:52 +000035 const CommandOptions& options)
36{
37 controller.fetch<ndn::nfd::FibDataset>(
38 [this, onSuccess] (const std::vector<FibEntry>& result) {
39 m_status = result;
40 onSuccess();
41 },
42 onFailure, options);
43}
44
45void
46FibModule::formatStatusXml(std::ostream& os) const
47{
48 os << "<fib>";
49 for (const FibEntry& item : m_status) {
50 this->formatItemXml(os, item);
51 }
52 os << "</fib>";
53}
54
55void
56FibModule::formatItemXml(std::ostream& os, const FibEntry& item) const
57{
58 os << "<fibEntry>";
59
60 os << "<prefix>" << xml::Text{item.getPrefix().toUri()} << "</prefix>";
61
62 os << "<nextHops>";
63 for (const NextHopRecord& nh : item.getNextHopRecords()) {
64 os << "<nextHop>"
65 << "<faceId>" << nh.getFaceId() << "</faceId>"
66 << "<cost>" << nh.getCost() << "</cost>"
67 << "</nextHop>";
68 }
69 os << "</nextHops>";
70
71 os << "</fibEntry>";
72}
73
74void
75FibModule::formatStatusText(std::ostream& os) const
76{
77 os << "FIB:\n";
78 for (const FibEntry& item : m_status) {
79 this->formatItemText(os, item);
80 }
81}
82
83void
84FibModule::formatItemText(std::ostream& os, const FibEntry& item) const
85{
86 os << " " << item.getPrefix() << " nexthops={";
87
88 text::Separator sep(", ");
89 for (const NextHopRecord& nh : item.getNextHopRecords()) {
90 os << sep
Ju Pan57113d12019-08-05 22:52:40 +000091 << "faceid=" << nh.getFaceId()
92 << " (cost=" << nh.getCost() << ")";
Junxiao Shi38f4ce92016-08-04 10:01:52 +000093 }
94
95 os << "}";
96 os << "\n";
97}
98
Davide Pesaventoe422f9e2022-06-03 01:30:23 -040099} // namespace nfd::tools::nfdc