Change policy about how we handle generated files
[amule.git] / src / KnownFile.h
blob0ef75596d07583390d6d70f1519c2c7cd5182617
1 //
2 // This file is part of the aMule Project.
3 //
4 // Copyright (c) 2003-2011 aMule Team ( admin@amule.org / http://www.amule.org )
5 // Copyright (c) 2002-2011 Merkur ( devs@emule-project.net / http://www.emule-project.net )
6 //
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
9 // respective authors.
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
27 #ifndef KNOWNFILE_H
28 #define KNOWNFILE_H
31 #include "MD4Hash.h"
32 #include "SHAHashSet.h"
34 #include <protocol/ed2k/Constants.h>
35 #include <common/Path.h>
37 #include "kademlia/kademlia/Indexed.h"
38 #include <ec/cpp/ECID.h> // Needed for CECID
41 #ifdef CLIENT_GUI
42 #include <ec/cpp/ECSpecialTags.h>
43 #include "RLE.h" // Needed for RLE_Data, PartFileEncoderData
44 #endif
46 #include "Constants.h" // Needed for PS_*, PR_*
47 #include "ClientRef.h" // Needed for CClientRef
49 class CFileDataIO;
50 class CPacket;
51 class CTag;
54 namespace Kademlia
56 class CEntry;
60 typedef vector<CMD4Hash> ArrayOfCMD4Hash;
63 typedef vector<CTag> ArrayOfCTag;
66 class CFileStatistic
68 friend class CKnownFilesRem;
69 public:
70 CFileStatistic(CKnownFile *parent);
71 void AddRequest();
72 void AddAccepted();
73 void AddTransferred(uint64 bytes);
74 uint16 GetRequests() const {return requested;}
75 uint16 GetAccepts() const {return accepted;}
76 uint64 GetTransferred() const {return transferred;}
77 uint32 GetAllTimeRequests() const {return alltimerequested;}
78 void SetAllTimeRequests(uint32 new_value) { alltimerequested = new_value; };
79 uint32 GetAllTimeAccepts() const {return alltimeaccepted;}
80 void SetAllTimeAccepts(uint32 new_value) { alltimeaccepted = new_value; };
81 uint64 GetAllTimeTransferred() const {return alltimetransferred;}
82 void SetAllTimeTransferred(uint64 new_value) { alltimetransferred = new_value; };
84 private:
85 CKnownFile* fileParent;
86 uint16 requested;
87 uint64 transferred;
88 uint16 accepted;
89 uint32 alltimerequested;
90 uint64 alltimetransferred;
91 uint32 alltimeaccepted;
95 CPartFile
97 CKnownFile
99 CAbstractFile
101 CSearchFile
103 class CAbstractFile
105 public:
106 CAbstractFile();
107 explicit CAbstractFile(const CAbstractFile& other);
108 virtual ~CAbstractFile() {}
110 const CPath& GetFileName() const { return m_fileName; }
111 const CMD4Hash& GetFileHash() const { return m_abyFileHash; }
113 uint64 GetFileSize() const { return m_nFileSize;}
114 bool IsLargeFile() const { return m_nFileSize > (uint64)OLD_MAX_FILE_SIZE; }
116 virtual void SetFileSize(uint64 nFileSize) { m_nFileSize = nFileSize; }
117 virtual void SetFileName(const CPath& filename);
119 /* Tags and Notes handling */
120 uint32 GetIntTagValue(uint8 tagname) const;
121 uint32 GetIntTagValue(const wxString& tagname) const;
122 bool GetIntTagValue(uint8 tagname, uint32& ruValue) const;
123 const wxString& GetStrTagValue(uint8 tagname) const;
124 const wxString& GetStrTagValue(const wxString& tagname) const;
125 const CTag *GetTag(const wxString& tagname) const;
126 const CTag *GetTag(const wxString& tagname, uint8 tagtype) const;
127 const CTag *GetTag(uint8 tagname) const;
128 const CTag *GetTag(uint8 tagname, uint8 tagtype) const;
129 void AddTagUnique(const CTag &pTag);
130 const ArrayOfCTag& GetTags() const { return m_taglist; }
131 void AddNote(Kademlia::CEntry* pEntry);
132 const CKadEntryPtrList& getNotes() const { return m_kadNotes; }
134 /* Comment and rating */
135 virtual const wxString& GetFileComment() const { return m_strComment; }
136 virtual int8 GetFileRating() const { return m_iRating; }
138 bool HasComment() const { return m_hasComment; }
139 bool HasRating() const { return (m_iUserRating != 0); }
140 int8 UserRating() const { return m_iUserRating; }
142 protected:
143 //! CAbstractFile is not assignable.
144 CAbstractFile& operator=(const CAbstractFile);
146 CMD4Hash m_abyFileHash;
147 // comment/rating are read from the config and cached in these variables,
148 // so make them mutable to allow GetFileComment() to be a const method
149 mutable wxString m_strComment;
150 mutable int8 m_iRating;
151 bool m_hasComment;
152 int8 m_iUserRating;
153 ArrayOfCTag m_taglist;
154 CKadEntryPtrList m_kadNotes;
156 private:
157 uint64 m_nFileSize;
158 CPath m_fileName;
162 class CSearchFile;
163 class CFile;
166 class CKnownFile : public CAbstractFile, public CECID
168 friend class CHashingTask;
169 public:
170 CKnownFile();
171 CKnownFile(uint32 ecid);
172 explicit CKnownFile(const CSearchFile &searchFile);
174 virtual ~CKnownFile();
176 void SetFilePath(const CPath& filePath);
177 const CPath& GetFilePath() const { return m_filePath; }
179 // virtual functions for CKnownFile and CPartFile:
180 virtual bool IsPartFile() const {return false;} // true if not completed
181 virtual bool IsCompleted() const { return true; } // true if completed
182 virtual bool IsCPartFile() const { return false; } // true if it's a CPartFile
184 virtual bool LoadFromFile(const CFileDataIO* file); //load date, hashset and tags from a .met file
185 virtual uint8 GetStatus(bool WXUNUSED(ignorepause) = false) const { return PS_COMPLETE; }
186 bool WriteToFile(CFileDataIO* file);
187 time_t GetLastChangeDatetime() const { return m_lastDateChanged; }
188 void SetLastChangeDatetime(time_t t) { m_lastDateChanged = t; }
190 virtual void SetFileSize(uint64 nFileSize);
192 // local available part hashs
193 size_t GetHashCount() const {return m_hashlist.size();}
194 const CMD4Hash& GetPartHash(uint16 part) const;
196 // nr. of part hashs according the file size wrt ED2K protocol
197 uint32 GetED2KPartHashCount() const { return m_iED2KPartHashCount; }
199 // nr. of 9MB parts (file data)
200 inline uint16 GetPartCount() const { return m_iPartCount; }
202 // nr. of 9MB parts according the file size wrt ED2K protocol (OP_FILESTATUS)
203 inline uint16 GetED2KPartCount() const { return m_iED2KPartCount; }
205 // size of a certain part, last is different, all others are PARTSIZE
206 uint32 GetPartSize(uint16 part) const { return part == m_iPartCount - 1 ? m_sizeLastPart : PARTSIZE; }
208 // file upload priority
209 uint8 GetUpPriority() const {return m_iUpPriority;}
210 void SetUpPriority(uint8 newUpPriority, bool bSave=true);
211 bool IsAutoUpPriority() const {return m_bAutoUpPriority;}
212 void SetAutoUpPriority(bool flag) {m_bAutoUpPriority = flag;}
213 void UpdateAutoUpPriority();
214 #ifdef CLIENT_GUI
215 uint16 GetQueuedCount() const { return m_queuedCount; }
216 #else
217 uint16 GetQueuedCount() const { return (uint16) m_ClientUploadList.size(); }
218 #endif
220 bool LoadHashsetFromFile(const CFileDataIO* file, bool checkhash);
221 void AddUploadingClient(CUpDownClient* client);
222 void RemoveUploadingClient(CUpDownClient* client);
224 // comment
225 const wxString& GetFileComment() const { if (!m_bCommentLoaded) LoadComment(); return m_strComment; }
226 int8 GetFileRating() const { if (!m_bCommentLoaded) LoadComment(); return m_iRating; }
228 void SetFileCommentRating(const wxString& strNewComment, int8 iNewRating);
229 void SetPublishedED2K( bool val );
230 bool GetPublishedED2K() const {return m_PublishedED2K;}
232 /* Kad stuff */
233 uint32 GetKadFileSearchID() const { return kadFileSearchID; }
234 // KAD TODO: This must be used on KadSearchListCtrl too once imported
235 void SetKadFileSearchID(uint32 id) { kadFileSearchID = id; } // John - Don't use this unless you know what your are DOING!! (Hopefully I do.. :)
236 const Kademlia::WordList& GetKadKeywords() const { return wordlist; }
237 // KAD TODO: If we add the proper column to SharedFilesCtrl, this is the funtion.
238 uint32 GetLastPublishTimeKadSrc() const { return m_lastPublishTimeKadSrc; }
239 void SetLastPublishTimeKadSrc(uint32 time, uint32 buddyip) { m_lastPublishTimeKadSrc = time; m_lastBuddyIP = buddyip;}
240 // Another unused function, useful for the shared files control column
241 uint32 GetLastPublishBuddy() const { return m_lastBuddyIP; }
242 void SetLastPublishTimeKadNotes(uint32 time) {m_lastPublishTimeKadNotes = time;}
243 uint32 GetLastPublishTimeKadNotes() const { return m_lastPublishTimeKadNotes; }
245 bool PublishSrc();
246 bool PublishNotes();
248 // TODO: This must be implemented if we ever want to have metadata.
249 uint32 GetMetaDataVer() const { return /*m_uMetaDataVer*/ 0; }
251 // file sharing
252 virtual CPacket* CreateSrcInfoPacket(const CUpDownClient* forClient, uint8 byRequestedVersion, uint16 nRequestedOptions);
253 void CreateOfferedFilePacket(CMemFile* files, class CServer* pServer, CUpDownClient* pClient);
255 virtual void UpdatePartsInfo();
258 CFileStatistic statistic;
260 time_t m_nCompleteSourcesTime;
261 uint16 m_nCompleteSourcesCount;
262 uint16 m_nCompleteSourcesCountLo;
263 uint16 m_nCompleteSourcesCountHi;
265 // Common for part and known files.
266 typedef std::set<CClientRef> SourceSet;
267 SourceSet m_ClientUploadList;
268 ArrayOfUInts16 m_AvailPartFrequency;
271 * Returns a base-16 encoding of the master hash, or
272 * an empty string if no such hash exists.
274 wxString GetAICHMasterHash() const;
275 /** Returns true if the AICH-Hashset is valid, and verified or complete. */
276 bool HasProperAICHHashSet() const;
279 * Updates the requency of uploading parts from with the data the client provides.
281 * @param client The clients whoose uploading parts should be considered.
282 * @param increment If true, the counts are incremented, otherwise they are decremented.
284 * This functions updates the frequency list of file-upparts, using the clients
285 * upparts-status. This function should be called by clients every time they update their
286 * upparts-status, or when they are added or removed from the file.
288 void UpdateUpPartsFrequency( CUpDownClient* client, bool increment );
290 static void CreateHashFromHashlist(const ArrayOfCMD4Hash& hashes, CMD4Hash* Output);
292 void ClearPriority();
294 time_t m_lastDateChanged;
296 virtual wxString GetFeedback() const;
298 void SetShowSources( bool val ) { m_showSources = val; }
299 bool ShowSources() const { return m_showSources; }
300 void SetShowPeers( bool val ) { m_showPeers = val; }
301 bool ShowPeers() const { return m_showPeers; }
303 virtual void SetHashingProgress(uint16) const {} // does something for CPartFile only
304 uint16 GetHashingProgress() const { return m_hashingProgress; }
306 #ifdef CLIENT_GUI
307 CKnownFile(const CEC_SharedFile_Tag *);
308 friend class CKnownFilesRem;
309 RLE_Data m_partStatus;
311 private:
312 uint8 m_iUpPriorityEC;
313 uint16 m_queuedCount;
315 protected:
316 //! The AICH master-hash, if it is known.
317 wxString m_AICHMasterHash;
318 #else
319 virtual void SetFileName(const CPath& filename);
321 // AICH
322 CAICHHashSet* GetAICHHashset() const { return m_pAICHHashSet; }
323 void SetAICHHashset(CAICHHashSet* val) { m_pAICHHashSet = val; }
325 protected:
326 CAICHHashSet* m_pAICHHashSet;
327 #endif
329 bool LoadTagsFromFile(const CFileDataIO* file);
330 bool LoadDateFromFile(const CFileDataIO* file);
331 void LoadComment() const;
332 ArrayOfCMD4Hash m_hashlist;
333 CPath m_filePath;
335 static void CreateHashFromFile(class CFileAutoClose& file, uint64 offset, uint32 Length, CMD4Hash* Output, CAICHHashTree* pShaHashOut);
336 static void CreateHashFromInput(const byte* input, uint32 Length, CMD4Hash* Output, CAICHHashTree* pShaHashOut);
338 mutable bool m_bCommentLoaded;
339 uint16 m_iPartCount;
340 uint16 m_iED2KPartCount;
341 uint16 m_iED2KPartHashCount;
342 uint32 m_sizeLastPart; // size of the last part
343 uint8 m_iUpPriority;
344 bool m_bAutoUpPriority;
345 bool m_PublishedED2K;
346 // Index of part being hashed, 0: no hashing in progress.
347 // The known file is const in the hashing thread, so rather drill this little hole by making it mutable
348 // than opening it all up.
349 mutable uint16 m_hashingProgress;
351 /* Kad stuff */
352 Kademlia::WordList wordlist;
353 uint32 kadFileSearchID;
354 uint32 m_lastPublishTimeKadSrc;
355 uint32 m_lastPublishTimeKadNotes;
356 uint32 m_lastBuddyIP;
358 bool m_showSources;
359 bool m_showPeers;
360 private:
361 /** Common initializations for constructors. */
362 void Init();
365 #endif // KNOWNFILE_H
366 // File_checked_for_headers