blob: acbd543fbf860f628bc510f564097e5276a36908 [file] [log] [blame]
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
/*
* Copyright (c) 2014-2018, Regents of the University of California,
* Arizona Board of Regents,
* Colorado State University,
* University Pierre & Marie Curie, Sorbonne University,
* Washington University in St. Louis,
* Beijing Institute of Technology,
* The University of Memphis.
*
* This file is part of NFD (Named Data Networking Forwarding Daemon).
* See AUTHORS.md for complete list of NFD authors and contributors.
*
* NFD is free software: you can redistribute it and/or modify it under the terms
* of the GNU General Public License as published by the Free Software Foundation,
* either version 3 of the License, or (at your option) any later version.
*
* NFD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
* PURPOSE. See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along with
* NFD, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
*/
#include "unix-stream-factory.hpp"
#include <boost/filesystem.hpp>
namespace nfd {
namespace face {
NFD_LOG_INIT("UnixStreamFactory");
NFD_REGISTER_PROTOCOL_FACTORY(UnixStreamFactory);
const std::string&
UnixStreamFactory::getId()
{
static std::string id("unix");
return id;
}
UnixStreamFactory::UnixStreamFactory(const CtorParams& params)
: ProtocolFactory(params)
{
}
void
UnixStreamFactory::processConfig(OptionalConfigSection configSection,
FaceSystem::ConfigContext& context)
{
// unix
// {
// path /var/run/nfd.sock
// }
m_wantCongestionMarking = context.generalConfig.wantCongestionMarking;
if (!configSection) {
if (!context.isDryRun && !m_channels.empty()) {
NFD_LOG_WARN("Cannot disable unix channel after initialization");
}
return;
}
std::string path = "/var/run/nfd.sock";
for (const auto& pair : *configSection) {
const std::string& key = pair.first;
const ConfigSection& value = pair.second;
if (key == "path") {
path = value.get_value<std::string>();
}
else {
BOOST_THROW_EXCEPTION(ConfigFile::Error("Unrecognized option face_system.unix." + key));
}
}
if (!context.isDryRun) {
auto channel = this->createChannel(path);
if (!channel->isListening()) {
channel->listen(this->addFace, nullptr);
}
}
}
void
UnixStreamFactory::createFace(const CreateFaceParams& params,
const FaceCreatedCallback& onCreated,
const FaceCreationFailedCallback& onFailure)
{
onFailure(406, "Unsupported protocol");
}
shared_ptr<UnixStreamChannel>
UnixStreamFactory::createChannel(const std::string& unixSocketPath)
{
boost::filesystem::path p(unixSocketPath);
p = boost::filesystem::canonical(p.parent_path()) / p.filename();
unix_stream::Endpoint endpoint(p.string());
auto channel = findChannel(endpoint);
if (channel)
return channel;
channel = make_shared<UnixStreamChannel>(endpoint, m_wantCongestionMarking);
m_channels[endpoint] = channel;
return channel;
}
std::vector<shared_ptr<const Channel>>
UnixStreamFactory::getChannels() const
{
return getChannelsFromMap(m_channels);
}
shared_ptr<UnixStreamChannel>
UnixStreamFactory::findChannel(const unix_stream::Endpoint& endpoint) const
{
auto i = m_channels.find(endpoint);
if (i != m_channels.end())
return i->second;
else
return nullptr;
}
} // namespace face
} // namespace nfd