blob: 315e8569b0d63c7f9cc446039ca9603c3df3bf29 [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"
Alexander Afanasyev2a655f72015-01-26 18:38:33 -080030
31namespace ndn {
32namespace tools {
33namespace autoconfig {
34
35/**
36 * @brief Guessing home router based on the default identity name
37 *
38 * This stage assumes that user has configured default certificate using
39 * http://ndncert.named-data.net/
40 *
41 * - Request
42 *
43 * The end host loads the default user identity (eg. /ndn/edu/ucla/cs/afanasev), and
44 * converts it to DNS format.
45 *
46 * The end host sends a DNS query for an SRV record of name _ndn._udp. + user identity in
47 * DNS format + _homehub._auto-conf.named-data.net. For example:
48 *
49 * _ndn._udp.afanasev.cs.ucla.edu.ndn._homehub._autoconf.named-data.net
50 *
51 * - Response
52 *
53 * The DNS server should answer with an SRV record that contains the hostname and UDP port
54 * number of the home NDN router of this user's site.
55 */
Junxiao Shif748a4e2017-07-05 23:41:48 +000056class GuessFromIdentityName : public Stage
Alexander Afanasyev2a655f72015-01-26 18:38:33 -080057{
58public:
59 /**
60 * @brief Create stage to guess home router based on the default identity name
Alexander Afanasyev2a655f72015-01-26 18:38:33 -080061 */
62 GuessFromIdentityName(Face& face, KeyChain& keyChain,
63 const NextStageCallback& nextStageOnFailure);
64
Junxiao Shif748a4e2017-07-05 23:41:48 +000065 void
Davide Pesaventob84bd3a2016-04-22 02:21:45 +020066 start() override;
Alexander Afanasyev2a655f72015-01-26 18:38:33 -080067};
68
69} // namespace autoconfig
70} // namespace tools
71} // namespace ndn
72
Junxiao Shif748a4e2017-07-05 23:41:48 +000073#endif // NFD_TOOLS_NDN_AUTOCONFIG_GUESS_FROM_IDENTITY_NAME_HPP