]>
git.saurik.com Git - apt.git/blob - apt-pkg/indexrecords.cc
1 // -*- mode: cpp; mode: fold -*-
3 // $Id: indexrecords.cc,v 1.1.2.4 2003/12/30 02:11:43 mdz Exp $
5 // Include Files /*{{{*/
8 #include <apt-pkg/indexrecords.h>
9 #include <apt-pkg/tagfile.h>
10 #include <apt-pkg/error.h>
11 #include <apt-pkg/strutl.h>
12 #include <apt-pkg/configuration.h>
13 #include <apt-pkg/fileutl.h>
14 #include <apt-pkg/hashes.h>
15 #include <apt-pkg/gpgv.h>
30 APT_PURE string
indexRecords::GetDist() const
35 APT_PURE string
indexRecords::GetSuite() const
40 APT_PURE
bool indexRecords::GetSupportsAcquireByHash() const
42 return this->SupportsAcquireByHash
;
45 APT_PURE
bool indexRecords::CheckDist(const string MaybeDist
) const
47 return (this->Dist
== MaybeDist
48 || this->Suite
== MaybeDist
);
51 APT_PURE string
indexRecords::GetExpectedDist() const
53 return this->ExpectedDist
;
56 APT_PURE
time_t indexRecords::GetValidUntil() const
58 return this->ValidUntil
;
61 APT_PURE
indexRecords::checkSum
*indexRecords::Lookup(const string MetaKey
)
63 std::map
<std::string
, indexRecords::checkSum
* >::const_iterator sum
= Entries
.find(MetaKey
);
64 if (sum
== Entries
.end())
69 APT_PURE
bool indexRecords::Exists(string
const &MetaKey
) const
71 return Entries
.count(MetaKey
) == 1;
74 bool indexRecords::Load(const string Filename
) /*{{{*/
77 if (OpenMaybeClearSignedFile(Filename
, Fd
) == false)
80 pkgTagFile
TagFile(&Fd
, Fd
.Size());
81 if (_error
->PendingError() == true)
83 strprintf(ErrorText
, _("Unable to parse Release file %s"),Filename
.c_str());
87 pkgTagSection Section
;
88 const char *Start
, *End
;
89 if (TagFile
.Step(Section
) == false)
91 strprintf(ErrorText
, _("No sections in Release file %s"), Filename
.c_str());
94 // FIXME: find better tag name
95 SupportsAcquireByHash
= Section
.FindB("Acquire-By-Hash", false);
97 Suite
= Section
.FindS("Suite");
98 Dist
= Section
.FindS("Codename");
100 bool FoundHashSum
= false;
101 for (int i
=0;HashString::SupportedHashes()[i
] != NULL
; i
++)
103 if (!Section
.Find(HashString::SupportedHashes()[i
], Start
, End
))
108 unsigned long long Size
;
111 if (!parseSumData(Start
, End
, Name
, Hash
, Size
))
114 if (Entries
.find(Name
) == Entries
.end())
116 indexRecords::checkSum
*Sum
= new indexRecords::checkSum
;
117 Sum
->MetaKeyFilename
= Name
;
120 #pragma GCC diagnostic push
121 #pragma GCC diagnostic ignored "-Wdeprecated-declarations"
123 Sum
->Hash
= HashString(HashString::SupportedHashes()[i
],Hash
);
125 #pragma GCC diagnostic pop
129 Entries
[Name
]->Hashes
.push_back(HashString(HashString::SupportedHashes()[i
],Hash
));
134 if(FoundHashSum
== false)
136 strprintf(ErrorText
, _("No Hash entry in Release file %s"), Filename
.c_str());
140 string Label
= Section
.FindS("Label");
141 string StrDate
= Section
.FindS("Date");
142 string StrValidUntil
= Section
.FindS("Valid-Until");
144 // if we have a Valid-Until header in the Release file, use it as default
145 if (StrValidUntil
.empty() == false)
147 if(RFC1123StrToTime(StrValidUntil
.c_str(), ValidUntil
) == false)
149 strprintf(ErrorText
, _("Invalid 'Valid-Until' entry in Release file %s"), Filename
.c_str());
153 // get the user settings for this archive and use what expires earlier
154 int MaxAge
= _config
->FindI("Acquire::Max-ValidTime", 0);
155 if (Label
.empty() == false)
156 MaxAge
= _config
->FindI(("Acquire::Max-ValidTime::" + Label
).c_str(), MaxAge
);
157 int MinAge
= _config
->FindI("Acquire::Min-ValidTime", 0);
158 if (Label
.empty() == false)
159 MinAge
= _config
->FindI(("Acquire::Min-ValidTime::" + Label
).c_str(), MinAge
);
162 (MinAge
== 0 || ValidUntil
== 0)) // No user settings, use the one from the Release file
166 if (RFC1123StrToTime(StrDate
.c_str(), date
) == false)
168 strprintf(ErrorText
, _("Invalid 'Date' entry in Release file %s"), Filename
.c_str());
172 if (MinAge
!= 0 && ValidUntil
!= 0) {
173 time_t const min_date
= date
+ MinAge
;
174 if (ValidUntil
< min_date
)
175 ValidUntil
= min_date
;
178 time_t const max_date
= date
+ MaxAge
;
179 if (ValidUntil
== 0 || ValidUntil
> max_date
)
180 ValidUntil
= max_date
;
186 std::vector
<string
> indexRecords::MetaKeys() /*{{{*/
188 std::vector
<std::string
> keys
;
189 std::map
<string
,checkSum
*>::iterator I
= Entries
.begin();
190 while(I
!= Entries
.end()) {
191 keys
.push_back((*I
).first
);
197 bool indexRecords::parseSumData(const char *&Start
, const char *End
, /*{{{*/
198 string
&Name
, string
&Hash
, unsigned long long &Size
)
203 /* Skip over the first blank */
204 while ((*Start
== '\t' || *Start
== ' ' || *Start
== '\n' || *Start
== '\r')
210 /* Move EntryEnd to the end of the first entry (the hash) */
211 const char *EntryEnd
= Start
;
212 while ((*EntryEnd
!= '\t' && *EntryEnd
!= ' ')
218 Hash
.append(Start
, EntryEnd
-Start
);
220 /* Skip over intermediate blanks */
222 while (*Start
== '\t' || *Start
== ' ')
228 /* Find the end of the second entry (the size) */
229 while ((*EntryEnd
!= '\t' && *EntryEnd
!= ' ' )
235 Size
= strtoull (Start
, NULL
, 10);
237 /* Skip over intermediate blanks */
239 while (*Start
== '\t' || *Start
== ' ')
245 /* Find the end of the third entry (the filename) */
246 while ((*EntryEnd
!= '\t' && *EntryEnd
!= ' ' &&
247 *EntryEnd
!= '\n' && *EntryEnd
!= '\r')
251 Name
.append(Start
, EntryEnd
-Start
);
252 Start
= EntryEnd
; //prepare for the next round
256 indexRecords::indexRecords()
260 indexRecords::indexRecords(const string ExpectedDist
) :
261 ExpectedDist(ExpectedDist
), ValidUntil(0), SupportsAcquireByHash(false)