* improve the timeout handling (again)
[ntk/apt.git] / apt-pkg / acquire-item.h
CommitLineData
0118833a
AL
1// -*- mode: cpp; mode: fold -*-
2// Description /*{{{*/
b3d44315 3// $Id: acquire-item.h,v 1.26.2.3 2004/01/02 18:51:00 mdz Exp $
0118833a
AL
4/* ######################################################################
5
6 Acquire Item - Item to acquire
7
8 When an item is instantiated it will add it self to the local list in
9 the Owner Acquire class. Derived classes will then call QueueURI to
17caf1b1 10 register all the URI's they wish to fetch at the initial moment.
0118833a
AL
11
12 Two item classes are provided to provide functionality for downloading
13 of Index files and downloading of Packages.
14
b185acc2 15 A Archive class is provided for downloading .deb files. It does Md5
17caf1b1 16 checking and source location as well as a retry algorithm.
b185acc2 17
0118833a
AL
18 ##################################################################### */
19 /*}}}*/
20#ifndef PKGLIB_ACQUIRE_ITEM_H
21#define PKGLIB_ACQUIRE_ITEM_H
22
23#include <apt-pkg/acquire.h>
b2e465d6 24#include <apt-pkg/indexfile.h>
b3d44315
MV
25#include <apt-pkg/vendor.h>
26#include <apt-pkg/sourcelist.h>
03e39e59 27#include <apt-pkg/pkgrecords.h>
b3d44315 28#include <apt-pkg/indexrecords.h>
0118833a
AL
29
30#ifdef __GNUG__
31#pragma interface "apt-pkg/acquire-item.h"
32#endif
33
34// Item to acquire
35class pkgAcquire::Item
36{
37 protected:
38
17caf1b1 39 // Some private helper methods for registering URIs
0118833a 40 pkgAcquire *Owner;
8267fe24
AL
41 inline void QueueURI(ItemDesc &Item)
42 {Owner->Enqueue(Item);};
681d76d0 43 inline void Dequeue() {Owner->Dequeue(this);};
0118833a 44
17caf1b1 45 // Safe rename function with timestamp preservation
8b89e57f
AL
46 void Rename(string From,string To);
47
0118833a
AL
48 public:
49
c88edf1d 50 // State of the item
b3d44315 51 enum {StatIdle, StatFetching, StatDone, StatError, StatAuthError} Status;
c88edf1d 52 string ErrorText;
8267fe24 53 unsigned long FileSize;
6b1ff003 54 unsigned long PartialSize;
b2e465d6 55 const char *Mode;
b98f2859 56 unsigned long ID;
8267fe24 57 bool Complete;
a6568219 58 bool Local;
30e1eab5 59
0a8a80e5 60 // Number of queues we are inserted into
0118833a 61 unsigned int QueueCounter;
0118833a 62
0a8a80e5
AL
63 // File to write the fetch into
64 string DestFile;
7d8afa39 65
17caf1b1 66 // Action members invoked by the worker
7d8afa39 67 virtual void Failed(string Message,pkgAcquire::MethodConfig *Cnf);
459681d3
AL
68 virtual void Done(string Message,unsigned long Size,string Md5Hash,
69 pkgAcquire::MethodConfig *Cnf);
8267fe24 70 virtual void Start(string Message,unsigned long Size);
17caf1b1 71 virtual string Custom600Headers() {return string();};
36375005 72 virtual string DescURI() = 0;
b3d44315 73 virtual string ShortDesc() {return DescURI();}
ab559b35 74 virtual void Finished() {};
17caf1b1
AL
75
76 // Inquire functions
f7a08e33 77 virtual string MD5Sum() {return string();};
c5ccf175 78 pkgAcquire *GetOwner() {return Owner;};
b3d44315 79 virtual bool IsTrusted() {return false;};
c5ccf175 80
0118833a
AL
81 Item(pkgAcquire *Owner);
82 virtual ~Item();
83};
84
85// Item class for index files
86class pkgAcqIndex : public pkgAcquire::Item
87{
88 protected:
89
8b89e57f 90 bool Decompression;
bfd22fc0 91 bool Erase;
8267fe24 92 pkgAcquire::ItemDesc Desc;
b2e465d6 93 string RealURI;
b3d44315 94 string ExpectedMD5;
0118833a
AL
95
96 public:
97
17caf1b1 98 // Specialized action members
debc84b2 99 virtual void Failed(string Message,pkgAcquire::MethodConfig *Cnf);
459681d3
AL
100 virtual void Done(string Message,unsigned long Size,string Md5Hash,
101 pkgAcquire::MethodConfig *Cnf);
0a8a80e5 102 virtual string Custom600Headers();
40285ffd 103 virtual string DescURI() {return RealURI + ".gz";};
0118833a 104
b2e465d6 105 pkgAcqIndex(pkgAcquire *Owner,string URI,string URIDesc,
b3d44315 106 string ShortDesct, string ExpectedMD5, string compressExt="");
0118833a
AL
107};
108
b3d44315
MV
109struct IndexTarget
110{
111 string URI;
112 string Description;
113 string ShortDesc;
114 string MetaKey;
115};
116
117// Item class for index signatures
118class pkgAcqMetaSig : public pkgAcquire::Item
0118833a
AL
119{
120 protected:
121
8267fe24 122 pkgAcquire::ItemDesc Desc;
b3d44315
MV
123 string RealURI,MetaIndexURI,MetaIndexURIDesc,MetaIndexShortDesc;
124 indexRecords* MetaIndexParser;
125 const vector<struct IndexTarget*>* IndexTargets;
126
0118833a
AL
127 public:
128
17caf1b1 129 // Specialized action members
681d76d0 130 virtual void Failed(string Message,pkgAcquire::MethodConfig *Cnf);
459681d3 131 virtual void Done(string Message,unsigned long Size,string Md5Hash,
b3d44315 132 pkgAcquire::MethodConfig *Cnf);
0a8a80e5 133 virtual string Custom600Headers();
b3d44315
MV
134 virtual string DescURI() {return RealURI; };
135
136 pkgAcqMetaSig(pkgAcquire *Owner,string URI,string URIDesc, string ShortDesc,
137 string MetaIndexURI, string MetaIndexURIDesc, string MetaIndexShortDesc,
138 const vector<struct IndexTarget*>* IndexTargets,
139 indexRecords* MetaIndexParser);
140};
141
142// Item class for index signatures
143class pkgAcqMetaIndex : public pkgAcquire::Item
144{
145 protected:
146
147 pkgAcquire::ItemDesc Desc;
148 string RealURI; // FIXME: is this redundant w/ Desc.URI?
149 string SigFile;
150 const vector<struct IndexTarget*>* IndexTargets;
151 indexRecords* MetaIndexParser;
152 bool AuthPass;
153
154 bool VerifyVendor();
155 void RetrievalDone(string Message);
156 void AuthDone(string Message);
157 void QueueIndexes(bool verify);
158
159 public:
0a8a80e5 160
b3d44315
MV
161 // Specialized action members
162 virtual void Failed(string Message,pkgAcquire::MethodConfig *Cnf);
163 virtual void Done(string Message,unsigned long Size,string Md5Hash,
164 pkgAcquire::MethodConfig *Cnf);
165 virtual string Custom600Headers();
166 virtual string DescURI() {return RealURI; };
167
168 pkgAcqMetaIndex(pkgAcquire *Owner,
169 string URI,string URIDesc, string ShortDesc,
170 string SigFile,
171 const vector<struct IndexTarget*>* IndexTargets,
172 indexRecords* MetaIndexParser);
0118833a
AL
173};
174
03e39e59
AL
175// Item class for archive files
176class pkgAcqArchive : public pkgAcquire::Item
177{
178 protected:
179
17caf1b1 180 // State information for the retry mechanism
03e39e59
AL
181 pkgCache::VerIterator Version;
182 pkgAcquire::ItemDesc Desc;
183 pkgSourceList *Sources;
184 pkgRecords *Recs;
185 string MD5;
30e1eab5 186 string &StoreFilename;
b185acc2 187 pkgCache::VerFileIterator Vf;
7d8afa39 188 unsigned int Retries;
b3d44315 189 bool Trusted;
17caf1b1
AL
190
191 // Queue the next available file for download.
b185acc2 192 bool QueueNext();
03e39e59
AL
193
194 public:
195
17caf1b1 196 // Specialized action members
7d8afa39 197 virtual void Failed(string Message,pkgAcquire::MethodConfig *Cnf);
459681d3
AL
198 virtual void Done(string Message,unsigned long Size,string Md5Hash,
199 pkgAcquire::MethodConfig *Cnf);
17caf1b1 200 virtual string MD5Sum() {return MD5;};
36375005 201 virtual string DescURI() {return Desc.URI;};
b3d44315 202 virtual string ShortDesc() {return Desc.ShortDesc;};
ab559b35 203 virtual void Finished();
b3d44315 204 virtual bool IsTrusted();
03e39e59
AL
205
206 pkgAcqArchive(pkgAcquire *Owner,pkgSourceList *Sources,
30e1eab5
AL
207 pkgRecords *Recs,pkgCache::VerIterator const &Version,
208 string &StoreFilename);
03e39e59
AL
209};
210
36375005
AL
211// Fetch a generic file to the current directory
212class pkgAcqFile : public pkgAcquire::Item
213{
214 pkgAcquire::ItemDesc Desc;
b3c39978 215 string Md5Hash;
08cfc005 216 unsigned int Retries;
36375005
AL
217
218 public:
219
220 // Specialized action members
08cfc005 221 virtual void Failed(string Message,pkgAcquire::MethodConfig *Cnf);
459681d3
AL
222 virtual void Done(string Message,unsigned long Size,string Md5Hash,
223 pkgAcquire::MethodConfig *Cnf);
b3c39978 224 virtual string MD5Sum() {return Md5Hash;};
36375005
AL
225 virtual string DescURI() {return Desc.URI;};
226
227 pkgAcqFile(pkgAcquire *Owner,string URI,string MD5,unsigned long Size,
228 string Desc,string ShortDesc);
229};
230
0118833a 231#endif