1 // -*- mode: cpp; mode: fold -*-
3 // $Id: hashes.h,v 1.2 2001/03/11 05:30:20 jgg Exp $
4 /* ######################################################################
6 Hashes - Simple wrapper around the hash functions
8 This is just used to make building the methods simpler, this is the
9 only interface required..
11 ##################################################################### */
13 #ifndef APTPKG_HASHES_H
14 #define APTPKG_HASHES_H
17 #include <apt-pkg/md5.h>
18 #include <apt-pkg/sha1.h>
19 #include <apt-pkg/sha2.h>
20 #include <apt-pkg/macros.h>
25 #ifndef APT_8_CLEANER_HEADERS
29 #ifndef APT_10_CLEANER_HEADERS
30 #include <apt-pkg/fileutl.h>
38 // helper class that contains hash function name
45 static const char * _SupportedHashes
[10];
48 std::string
GetHashForFile(std::string filename
) const;
51 HashString(std::string Type
, std::string Hash
);
52 HashString(std::string StringedHashString
); // init from str as "type:hash"
56 std::string
HashType() { return Type
; };
57 std::string
HashType() const { return Type
; };
58 std::string
HashValue() const { return Hash
; };
60 // verify the given filename against the currently loaded hash
61 bool VerifyFile(std::string filename
) const;
63 // generate a hash string from the given filename
64 bool FromFile(std::string filename
);
68 std::string
toStr() const; // convert to str as "type:hash"
70 bool operator==(HashString
const &other
) const;
71 bool operator!=(HashString
const &other
) const;
73 // return the list of hashes we support
74 static APT_CONST
const char** SupportedHashes();
80 /** find best hash if no specific one is requested
82 * @param type of the checksum to return, can be \b NULL
83 * @return If type is \b NULL (or the empty string) it will
84 * return the 'best' hash; otherwise the hash which was
85 * specifically requested. If no hash is found \b NULL will be returned.
87 HashString
const * find(char const * const type
) const;
88 HashString
const * find(std::string
const &type
) const { return find(type
.c_str()); }
89 /** check if the given hash type is supported
91 * @param type to check
92 * @return true if supported, otherwise false
94 static APT_PURE
bool supported(char const * const type
);
95 /** add the given #HashString to the list
97 * @param hashString to add
98 * @return true if the hash is added because it is supported and
99 * not already a different hash of the same type included, otherwise false
101 bool push_back(const HashString
&hashString
);
102 /** @return size of the list of HashStrings */
103 size_t size() const { return list
.size(); }
105 /** take the 'best' hash and verify file with it
107 * @param filename to verify
108 * @return true if the file matches the hashsum, otherwise false
110 bool VerifyFile(std::string filename
) const;
112 /** is the list empty ?
114 * @return \b true if the list is empty, otherwise \b false
116 bool empty() const { return list
.empty(); }
118 typedef std::vector
<HashString
>::const_iterator const_iterator
;
120 /** iterator to the first element */
121 const_iterator
begin() const { return list
.begin(); }
123 /** iterator to the end element */
124 const_iterator
end() const { return list
.end(); }
126 /** start fresh with a clear list */
127 void clear() { list
.clear(); }
129 /** compare two HashStringList for similarity.
131 * Two lists are similar if at least one hashtype is in both lists
132 * and the hashsum matches. All hashes are checked, if one doesn't
133 * match false is returned regardless of how many matched before.
135 bool operator==(HashStringList
const &other
) const;
136 bool operator!=(HashStringList
const &other
) const;
140 // simplifying API-compatibility constructors
141 HashStringList(std::string
const &hash
) {
142 if (hash
.empty() == false)
143 list
.push_back(HashString(hash
));
145 HashStringList(char const * const hash
) {
146 if (hash
!= NULL
&& hash
[0] != '\0')
147 list
.push_back(HashString(hash
));
151 std::vector
<HashString
> list
;
160 SHA256Summation SHA256
;
161 SHA512Summation SHA512
;
163 static const int UntilEOF
= 0;
165 inline bool Add(const unsigned char *Data
,unsigned long long Size
)
167 return MD5
.Add(Data
,Size
) && SHA1
.Add(Data
,Size
) && SHA256
.Add(Data
,Size
) && SHA512
.Add(Data
,Size
);
169 inline bool Add(const char *Data
) {return Add((unsigned char const *)Data
,strlen(Data
));};
170 inline bool AddFD(int const Fd
,unsigned long long Size
= 0)
171 { return AddFD(Fd
, Size
, true, true, true, true); };
172 bool AddFD(int const Fd
, unsigned long long Size
, bool const addMD5
,
173 bool const addSHA1
, bool const addSHA256
, bool const addSHA512
);
174 inline bool AddFD(FileFd
&Fd
,unsigned long long Size
= 0)
175 { return AddFD(Fd
, Size
, true, true, true, true); };
176 bool AddFD(FileFd
&Fd
, unsigned long long Size
, bool const addMD5
,
177 bool const addSHA1
, bool const addSHA256
, bool const addSHA512
);
178 inline bool Add(const unsigned char *Beg
,const unsigned char *End
)
179 {return Add(Beg
,End
-Beg
);};