/* */ #ifndef D_ABSTRACT_COMMAND_H #define D_ABSTRACT_COMMAND_H #include "Command.h" #include #include #include "SharedHandle.h" #include "TimerA2.h" namespace aria2 { class FileEntry; class RequestGroup; class CheckIntegrityEntry; class DownloadContext; class SegmentMan; class PieceStorage; class Request; class DownloadEngine; class Segment; class SocketCore; class Option; class SocketRecvBuffer; #ifdef ENABLE_ASYNC_DNS class AsyncNameResolver; #endif // ENABLE_ASYNC_DNS class AbstractCommand : public Command { private: Timer checkPoint_; time_t timeout_; RequestGroup* requestGroup_; SharedHandle req_; SharedHandle fileEntry_; DownloadEngine* e_; SharedHandle socket_; SharedHandle socketRecvBuffer_; std::vector > segments_; #ifdef ENABLE_ASYNC_DNS SharedHandle asyncNameResolver_; #endif // ENABLE_ASYNC_DNS bool checkSocketIsReadable_; bool checkSocketIsWritable_; SharedHandle readCheckTarget_; SharedHandle writeCheckTarget_; bool nameResolverCheck_; bool incNumConnection_; Timer serverStatTimer_; size_t calculateMinSplitSize() const; void useFasterRequest(const SharedHandle& fasterRequest); #ifdef ENABLE_ASYNC_DNS void setNameResolverCheck(const SharedHandle& resolver); void disableNameResolverCheck (const SharedHandle& resolver); bool nameResolveFinished() const; #endif // ENABLE_ASYNC_DNS protected: RequestGroup* getRequestGroup() const { return requestGroup_; } const SharedHandle& getRequest() const { return req_; } void setRequest(const SharedHandle& request); const SharedHandle& getFileEntry() const { return fileEntry_; } void setFileEntry(const SharedHandle& fileEntry); DownloadEngine* getDownloadEngine() const { return e_; } const SharedHandle& getSocket() const { return socket_; } void setSocket(const SharedHandle& s); void createSocket(); const SharedHandle& getSocketRecvBuffer() const { return socketRecvBuffer_; } const std::vector >& getSegments() const { return segments_; } #ifdef ENABLE_ASYNC_DNS bool isAsyncNameResolverInitialized() const; void initAsyncNameResolver(const std::string& hostname); bool asyncResolveHostname(); const std::vector& getResolvedAddresses(); #endif // ENABLE_ASYNC_DNS // Resolves hostname. The resolved addresses are stored in addrs // and first element is returned. If resolve is not finished, // return empty string. In this case, call this function with same // arguments until resolved address is returned. Exception is // thrown on error. port is used for retrieving cached addresses. std::string resolveHostname (std::vector& addrs, const std::string& hostname, uint16_t port); void tryReserved(); virtual bool prepareForRetry(time_t wait); virtual void onAbort(); virtual bool executeInternal() = 0; void setReadCheckSocket(const SharedHandle& socket); void setWriteCheckSocket(const SharedHandle& socket); void disableReadCheckSocket(); void disableWriteCheckSocket(); /** * If pred == true, calls setReadCheckSocket(socket). Otherwise, calls * disableReadCheckSocket(). */ void setReadCheckSocketIf(const SharedHandle& socket, bool pred); /** * If pred == true, calls setWriteCheckSocket(socket). Otherwise, calls * disableWriteCheckSocket(). */ void setWriteCheckSocketIf(const SharedHandle& socket, bool pred); time_t getTimeout() const { return timeout_; } void setTimeout(time_t timeout) { timeout_ = timeout; } void prepareForNextAction (const SharedHandle& checkEntry); // Check if socket is connected. If socket is not connected and // there are other addresses to try, command is created using // InitiateConnectionCommandFactory and it is pushed to // DownloadEngine and returns false. If no addresses left, DlRetryEx // exception is thrown. bool checkIfConnectionEstablished (const SharedHandle& socket, const std::string& connectedHostname, const std::string& connectedAddr, uint16_t connectedPort); /* * Returns true if proxy for the procol indicated by Request::getProtocol() * is defined. Otherwise, returns false. */ bool isProxyDefined() const; /* * Creates Request object for proxy URI and returns it. * If no valid proxy is defined, then returns SharedHandle(). */ SharedHandle createProxyRequest() const; // Returns proxy method for given protocol. Either V_GET or V_TUNNEL // is returned. For HTTPS, always returns V_TUNNEL. const std::string& resolveProxyMethod(const std::string& protocol) const; const SharedHandle