| 1 | /**************************************************************************** | 
| 2 | ** | 
| 3 | ** Copyright (C) 2015 The Qt Company Ltd and/or its subsidiary(-ies). | 
| 4 | ** Contact: http://www.qt-project.org/legal | 
| 5 | ** | 
| 6 | ** This file is part of the QtSystems module of the Qt Toolkit. | 
| 7 | ** | 
| 8 | ** $QT_BEGIN_LICENSE:LGPL21$ | 
| 9 | ** Commercial License Usage | 
| 10 | ** Licensees holding valid commercial Qt licenses may use this file in | 
| 11 | ** accordance with the commercial license agreement provided with the | 
| 12 | ** Software or, alternatively, in accordance with the terms contained in | 
| 13 | ** a written agreement between you and The Qt Company. For licensing terms | 
| 14 | ** and conditions see http://www.qt.io/terms-conditions. For further | 
| 15 | ** information use the contact form at http://www.qt.io/contact-us. | 
| 16 | ** | 
| 17 | ** GNU Lesser General Public License Usage | 
| 18 | ** Alternatively, this file may be used under the terms of the GNU Lesser | 
| 19 | ** General Public License version 2.1 or version 3 as published by the Free | 
| 20 | ** Software Foundation and appearing in the file LICENSE.LGPLv21 and | 
| 21 | ** LICENSE.LGPLv3 included in the packaging of this file. Please review the | 
| 22 | ** following information to ensure the GNU Lesser General Public License | 
| 23 | ** requirements will be met: https://www.gnu.org/licenses/lgpl.html and | 
| 24 | ** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. | 
| 25 | ** | 
| 26 | ** As a special exception, The Qt Company gives you certain additional | 
| 27 | ** rights. These rights are described in The Qt Company LGPL Exception | 
| 28 | ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. | 
| 29 | ** | 
| 30 | ** $QT_END_LICENSE$ | 
| 31 | ** | 
| 32 | ****************************************************************************/ | 
| 33 |  | 
| 34 | #ifndef DATABASEMANAGER_H_ | 
| 35 | #define DATABASEMANAGER_H_ | 
| 36 |  | 
| 37 | // | 
| 38 | //  W A R N I N G | 
| 39 | //  ------------- | 
| 40 | // | 
| 41 | // This file is not part of the Qt API. It exists purely as an | 
| 42 | // implementation detail. This header file may change from version to | 
| 43 | // version without notice, or even be removed. | 
| 44 | // | 
| 45 | // We mean it. | 
| 46 | // | 
| 47 |  | 
| 48 | #include "qserviceframeworkglobal.h" | 
| 49 | #include "servicedatabase_p.h" | 
| 50 | #include <QObject> | 
| 51 |  | 
| 52 | #ifdef QT_SFW_SERVICEDATABASE_GENERATE | 
| 53 | #undef Q_AUTOTEST_EXPORT | 
| 54 | #define Q_AUTOTEST_EXPORT | 
| 55 | #endif | 
| 56 |  | 
| 57 | QT_BEGIN_NAMESPACE | 
| 58 |  | 
| 59 | class DatabaseFileWatcher; | 
| 60 | class Q_AUTOTEST_EXPORT DatabaseManager : public QObject | 
| 61 | { | 
| 62 |     Q_OBJECT | 
| 63 |  | 
| 64 |     public: | 
| 65 |         enum DbScope{UserScope, SystemScope, UserOnlyScope}; | 
| 66 |         DatabaseManager(void); | 
| 67 |         virtual ~DatabaseManager(); | 
| 68 |  | 
| 69 |         bool registerService(ServiceMetaDataResults &service, DbScope scope); | 
| 70 |         bool unregisterService(const QString &serviceName, DbScope scope); | 
| 71 |         bool serviceInitialized(const QString &serviceName, DbScope scope); | 
| 72 |  | 
| 73 |         QList<QServiceInterfaceDescriptor> getInterfaces(const QServiceFilter &filter, DbScope scope); | 
| 74 |         QStringList getServiceNames(const QString &interfaceName, DbScope scope); | 
| 75 |  | 
| 76 |         QServiceInterfaceDescriptor interfaceDefault(const QString &interfaceName, DbScope scope); | 
| 77 |         bool setInterfaceDefault(const QString &serviceName, const QString &interfaceName, DbScope scope); | 
| 78 |         bool setInterfaceDefault(const QServiceInterfaceDescriptor &serviceInterface, DbScope scope); | 
| 79 |  | 
| 80 |         DBError lastError(){ return m_lastError;} | 
| 81 |  | 
| 82 |         void setChangeNotificationsEnabled(DbScope scope, bool enabled); | 
| 83 |  | 
| 84 |     Q_SIGNALS: | 
| 85 |         void serviceAdded(const QString &serviceName, DatabaseManager::DbScope scope); | 
| 86 |         void serviceRemoved(const QString &serviceName, DatabaseManager::DbScope scope); | 
| 87 |  | 
| 88 |     private: | 
| 89 |         void initDbPath(DbScope scope); | 
| 90 |         bool openDb(DbScope scope); | 
| 91 |  | 
| 92 |         ServiceDatabase *m_userDb; | 
| 93 |         ServiceDatabase *m_systemDb; | 
| 94 |         DBError m_lastError; | 
| 95 |  | 
| 96 |         friend class DatabaseFileWatcher; | 
| 97 |         DatabaseFileWatcher *m_fileWatcher; | 
| 98 |         QServiceInterfaceDescriptor latestDescriptor(const QList<QServiceInterfaceDescriptor> &descriptors); | 
| 99 |  | 
| 100 |         bool m_hasAccessedUserDb; | 
| 101 |         bool m_alreadyWarnedOpenError; | 
| 102 | }; | 
| 103 |  | 
| 104 |  | 
| 105 | class Q_AUTOTEST_EXPORT DatabaseFileWatcher : public QObject | 
| 106 | { | 
| 107 |     Q_OBJECT | 
| 108 | public: | 
| 109 |     DatabaseFileWatcher(DatabaseManager *parent = 0); | 
| 110 |  | 
| 111 |     void setEnabled(ServiceDatabase *database, bool enabled); | 
| 112 |  | 
| 113 | private Q_SLOTS: | 
| 114 |     void databaseChanged(const QString &path); | 
| 115 |     void databaseDirectoryChanged(const QString &path); | 
| 116 |  | 
| 117 | private: | 
| 118 |     void notifyChanges(ServiceDatabase *database, DatabaseManager::DbScope scope); | 
| 119 |     QString closestExistingParent(const QString &path); | 
| 120 |     void restartDirMonitoring(const QString &dbPath, const QString &previousDirPath); | 
| 121 |  | 
| 122 |     DatabaseManager *m_manager; | 
| 123 |     QFileSystemWatcher *m_watcher; | 
| 124 |     QHash<QString, QStringList> m_knownServices; | 
| 125 |     QStringList m_monitoredDbPaths; | 
| 126 | }; | 
| 127 |  | 
| 128 | QT_END_NAMESPACE | 
| 129 |  | 
| 130 | #endif | 
| 131 |  |