/* * Copyright (C) by Klaas Freitag * * 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. */ #ifndef FOLDERMAN_H #define FOLDERMAN_H #include #include #include #include #include "mirall/folder.h" #include "mirall/folderwatcher.h" #include "mirall/syncfileitem.h" class QSignalMapper; namespace Mirall { class Application; class SyncResult; class SocketApi; class FolderMan : public QObject { Q_OBJECT public: static FolderMan* instance(); int setupFolders(); Mirall::Folder::Map map(); /** * Add a folder definition to the config * Params: * QString alias * QString sourceFolder on local machine * QString targetPath on remote */ void addFolderDefinition(const QString&, const QString&, const QString& , const QStringList &selectiveSyncBlacklist = QStringList() ); /** Returns the folder which the file or directory stored in path is in */ Folder* folderForPath(const QString& path); /** Returns the folder by alias or NULL if no folder with the alias exists. */ Folder *folder( const QString& ); /** Returns the last sync result by alias */ SyncResult syncResult( const QString& ); /** Creates a folder for a specific configuration, identified by alias. */ Folder* setupFolderFromConfigFile(const QString & ); /** Wipes all folder defintions. No way back! */ void removeAllFolderDefinitions(); /** * Ensures that a given directory does not contain a .csync_journal. * * @returns false if the journal could not be removed, true otherwise. */ static bool ensureJournalGone(const QString &path); /** Creates a new and empty local directory. */ bool startFromScratch( const QString& ); QString statusToString(SyncResult, bool paused ) const; static SyncResult accountStatus( const QList &folders ); void removeMonitorPath( const QString& alias, const QString& path ); void addMonitorPath( const QString& alias, const QString& path ); // Escaping of the alias which is used in QSettings AND the file // system, thus need to be escaped. static QString escapeAlias( const QString& ); signals: /** * signal to indicate a folder named by alias has changed its sync state. * Get the state via the Folder Map or the syncResult and syncState methods. * * Attention: The alias string may be zero. Do a general update of the state than. */ void folderSyncStateChange( const QString & ); void folderListLoaded(const Folder::Map &); public slots: void slotRemoveFolder( const QString& ); void slotSetFolderPaused(const QString&, bool paused); void slotFolderSyncStarted(); void slotFolderSyncFinished( const SyncResult& ); /** * Terminates the current folder sync. * * It does not switch the folder to paused state. */ void terminateSyncProcess(); /* unload and delete on folder object */ void unloadFolder( const QString& alias ); /* delete all folder objects */ int unloadAllFolders(); // if enabled is set to false, no new folders will start to sync. // the current one will finish. void setSyncEnabled( bool ); void slotScheduleAllFolders(); void setDirtyProxy(bool value = true); void setDirtyNetworkLimits(); // slot to add a folder to the syncing queue void slotScheduleSync( const QString & ); // slot to scheule an ETag job void slotScheduleETagJob ( const QString &alias, RequestEtagJob *job); void slotEtagJobDestroyed (QObject*); void slotRunOneEtagJob(); private slots: // slot to take the next folder from queue and start syncing. void slotStartScheduledFolderSync(); void slotEtagPollTimerTimeout(); private: // finds all folder configuration files // and create the folders QString getBackupName( QString fullPathName ) const; void registerFolderMonitor( Folder *folder ); QString unescapeAlias( const QString& ) const; void removeFolder( const QString& ); QSet _disabledFolders; Folder::Map _folderMap; QString _folderConfigPath; QSignalMapper *_folderChangeSignalMapper; QSignalMapper *_folderWatcherSignalMapper; QString _currentSyncFolder; bool _syncEnabled; QTimer _etagPollTimer; QPointer _currentEtagJob; // alias of Folder running the current RequestEtagJob QMap _folderWatchers; QPointer _socketApi; /** The aliases of folders that shall be synced. */ QQueue _scheduleQueue; static FolderMan *_instance; explicit FolderMan(QObject *parent = 0); ~FolderMan(); friend class Mirall::Application; }; } // namespace Mirall #endif // FOLDERMAN_H