Zhenkai Zhu | 0f05412 | 2012-12-25 22:22:50 -0800 | [diff] [blame] | 1 | #ifndef CCNX_TUNNEL_H |
| 2 | #define CCNX_TUNNEL_H |
| 3 | |
Zhenkai Zhu | 0f05412 | 2012-12-25 22:22:50 -0800 | [diff] [blame] | 4 | #include <boost/variant.hpp> |
Zhenkai Zhu | 0f05412 | 2012-12-25 22:22:50 -0800 | [diff] [blame] | 5 | |
Zhenkai Zhu | 974c5a6 | 2012-12-28 14:15:30 -0800 | [diff] [blame] | 6 | #include "ccnx-common.h" |
Zhenkai Zhu | d492431 | 2012-12-28 11:35:12 -0800 | [diff] [blame] | 7 | #include "ccnx-wrapper.h" |
| 8 | |
| 9 | #define _OVERRIDE |
| 10 | #ifdef __GNUC__ |
| 11 | #if __GNUC_MAJOR >= 4 && __GNUC_MINOR__ >= 7 |
| 12 | #undef _OVERRIDE |
| 13 | #define _OVERRIDE override |
| 14 | #endif // __GNUC__ version |
| 15 | #endif // __GNUC__ |
| 16 | |
Zhenkai Zhu | 0f05412 | 2012-12-25 22:22:50 -0800 | [diff] [blame] | 17 | using namespace std; |
| 18 | |
| 19 | // Eventually, Sync::CcnxWrapper should be moved to this namespace. |
| 20 | // It has nothing to do with Sync. |
| 21 | namespace Ccnx |
| 22 | { |
| 23 | |
| 24 | class CcnxTunnel : public CcnxWrapper |
| 25 | { |
| 26 | public: |
Zhenkai Zhu | 0f05412 | 2012-12-25 22:22:50 -0800 | [diff] [blame] | 27 | typedef multimap<string, InterestCallback> RegisteredInterestTable; |
Zhenkai Zhu | d492431 | 2012-12-28 11:35:12 -0800 | [diff] [blame] | 28 | typedef multimap<string, InterestCallback>::iterator RitIter; |
Zhenkai Zhu | 0f05412 | 2012-12-25 22:22:50 -0800 | [diff] [blame] | 29 | |
| 30 | |
| 31 | CcnxTunnel(); |
| 32 | virtual ~CcnxTunnel(); |
| 33 | |
| 34 | // name is topology-independent |
| 35 | virtual int |
Zhenkai Zhu | 974c5a6 | 2012-12-28 14:15:30 -0800 | [diff] [blame] | 36 | publishData(const string &name, const unsigned char *buf, size_t len, int freshness) _OVERRIDE; |
Zhenkai Zhu | d492431 | 2012-12-28 11:35:12 -0800 | [diff] [blame] | 37 | |
Zhenkai Zhu | f118526 | 2012-12-29 17:06:00 -0800 | [diff] [blame] | 38 | int |
| 39 | publishContentObject(const string &name, const Bytes &contentObject, int freshness); |
| 40 | |
Zhenkai Zhu | d492431 | 2012-12-28 11:35:12 -0800 | [diff] [blame] | 41 | virtual int |
Zhenkai Zhu | 9bad2bf | 2012-12-28 15:31:46 -0800 | [diff] [blame] | 42 | sendInterest (const Interest &interest, Closure *closure); |
Zhenkai Zhu | d492431 | 2012-12-28 11:35:12 -0800 | [diff] [blame] | 43 | |
Zhenkai Zhu | 0f05412 | 2012-12-25 22:22:50 -0800 | [diff] [blame] | 44 | |
| 45 | // prefix is topology-independent |
| 46 | virtual int |
Zhenkai Zhu | d492431 | 2012-12-28 11:35:12 -0800 | [diff] [blame] | 47 | setInterestFilter(const string &prefix, const InterestCallback &interestCallback) _OVERRIDE; |
Zhenkai Zhu | 0f05412 | 2012-12-25 22:22:50 -0800 | [diff] [blame] | 48 | |
| 49 | // prefix is topology-independent |
| 50 | // this clears all entries with key equal to prefix |
| 51 | virtual void |
Zhenkai Zhu | d492431 | 2012-12-28 11:35:12 -0800 | [diff] [blame] | 52 | clearInterestFilter(const string &prefix) _OVERRIDE; |
Zhenkai Zhu | 0f05412 | 2012-12-25 22:22:50 -0800 | [diff] [blame] | 53 | |
| 54 | // subclass should provide translation service from topology-independent name |
| 55 | // to routable name |
| 56 | virtual string |
Zhenkai Zhu | d492431 | 2012-12-28 11:35:12 -0800 | [diff] [blame] | 57 | queryRoutableName(const string &name) = 0; |
Zhenkai Zhu | 0f05412 | 2012-12-25 22:22:50 -0800 | [diff] [blame] | 58 | |
| 59 | // subclass should implement the function to store ContentObject with topoloy-independent |
| 60 | // name to the permanent storage; default does nothing |
| 61 | virtual void |
Zhenkai Zhu | d492431 | 2012-12-28 11:35:12 -0800 | [diff] [blame] | 62 | storeContentObject(const string &name, const Bytes &content) {} |
Zhenkai Zhu | 0f05412 | 2012-12-25 22:22:50 -0800 | [diff] [blame] | 63 | |
| 64 | // should be called when connect to a different network |
| 65 | void |
| 66 | refreshLocalPrefix(); |
| 67 | |
| 68 | static bool |
Zhenkai Zhu | d492431 | 2012-12-28 11:35:12 -0800 | [diff] [blame] | 69 | isPrefix(const string &prefix, const string &name); |
Zhenkai Zhu | 0f05412 | 2012-12-25 22:22:50 -0800 | [diff] [blame] | 70 | |
Zhenkai Zhu | 0f05412 | 2012-12-25 22:22:50 -0800 | [diff] [blame] | 71 | void |
Zhenkai Zhu | d492431 | 2012-12-28 11:35:12 -0800 | [diff] [blame] | 72 | handleTunneledInterest(const string &tunneldInterest); |
| 73 | |
| 74 | void |
Zhenkai Zhu | 974c5a6 | 2012-12-28 14:15:30 -0800 | [diff] [blame] | 75 | handleTunneledData(const string &name, const Bytes &tunneledData, const Closure::DataCallback &originalDataCallback); |
Zhenkai Zhu | 0f05412 | 2012-12-25 22:22:50 -0800 | [diff] [blame] | 76 | |
| 77 | protected: |
| 78 | // need a way to update local prefix, perhaps using macports trick, but eventually we need something more portable |
| 79 | string m_localPrefix; |
Zhenkai Zhu | 0f05412 | 2012-12-25 22:22:50 -0800 | [diff] [blame] | 80 | RegisteredInterestTable m_rit; |
Zhenkai Zhu | 0f05412 | 2012-12-25 22:22:50 -0800 | [diff] [blame] | 81 | Lock m_ritLock; |
| 82 | }; |
| 83 | |
Zhenkai Zhu | 974c5a6 | 2012-12-28 14:15:30 -0800 | [diff] [blame] | 84 | class TunnelClosure : public Closure |
Zhenkai Zhu | d492431 | 2012-12-28 11:35:12 -0800 | [diff] [blame] | 85 | { |
| 86 | public: |
Zhenkai Zhu | 974c5a6 | 2012-12-28 14:15:30 -0800 | [diff] [blame] | 87 | TunnelClosure(int retry, const DataCallback &dataCallback, const TimeoutCallback &timeoutCallback, CcnxTunnel *tunnel, const string &originalInterest); |
| 88 | |
| 89 | TunnelClosure(const Closure *closure, CcnxTunnel *tunnel, const string &originalInterest); |
Zhenkai Zhu | d492431 | 2012-12-28 11:35:12 -0800 | [diff] [blame] | 90 | |
| 91 | virtual void |
| 92 | runDataCallback(const string &name, const Bytes &content) _OVERRIDE; |
| 93 | |
Zhenkai Zhu | 974c5a6 | 2012-12-28 14:15:30 -0800 | [diff] [blame] | 94 | virtual TimeoutCallbackReturnValue |
Zhenkai Zhu | d492431 | 2012-12-28 11:35:12 -0800 | [diff] [blame] | 95 | runTimeoutCallback(const string &interest) _OVERRIDE; |
| 96 | |
| 97 | private: |
| 98 | CcnxTunnel *m_tunnel; |
| 99 | string m_originalInterest; |
| 100 | }; |
| 101 | |
Zhenkai Zhu | 0f05412 | 2012-12-25 22:22:50 -0800 | [diff] [blame] | 102 | }; |
| 103 | |
| 104 | #endif |