// // This file is part of the aMule Project. // // Copyright (c) 2003-2011 aMule Team ( admin@amule.org / http://www.amule.org ) // Copyright (c) 2002-2011 Merkur ( devs@emule-project.net / http://www.emule-project.net ) // // Any parts of this program derived from the xMule, lMule or eMule project, // or contributed by third-party developers are copyrighted by their // respective authors. // // This program is free software; you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation; either version 2 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program; if not, write to the Free Software // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // #ifndef SHAREDFILELIST_H #define SHAREDFILELIST_H #include #include #include // Needed for wxMutex #include "Types.h" // Needed for uint16 and uint64 struct UnknownFile_Struct; class CKnownFileList; class CKnownFile; class CMemFile; class CMD4Hash; class CServer; class CPublishKeywordList; class CPath; class CAICHHash; class CThreadTask; typedef std::map CKnownFileMap; typedef std::map StringPathMap; typedef std::list PathList; class CSharedFileList { public: CSharedFileList(CKnownFileList* in_filelist); ~CSharedFileList(); void Reload(); void SafeAddKFile(CKnownFile* toadd, bool bOnlyAdd = false); void RemoveFile(CKnownFile* toremove); CKnownFile* GetFileByID(const CMD4Hash& filehash); short GetFilePriorityByID(const CMD4Hash& filehash); const CKnownFile* GetFileByIndex(unsigned int index) const; size_t GetCount() { wxMutexLocker lock(list_mut); return m_Files_map.size(); } size_t GetFileCount() { wxMutexLocker lock(list_mut); return m_Files_map.size(); } void CopyFileList(std::vector& out_list) const; void UpdateItem(CKnownFile* toupdate); void GetSharedFilesByDirectory(const wxString& directory, CKnownFilePtrList& list); void ClearED2KPublishInfo(); void RepublishFile(CKnownFile* pFile); void Process(); void PublishNextTurn() { m_lastPublishED2KFlag = true; } bool RenameFile(CKnownFile* pFile, const CPath& newName); /** * Returns the name of a folder visible to the public. * * @param dir The full path to a shared directory. * @return The name of the shared directory that will be visible to the public. * * This function is used to hide sensitive data considering the directory structure of the client. * The returned public name consists of only subdirectories that are shared. * Example: /ed2k/shared/games/tetris -> "games/tetris" if /ed2k/shared are not marked as shared */ wxString GetPublicSharedDirName(const CPath& dir); const CPath* GetDirForPublicSharedDirName(const wxString& strSharedDir) const; /** * Returns true, if the specified path points to a shared directory or single shared file. */ bool IsShared(const CPath& path) const; /* Kad Stuff */ void Publish(); void AddKeywords(CKnownFile* pFile); void RemoveKeywords(CKnownFile* pFile); // This is actually unused, but keep it here - will be needed later. void ClearKadSourcePublishInfo(); /** * Checks for files which missing or wrong AICH hashes. * Those that are found are scheduled for ACIH hashing. */ void CheckAICHHashes(const std::list& hashes); private: typedef std::list TaskList; bool AddFile(CKnownFile* pFile); unsigned AddFilesFromDirectory(const CPath& directory, TaskList & hashTasks); void FindSharedFiles(); bool reloading; void SendListToServer(); uint32 m_lastPublishED2K; bool m_lastPublishED2KFlag; CKnownFileList* filelist; CKnownFileMap m_Files_map; mutable wxMutex list_mut; StringPathMap m_PublicSharedDirNames; //! used for mapping strings to shared directories /* Kad Stuff */ CPublishKeywordList* m_keywords; unsigned int m_currFileSrc; unsigned int m_currFileNotes; unsigned int m_currFileKey; uint32 m_lastPublishKadSrc; uint32 m_lastPublishKadNotes; }; #endif // SHAREDFILELIST_H // File_checked_for_headers