#include <Downloader.h>

Inheritance diagram for Downloader:
Collaboration diagram for Downloader:


class  CbDialer
 Callback data to use with Downloader callbacks. More...

Public Types

typedef CbcPointer< AsyncJobPointer

Public Member Functions

 Downloader (const SBuf &url, const AsyncCall::Pointer &aCallback, const MasterXactionPointer &, unsigned int level=0)
virtual ~Downloader ()
virtual void swanSong ()
void downloadFinished ()
 delays destruction to protect doCallouts() More...
unsigned int nestedLevel () const
 The nested level of Downloader object (downloads inside downloads). More...
void handleReply (clientStreamNode *, ClientHttpRequest *, HttpReply *, StoreIOBuffer)
bool canBeCalled (AsyncCall &call) const
 whether we can be called More...
void callStart (AsyncCall &call)
virtual void callEnd ()
 called right after the called job method More...
virtual void callException (const std::exception &e)
 called when the job throws during an async call More...
void handleStopRequest ()
 process external request to terminate now (i.e. during this async call) More...
virtual void * toCbdata ()=0

Static Public Member Functions

static void Start (const Pointer &job)

Public Attributes

const InstanceId< AsyncJobid
 job identifier More...

Protected Member Functions

virtual bool doneAll () const
 whether positive goal has been reached More...
virtual void start ()
 called by AsyncStart; do not call directly More...
void deleteThis (const char *aReason)
void mustStop (const char *aReason)
bool done () const
 the job is destroyed in callEnd() when done() More...
virtual const char * status () const
 internal cleanup; do not call directly More...

Protected Attributes

const char * stopReason
 reason for forcing done() to be true More...
const char * typeName
 kid (leaf) class name, for debugging More...
AsyncCall::Pointer inCall
 the asynchronous call being handled, if any More...
bool started_ = false
 Start() has finished successfully. More...
bool swanSang_ = false
 swanSong() was called More...

Private Member Functions

 CBDATA_CLASS (Downloader)
bool buildRequest ()
 Initializes and starts the HTTP GET request to the remote server. More...
void callBack (Http::StatusCode const status)

Private Attributes

SBuf url_
 the url to download More...
AsyncCall::Pointer callback_
 callback to call when download finishes More...
SBuf object_
 the object body data More...
const unsigned int level_
 holds the nested downloads level More...
MasterXactionPointer masterXaction_
 download transaction context More...
DownloaderContextPointer context_
 Pointer to an object that stores the clientStream required info. More...

Static Private Attributes

static const size_t MaxObjectSize = 1*1024*1024
 The maximum allowed object size. More...

Detailed Description

The Downloader class fetches SBuf-storable things for other Squid components/transactions using internal requests. For example, it is used to fetch missing intermediate certificates when validating origin server certificate chains.

Definition at line 30 of file Downloader.h.

Member Typedef Documentation

◆ Pointer

Definition at line 34 of file AsyncJob.h.

Constructor & Destructor Documentation

◆ Downloader()

Downloader::Downloader ( const SBuf url,
const AsyncCall::Pointer aCallback,
const MasterXactionPointer masterXaction,
unsigned int  level = 0 

Definition at line 67 of file Downloader.cc.

◆ ~Downloader()

Downloader::~Downloader ( )

Definition at line 76 of file Downloader.cc.

References debugs.

Member Function Documentation

◆ buildRequest()

◆ callBack()

void Downloader::callBack ( Http::StatusCode const  statusCode)

Schedules for execution the "callback" with parameters the status and object.

Definition at line 256 of file Downloader.cc.

References assert, callback_, CallJobHere, downloadFinished(), AsyncCall::getDialer(), Must, Downloader::CbDialer::object, object_, ScheduleCallHere, Http::scOkay, and Downloader::CbDialer::status.

Referenced by handleReply(), start(), and swanSong().

◆ callEnd()

void AsyncJob::callEnd ( )

◆ callException()

◆ callStart()

void AsyncJob::callStart ( AsyncCall call)

◆ canBeCalled()

bool AsyncJob::canBeCalled ( AsyncCall call) const

Definition at line 102 of file AsyncJob.cc.

References AsyncCall::cancel(), debugs, and AsyncJob::inCall.


Downloader::CBDATA_CLASS ( Downloader  )

◆ deleteThis()

void AsyncJob::deleteThis ( const char *  aReason)

◆ done()

bool AsyncJob::done ( ) const

◆ doneAll()

bool Downloader::doneAll ( ) const

Reimplemented from AsyncJob.

Definition at line 96 of file Downloader.cc.

References callback_, AsyncCall::canceled(), and AsyncJob::doneAll().

◆ downloadFinished()

void Downloader::downloadFinished ( )

Definition at line 247 of file Downloader.cc.

References debugs, AsyncJob::done(), and Must.

Referenced by callBack().

◆ handleReply()

◆ handleStopRequest()

void AsyncJob::handleStopRequest ( )

Definition at line 71 of file AsyncJob.h.

References AsyncJob::mustStop().

◆ mustStop()

◆ nestedLevel()

unsigned int Downloader::nestedLevel ( ) const

Definition at line 58 of file Downloader.h.

References level_.

◆ start()

void Downloader::start ( )

Reimplemented from AsyncJob.

Definition at line 181 of file Downloader.cc.

References buildRequest(), callBack(), and Http::scInternalServerError.

◆ Start()

◆ status()

◆ swanSong()

void Downloader::swanSong ( )

Reimplemented from AsyncJob.

Definition at line 82 of file Downloader.cc.

References callBack(), callback_, context_, debugs, DownloaderContext::finished(), and Http::scInternalServerError.

◆ toCbdata()

virtual void * CbdataParent::toCbdata ( )
pure virtualinherited

Member Data Documentation

◆ callback_

AsyncCall::Pointer Downloader::callback_

Definition at line 77 of file Downloader.h.

Referenced by callBack(), doneAll(), and swanSong().

◆ context_

DownloaderContextPointer Downloader::context_

Definition at line 83 of file Downloader.h.

Referenced by buildRequest(), handleReply(), and swanSong().

◆ id

const InstanceId<AsyncJob> AsyncJob::id

Definition at line 73 of file AsyncJob.h.

◆ inCall

AsyncCall::Pointer AsyncJob::inCall

◆ level_

const unsigned int Downloader::level_

Definition at line 79 of file Downloader.h.

Referenced by nestedLevel().

◆ masterXaction_

MasterXactionPointer Downloader::masterXaction_

Definition at line 80 of file Downloader.h.

Referenced by buildRequest().

◆ MaxObjectSize

const size_t Downloader::MaxObjectSize = 1*1024*1024

Definition at line 74 of file Downloader.h.

Referenced by handleReply().

◆ object_

SBuf Downloader::object_

Definition at line 78 of file Downloader.h.

Referenced by callBack(), and handleReply().

◆ started_

bool AsyncJob::started_ = false

Definition at line 83 of file AsyncJob.h.

Referenced by AsyncJob::~AsyncJob(), AsyncJob::callEnd(), and AsyncJob::Start().

◆ stopReason

const char* AsyncJob::stopReason

◆ swanSang_

bool AsyncJob::swanSang_ = false

Definition at line 84 of file AsyncJob.h.

Referenced by AsyncJob::~AsyncJob(), and AsyncJob::callEnd().

◆ typeName

◆ url_

SBuf Downloader::url_

Definition at line 76 of file Downloader.h.

Referenced by buildRequest().

The documentation for this class was generated from the following files:






Web Site Translations