blob: 410d193d0bc8fef9f6d13317220f1b3fb568e2b9 [file] [log] [blame]
Zhenkai Zhue42b4572013-01-22 15:57:54 -08001/* -*- Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil -*- */
2/*
3 * Copyright (c) 2013 University of California, Los Angeles
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2 as
7 * published by the Free Software Foundation;
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17 *
18 * Author: Zhenkai Zhu <zhenkai@cs.ucla.edu>
19 * Alexander Afanasyev <alexander.afanasyev@ucla.edu>
20 */
21
Alexander Afanasyev28ca3ed2013-01-24 23:17:15 -080022#ifndef CONTENT_SERVER_H
23#define CONTENT_SERVER_H
24
Alexander Afanasyevf4cde4e2016-12-25 13:42:57 -080025#include "ccnx-wrapper.hpp"
26#include "object-db.hpp"
27#include "action-log.hpp"
Zhenkai Zhue42b4572013-01-22 15:57:54 -080028#include <set>
Zhenkai Zhu92bb6952013-02-06 16:43:30 -080029#include <map>
Zhenkai Zhue42b4572013-01-22 15:57:54 -080030#include <boost/thread/shared_mutex.hpp>
31#include <boost/thread/locks.hpp>
Alexander Afanasyevf4cde4e2016-12-25 13:42:57 -080032#include "scheduler.hpp"
Zhenkai Zhue42b4572013-01-22 15:57:54 -080033
34class ContentServer
35{
36public:
Alexander Afanasyev1dd37ed2013-08-14 18:08:09 -070037 ContentServer(Ndnx::NdnxWrapperPtr ndnx, ActionLogPtr actionLog, const boost::filesystem::path &rootDir,
38 const Ndnx::Name &userName, const std::string &sharedFolderName, const std::string &appName,
Alexander Afanasyev1d1cc832013-02-05 20:03:36 -080039 int freshness = -1);
Zhenkai Zhue42b4572013-01-22 15:57:54 -080040 ~ContentServer();
41
42 // the assumption is, when the interest comes in, interest is informs of
43 // /some-prefix/topology-independent-name
44 // currently /topology-independent-name must begin with /action or /file
45 // so that ContentServer knows where to look for the content object
Alexander Afanasyev1dd37ed2013-08-14 18:08:09 -070046 void registerPrefix(const Ndnx::Name &prefix);
47 void deregisterPrefix(const Ndnx::Name &prefix);
Zhenkai Zhue42b4572013-01-22 15:57:54 -080048
Alexander Afanasyev28ca3ed2013-01-24 23:17:15 -080049private:
Alexander Afanasyev4d086752013-02-07 13:06:04 -080050 void
Alexander Afanasyev1dd37ed2013-08-14 18:08:09 -070051 filterAndServe (Ndnx::Name forwardingHint, const Ndnx::Name &interest);
Zhenkai Zhuc3a27872013-01-25 19:21:25 -080052
53 void
Alexander Afanasyev1dd37ed2013-08-14 18:08:09 -070054 filterAndServeImpl (const Ndnx::Name &forwardingHint, const Ndnx::Name &name, const Ndnx::Name &interest);
Alexander Afanasyev28ca3ed2013-01-24 23:17:15 -080055
56 void
Alexander Afanasyev1dd37ed2013-08-14 18:08:09 -070057 serve_Action (const Ndnx::Name &forwardingHint, const Ndnx::Name &name, const Ndnx::Name &interest);
Alexander Afanasyev28ca3ed2013-01-24 23:17:15 -080058
59 void
Alexander Afanasyev1dd37ed2013-08-14 18:08:09 -070060 serve_File (const Ndnx::Name &forwardingHint, const Ndnx::Name &name, const Ndnx::Name &interest);
Alexander Afanasyev28ca3ed2013-01-24 23:17:15 -080061
62 void
Alexander Afanasyev1dd37ed2013-08-14 18:08:09 -070063 serve_Action_Execute(const Ndnx::Name &forwardingHint, const Ndnx::Name &name, const Ndnx::Name &interest);
Alexander Afanasyev3cca13f2013-02-07 16:06:46 -080064
65 void
Alexander Afanasyev1dd37ed2013-08-14 18:08:09 -070066 serve_File_Execute(const Ndnx::Name &forwardingHint, const Ndnx::Name &name, const Ndnx::Name &interest);
Zhenkai Zhue42b4572013-01-22 15:57:54 -080067
Zhenkai Zhu92bb6952013-02-06 16:43:30 -080068 void
69 flushStaleDbCache();
70
Zhenkai Zhue42b4572013-01-22 15:57:54 -080071private:
Alexander Afanasyev1dd37ed2013-08-14 18:08:09 -070072 Ndnx::NdnxWrapperPtr m_ndnx;
Zhenkai Zhue42b4572013-01-22 15:57:54 -080073 ActionLogPtr m_actionLog;
74 typedef boost::shared_mutex Mutex;
Alexander Afanasyev28ca3ed2013-01-24 23:17:15 -080075
76 typedef boost::unique_lock<Mutex> ScopedLock;
Alexander Afanasyev1dd37ed2013-08-14 18:08:09 -070077 typedef std::set<Ndnx::Name>::iterator PrefixIt;
78 std::set<Ndnx::Name> m_prefixes;
Zhenkai Zhue42b4572013-01-22 15:57:54 -080079 Mutex m_mutex;
80 boost::filesystem::path m_dbFolder;
Zhenkai Zhu13d224d2013-01-23 19:40:25 -080081 int m_freshness;
Alexander Afanasyev28ca3ed2013-01-24 23:17:15 -080082
Zhenkai Zhu92bb6952013-02-06 16:43:30 -080083 SchedulerPtr m_scheduler;
84 typedef std::map<Hash, ObjectDbPtr> DbCache;
85 DbCache m_dbCache;
86 Mutex m_dbCacheMutex;
Alexander Afanasyev28ca3ed2013-01-24 23:17:15 -080087
Alexander Afanasyev1dd37ed2013-08-14 18:08:09 -070088 Ndnx::Name m_userName;
Alexander Afanasyev28ca3ed2013-01-24 23:17:15 -080089 std::string m_sharedFolderName;
Alexander Afanasyev1d1cc832013-02-05 20:03:36 -080090 std::string m_appName;
Zhenkai Zhue42b4572013-01-22 15:57:54 -080091};
92#endif // CONTENT_SERVER_H