2 // This file is part of the aMule Project.
4 // Copyright (c) 2003-2008 aMule Team ( admin@amule.org / http://www.amule.org )
5 // Copyright (c) 2002-2008 Merkur ( devs@emule-project.net / http://www.emule-project.net )
7 // Any parts of this program derived from the xMule, lMule or eMule project,
8 // or contributed by third-party developers are copyrighted by their
11 // This program is free software; you can redistribute it and/or modify
12 // it under the terms of the GNU General Public License as published by
13 // the Free Software Foundation; either version 2 of the License, or
14 // (at your option) any later version.
16 // This program is distributed in the hope that it will be useful,
17 // but WITHOUT ANY WARRANTY; without even the implied warranty of
18 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 // GNU General Public License for more details.
21 // You should have received a copy of the GNU General Public License
22 // along with this program; if not, write to the Free Software
23 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
32 #include "SHAHashSet.h"
34 #include <protocol/ed2k/Constants.h>
35 #include <common/Path.h>
37 #include "kademlia/kademlia/Indexed.h"
41 #include <ec/cpp/ECSpecialTags.h>
47 #define PS_WAITINGFORHASH 2
50 #define PS_INSUFFICIENT 5
53 #define PS_COMPLETING 8
55 #define PS_ALLOCATING 10
58 #define PR_VERYLOW 4 // I Had to change this because
59 // it didn't save negative number
60 // correctly.. Had to modify the
61 // sort function for this change..
63 #define PR_NORMAL 1 // Don't change this - needed for
64 // edonkey clients and server!
68 #define PR_POWERSHARE 6 //added for powershare (deltaHF)
83 typedef vector
<CMD4Hash
> ArrayOfCMD4Hash
;
86 typedef vector
<CTag
> ArrayOfCTag
;
91 friend class CKnownFile
;
92 friend class CSharedFilesRem
;
98 void AddTransferred(uint64 bytes
);
99 uint16
GetRequests() const {return requested
;}
100 uint16
GetAccepts() const {return accepted
;}
101 uint64
GetTransferred() const {return transferred
;}
102 uint32
GetAllTimeRequests() const {return alltimerequested
;}
103 void SetAllTimeRequests(uint32 new_value
) { alltimerequested
= new_value
; };
104 uint32
GetAllTimeAccepts() const {return alltimeaccepted
;}
105 void SetAllTimeAccepts(uint32 new_value
) { alltimeaccepted
= new_value
; };
106 uint64
GetAllTimeTransferred() const {return alltimetransferred
;}
107 void SetAllTimeTransferred(uint64 new_value
) { alltimetransferred
= new_value
; };
108 CKnownFile
* fileParent
;
114 uint32 alltimerequested
;
115 uint64 alltimetransferred
;
116 uint32 alltimeaccepted
;
132 explicit CAbstractFile(const CAbstractFile
& other
);
133 virtual ~CAbstractFile() {}
135 const CPath
& GetFileName() const { return m_fileName
; }
136 const CMD4Hash
& GetFileHash() const { return m_abyFileHash
; }
138 uint64
GetFileSize() const { return m_nFileSize
;}
139 bool IsLargeFile() const { return m_nFileSize
> (uint64
)OLD_MAX_FILE_SIZE
; }
141 virtual void SetFileSize(uint64 nFileSize
) { m_nFileSize
= nFileSize
; }
142 virtual void SetFileName(const CPath
& filename
);
144 /* Tags and Notes handling */
145 uint32
GetIntTagValue(uint8 tagname
) const;
146 uint32
GetIntTagValue(const wxString
& tagname
) const;
147 bool GetIntTagValue(uint8 tagname
, uint32
& ruValue
) const;
148 void SetIntTagValue(uint8 tagname
, uint32 ruValue
) const;
149 const wxString
& GetStrTagValue(uint8 tagname
) const;
150 const wxString
& GetStrTagValue(const wxString
& tagname
) const;
151 const CTag
*GetTag(const wxString
& tagname
) const;
152 const CTag
*GetTag(const wxString
& tagname
, uint8 tagtype
) const;
153 const CTag
*GetTag(uint8 tagname
) const;
154 const CTag
*GetTag(uint8 tagname
, uint8 tagtype
) const;
155 void AddTagUnique(const CTag
&pTag
);
156 const ArrayOfCTag
& GetTags() const { return m_taglist
; }
157 void AddNote(Kademlia::CEntry
* pEntry
);
158 const CKadEntryPtrList
& getNotes() const { return m_kadNotes
; }
160 /* Comment and rating */
161 virtual const wxString
& GetFileComment() const { return m_strComment
; }
162 virtual int8
GetFileRating() const { return m_iRating
; }
164 bool HasComment() const { return m_hasComment
; }
165 bool HasRating() const { return (m_iUserRating
!= 0); }
166 int8
UserRating() const { return m_iUserRating
; }
167 void UpdateFileRatingCommentAvail();
170 //! CAbstractFile is not assignable.
171 CAbstractFile
& operator=(const CAbstractFile
);
173 CMD4Hash m_abyFileHash
;
174 wxString m_strComment
;
178 ArrayOfCTag m_taglist
;
179 CKadEntryPtrList m_kadNotes
;
191 class CKnownFile
: public CAbstractFile
193 friend class CHashingTask
;
196 explicit CKnownFile(const CSearchFile
&searchFile
);
198 virtual ~CKnownFile();
200 void SetFilePath(const CPath
& filePath
);
201 const CPath
& GetFilePath() const { return m_filePath
; }
203 virtual bool IsPartFile() const {return false;}
204 virtual bool LoadFromFile(const CFileDataIO
* file
); //load date, hashset and tags from a .met file
205 virtual uint8
GetStatus(bool WXUNUSED(ignorepause
) = false) const { return PS_COMPLETE
; }
206 bool WriteToFile(CFileDataIO
* file
);
207 time_t GetLastChangeDatetime() const { return m_lastDateChanged
; }
209 virtual void SetFileSize(uint64 nFileSize
);
211 // local available part hashs
212 size_t GetHashCount() const {return m_hashlist
.size();}
213 const CMD4Hash
& GetPartHash(uint16 part
) const;
215 // nr. of part hashs according the file size wrt ED2K protocol
216 uint32
GetED2KPartHashCount() const { return m_iED2KPartHashCount
; }
218 // nr. of 9MB parts (file data)
219 inline uint16
GetPartCount() const { return m_iPartCount
; }
221 // nr. of 9MB parts according the file size wrt ED2K protocol (OP_FILESTATUS)
222 inline uint16
GetED2KPartCount() const { return m_iED2KPartCount
; }
224 // size of a certain part, last is different, all others are PARTSIZE
225 uint32
GetPartSize(uint16 part
) const { return part
== m_iPartCount
- 1 ? m_sizeLastPart
: PARTSIZE
; }
227 // file upload priority
228 uint8
GetUpPriority() const {return m_iUpPriority
;}
229 void SetUpPriority(uint8 newUpPriority
, bool bSave
=true);
230 bool IsAutoUpPriority() const {return m_bAutoUpPriority
;}
231 void SetAutoUpPriority(bool flag
) {m_bAutoUpPriority
= flag
;}
232 void UpdateAutoUpPriority();
233 size_t GetQueuedCount() const {return m_ClientUploadList
.size();}
235 bool LoadHashsetFromFile(const CFileDataIO
* file
, bool checkhash
);
236 void AddUploadingClient(CUpDownClient
* client
);
237 void RemoveUploadingClient(CUpDownClient
* client
);
240 const wxString
& GetFileComment() { if (!m_bCommentLoaded
) LoadComment(); return m_strComment
; }
241 int8
GetFileRating() { if (!m_bCommentLoaded
) LoadComment(); return m_iRating
; }
243 void SetFileComment(const wxString
& strNewComment
);
244 void SetFileRating(int8 iNewRating
);
245 void SetPublishedED2K( bool val
);
246 bool GetPublishedED2K() const {return m_PublishedED2K
;}
249 uint32
GetKadFileSearchID() const { return kadFileSearchID
; }
250 // KAD TODO: This must be used on KadSearchListCtrl too once imported
251 void SetKadFileSearchID(uint32 id
) { kadFileSearchID
= id
; } // John - Don't use this unless you know what your are DOING!! (Hopefully I do.. :)
252 const Kademlia::WordList
& GetKadKeywords() const { return wordlist
; }
253 // KAD TODO: If we add the proper column to SharedFilesCtrl, this is the funtion.
254 uint32
GetLastPublishTimeKadSrc() const { return m_lastPublishTimeKadSrc
; }
255 void SetLastPublishTimeKadSrc(uint32 time
, uint32 buddyip
) { m_lastPublishTimeKadSrc
= time
; m_lastBuddyIP
= buddyip
;}
256 // Another unused function, useful for the shared files control column
257 uint32
GetLastPublishBuddy() const { return m_lastBuddyIP
; }
258 void SetLastPublishTimeKadNotes(uint32 time
) {m_lastPublishTimeKadNotes
= time
;}
259 uint32
GetLastPublishTimeKadNotes() const { return m_lastPublishTimeKadNotes
; }
264 // TODO: This must be implemented if we ever want to have metadata.
265 uint32
GetMetaDataVer() const { return /*m_uMetaDataVer*/ 0; }
268 virtual CPacket
* CreateSrcInfoPacket(const CUpDownClient
* forClient
, uint8 byRequestedVersion
, uint16 nRequestedOptions
);
270 virtual void UpdatePartsInfo();
273 CFileStatistic statistic
;
275 time_t m_nCompleteSourcesTime
;
276 uint16 m_nCompleteSourcesCount
;
277 uint16 m_nCompleteSourcesCountLo
;
278 uint16 m_nCompleteSourcesCountHi
;
280 // Maybe find a common place for this typedef?
281 typedef std::set
<CUpDownClient
*> SourceSet
;
282 SourceSet m_ClientUploadList
;
283 ArrayOfUInts16 m_AvailPartFrequency
;
286 * Returns a base-16 encoding of the master hash, or
287 * an empty string if no such hash exists.
289 wxString
GetAICHMasterHash() const;
290 /** Returns true if the AICH-Hashset is valid, and verified or complete. */
291 bool HasProperAICHHashSet() const;
294 * Updates the requency of uploading parts from with the data the client provides.
296 * @param client The clients whoose uploading parts should be considered.
297 * @param increment If true, the counts are incremented, otherwise they are decremented.
299 * This functions updates the frequency list of file-upparts, using the clients
300 * upparts-status. This function should be called by clients every time they update their
301 * upparts-status, or when they are added or removed from the file.
303 void UpdateUpPartsFrequency( CUpDownClient
* client
, bool increment
);
305 static void CreateHashFromHashlist(const ArrayOfCMD4Hash
& hashes
, CMD4Hash
* Output
);
307 void ClearPriority();
309 time_t m_lastDateChanged
;
311 virtual wxString
GetFeedback() const;
315 CKnownFile(CEC_SharedFile_Tag
*);
316 friend class CSharedFilesRem
;
319 //! The AICH master-hash, if it is known.
320 wxString m_AICHMasterHash
;
322 virtual void SetFileName(const CPath
& filename
);
325 CAICHHashSet
* GetAICHHashset() const { return m_pAICHHashSet
; }
326 void SetAICHHashset(CAICHHashSet
* val
) { m_pAICHHashSet
= val
; }
329 CAICHHashSet
* m_pAICHHashSet
;
332 bool LoadTagsFromFile(const CFileDataIO
* file
);
333 bool LoadDateFromFile(const CFileDataIO
* file
);
334 void LoadComment();//comment
335 ArrayOfCMD4Hash m_hashlist
;
338 static void CreateHashFromFile(CFile
& file
, uint32 Length
, CMD4Hash
* Output
, CAICHHashTree
* pShaHashOut
);
339 static void CreateHashFromInput(const byte
* input
, uint32 Length
, CMD4Hash
* Output
, CAICHHashTree
* pShaHashOut
);
341 bool m_bCommentLoaded
;
343 uint16 m_iED2KPartCount
;
344 uint16 m_iED2KPartHashCount
;
345 uint32 m_sizeLastPart
; // size of the last part
347 bool m_bAutoUpPriority
;
348 bool m_PublishedED2K
;
351 Kademlia::WordList wordlist
;
352 uint32 kadFileSearchID
;
353 uint32 m_lastPublishTimeKadSrc
;
354 uint32 m_lastPublishTimeKadNotes
;
355 uint32 m_lastBuddyIP
;
358 /** Common initializations for constructors. */
362 #endif // KNOWNFILE_H
363 // File_checked_for_headers