3 #include <apt-pkg/debmetaindex.h>
4 #include <apt-pkg/debindexfile.h>
5 #include <apt-pkg/strutl.h>
6 #include <apt-pkg/acquire-item.h>
7 #include <apt-pkg/configuration.h>
8 #include <apt-pkg/aptconfiguration.h>
9 #include <apt-pkg/error.h>
15 string
debReleaseIndex::Info(const char *Type
, string
const &Section
, string
const &Arch
) const
17 string Info
= ::URI::SiteOnly(URI
) + ' ';
18 if (Dist
[Dist
.size() - 1] == '/')
25 Info
+= Dist
+ '/' + Section
;
26 if (Arch
.empty() == true)
34 string
debReleaseIndex::MetaIndexInfo(const char *Type
) const
36 string Info
= ::URI::SiteOnly(URI
) + ' ';
37 if (Dist
[Dist
.size() - 1] == '/')
49 string
debReleaseIndex::MetaIndexFile(const char *Type
) const
51 return _config
->FindDir("Dir::State::lists") +
52 URItoFileName(MetaIndexURI(Type
));
55 string
debReleaseIndex::MetaIndexURI(const char *Type
) const
61 else if (Dist
[Dist
.size()-1] == '/')
64 Res
= URI
+ "dists/" + Dist
+ "/";
70 string
debReleaseIndex::IndexURISuffix(const char *Type
, string
const &Section
, string
const &Arch
) const
73 if (Dist
[Dist
.size() - 1] != '/')
76 Res
+= Section
+ "/binary-" + _config
->Find("APT::Architecture") + '/';
78 Res
+= Section
+ "/binary-" + Arch
+ '/';
84 string
debReleaseIndex::IndexURI(const char *Type
, string
const &Section
, string
const &Arch
) const
86 if (Dist
[Dist
.size() - 1] == '/')
96 return URI
+ "dists/" + Dist
+ '/' + IndexURISuffix(Type
, Section
, Arch
);
99 string
debReleaseIndex::SourceIndexURISuffix(const char *Type
, const string
&Section
) const
102 if (Dist
[Dist
.size() - 1] != '/')
103 Res
+= Section
+ "/source/";
107 string
debReleaseIndex::SourceIndexURI(const char *Type
, const string
&Section
) const
110 if (Dist
[Dist
.size() - 1] == '/')
119 return URI
+ "dists/" + Dist
+ "/" + SourceIndexURISuffix(Type
, Section
);
122 debReleaseIndex::debReleaseIndex(string
const &URI
, string
const &Dist
) {
125 this->Indexes
= NULL
;
129 debReleaseIndex::~debReleaseIndex() {
130 for (map
<string
, vector
<debSectionEntry
const*> >::const_iterator A
= ArchEntries
.begin();
131 A
!= ArchEntries
.end(); ++A
)
132 for (vector
<const debSectionEntry
*>::const_iterator S
= A
->second
.begin();
133 S
!= A
->second
.end(); ++S
)
137 vector
<struct IndexTarget
*>* debReleaseIndex::ComputeIndexTargets() const {
138 vector
<struct IndexTarget
*>* IndexTargets
= new vector
<IndexTarget
*>;
140 map
<string
, vector
<debSectionEntry
const*> >::const_iterator
const src
= ArchEntries
.find("source");
141 if (src
!= ArchEntries
.end()) {
142 vector
<debSectionEntry
const*> const SectionEntries
= src
->second
;
143 for (vector
<debSectionEntry
const*>::const_iterator I
= SectionEntries
.begin();
144 I
!= SectionEntries
.end(); ++I
) {
145 IndexTarget
* Target
= new IndexTarget();
146 Target
->ShortDesc
= "Sources";
147 Target
->MetaKey
= SourceIndexURISuffix(Target
->ShortDesc
.c_str(), (*I
)->Section
);
148 Target
->URI
= SourceIndexURI(Target
->ShortDesc
.c_str(), (*I
)->Section
);
149 Target
->Description
= Info (Target
->ShortDesc
.c_str(), (*I
)->Section
);
150 IndexTargets
->push_back (Target
);
154 // Only source release
155 if (IndexTargets
->empty() == false && ArchEntries
.size() == 1)
158 for (map
<string
, vector
<debSectionEntry
const*> >::const_iterator a
= ArchEntries
.begin();
159 a
!= ArchEntries
.end(); ++a
) {
160 if (a
->first
== "source")
162 for (vector
<const debSectionEntry
*>::const_iterator I
= a
->second
.begin();
163 I
!= a
->second
.end(); ++I
) {
164 IndexTarget
* Target
= new IndexTarget();
165 Target
->ShortDesc
= "Packages";
166 Target
->MetaKey
= IndexURISuffix(Target
->ShortDesc
.c_str(), (*I
)->Section
, a
->first
);
167 Target
->URI
= IndexURI(Target
->ShortDesc
.c_str(), (*I
)->Section
, a
->first
);
168 Target
->Description
= Info (Target
->ShortDesc
.c_str(), (*I
)->Section
, a
->first
);
169 IndexTargets
->push_back (Target
);
176 bool debReleaseIndex::GetIndexes(pkgAcquire
*Owner
, bool const &GetAll
) const
178 // special case for --print-uris
180 vector
<struct IndexTarget
*> *targets
= ComputeIndexTargets();
181 for (vector
<struct IndexTarget
*>::const_iterator Target
= targets
->begin(); Target
!= targets
->end(); Target
++) {
182 new pkgAcqIndex(Owner
, (*Target
)->URI
, (*Target
)->Description
,
183 (*Target
)->ShortDesc
, HashString());
185 // this is normally created in pkgAcqMetaSig, but if we run
186 // in --print-uris mode, we add it here
187 new pkgAcqMetaIndex(Owner
, MetaIndexURI("Release"),
188 MetaIndexInfo("Release"), "Release",
189 MetaIndexURI("Release.gpg"),
190 ComputeIndexTargets(),
191 new indexRecords (Dist
));
195 new pkgAcqMetaSig(Owner
, MetaIndexURI("Release.gpg"),
196 MetaIndexInfo("Release.gpg"), "Release.gpg",
197 MetaIndexURI("Release"), MetaIndexInfo("Release"), "Release",
198 ComputeIndexTargets(),
199 new indexRecords (Dist
));
201 // Queue the translations
202 std::vector
<std::string
> const lang
= APT::Configuration::getLanguages(true);
203 map
<string
, set
<string
> > sections
;
204 for (map
<string
, vector
<debSectionEntry
const*> >::const_iterator a
= ArchEntries
.begin();
205 a
!= ArchEntries
.end(); ++a
) {
206 if (a
->first
== "source")
208 for (vector
<debSectionEntry
const*>::const_iterator I
= a
->second
.begin();
209 I
!= a
->second
.end(); I
++)
210 sections
[(*I
)->Section
].insert(lang
.begin(), lang
.end());
213 for (map
<string
, set
<string
> >::const_iterator s
= sections
.begin();
214 s
!= sections
.end(); ++s
)
215 for (set
<string
>::const_iterator l
= s
->second
.begin();
216 l
!= s
->second
.end(); l
++) {
217 if (*l
== "none") continue;
218 debTranslationsIndex i
= debTranslationsIndex(URI
,Dist
,s
->first
,(*l
).c_str());
225 bool debReleaseIndex::IsTrusted() const
227 string VerifiedSigFile
= _config
->FindDir("Dir::State::lists") +
228 URItoFileName(MetaIndexURI("Release")) + ".gpg";
230 if(_config
->FindB("APT::Authentication::TrustCDROM", false))
231 if(URI
.substr(0,strlen("cdrom:")) == "cdrom:")
234 if (FileExists(VerifiedSigFile
))
239 vector
<pkgIndexFile
*> *debReleaseIndex::GetIndexFiles() {
243 Indexes
= new vector
<pkgIndexFile
*>;
244 map
<string
, vector
<debSectionEntry
const*> >::const_iterator
const src
= ArchEntries
.find("source");
245 if (src
!= ArchEntries
.end()) {
246 vector
<debSectionEntry
const*> const SectionEntries
= src
->second
;
247 for (vector
<debSectionEntry
const*>::const_iterator I
= SectionEntries
.begin();
248 I
!= SectionEntries
.end(); I
++)
249 Indexes
->push_back(new debSourcesIndex (URI
, Dist
, (*I
)->Section
, IsTrusted()));
252 // Only source release
253 if (Indexes
->empty() == false && ArchEntries
.size() == 1)
256 std::vector
<std::string
> const lang
= APT::Configuration::getLanguages(true);
257 map
<string
, set
<string
> > sections
;
258 for (map
<string
, vector
<debSectionEntry
const*> >::const_iterator a
= ArchEntries
.begin();
259 a
!= ArchEntries
.end(); ++a
) {
260 if (a
->first
== "source")
262 for (vector
<debSectionEntry
const*>::const_iterator I
= a
->second
.begin();
263 I
!= a
->second
.end(); I
++) {
264 Indexes
->push_back(new debPackagesIndex (URI
, Dist
, (*I
)->Section
, IsTrusted(), a
->first
));
265 sections
[(*I
)->Section
].insert(lang
.begin(), lang
.end());
269 for (map
<string
, set
<string
> >::const_iterator s
= sections
.begin();
270 s
!= sections
.end(); ++s
)
271 for (set
<string
>::const_iterator l
= s
->second
.begin();
272 l
!= s
->second
.end(); l
++) {
273 if (*l
== "none") continue;
274 Indexes
->push_back(new debTranslationsIndex(URI
,Dist
,s
->first
,(*l
).c_str()));
280 void debReleaseIndex::PushSectionEntry(vector
<string
> const &Archs
, const debSectionEntry
*Entry
) {
281 for (vector
<string
>::const_iterator a
= Archs
.begin();
282 a
!= Archs
.end(); ++a
)
283 ArchEntries
[*a
].push_back(new debSectionEntry(Entry
->Section
, Entry
->IsSrc
));
287 void debReleaseIndex::PushSectionEntry(string
const &Arch
, const debSectionEntry
*Entry
) {
288 ArchEntries
[Arch
].push_back(Entry
);
291 void debReleaseIndex::PushSectionEntry(const debSectionEntry
*Entry
) {
292 if (Entry
->IsSrc
== true)
293 PushSectionEntry("source", Entry
);
295 for (map
<string
, vector
<const debSectionEntry
*> >::iterator a
= ArchEntries
.begin();
296 a
!= ArchEntries
.end(); ++a
) {
297 a
->second
.push_back(Entry
);
302 debReleaseIndex::debSectionEntry::debSectionEntry (string
const &Section
,
303 bool const &IsSrc
): Section(Section
), IsSrc(IsSrc
)
306 class debSLTypeDebian
: public pkgSourceList::Type
310 bool CreateItemInternal(vector
<metaIndex
*> &List
, string
const &URI
,
311 string
const &Dist
, string
const &Section
,
312 bool const &IsSrc
, map
<string
, string
> const &Options
) const
314 map
<string
, string
>::const_iterator
const arch
= Options
.find("arch");
315 vector
<string
> const Archs
=
316 (arch
!= Options
.end()) ? VectorizeString(arch
->second
, ',') :
317 APT::Configuration::getArchitectures();
319 for (vector
<metaIndex
*>::const_iterator I
= List
.begin();
320 I
!= List
.end(); I
++)
322 // We only worry about debian entries here
323 if (strcmp((*I
)->GetType(), "deb") != 0)
326 debReleaseIndex
*Deb
= (debReleaseIndex
*) (*I
);
327 /* This check insures that there will be only one Release file
328 queued for all the Packages files and Sources files it
330 if (Deb
->GetURI() == URI
&& Deb
->GetDist() == Dist
)
333 Deb
->PushSectionEntry("source", new debReleaseIndex::debSectionEntry(Section
, IsSrc
));
335 Deb
->PushSectionEntry(Archs
, new debReleaseIndex::debSectionEntry(Section
, IsSrc
));
339 // No currently created Release file indexes this entry, so we create a new one.
340 // XXX determine whether this release is trusted or not
341 debReleaseIndex
*Deb
= new debReleaseIndex(URI
, Dist
);
343 Deb
->PushSectionEntry ("source", new debReleaseIndex::debSectionEntry(Section
, IsSrc
));
345 Deb
->PushSectionEntry (Archs
, new debReleaseIndex::debSectionEntry(Section
, IsSrc
));
351 class debSLTypeDeb
: public debSLTypeDebian
355 bool CreateItem(vector
<metaIndex
*> &List
, string
const &URI
,
356 string
const &Dist
, string
const &Section
,
357 std::map
<string
, string
> const &Options
) const
359 return CreateItemInternal(List
, URI
, Dist
, Section
, false, Options
);
365 Label
= "Standard Debian binary tree";
369 class debSLTypeDebSrc
: public debSLTypeDebian
373 bool CreateItem(vector
<metaIndex
*> &List
, string
const &URI
,
374 string
const &Dist
, string
const &Section
,
375 std::map
<string
, string
> const &Options
) const
377 return CreateItemInternal(List
, URI
, Dist
, Section
, true, Options
);
383 Label
= "Standard Debian source tree";
387 debSLTypeDeb _apt_DebType
;
388 debSLTypeDebSrc _apt_DebSrcType
;