mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-16 01:47:17 -05:00
added load/save of own file hierarchy
This commit is contained in:
parent
ff4e6f3b2c
commit
36755c4092
@ -82,11 +82,14 @@ std::string DirectoryStorage::DirIterator::name() const { const InternalFil
|
|||||||
/* Directory Storage */
|
/* Directory Storage */
|
||||||
/******************************************************************************************************************/
|
/******************************************************************************************************************/
|
||||||
|
|
||||||
DirectoryStorage::DirectoryStorage(const RsPeerId &pid)
|
DirectoryStorage::DirectoryStorage(const RsPeerId &pid,const std::string& fname)
|
||||||
: mPeerId(pid), mDirStorageMtx("Directory storage "+pid.toStdString())
|
: mPeerId(pid), mDirStorageMtx("Directory storage "+pid.toStdString()),mLastSavedTime(0),mChanged(false),mFileName(fname)
|
||||||
{
|
{
|
||||||
|
{
|
||||||
RS_STACK_MUTEX(mDirStorageMtx) ;
|
RS_STACK_MUTEX(mDirStorageMtx) ;
|
||||||
mFileHierarchy = new InternalFileHierarchyStorage();
|
mFileHierarchy = new InternalFileHierarchyStorage();
|
||||||
|
}
|
||||||
|
load(fname) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
DirectoryStorage::EntryIndex DirectoryStorage::root() const
|
DirectoryStorage::EntryIndex DirectoryStorage::root() const
|
||||||
@ -131,14 +134,14 @@ bool DirectoryStorage::updateSubDirectoryList(const EntryIndex& indx,const std::
|
|||||||
{
|
{
|
||||||
RS_STACK_MUTEX(mDirStorageMtx) ;
|
RS_STACK_MUTEX(mDirStorageMtx) ;
|
||||||
bool res = mFileHierarchy->updateSubDirectoryList(indx,subdirs,hash_salt) ;
|
bool res = mFileHierarchy->updateSubDirectoryList(indx,subdirs,hash_salt) ;
|
||||||
locked_check() ;
|
mChanged = true ;
|
||||||
return res ;
|
return res ;
|
||||||
}
|
}
|
||||||
bool DirectoryStorage::updateSubFilesList(const EntryIndex& indx,const std::map<std::string,FileTS>& subfiles,std::map<std::string,FileTS>& new_files)
|
bool DirectoryStorage::updateSubFilesList(const EntryIndex& indx,const std::map<std::string,FileTS>& subfiles,std::map<std::string,FileTS>& new_files)
|
||||||
{
|
{
|
||||||
RS_STACK_MUTEX(mDirStorageMtx) ;
|
RS_STACK_MUTEX(mDirStorageMtx) ;
|
||||||
bool res = mFileHierarchy->updateSubFilesList(indx,subfiles,new_files) ;
|
bool res = mFileHierarchy->updateSubFilesList(indx,subfiles,new_files) ;
|
||||||
locked_check() ;
|
mChanged = true ;
|
||||||
return res ;
|
return res ;
|
||||||
}
|
}
|
||||||
bool DirectoryStorage::removeDirectory(const EntryIndex& indx)
|
bool DirectoryStorage::removeDirectory(const EntryIndex& indx)
|
||||||
@ -146,7 +149,6 @@ bool DirectoryStorage::removeDirectory(const EntryIndex& indx)
|
|||||||
RS_STACK_MUTEX(mDirStorageMtx) ;
|
RS_STACK_MUTEX(mDirStorageMtx) ;
|
||||||
bool res = mFileHierarchy->removeDirectory(indx);
|
bool res = mFileHierarchy->removeDirectory(indx);
|
||||||
|
|
||||||
locked_check();
|
|
||||||
return res ;
|
return res ;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -160,11 +162,13 @@ void DirectoryStorage::locked_check()
|
|||||||
bool DirectoryStorage::updateFile(const EntryIndex& index,const RsFileHash& hash,const std::string& fname, uint64_t size,time_t modf_time)
|
bool DirectoryStorage::updateFile(const EntryIndex& index,const RsFileHash& hash,const std::string& fname, uint64_t size,time_t modf_time)
|
||||||
{
|
{
|
||||||
RS_STACK_MUTEX(mDirStorageMtx) ;
|
RS_STACK_MUTEX(mDirStorageMtx) ;
|
||||||
|
mChanged = true ;
|
||||||
return mFileHierarchy->updateFile(index,hash,fname,size,modf_time);
|
return mFileHierarchy->updateFile(index,hash,fname,size,modf_time);
|
||||||
}
|
}
|
||||||
bool DirectoryStorage::updateHash(const EntryIndex& index,const RsFileHash& hash)
|
bool DirectoryStorage::updateHash(const EntryIndex& index,const RsFileHash& hash)
|
||||||
{
|
{
|
||||||
RS_STACK_MUTEX(mDirStorageMtx) ;
|
RS_STACK_MUTEX(mDirStorageMtx) ;
|
||||||
|
mChanged = true ;
|
||||||
return mFileHierarchy->updateHash(index,hash);
|
return mFileHierarchy->updateHash(index,hash);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -177,6 +181,7 @@ void DirectoryStorage::getStatistics(SharedDirStats& stats)
|
|||||||
bool DirectoryStorage::load(const std::string& local_file_name)
|
bool DirectoryStorage::load(const std::string& local_file_name)
|
||||||
{
|
{
|
||||||
RS_STACK_MUTEX(mDirStorageMtx) ;
|
RS_STACK_MUTEX(mDirStorageMtx) ;
|
||||||
|
mChanged = false ;
|
||||||
return mFileHierarchy->load(local_file_name);
|
return mFileHierarchy->load(local_file_name);
|
||||||
}
|
}
|
||||||
void DirectoryStorage::save(const std::string& local_file_name)
|
void DirectoryStorage::save(const std::string& local_file_name)
|
||||||
@ -289,6 +294,19 @@ bool DirectoryStorage::getIndexFromDirHash(const RsFileHash& hash,EntryIndex& in
|
|||||||
return mFileHierarchy->getIndexFromDirHash(hash,index) ;
|
return mFileHierarchy->getIndexFromDirHash(hash,index) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DirectoryStorage::checkSave()
|
||||||
|
{
|
||||||
|
time_t now = time(NULL);
|
||||||
|
|
||||||
|
if(mChanged && mLastSavedTime + MIN_INTERVAL_BETWEEN_REMOTE_DIRECTORY_SAVE < now)
|
||||||
|
{
|
||||||
|
locked_check();
|
||||||
|
|
||||||
|
save(mFileName);
|
||||||
|
mLastSavedTime = now ;
|
||||||
|
mChanged = false ;
|
||||||
|
}
|
||||||
|
}
|
||||||
/******************************************************************************************************************/
|
/******************************************************************************************************************/
|
||||||
/* Local Directory Storage */
|
/* Local Directory Storage */
|
||||||
/******************************************************************************************************************/
|
/******************************************************************************************************************/
|
||||||
@ -753,15 +771,14 @@ bool LocalDirectoryStorage::serialiseDirEntry(const EntryIndex& indx,RsTlvBinary
|
|||||||
return true ;
|
return true ;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/******************************************************************************************************************/
|
/******************************************************************************************************************/
|
||||||
/* Remote Directory Storage */
|
/* Remote Directory Storage */
|
||||||
/******************************************************************************************************************/
|
/******************************************************************************************************************/
|
||||||
|
|
||||||
RemoteDirectoryStorage::RemoteDirectoryStorage(const RsPeerId& pid,const std::string& fname)
|
RemoteDirectoryStorage::RemoteDirectoryStorage(const RsPeerId& pid,const std::string& fname)
|
||||||
: DirectoryStorage(pid),mLastSavedTime(0),mChanged(false),mFileName(fname)
|
: DirectoryStorage(pid,fname)
|
||||||
{
|
{
|
||||||
load(fname) ;
|
|
||||||
|
|
||||||
mLastSweepTime = time(NULL) - (RSRandom::random_u32() % DELAY_BETWEEN_REMOTE_DIRECTORIES_SWEEP) ;
|
mLastSweepTime = time(NULL) - (RSRandom::random_u32() % DELAY_BETWEEN_REMOTE_DIRECTORIES_SWEEP) ;
|
||||||
|
|
||||||
std::cerr << "Loaded remote directory for peer " << pid << ", inited last sweep time to " << time(NULL) - mLastSweepTime << " secs ago." << std::endl;
|
std::cerr << "Loaded remote directory for peer " << pid << ", inited last sweep time to " << time(NULL) - mLastSweepTime << " secs ago." << std::endl;
|
||||||
@ -770,18 +787,6 @@ RemoteDirectoryStorage::RemoteDirectoryStorage(const RsPeerId& pid,const std::st
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void RemoteDirectoryStorage::checkSave()
|
|
||||||
{
|
|
||||||
time_t now = time(NULL);
|
|
||||||
|
|
||||||
if(mChanged && mLastSavedTime + MIN_INTERVAL_BETWEEN_REMOTE_DIRECTORY_SAVE < now)
|
|
||||||
{
|
|
||||||
save(mFileName);
|
|
||||||
mLastSavedTime = now ;
|
|
||||||
mChanged = false ;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
bool RemoteDirectoryStorage::deserialiseUpdateDirEntry(const EntryIndex& indx,const RsTlvBinaryData& bindata)
|
bool RemoteDirectoryStorage::deserialiseUpdateDirEntry(const EntryIndex& indx,const RsTlvBinaryData& bindata)
|
||||||
{
|
{
|
||||||
const unsigned char *section_data = (unsigned char*)bindata.bin_data ;
|
const unsigned char *section_data = (unsigned char*)bindata.bin_data ;
|
||||||
|
@ -41,7 +41,7 @@ class RsTlvBinaryData ;
|
|||||||
class DirectoryStorage
|
class DirectoryStorage
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
DirectoryStorage(const RsPeerId& pid) ;
|
DirectoryStorage(const RsPeerId& pid, const std::string& fname) ;
|
||||||
virtual ~DirectoryStorage() {}
|
virtual ~DirectoryStorage() {}
|
||||||
|
|
||||||
typedef uint32_t EntryIndex ;
|
typedef uint32_t EntryIndex ;
|
||||||
@ -156,6 +156,14 @@ class DirectoryStorage
|
|||||||
void print();
|
void print();
|
||||||
void cleanup();
|
void cleanup();
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief checkSave
|
||||||
|
* Checks the time of last saving, last modification time, and saves if needed.
|
||||||
|
*/
|
||||||
|
void checkSave() ;
|
||||||
|
|
||||||
|
const std::string& filename() const { return mFileName ; }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
bool load(const std::string& local_file_name) ;
|
bool load(const std::string& local_file_name) ;
|
||||||
void save(const std::string& local_file_name) ;
|
void save(const std::string& local_file_name) ;
|
||||||
@ -173,6 +181,10 @@ class DirectoryStorage
|
|||||||
mutable RsMutex mDirStorageMtx ;
|
mutable RsMutex mDirStorageMtx ;
|
||||||
|
|
||||||
InternalFileHierarchyStorage *mFileHierarchy ;
|
InternalFileHierarchyStorage *mFileHierarchy ;
|
||||||
|
|
||||||
|
time_t mLastSavedTime ;
|
||||||
|
bool mChanged ;
|
||||||
|
std::string mFileName;
|
||||||
};
|
};
|
||||||
|
|
||||||
class RemoteDirectoryStorage: public DirectoryStorage
|
class RemoteDirectoryStorage: public DirectoryStorage
|
||||||
@ -192,31 +204,20 @@ public:
|
|||||||
*/
|
*/
|
||||||
bool deserialiseUpdateDirEntry(const EntryIndex& indx,const RsTlvBinaryData& data) ;
|
bool deserialiseUpdateDirEntry(const EntryIndex& indx,const RsTlvBinaryData& data) ;
|
||||||
|
|
||||||
/*!
|
|
||||||
* \brief checkSave
|
|
||||||
* Checks the time of last saving, last modification time, and saves if needed.
|
|
||||||
*/
|
|
||||||
void checkSave() ;
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief lastSweepTime
|
* \brief lastSweepTime
|
||||||
* returns the last time a sweep has been done over the directory in order to check update TS.
|
* returns the last time a sweep has been done over the directory in order to check update TS.
|
||||||
* \return
|
* \return
|
||||||
*/
|
*/
|
||||||
time_t& lastSweepTime() { return mLastSweepTime ; }
|
time_t& lastSweepTime() { return mLastSweepTime ; }
|
||||||
|
|
||||||
const std::string& filename() const { return mFileName ; }
|
|
||||||
private:
|
private:
|
||||||
time_t mLastSavedTime ;
|
|
||||||
time_t mLastSweepTime ;
|
time_t mLastSweepTime ;
|
||||||
bool mChanged ;
|
|
||||||
std::string mFileName;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class LocalDirectoryStorage: public DirectoryStorage
|
class LocalDirectoryStorage: public DirectoryStorage
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
LocalDirectoryStorage(const std::string& fname,const RsPeerId& own_id) : DirectoryStorage(own_id),mFileName(fname) {}
|
LocalDirectoryStorage(const std::string& fname,const RsPeerId& own_id) : DirectoryStorage(own_id,fname) {}
|
||||||
virtual ~LocalDirectoryStorage() {}
|
virtual ~LocalDirectoryStorage() {}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@ -299,7 +300,6 @@ private:
|
|||||||
|
|
||||||
std::map<std::string,SharedDirInfo> mLocalDirs ; // map is better for search. it->first=it->second.filename
|
std::map<std::string,SharedDirInfo> mLocalDirs ; // map is better for search. it->first=it->second.filename
|
||||||
std::map<RsFileHash,RsFileHash> mEncryptedHashes; // map such that hash(it->second) = it->first
|
std::map<RsFileHash,RsFileHash> mEncryptedHashes; // map such that hash(it->second) = it->first
|
||||||
std::string mFileName;
|
|
||||||
|
|
||||||
bool mTSChanged ;
|
bool mTSChanged ;
|
||||||
};
|
};
|
||||||
|
@ -41,6 +41,7 @@ static const std::string WATCH_HASH_SALT_SS = "WATCH_HASH_SALT"; // Salt
|
|||||||
|
|
||||||
static const std::string FILE_SHARING_DIR_NAME = "file_sharing" ; // hard-coded directory name to store friend file lists, hash cache, etc.
|
static const std::string FILE_SHARING_DIR_NAME = "file_sharing" ; // hard-coded directory name to store friend file lists, hash cache, etc.
|
||||||
static const std::string HASH_CACHE_FILE_NAME = "hash_cache.bin" ; // hard-coded directory name to store encrypted hash cache.
|
static const std::string HASH_CACHE_FILE_NAME = "hash_cache.bin" ; // hard-coded directory name to store encrypted hash cache.
|
||||||
|
static const std::string LOCAL_SHARED_DIRS_FILE_NAME = "local_dir_hierarchy.bin" ; // hard-coded directory name to store encrypted local dir hierarchy.
|
||||||
|
|
||||||
static const uint32_t MIN_INTERVAL_BETWEEN_HASH_CACHE_SAVE = 20 ; // never save hash cache more often than every 20 secs.
|
static const uint32_t MIN_INTERVAL_BETWEEN_HASH_CACHE_SAVE = 20 ; // never save hash cache more often than every 20 secs.
|
||||||
static const uint32_t MIN_INTERVAL_BETWEEN_REMOTE_DIRECTORY_SAVE = 23 ; // never save remote directories more often than this
|
static const uint32_t MIN_INTERVAL_BETWEEN_REMOTE_DIRECTORY_SAVE = 23 ; // never save remote directories more often than this
|
||||||
|
@ -66,7 +66,7 @@ p3FileDatabase::p3FileDatabase(p3ServiceControl *mpeers)
|
|||||||
mRemoteDirectories.clear() ; // we should load them!
|
mRemoteDirectories.clear() ; // we should load them!
|
||||||
mOwnId = mpeers->getOwnId() ;
|
mOwnId = mpeers->getOwnId() ;
|
||||||
|
|
||||||
mLocalSharedDirs = new LocalDirectoryStorage("local_file_store.bin",mOwnId);
|
mLocalSharedDirs = new LocalDirectoryStorage(mFileSharingDir + "/" + LOCAL_SHARED_DIRS_FILE_NAME,mOwnId);
|
||||||
mHashCache = new HashStorage(mFileSharingDir + "/" + HASH_CACHE_FILE_NAME) ;
|
mHashCache = new HashStorage(mFileSharingDir + "/" + HASH_CACHE_FILE_NAME) ;
|
||||||
|
|
||||||
mLocalDirWatcher = new LocalDirectoryUpdater(mHashCache,mLocalSharedDirs) ;
|
mLocalDirWatcher = new LocalDirectoryUpdater(mHashCache,mLocalSharedDirs) ;
|
||||||
@ -219,6 +219,7 @@ int p3FileDatabase::tick()
|
|||||||
}
|
}
|
||||||
|
|
||||||
mLastRemoteDirSweepTS = now;
|
mLastRemoteDirSweepTS = now;
|
||||||
|
mLocalSharedDirs->checkSave() ;
|
||||||
|
|
||||||
// This is a hack to make loaded directories show up in the GUI, because the GUI generally isn't ready at the time they are actually loaded up,
|
// This is a hack to make loaded directories show up in the GUI, because the GUI generally isn't ready at the time they are actually loaded up,
|
||||||
// so the first notify is ignored, and no other notify will happen next.
|
// so the first notify is ignored, and no other notify will happen next.
|
||||||
|
Loading…
Reference in New Issue
Block a user