blob: 9da9093749cc84de5080187ea2bc9085d29b4c96 [file] [log] [blame]
Alexander Afanasyev2a655f72015-01-26 18:38:33 -08001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Junxiao Shif748a4e2017-07-05 23:41:48 +00002/*
3 * 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#ifndef NFD_TOOLS_NDN_AUTOCONFIG_GUESS_FROM_IDENTITY_NAME_HPP
27#define NFD_TOOLS_NDN_AUTOCONFIG_GUESS_FROM_IDENTITY_NAME_HPP
28
Junxiao Shif748a4e2017-07-05 23:41:48 +000029#include "stage.hpp"
Junxiao Shicb766862017-07-07 22:21:04 +000030#include <ndn-cxx/security/key-chain.hpp>
Alexander Afanasyev2a655f72015-01-26 18:38:33 -080031
32namespace ndn {
33namespace tools {
34namespace autoconfig {
35
36/**
37 * @brief Guessing home router based on the default identity name
38 *
39 * This stage assumes that user has configured default certificate using
40 * http://ndncert.named-data.net/
41 *
42 * - Request
43 *
44 * The end host loads the default user identity (eg. /ndn/edu/ucla/cs/afanasev), and
45 * converts it to DNS format.
46 *
47 * The end host sends a DNS query for an SRV record of name _ndn._udp. + user identity in
48 * DNS format + _homehub._auto-conf.named-data.net. For example:
49 *
50 * _ndn._udp.afanasev.cs.ucla.edu.ndn._homehub._autoconf.named-data.net
51 *
52 * - Response
53 *
54 * The DNS server should answer with an SRV record that contains the hostname and UDP port
55 * number of the home NDN router of this user's site.
56 */
Junxiao Shif748a4e2017-07-05 23:41:48 +000057class GuessFromIdentityName : public Stage
Alexander Afanasyev2a655f72015-01-26 18:38:33 -080058{
59public:
Junxiao Shicb766862017-07-07 22:21:04 +000060 explicit
61 GuessFromIdentityName(KeyChain& keyChain);
Alexander Afanasyev2a655f72015-01-26 18:38:33 -080062
Junxiao Shicb766862017-07-07 22:21:04 +000063 const std::string&
64 getName() const override
65 {
66 static const std::string STAGE_NAME("guess from identity name");
67 return STAGE_NAME;
68 }
69
70private:
Junxiao Shif748a4e2017-07-05 23:41:48 +000071 void
Junxiao Shicb766862017-07-07 22:21:04 +000072 doStart() override;
73
74private:
75 KeyChain& m_keyChain;
Alexander Afanasyev2a655f72015-01-26 18:38:33 -080076};
77
78} // namespace autoconfig
79} // namespace tools
80} // namespace ndn
81
Junxiao Shif748a4e2017-07-05 23:41:48 +000082#endif // NFD_TOOLS_NDN_AUTOCONFIG_GUESS_FROM_IDENTITY_NAME_HPP