]> git.saurik.com Git - apt.git/blob - methods/server.h
treat older Release files than we already have as an IMSHit
[apt.git] / methods / server.h
1 // -*- mode: cpp; mode: fold -*-
2 // Description /*{{{*/
3 /* ######################################################################
4
5 Classes dealing with the abstraction of talking to a end via a text
6 protocol like HTTP (which is used by the http and https methods)
7
8 ##################################################################### */
9 /*}}}*/
10
11 #ifndef APT_SERVER_H
12 #define APT_SERVER_H
13
14 #include <apt-pkg/strutl.h>
15 #include <apt-pkg/acquire-method.h>
16
17 #include <time.h>
18 #include <iostream>
19 #include <string>
20
21 using std::cout;
22 using std::endl;
23
24 class Hashes;
25 class ServerMethod;
26 class FileFd;
27
28 struct ServerState
29 {
30 // This is the last parsed Header Line
31 unsigned int Major;
32 unsigned int Minor;
33 unsigned int Result;
34 char Code[360];
35
36 // These are some statistics from the last parsed header lines
37 unsigned long long Size; // size of the usable content (aka: the file)
38 unsigned long long JunkSize; // size of junk content (aka: server error pages)
39 unsigned long long StartPos;
40 time_t Date;
41 bool HaveContent;
42 enum {Chunked,Stream,Closes} Encoding;
43 enum {Header, Data} State;
44 bool Persistent;
45 std::string Location;
46
47 // This is a Persistent attribute of the server itself.
48 bool Pipeline;
49 URI ServerName;
50 URI Proxy;
51 unsigned long TimeOut;
52
53 unsigned long long MaximumSize;
54
55 protected:
56 ServerMethod *Owner;
57
58 virtual bool ReadHeaderLines(std::string &Data) = 0;
59 virtual bool LoadNextResponse(bool const ToFile, FileFd * const File) = 0;
60
61 public:
62 bool HeaderLine(std::string Line);
63
64 /** \brief Result of the header acquire */
65 enum RunHeadersResult {
66 /** \brief Header ok */
67 RUN_HEADERS_OK,
68 /** \brief IO error while retrieving */
69 RUN_HEADERS_IO_ERROR,
70 /** \brief Parse error after retrieving */
71 RUN_HEADERS_PARSE_ERROR
72 };
73 /** \brief Get the headers before the data */
74 RunHeadersResult RunHeaders(FileFd * const File, const std::string &Uri);
75 bool AddPartialFileToHashes(FileFd &File);
76
77 bool Comp(URI Other) const {return Other.Host == ServerName.Host && Other.Port == ServerName.Port;};
78 virtual void Reset() {Major = 0; Minor = 0; Result = 0; Code[0] = '\0'; Size = 0; JunkSize = 0;
79 StartPos = 0; Encoding = Closes; time(&Date); HaveContent = false;
80 State = Header; Persistent = false; Pipeline = true; MaximumSize = 0;};
81 virtual bool WriteResponse(std::string const &Data) = 0;
82
83 /** \brief Transfer the data from the socket */
84 virtual bool RunData(FileFd * const File) = 0;
85
86 virtual bool Open() = 0;
87 virtual bool IsOpen() = 0;
88 virtual bool Close() = 0;
89 virtual bool InitHashes(HashStringList const &ExpectedHashes) = 0;
90 virtual Hashes * GetHashes() = 0;
91 virtual bool Die(FileFd &File) = 0;
92 virtual bool Flush(FileFd * const File) = 0;
93 virtual bool Go(bool ToFile, FileFd * const File) = 0;
94
95 ServerState(URI Srv, ServerMethod *Owner);
96 virtual ~ServerState() {};
97 };
98
99 class ServerMethod : public pkgAcqMethod
100 {
101 protected:
102 virtual bool Fetch(FetchItem *);
103
104 ServerState *Server;
105 std::string NextURI;
106 FileFd *File;
107
108 unsigned long PipelineDepth;
109 bool AllowRedirect;
110
111 // Find the biggest item in the fetch queue for the checking of the maximum
112 // size
113 unsigned long long FindMaximumObjectSizeInQueue() const APT_PURE;
114
115 public:
116 bool Debug;
117
118 /** \brief Result of the header parsing */
119 enum DealWithHeadersResult {
120 /** \brief The file is open and ready */
121 FILE_IS_OPEN,
122 /** \brief We got a IMS hit, the file has not changed */
123 IMS_HIT,
124 /** \brief The server reported a unrecoverable error */
125 ERROR_UNRECOVERABLE,
126 /** \brief The server reported a error with a error content page */
127 ERROR_WITH_CONTENT_PAGE,
128 /** \brief An error on the client side */
129 ERROR_NOT_FROM_SERVER,
130 /** \brief A redirect or retry request */
131 TRY_AGAIN_OR_REDIRECT
132 };
133 /** \brief Handle the retrieved header data */
134 DealWithHeadersResult DealWithHeaders(FetchResult &Res);
135
136 // In the event of a fatal signal this file will be closed and timestamped.
137 static std::string FailFile;
138 static int FailFd;
139 static time_t FailTime;
140 static APT_NORETURN void SigTerm(int);
141
142 virtual bool Configuration(std::string Message);
143 virtual bool Flush() { return Server->Flush(File); };
144
145 int Loop();
146
147 virtual void SendReq(FetchItem *Itm) = 0;
148 virtual ServerState * CreateServerState(URI uri) = 0;
149 virtual void RotateDNS() = 0;
150
151 ServerMethod(const char *Ver,unsigned long Flags = 0) : pkgAcqMethod(Ver, Flags), Server(NULL), File(NULL), PipelineDepth(10), AllowRedirect(false), Debug(false) {};
152 virtual ~ServerMethod() {};
153 };
154
155 #endif