blob: 3e0008f8d7fb749fb54a8b863691a4564d3e5e3d [file] [log] [blame]
Alexander Afanasyev2a655f72015-01-26 18:38:33 -08001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
3 * Copyright (c) 2014-2015, 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#ifndef NFD_TOOLS_NDN_AUTOCONFIG_GUESS_FROM_IDENTITY_NAME_HPP
27#define NFD_TOOLS_NDN_AUTOCONFIG_GUESS_FROM_IDENTITY_NAME_HPP
28
29#include "base-dns.hpp"
30
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 */
56class GuessFromIdentityName : public BaseDns
57{
58public:
59 /**
60 * @brief Create stage to guess home router based on the default identity name
61 * @sa Base::Base
62 */
63 GuessFromIdentityName(Face& face, KeyChain& keyChain,
64 const NextStageCallback& nextStageOnFailure);
65
66 virtual void
67 start() DECL_OVERRIDE;
68};
69
70} // namespace autoconfig
71} // namespace tools
72} // namespace ndn
73
74#endif // NFD_TOOLS_NDN_AUTOCONFIG_GUESSING_FROM_IDENTITY_NAME_HPP