/usr/include/qgis/qgsauthmethod.h is in libqgis-dev 2.18.17+dfsg-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 | /***************************************************************************
qgsauthmethod.h
---------------------
begin : September 1, 2015
copyright : (C) 2015 by Boundless Spatial, Inc. USA
author : Larry Shaffer
email : lshaffer at boundlessgeo dot com
***************************************************************************
* *
* 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. *
* *
***************************************************************************/
#ifndef QGSAUTHMETHOD_H
#define QGSAUTHMETHOD_H
#include <QObject>
#include <QFlags>
#include <QNetworkReply>
#include <QNetworkRequest>
#include <QStringList>
#include <QUrl>
#include "qgsauthconfig.h"
/** \ingroup core
* Abstract base class for authentication method plugins
*/
class CORE_EXPORT QgsAuthMethod : public QObject
{
Q_OBJECT
public:
/** Flags that represent the update points (where authentication configurations are expanded)
* supported by an authentication method. These equate to the 'update*()' virtual functions
* below, and allow for update point code to skip calling an unused update by a method, because
* the base virtual funtion will always return true, giving a false impression an update occurred.
* @note When adding an 'update' member function, also add the corresponding Expansion flag.
* @note These flags will be added to as new update points are added
*/
enum Expansion
{
// TODO: Figure out all different authentication expansions current layer providers use
NetworkRequest = 0x1,
NetworkReply = 0x2,
DataSourceURI = 0x4,
GenericDataSourceURI = 0x8,
All = NetworkRequest | NetworkReply | DataSourceURI | GenericDataSourceURI
};
Q_DECLARE_FLAGS( Expansions, Expansion )
virtual ~QgsAuthMethod() {}
/** A non-translated short name representing the auth method */
virtual QString key() const = 0;
/** A non-translated short description representing the auth method for use in debug output and About dialog */
virtual QString description() const = 0;
/** Translatable display version of the 'description()' */
virtual QString displayDescription() const = 0;
/** Increment this if method is significantly updated, allow updater code to be written for previously stored authcfg */
int version() const { return mVersion; }
/** Flags that represent the update points (where authentication configurations are expanded)
* supported by an authentication method.
* @note These should directly correlate to existing 'update*()' member functions
*/
QgsAuthMethod::Expansions supportedExpansions() const { return mExpansions; }
/** The data providers that the method supports, allowing for filtering out authcfgs that are not
* applicable to a given provider, or where the updating code is not currently implemented.
*/
QStringList supportedDataProviders() const { return mDataProviders; }
/** Update a network request with authentication components
* @param request The network request to update
* @param authcfg Authentication configuration ID
* @param dataprovider Textual key for a data provider, e.g. 'postgres', that allows
* for custom updater code specific to the provider
* @return Whether the update succeeded
*/
virtual bool updateNetworkRequest( QNetworkRequest &request, const QString &authcfg,
const QString &dataprovider = QString() )
{
Q_UNUSED( request )
Q_UNUSED( authcfg )
Q_UNUSED( dataprovider )
return true; // noop
}
/** Update a network reply with authentication components
* @param reply The network reply object to update
* @param authcfg Authentication configuration ID
* @param dataprovider Textual key for a data provider, e.g. 'postgres', that allows
* for custom updater code specific to the provider
* @return Whether the update succeeded
*/
virtual bool updateNetworkReply( QNetworkReply *reply, const QString &authcfg,
const QString &dataprovider = QString() )
{
Q_UNUSED( reply )
Q_UNUSED( authcfg )
Q_UNUSED( dataprovider )
return true; // noop
}
/** Update data source connection items with authentication components
* @param connectionItems QStringlist of 'key=value' pairs, as utilized in QgsDataSourceURI::connectionInfo()
* @param authcfg Authentication configuration ID
* @param dataprovider Textual key for a data provider, e.g. 'postgres', that allows
* for custom updater code specific to the provider
* @return Whether the update succeeded
*/
virtual bool updateDataSourceUriItems( QStringList &connectionItems, const QString &authcfg,
const QString &dataprovider = QString() )
{
Q_UNUSED( connectionItems )
Q_UNUSED( authcfg )
Q_UNUSED( dataprovider )
return true; // noop
}
/** Clear any cached configuration. Called when the QgsAuthManager deletes an authentication configuration (authcfg).
* @note It is highly recommended that a cache of authentication components (per requested authcfg)
* be implemented, to avoid excessive queries on the auth database. Such a cache could be as
* simple as a QHash or QMap of authcfg -> QgsAuthMethodConfig. See 'Basic' auth method plugin for example.
*/
virtual void clearCachedConfig( const QString &authcfg ) = 0;
/** Update an authentication configuration in place
* @note Useful for updating previously stored authcfgs, when an authentication method has been significantly updated
*/
virtual void updateMethodConfig( QgsAuthMethodConfig &mconfig ) = 0;
protected:
/**
* Construct a default authentication method
* @note Non-public since this is an abstract base class
*/
explicit QgsAuthMethod()
: mExpansions( QgsAuthMethod::Expansions( nullptr ) )
, mDataProviders( QStringList() )
, mVersion( 0 )
{}
/** Tag signifying that this is an authentcation method (e.g. for use as title in message log panel output) */
static QString authMethodTag() { return QObject::tr( "Authentication method" ); }
/** Set the version of the auth method (useful for future upgrading) */
void setVersion( int version ) { mVersion = version; }
/** Set the support expansions (points in providers where the authentication is injected) of the auth method */
void setExpansions( const QgsAuthMethod::Expansions& expansions ) { mExpansions = expansions; }
/** Set list of data providers this auth method supports */
void setDataProviders( const QStringList& dataproviders ) { mDataProviders = dataproviders; }
QgsAuthMethod::Expansions mExpansions;
QStringList mDataProviders;
int mVersion;
};
Q_DECLARE_OPERATORS_FOR_FLAGS( QgsAuthMethod::Expansions )
typedef QHash<QString, QgsAuthMethod*> QgsAuthMethodsMap;
#endif // QGSAUTHMETHOD_H
|