File indexing completed on 2024-12-01 03:37:37

0001 /*
0002     This file is part of KDE.
0003 
0004     SPDX-FileCopyrightText: 2009 Eckhart Wörner <ewoerner@kde.org>
0005     SPDX-FileCopyrightText: 2009 Frederik Gladhorn <gladhorn@kde.org>
0006 
0007     SPDX-License-Identifier: LGPL-2.1-only OR LGPL-3.0-only OR LicenseRef-KDE-Accepted-LGPL
0008 */
0009 
0010 #ifndef ATTICA_PROVIDERMANAGER_H
0011 #define ATTICA_PROVIDERMANAGER_H
0012 
0013 #include <QNetworkReply>
0014 #include <QUrl>
0015 
0016 #include "attica_export.h"
0017 #include "provider.h"
0018 
0019 /**
0020  * The Attica namespace,
0021  */
0022 namespace Attica
0023 {
0024 /**
0025  * @class ProviderManager providermanager.h <Attica/ProviderManager>
0026  *
0027  * Attica ProviderManager
0028  *
0029  * This class is the primary access to Attica's functions.
0030  * Use the ProviderManager to load Open Collaboration Service providers,
0031  * either the default system ones, or from XML or custom locations.
0032  *
0033  * \section providerfiles Provider Files
0034  * Provider files are defined here:
0035  * http://www.freedesktop.org/wiki/Specifications/open-collaboration-services
0036  *
0037  * \section basicuse Basic Use
0038  *
0039  * See addProviderFileToDefaultProviders(const QUrl &url) for an example of
0040  * what the provider file sohuld look like. You can add providers to the
0041  * ProviderManager as either raw XML data using addProviderFromXml(const QString &providerXml),
0042  * or from a file somewhere on the system through addProviderFile(const QUrl &file),
0043  * or you can simply load the default providers provided by your system
0044  * (which generally means KDE's provider opendesktop.org).
0045  *
0046  * Importantly, to be able to detect when the ProviderManager is ready to
0047  * manage things, before initialising it you will want to connect to the
0048  * providerAdded(const Attica::Provider &provider) signal, which is fired
0049  * every time a new provider is added to the manager.
0050  *
0051  * If you manually add all providers from XML, you can expect this to happen
0052  * immediately. This means that once you have added your providers that way,
0053  * you can access them through the providers() function, which returns
0054  * a list of all loaded Providers.
0055  *
0056  * Once you have loaded a Provider, you can use its functions to access the
0057  * services offered by that provider.
0058  */
0059 class ATTICA_EXPORT ProviderManager : public QObject
0060 {
0061     Q_OBJECT
0062 
0063 public:
0064     enum ProviderFlag {
0065         NoFlags = 0x0,
0066         DisablePlugins = 0x1,
0067     };
0068     Q_DECLARE_FLAGS(ProviderFlags, ProviderFlag)
0069 
0070     ProviderManager(const ProviderFlags &flags = NoFlags);
0071     ~ProviderManager() override;
0072 
0073     /**
0074      * Load available providers from configuration
0075      */
0076     void loadDefaultProviders();
0077 
0078     /**
0079      * The list of provider files that get loaded by loadDefaultProviders.
0080      * Each of these files can contain multiple providers.
0081      * @return list of provider file urls
0082      */
0083     QList<QUrl> defaultProviderFiles();
0084 
0085     /**
0086     * Add a provider file to the default providers (xml that contains provider descriptions).
0087       Provider files contain information about each provider:
0088      <pre>
0089      <providers>
0090      <provider>
0091         <id>opendesktop</id>
0092         <location>https://api.opendesktop.org/v1/</location>
0093         <name>openDesktop.org</name>
0094         <icon></icon>
0095         <termsofuse>https://opendesktop.org/terms/</termsofuse>
0096         <register>https://opendesktop.org/usermanager/new.php</register>
0097         <services>
0098             <person ocsversion="1.3" />
0099             <friend ocsversion="1.3" />
0100             <message ocsversion="1.3" />
0101             <activity ocsversion="1.3" />
0102             <content ocsversion="1.3" />
0103             <fan ocsversion="1.3" />
0104             <knowledgebase ocsversion="1.3" />
0105             <event ocsversion="1.3" />
0106         </services>
0107      </provider>
0108      </providers>
0109      </pre>
0110     * @param url the url of the provider file
0111     */
0112     void addProviderFileToDefaultProviders(const QUrl &url);
0113 
0114     void removeProviderFileFromDefaultProviders(const QUrl &url);
0115 
0116     /**
0117      * Suppresses the authentication, so that the application can take care of authenticating itself
0118      */
0119     void setAuthenticationSuppressed(bool suppressed);
0120 
0121     /**
0122      * Remove all providers and provider files that have been loaded
0123      */
0124     void clear();
0125 
0126     /**
0127      * Parse a xml file containing a provider description
0128      */
0129     void addProviderFromXml(const QString &providerXml);
0130     void addProviderFile(const QUrl &file);
0131     QList<QUrl> providerFiles() const;
0132 
0133     /**
0134      * @returns all loaded providers
0135      */
0136     QList<Provider> providers() const;
0137 
0138     /**
0139      * @returns whether there's a provider with base url @p provider
0140      */
0141     bool contains(const QUrl &provider) const;
0142 
0143     /**
0144      * @returns the provider with @p url base url.
0145      */
0146     Provider providerByUrl(const QUrl &url) const;
0147 
0148     /**
0149      * @returns the provider for a given provider @p url.
0150      */
0151     Provider providerFor(const QUrl &url) const;
0152 
0153 Q_SIGNALS:
0154     void providerAdded(const Attica::Provider &provider);
0155     void defaultProvidersLoaded();
0156     void authenticationCredentialsMissing(const Provider &provider);
0157     void failedToLoad(const QUrl &provider, QNetworkReply::NetworkError error);
0158 
0159 private Q_SLOTS:
0160     ATTICA_NO_EXPORT void fileFinished(const QString &url);
0161     ATTICA_NO_EXPORT void authenticate(QNetworkReply *, QAuthenticator *);
0162     ATTICA_NO_EXPORT void proxyAuthenticationRequired(const QNetworkProxy &proxy, QAuthenticator *authenticator);
0163     ATTICA_NO_EXPORT void slotLoadDefaultProvidersInternal();
0164 
0165 private:
0166     ProviderManager(const ProviderManager &other) = delete;
0167     ProviderManager &operator=(const ProviderManager &other) = delete;
0168 
0169     ATTICA_NO_EXPORT void initNetworkAccesssManager();
0170     ATTICA_NO_EXPORT PlatformDependent *loadPlatformDependent(const ProviderFlags &flags);
0171 
0172     ATTICA_NO_EXPORT void parseProviderFile(const QString &xmlString, const QUrl &url);
0173 
0174     class Private;
0175     Private *const d;
0176 };
0177 
0178 Q_DECLARE_OPERATORS_FOR_FLAGS(ProviderManager::ProviderFlags)
0179 
0180 }
0181 
0182 #endif