libzypp  17.7.0
MediaMultiCurl.h
Go to the documentation of this file.
1 /*---------------------------------------------------------------------\
2 | ____ _ __ __ ___ |
3 | |__ / \ / / . \ . \ |
4 | / / \ V /| _/ _/ |
5 | / /__ | | | | | | |
6 | /_____||_| |_| |_| |
7 | |
8 \---------------------------------------------------------------------*/
12 #ifndef ZYPP_MEDIA_MEDIAMULTICURL_H
13 #define ZYPP_MEDIA_MEDIAMULTICURL_H
14 
15 #include <string>
16 #include <vector>
17 #include <list>
18 #include <set>
19 
21 #include "zypp/media/MediaCurl.h"
24 #include "zypp/ZYppCallbacks.h"
25 
26 namespace zypp {
27  namespace media {
28 
37 class multifetchrequest;
38 class multifetchworker;
39 
40 class MediaMultiCurl : public MediaCurl {
41 public:
42  friend class multifetchrequest;
43  friend class multifetchworker;
44 
45  MediaMultiCurl(const Url &url_r, const Pathname & attach_point_hint_r);
47 
48  virtual void doGetFileCopy( const Pathname & srcFilename, const Pathname & targetFilename, callback::SendReport<DownloadProgressReport> & _report, const ByteCount &expectedFileSize_r, RequestOptions options = OPTION_NONE ) const override;
49 
50  void multifetch(const Pathname &filename, FILE *fp, std::vector<Url> *urllist, callback::SendReport<DownloadProgressReport> *report = 0, MediaBlockList *blklist = 0, off_t filesize = off_t(-1)) const;
51 
52 protected:
53 
54  bool isDNSok(const std::string &host) const;
55  void setDNSok(const std::string &host) const;
56 
57  CURL *fromEasyPool(const std::string &host) const;
58  void toEasyPool(const std::string &host, CURL *easy) const;
59 
60  virtual void setupEasy();
61  void checkFileDigest(Url &url, FILE *fp, MediaBlockList *blklist) const;
62  static int progressCallback( void *clientp, double dltotal, double dlnow, double ultotal, double ulnow );
63 
64 private:
65  // the custom headers from MediaCurl plus a "Accept: metalink" header
67  mutable CURLM *_multi; // reused for all fetches so we can make use of the dns cache
68  mutable std::set<std::string> _dnsok;
69  mutable std::map<std::string, CURL *> _easypool;
70 };
71 
73 
74  } // namespace media
75 } // namespace zypp
76 
77 #endif // ZYPP_MEDIA_MEDIAMULTICURL_H
zypp::media::MediaMultiCurl::setupEasy
virtual void setupEasy()
initializes the curl easy handle with the data from the url
Definition: MediaMultiCurl.cc:1192
zypp::media::MediaMultiCurl::_customHeadersMetalink
curl_slist * _customHeadersMetalink
Definition: MediaMultiCurl.h:66
zypp::media::MediaMultiCurl::_dnsok
std::set< std::string > _dnsok
Definition: MediaMultiCurl.h:68
zypp::callback::SendReport
Definition: Callback.h:236
zypp::media::MediaBlockList
Definition: MediaBlockList.h:35
MediaHandler.h
zypp::media::MediaCurl
Implementation class for FTP, HTTP and HTTPS MediaHandler.
Definition: MediaCurl.h:32
report
callback::SendReport< DownloadProgressReport > * report
Definition: MediaCurl.cc:203
zypp::media::MediaMultiCurl::toEasyPool
void toEasyPool(const std::string &host, CURL *easy) const
Definition: MediaMultiCurl.cc:1598
zypp::media::MediaMultiCurl::setDNSok
void setDNSok(const std::string &host) const
Definition: MediaMultiCurl.cc:1584
zypp::ByteCount
Store and operate with byte count.
Definition: ByteCount.h:30
MediaBlockList.h
ZYppCallbacks.h
TransferSettings.h
zypp
Easy-to use interface to the ZYPP dependency resolver.
Definition: CodePitfalls.doc:1
zypp::media::MediaHandler::url
Url url() const
Url used.
Definition: MediaHandler.h:507
zypp::media::MediaMultiCurl::fromEasyPool
CURL * fromEasyPool(const std::string &host) const
Definition: MediaMultiCurl.cc:1589
zypp::media::MediaMultiCurl::progressCallback
static int progressCallback(void *clientp, double dltotal, double dlnow, double ultotal, double ulnow)
Definition: MediaMultiCurl.cc:1246
zypp::media::MediaMultiCurl::_multi
CURLM * _multi
Definition: MediaMultiCurl.h:67
zypp::media::MediaMultiCurl::checkFileDigest
void checkFileDigest(Url &url, FILE *fp, MediaBlockList *blklist) const
Definition: MediaMultiCurl.cc:1563
zypp::media::MediaMultiCurl
Definition: MediaMultiCurl.h:40
zypp::media::multifetchworker
Definition: MediaMultiCurl.cc:48
zypp::media::multifetchrequest
Definition: MediaMultiCurl.cc:113
zypp::media::MediaMultiCurl::doGetFileCopy
virtual void doGetFileCopy(const Pathname &srcFilename, const Pathname &targetFilename, callback::SendReport< DownloadProgressReport > &_report, const ByteCount &expectedFileSize_r, RequestOptions options=OPTION_NONE) const override
Definition: MediaMultiCurl.cc:1297
zypp::media::MediaCurl::OPTION_NONE
@ OPTION_NONE
Defaults.
Definition: MediaCurl.h:38
zypp::filesystem::Pathname
Pathname.
Definition: Pathname.h:43
zypp::media::MediaMultiCurl::MediaMultiCurl
MediaMultiCurl(const Url &url_r, const Pathname &attach_point_hint_r)
Definition: MediaMultiCurl.cc:1160
zypp::media::MediaMultiCurl::isDNSok
bool isDNSok(const std::string &host) const
Definition: MediaMultiCurl.cc:1579
MediaCurl.h
zypp::Url
Url manipulation class.
Definition: Url.h:87
zypp::media::MediaMultiCurl::~MediaMultiCurl
~MediaMultiCurl()
Definition: MediaMultiCurl.cc:1168
zypp::media::MediaMultiCurl::_easypool
std::map< std::string, CURL * > _easypool
Definition: MediaMultiCurl.h:69
zypp::media::MediaMultiCurl::multifetch
void multifetch(const Pathname &filename, FILE *fp, std::vector< Url > *urllist, callback::SendReport< DownloadProgressReport > *report=0, MediaBlockList *blklist=0, off_t filesize=off_t(-1)) const
Definition: MediaMultiCurl.cc:1511