blob: 328d46e9d1ef898f32cddd8a552cd147ca813cc8 [file] [log] [blame]
Alexander Afanasyeva9034b02014-01-26 18:32:02 -08001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
Junxiao Shi38b24c72017-01-05 02:59:31 +00003 * Copyright (c) 2014-2017, Regents of the University of California,
Davide Pesavento1d7e7af2015-10-10 23:54:08 +02004 * 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.
Alexander Afanasyev9bcbc7c2014-04-06 19:37:37 -070010 *
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/>.
Steve DiBenedettoef04f272014-06-04 14:28:31 -060024 */
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080025
Alexander Afanasyev613e2a92014-04-15 13:36:58 -070026#ifndef NFD_DAEMON_FACE_PROTOCOL_FACTORY_HPP
27#define NFD_DAEMON_FACE_PROTOCOL_FACTORY_HPP
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080028
Davide Pesavento47ab0292015-11-02 18:45:39 +010029#include "channel.hpp"
Junxiao Shi38b24c72017-01-05 02:59:31 +000030#include "face-system.hpp"
Junxiao Shi0de23a22015-12-03 20:07:02 +000031#include <ndn-cxx/encoding/nfd-constants.hpp>
Junxiao Shi38b24c72017-01-05 02:59:31 +000032#include <boost/range/adaptor/map.hpp>
33#include <boost/range/algorithm/copy.hpp>
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080034
Alexander Afanasyev18bbf812014-01-29 01:40:23 -080035namespace nfd {
Junxiao Shi38b24c72017-01-05 02:59:31 +000036namespace face {
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080037
Junxiao Shi38b24c72017-01-05 02:59:31 +000038/** \brief provide support for an underlying protocol
39 * \sa FaceSystem
40 *
41 * A protocol factory provides support for an underlying protocol and owns Channel objects.
42 * It can process a subsection of face_system config section and create channels and multicast
43 * faces accordingly.
Davide Pesavento1d7e7af2015-10-10 23:54:08 +020044 */
Junxiao Shi38b24c72017-01-05 02:59:31 +000045class ProtocolFactory : noncopyable
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080046{
47public:
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080048 /**
Davide Pesavento1d7e7af2015-10-10 23:54:08 +020049 * \brief Base class for all exceptions thrown by protocol factories
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080050 */
Davide Pesavento1d7e7af2015-10-10 23:54:08 +020051 class Error : public std::runtime_error
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080052 {
Davide Pesavento1d7e7af2015-10-10 23:54:08 +020053 public:
54 explicit
55 Error(const std::string& what)
56 : std::runtime_error(what)
57 {
58 }
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080059 };
Alexander Afanasyevd6655302014-02-28 08:41:28 -080060
Junxiao Shi38b24c72017-01-05 02:59:31 +000061 /** \brief process face_system subsection that corresponds to this ProtocolFactory type
62 * \param configSection the configuration section or boost::null to indicate it is omitted
63 * \param context provides access to data structures and contextual information
64 * \throw ConfigFile::Error invalid configuration
65 *
66 * This function updates \p providedSchemes
67 */
68 virtual void
69 processConfig(OptionalConfigSection configSection,
70 FaceSystem::ConfigContext& context)
71 {
72 ///\todo implement in every subclass and make this pure-virtual
73 BOOST_THROW_EXCEPTION(Error("processConfig is not implemented"));
74 }
75
76 /** \return FaceUri schemes accepted by this ProtocolFactory
77 */
78 const std::set<std::string>&
79 getProvidedSchemes()
80 {
81 return providedSchemes;
82 }
83
Yukai Tu7c90e6d2015-07-11 12:21:46 +080084 /** \brief Try to create Face using the supplied FaceUri
Alexander Afanasyevd6655302014-02-28 08:41:28 -080085 *
Yukai Tu7c90e6d2015-07-11 12:21:46 +080086 * This method should automatically choose channel, based on supplied FaceUri
Alexander Afanasyevd6655302014-02-28 08:41:28 -080087 * and create face.
88 *
Eric Newberryf40551a2016-09-05 15:41:16 -070089 * \param uri remote URI of the new face
90 * \param persistency persistency of the new face
91 * \param wantLocalFieldsEnabled whether local fields should be enabled on the face
92 * \param onCreated callback if face creation succeeds
93 * If a face with the same remote URI already exists, its persistency and
94 * LocalFieldsEnabled setting will not be modified.
95 * \param onFailure callback if face creation fails
Alexander Afanasyevd6655302014-02-28 08:41:28 -080096 */
97 virtual void
98 createFace(const FaceUri& uri,
Yukai Tu7c90e6d2015-07-11 12:21:46 +080099 ndn::nfd::FacePersistency persistency,
Eric Newberryf40551a2016-09-05 15:41:16 -0700100 bool wantLocalFieldsEnabled,
Alexander Afanasyevd6655302014-02-28 08:41:28 -0800101 const FaceCreatedCallback& onCreated,
Eric Newberryf40551a2016-09-05 15:41:16 -0700102 const FaceCreationFailedCallback& onFailure) = 0;
Steve DiBenedettoef04f272014-06-04 14:28:31 -0600103
Davide Pesavento1d7e7af2015-10-10 23:54:08 +0200104 virtual std::vector<shared_ptr<const Channel>>
Steve DiBenedettoef04f272014-06-04 14:28:31 -0600105 getChannels() const = 0;
Junxiao Shi38b24c72017-01-05 02:59:31 +0000106
107protected:
108 template<typename ChannelMap>
109 static std::vector<shared_ptr<const Channel>>
110 getChannelsFromMap(const ChannelMap& channelMap)
111 {
112 std::vector<shared_ptr<const Channel>> channels;
113 boost::copy(channelMap | boost::adaptors::map_values, std::back_inserter(channels));
114 return channels;
115 }
116
117protected:
118 /** \brief FaceUri schemes provided by this ProtocolFactory
119 */
120 std::set<std::string> providedSchemes;
Alexander Afanasyeva9034b02014-01-26 18:32:02 -0800121};
122
Junxiao Shi38b24c72017-01-05 02:59:31 +0000123} // namespace face
124
125using face::ProtocolFactory;
126
Alexander Afanasyev18bbf812014-01-29 01:40:23 -0800127} // namespace nfd
Alexander Afanasyeva9034b02014-01-26 18:32:02 -0800128
Alexander Afanasyev613e2a92014-04-15 13:36:58 -0700129#endif // NFD_DAEMON_FACE_PROTOCOL_FACTORY_HPP