blob: 410d193d0bc8fef9f6d13317220f1b3fb568e2b9 [file] [log] [blame]
/* -*- Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil -*- */
/*
* Copyright (c) 2013 University of California, Los Angeles
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation;
*
* This program 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 this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* Author: Zhenkai Zhu <zhenkai@cs.ucla.edu>
* Alexander Afanasyev <alexander.afanasyev@ucla.edu>
*/
#ifndef CONTENT_SERVER_H
#define CONTENT_SERVER_H
#include "ccnx-wrapper.hpp"
#include "object-db.hpp"
#include "action-log.hpp"
#include <set>
#include <map>
#include <boost/thread/shared_mutex.hpp>
#include <boost/thread/locks.hpp>
#include "scheduler.hpp"
class ContentServer
{
public:
ContentServer(Ndnx::NdnxWrapperPtr ndnx, ActionLogPtr actionLog, const boost::filesystem::path &rootDir,
const Ndnx::Name &userName, const std::string &sharedFolderName, const std::string &appName,
int freshness = -1);
~ContentServer();
// the assumption is, when the interest comes in, interest is informs of
// /some-prefix/topology-independent-name
// currently /topology-independent-name must begin with /action or /file
// so that ContentServer knows where to look for the content object
void registerPrefix(const Ndnx::Name &prefix);
void deregisterPrefix(const Ndnx::Name &prefix);
private:
void
filterAndServe (Ndnx::Name forwardingHint, const Ndnx::Name &interest);
void
filterAndServeImpl (const Ndnx::Name &forwardingHint, const Ndnx::Name &name, const Ndnx::Name &interest);
void
serve_Action (const Ndnx::Name &forwardingHint, const Ndnx::Name &name, const Ndnx::Name &interest);
void
serve_File (const Ndnx::Name &forwardingHint, const Ndnx::Name &name, const Ndnx::Name &interest);
void
serve_Action_Execute(const Ndnx::Name &forwardingHint, const Ndnx::Name &name, const Ndnx::Name &interest);
void
serve_File_Execute(const Ndnx::Name &forwardingHint, const Ndnx::Name &name, const Ndnx::Name &interest);
void
flushStaleDbCache();
private:
Ndnx::NdnxWrapperPtr m_ndnx;
ActionLogPtr m_actionLog;
typedef boost::shared_mutex Mutex;
typedef boost::unique_lock<Mutex> ScopedLock;
typedef std::set<Ndnx::Name>::iterator PrefixIt;
std::set<Ndnx::Name> m_prefixes;
Mutex m_mutex;
boost::filesystem::path m_dbFolder;
int m_freshness;
SchedulerPtr m_scheduler;
typedef std::map<Hash, ObjectDbPtr> DbCache;
DbCache m_dbCache;
Mutex m_dbCacheMutex;
Ndnx::Name m_userName;
std::string m_sharedFolderName;
std::string m_appName;
};
#endif // CONTENT_SERVER_H