blob: 9a1f387694116a5de2b9bcfb4d2fd5d48bac1680 [file] [log] [blame]
Alexander Afanasyev2a655f72015-01-26 18:38:33 -08001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
Qi Zhao6fc57a62017-04-05 16:53:10 +00003 * Copyright (c) 2014-2017, Regents of the University of California,
Alexander Afanasyev2a655f72015-01-26 18:38:33 -08004 * 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 "base.hpp"
27
28namespace ndn {
29namespace tools {
30namespace autoconfig {
31
32Base::Base(Face& face, KeyChain& keyChain, const NextStageCallback& nextStageOnFailure)
33 : m_face(face)
34 , m_keyChain(keyChain)
35 , m_controller(face, keyChain)
36 , m_nextStageOnFailure(nextStageOnFailure)
37{
38}
39
40void
41Base::connectToHub(const std::string& uri)
42{
Junxiao Shi52fa45c2016-11-29 21:18:13 +000043 FaceUri faceUri(uri);
Alexander Afanasyev2a001942016-12-14 18:18:41 -080044 std::cerr << "About to connect to: " << uri << std::endl;
Alexander Afanasyev2a655f72015-01-26 18:38:33 -080045
46 faceUri.canonize(bind(&Base::onCanonizeSuccess, this, _1),
47 bind(&Base::onCanonizeFailure, this, _1),
48 m_face.getIoService(), time::seconds(4));
49
50}
51
52
53void
Junxiao Shi52fa45c2016-11-29 21:18:13 +000054Base::onCanonizeSuccess(const FaceUri& canonicalUri)
Alexander Afanasyev2a655f72015-01-26 18:38:33 -080055{
Junxiao Shi52fa45c2016-11-29 21:18:13 +000056 m_controller.start<ndn::nfd::FaceCreateCommand>(
57 ControlParameters().setUri(canonicalUri.toString()),
58 bind(&Base::onHubConnectSuccess, this, _1),
59 bind(&Base::onHubConnectError, this, _1));
Alexander Afanasyev2a655f72015-01-26 18:38:33 -080060}
61
62void
63Base::onCanonizeFailure(const std::string& reason)
64{
Junxiao Shi52fa45c2016-11-29 21:18:13 +000065 BOOST_THROW_EXCEPTION(Error("FaceUri canonization failed: " + reason));
Alexander Afanasyev2a655f72015-01-26 18:38:33 -080066}
67
68void
Junxiao Shi52fa45c2016-11-29 21:18:13 +000069Base::onHubConnectSuccess(const ControlParameters& resp)
Alexander Afanasyev2a655f72015-01-26 18:38:33 -080070{
71 std::cerr << "Successfully created face: " << resp << std::endl;
72
Qi Zhao6fc57a62017-04-05 16:53:10 +000073 registerAutoConfigNames(resp.getFaceId());
Alexander Afanasyev2a655f72015-01-26 18:38:33 -080074}
75
76void
Junxiao Shi52fa45c2016-11-29 21:18:13 +000077Base::onHubConnectError(const ControlResponse& response)
Alexander Afanasyev2a655f72015-01-26 18:38:33 -080078{
Qi Zhao6fc57a62017-04-05 16:53:10 +000079 // If face exists, continue proceeding with the existing face
80 if (response.getCode() == 409) {
81 std::cerr << "Face exists. Proceeding with existing face: " << ControlParameters(response.getBody()) << std::endl;
82
83 registerAutoConfigNames(ControlParameters(response.getBody()).getFaceId());
84 }
85 // Otherwise, report the failure and throw out exception
86 else {
87 std::ostringstream os;
88 os << "Failed to create face: " << response.getText() << " (code: " << response.getCode() << ")";
89 BOOST_THROW_EXCEPTION(Error(os.str()));
90 }
91}
92
93void
94Base::registerAutoConfigNames(uint64_t faceId)
95{
96 static const Name TESTBED_PREFIX = "/ndn";
97 registerPrefix(TESTBED_PREFIX, faceId);
98
99 static const Name LOCALHOP_NFD_PREFIX = "/localhop/nfd";
100 registerPrefix(LOCALHOP_NFD_PREFIX, faceId);
Alexander Afanasyev2a655f72015-01-26 18:38:33 -0800101}
102
103void
104Base::registerPrefix(const Name& prefix, uint64_t faceId)
105{
106 // Register a prefix in RIB
Junxiao Shi52fa45c2016-11-29 21:18:13 +0000107 m_controller.start<ndn::nfd::RibRegisterCommand>(
108 ControlParameters()
109 .setName(prefix)
110 .setFaceId(faceId)
111 .setOrigin(ndn::nfd::ROUTE_ORIGIN_AUTOCONF)
112 .setCost(100)
113 .setExpirationPeriod(time::milliseconds::max()),
114 bind(&Base::onPrefixRegistrationSuccess, this, _1),
115 bind(&Base::onPrefixRegistrationError, this, _1));
Alexander Afanasyev2a655f72015-01-26 18:38:33 -0800116}
117
118void
Junxiao Shi52fa45c2016-11-29 21:18:13 +0000119Base::onPrefixRegistrationSuccess(const ControlParameters& commandSuccessResult)
Alexander Afanasyev2a655f72015-01-26 18:38:33 -0800120{
121 std::cerr << "Successful in name registration: " << commandSuccessResult << std::endl;
122}
123
124void
Junxiao Shi52fa45c2016-11-29 21:18:13 +0000125Base::onPrefixRegistrationError(const ControlResponse& response)
Alexander Afanasyev2a655f72015-01-26 18:38:33 -0800126{
Junxiao Shi52fa45c2016-11-29 21:18:13 +0000127 BOOST_THROW_EXCEPTION(Error("Failed in name registration, " + response.getText() +
128 " (code: " + to_string(response.getCode()) + ")"));
Alexander Afanasyev2a655f72015-01-26 18:38:33 -0800129}
130
131
132} // namespace autoconfig
133} // namespace tools
134} // namespace ndn