https.h 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. // -*- mode: cpp; mode: fold -*-
  2. // Description /*{{{*/// $Id: http.h,v 1.12 2002/04/18 05:09:38 jgg Exp $
  3. // $Id: http.h,v 1.12 2002/04/18 05:09:38 jgg Exp $
  4. /* ######################################################################
  5. HTTP Acquire Method - This is the HTTP acquire method for APT.
  6. ##################################################################### */
  7. /*}}}*/
  8. #ifndef APT_HTTPS_H
  9. #define APT_HTTPS_H
  10. #include <apt-pkg/acquire-method.h>
  11. #include <curl/curl.h>
  12. #include <iostream>
  13. #include <stddef.h>
  14. #include <string>
  15. #include <memory>
  16. #include "server.h"
  17. using std::cout;
  18. using std::endl;
  19. class Hashes;
  20. class HttpsMethod;
  21. class FileFd;
  22. class HttpsServerState : public ServerState
  23. {
  24. Hashes * Hash;
  25. protected:
  26. virtual bool ReadHeaderLines(std::string &/*Data*/) APT_OVERRIDE { return false; }
  27. virtual bool LoadNextResponse(bool const /*ToFile*/, FileFd * const /*File*/) APT_OVERRIDE { return false; }
  28. public:
  29. virtual bool WriteResponse(std::string const &/*Data*/) APT_OVERRIDE { return false; }
  30. /** \brief Transfer the data from the socket */
  31. virtual bool RunData(FileFd * const /*File*/) APT_OVERRIDE { return false; }
  32. virtual bool Open() APT_OVERRIDE { return false; }
  33. virtual bool IsOpen() APT_OVERRIDE { return false; }
  34. virtual bool Close() APT_OVERRIDE { return false; }
  35. virtual bool InitHashes(HashStringList const &ExpectedHashes) APT_OVERRIDE;
  36. virtual Hashes * GetHashes() APT_OVERRIDE;
  37. virtual bool Die(FileFd &/*File*/) APT_OVERRIDE { return false; }
  38. virtual bool Flush(FileFd * const /*File*/) APT_OVERRIDE { return false; }
  39. virtual bool Go(bool /*ToFile*/, FileFd * const /*File*/) APT_OVERRIDE { return false; }
  40. HttpsServerState(URI Srv, HttpsMethod *Owner);
  41. virtual ~HttpsServerState() {Close();};
  42. };
  43. class HttpsMethod : public ServerMethod
  44. {
  45. // minimum speed in bytes/se that triggers download timeout handling
  46. static const int DL_MIN_SPEED = 10;
  47. virtual bool Fetch(FetchItem *) APT_OVERRIDE;
  48. static size_t parse_header(void *buffer, size_t size, size_t nmemb, void *userp);
  49. static size_t write_data(void *buffer, size_t size, size_t nmemb, void *userp);
  50. static int progress_callback(void *clientp, double dltotal, double dlnow,
  51. double ultotal, double ulnow);
  52. void SetupProxy();
  53. CURL *curl;
  54. // Used by ServerMethods unused by https
  55. virtual void SendReq(FetchItem *) APT_OVERRIDE { exit(42); }
  56. virtual void RotateDNS() APT_OVERRIDE { exit(42); }
  57. public:
  58. virtual bool Configuration(std::string Message) APT_OVERRIDE;
  59. virtual std::unique_ptr<ServerState> CreateServerState(URI const &uri) APT_OVERRIDE;
  60. using pkgAcqMethod::FetchResult;
  61. using pkgAcqMethod::FetchItem;
  62. HttpsMethod() : ServerMethod("https","1.2",Pipeline | SendConfig)
  63. {
  64. curl = curl_easy_init();
  65. };
  66. ~HttpsMethod()
  67. {
  68. curl_easy_cleanup(curl);
  69. };
  70. };
  71. #include <apt-pkg/strutl.h>
  72. URI Proxy;
  73. #endif