1 // -*- mode: cpp; mode: fold -*-
3 // $Id: indexrecords.h,v 1.1.2.1 2003/12/24 23:09:17 mdz Exp $
5 #ifndef PKGLIB_INDEXRECORDS_H
6 #define PKGLIB_INDEXRECORDS_H
8 #include <apt-pkg/hashes.h>
15 #ifndef APT_8_CLEANER_HEADERS
16 #include <apt-pkg/fileutl.h>
18 #ifndef APT_10_CLEANER_HEADERS
19 #include <apt-pkg/pkgcache.h>
24 APT_HIDDEN
bool parseSumData(const char *&Start
, const char *End
, std::string
&Name
,
25 std::string
&Hash
, unsigned long long &Size
);
28 std::string ErrorText
;
31 enum APT_HIDDEN
{ ALWAYS_TRUSTED
, NEVER_TRUSTED
, CHECK_TRUST
} Trusted
;
32 // dpointer (for later)
38 std::string ExpectedDist
;
40 bool SupportsAcquireByHash
;
42 std::map
<std::string
,checkSum
*> Entries
;
46 indexRecords(const std::string
&ExpectedDist
= "");
49 virtual checkSum
*Lookup(const std::string MetaKey
);
50 /** \brief tests if a checksum for this file is available */
51 bool Exists(std::string
const &MetaKey
) const;
52 std::vector
<std::string
> MetaKeys();
54 virtual bool Load(std::string Filename
);
55 virtual bool CheckDist(const std::string MaybeDist
) const;
57 std::string
GetDist() const;
58 std::string
GetSuite() const;
59 bool GetSupportsAcquireByHash() const;
60 time_t GetValidUntil() const;
61 std::string
GetExpectedDist() const;
63 /** \brief check if source is marked as always trusted */
64 bool IsAlwaysTrusted() const;
65 /** \brief check if source is marked as never trusted */
66 bool IsNeverTrusted() const;
68 /** \brief sets an explicit trust value
70 * \b true means that the source should always be considered trusted,
71 * while \b false marks a source as always untrusted, even if we have
72 * a valid signature and everything.
74 void SetTrusted(bool const Trusted
);
76 virtual ~indexRecords();
79 APT_IGNORE_DEPRECATED_PUSH
80 struct indexRecords::checkSum
82 std::string MetaKeyFilename
;
83 HashStringList Hashes
;
84 unsigned long long Size
;
86 APT_DEPRECATED HashString Hash
;
88 APT_IGNORE_DEPRECATED_POP