blob: 8e6b4415ae4db5e29cf34d938d1617248bb05320 [file] [log] [blame]
/* -*- Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil -*- */
/*
* Copyright (c) 2012-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: Alexander Afanasyev <alexander.afanasyev@ucla.edu>
* Zhenkai Zhu <zhenkai@cs.ucla.edu>
*/
#ifndef FETCHER_H
#define FETCHER_H
#include "ccnx-wrapper.h"
#include "ccnx-name.h"
#include "executor.h"
#include <boost/intrusive/list.hpp>
#include <boost/date_time/posix_time/posix_time_types.hpp>
class FetchManager;
class Fetcher
{
public:
typedef boost::function<void(Ccnx::Name &deviceName, Ccnx::Name &baseName, uint64_t seq, Ccnx::PcoPtr pco)> SegmentCallback;
typedef boost::function<void(Ccnx::Name &deviceName, Ccnx::Name &baseName)> FinishCallback;
typedef boost::function<void (Fetcher &)> OnFetchCompleteCallback;
typedef boost::function<void (Fetcher &)> OnFetchFailedCallback;
Fetcher (Ccnx::CcnxWrapperPtr ccnx,
ExecutorPtr executor,
const SegmentCallback &segmentCallback, // callback passed by caller of FetchManager
const FinishCallback &finishCallback, // callback passed by caller of FetchManager
OnFetchCompleteCallback onFetchComplete, OnFetchFailedCallback onFetchFailed, // callbacks provided by FetchManager
const Ccnx::Name &deviceName, const Ccnx::Name &name, int64_t minSeqNo, int64_t maxSeqNo,
boost::posix_time::time_duration timeout = boost::posix_time::seconds (30), // this time is not precise, but sets min bound
// actual time depends on how fast Interests timeout
const Ccnx::Name &forwardingHint = Ccnx::Name ());
virtual ~Fetcher ();
inline bool
IsActive () const;
void
RestartPipeline ();
void
SetForwardingHint (const Ccnx::Name &forwardingHint);
const Ccnx::Name &
GetForwardingHint () const { return m_forwardingHint; }
const Ccnx::Name &
GetName () const { return m_name; }
const Ccnx::Name &
GetDeviceName () const { return m_deviceName; }
double
GetRetryPause () const { return m_retryPause; }
void
SetRetryPause (double pause) { m_retryPause = pause; }
boost::posix_time::ptime
GetNextScheduledRetry () const { return m_nextScheduledRetry; }
void
SetNextScheduledRetry (boost::posix_time::ptime nextScheduledRetry) { m_nextScheduledRetry = nextScheduledRetry; }
private:
void
FillPipeline ();
void
OnData (uint64_t seqno, const Ccnx::Name &name, Ccnx::PcoPtr data);
void
OnData_Execute (uint64_t seqno, Ccnx::Name name, Ccnx::PcoPtr data);
void
OnTimeout (uint64_t seqno, const Ccnx::Name &name, const Ccnx::Closure &closure, Ccnx::Selectors selectors);
void
OnTimeout_Execute (uint64_t seqno, Ccnx::Name name, Ccnx::Closure closure, Ccnx::Selectors selectors);
public:
boost::intrusive::list_member_hook<> m_managerListHook;
private:
Ccnx::CcnxWrapperPtr m_ccnx;
SegmentCallback m_segmentCallback;
OnFetchCompleteCallback m_onFetchComplete;
OnFetchFailedCallback m_onFetchFailed;
FinishCallback m_finishCallback;
bool m_active;
Ccnx::Name m_name;
Ccnx::Name m_deviceName;
Ccnx::Name m_forwardingHint;
boost::posix_time::time_duration m_maximumNoActivityPeriod;
int64_t m_minSendSeqNo;
int64_t m_maxInOrderRecvSeqNo;
std::set<int64_t> m_outOfOrderRecvSeqNo;
std::set<int64_t> m_inActivePipeline;
int64_t m_minSeqNo;
int64_t m_maxSeqNo;
uint32_t m_pipeline;
uint32_t m_activePipeline;
boost::posix_time::ptime m_lastPositiveActivity;
double m_retryPause; // pause to stop trying to fetch (for fetch-manager)
boost::posix_time::ptime m_nextScheduledRetry;
ExecutorPtr m_executor; // to serialize FillPipeline events
};
typedef boost::error_info<struct tag_errmsg, std::string> errmsg_info_str;
namespace Error {
struct Fetcher : virtual boost::exception, virtual std::exception { };
}
typedef boost::shared_ptr<Fetcher> FetcherPtr;
bool
Fetcher::IsActive () const
{
return m_active;
}
#endif // FETCHER_H