blob: 27d3922219aef543f8af86e4a2b5065eb8456610 [file] [log] [blame]
Junxiao Shi38f4ce92016-08-04 10:01:52 +00001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
3 * Copyright (c) 2014-2016, Regents of the University of California,
4 * 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
29namespace nfd {
30namespace tools {
Junxiao Shi331ade72016-08-19 14:07:19 +000031namespace nfdc {
Junxiao Shi38f4ce92016-08-04 10:01:52 +000032
33void
34FibModule::fetchStatus(Controller& controller,
35 const function<void()>& onSuccess,
36 const Controller::CommandFailCallback& onFailure,
37 const CommandOptions& options)
38{
39 controller.fetch<ndn::nfd::FibDataset>(
40 [this, onSuccess] (const std::vector<FibEntry>& result) {
41 m_status = result;
42 onSuccess();
43 },
44 onFailure, options);
45}
46
47void
48FibModule::formatStatusXml(std::ostream& os) const
49{
50 os << "<fib>";
51 for (const FibEntry& item : m_status) {
52 this->formatItemXml(os, item);
53 }
54 os << "</fib>";
55}
56
57void
58FibModule::formatItemXml(std::ostream& os, const FibEntry& item) const
59{
60 os << "<fibEntry>";
61
62 os << "<prefix>" << xml::Text{item.getPrefix().toUri()} << "</prefix>";
63
64 os << "<nextHops>";
65 for (const NextHopRecord& nh : item.getNextHopRecords()) {
66 os << "<nextHop>"
67 << "<faceId>" << nh.getFaceId() << "</faceId>"
68 << "<cost>" << nh.getCost() << "</cost>"
69 << "</nextHop>";
70 }
71 os << "</nextHops>";
72
73 os << "</fibEntry>";
74}
75
76void
77FibModule::formatStatusText(std::ostream& os) const
78{
79 os << "FIB:\n";
80 for (const FibEntry& item : m_status) {
81 this->formatItemText(os, item);
82 }
83}
84
85void
86FibModule::formatItemText(std::ostream& os, const FibEntry& item) const
87{
88 os << " " << item.getPrefix() << " nexthops={";
89
90 text::Separator sep(", ");
91 for (const NextHopRecord& nh : item.getNextHopRecords()) {
92 os << sep
93 << "faceid=" << nh.getFaceId()
94 << " (cost=" << nh.getCost() << ")";
95 }
96
97 os << "}";
98 os << "\n";
99}
100
Junxiao Shi331ade72016-08-19 14:07:19 +0000101} // namespace nfdc
Junxiao Shi38f4ce92016-08-04 10:01:52 +0000102} // namespace tools
103} // namespace nfd