QGIS/python/core/qgsdatasourceuri.sip

179 lines
5.6 KiB
Plaintext
Raw Normal View History

2016-02-14 03:50:23 +01:00
/** \ingroup core
* Class for storing the component parts of a PostgreSQL/RDBMS datasource URI.
* This structure stores the database connection information, including host, database,
* user name, password, schema, password, and sql where clause
*
* Extended to support generic params so that it may be used by any provider.
* The 2 modes (the old - RDMS specific and the new generic) may not yet be mixed.
* (Radim Blazek 4/2012)
*/
class QgsDataSourceURI
{
%TypeHeaderCode
#include <qgsdatasourceuri.h>
%End
public:
enum SSLmode { SSLprefer, SSLdisable, SSLallow, SSLrequire, SSLverifyCA, SSLverifyFull };
//! default constructor
QgsDataSourceURI();
//! constructor which parses input URI
QgsDataSourceURI( QString uri );
//! return connection part of URI
QString connectionInfo( bool expandAuthConfig = true ) const;
//! return complete uri
QString uri( bool expandAuthConfig = true ) const;
2012-10-10 11:57:00 +03:00
//! return complete encoded uri (generic mode)
QByteArray encodedUri() const;
2016-02-14 03:50:23 +01:00
//! set complete encoded uri (generic mode)
// \note not available in python bindings
// void setEncodedUri( const QByteArray & uri );
//! set complete encoded uri (generic mode)
void setEncodedUri( const QString & uri );
//! quoted table name
QString quotedTablename() const;
//! Set generic param (generic mode)
// \note if key exists, another is inserted
void setParam( const QString &key, const QString &value );
//! @note available in python as setParamList
2014-01-26 18:35:21 +01:00
void setParam( const QString &key, const QStringList &value ) /PyName=setParamList/;
//! Remove generic param (generic mode)
// \note remove all occurrences of key, returns number of params removed
int removeParam( const QString &key );
//! Get generic param (generic mode)
QString param( const QString &key ) const;
//! Get multiple generic param (generic mode)
QStringList params( const QString &key ) const;
//! Test if param exists (generic mode)
bool hasParam( const QString &key ) const;
//! Set all connection related members at once
void setConnection( const QString& aHost,
const QString& aPort,
const QString& aDatabase,
const QString& aUsername,
const QString& aPassword,
SSLmode sslmode = SSLprefer,
const QString& authConfigId = QString() );
//! Set all connection related members at once (for the service case)
void setConnection( const QString& aService,
const QString& aDatabase,
const QString& aUsername,
const QString& aPassword,
SSLmode sslmode = SSLprefer,
const QString& authConfigId = QString() );
//! Set database
void setDatabase( const QString &database );
//! Set all data source related members at once
void setDataSource( const QString& aSchema,
const QString& aTable,
const QString& aGeometryColumn,
const QString& aSql = QString(),
const QString& aKeyColumn = QString() );
2016-02-14 03:50:23 +01:00
//! Set authentication configuration ID
void setAuthConfigId( const QString& authcfg );
//! set username
void setUsername( const QString& username );
//! set password
void setPassword( const QString& password );
//! Removes password element from uris
static QString removePassword( const QString& aUri );
2016-02-14 03:50:23 +01:00
//! Any associated authentication configuration ID
QString authConfigId() const;
2016-02-14 03:50:23 +01:00
//! Returns the username
QString username() const;
2016-02-14 03:50:23 +01:00
//! Returns the schema
QString schema() const;
2016-02-14 03:50:23 +01:00
//! Returns the table
QString table() const;
2016-02-14 03:50:23 +01:00
//! Returns the SQL query
QString sql() const;
2016-02-14 03:50:23 +01:00
//! Return the name of the geometry column
QString geometryColumn() const;
//! set use Estimated Metadata
void setUseEstimatedMetadata( bool theFlag );
2016-02-14 03:50:23 +01:00
//! Returns true if estimated metadata are used
bool useEstimatedMetadata() const;
2016-02-14 03:50:23 +01:00
//! Set to true to disable selection by id
void disableSelectAtId( bool theFlag );
2016-02-14 03:50:23 +01:00
//! Returns whether the selection by id is disabled
bool selectAtIdDisabled() const;
2016-02-14 03:50:23 +01:00
//! Clears the schema
void clearSchema();
//! set the table schema
// @note added in 2.11
void setSchema( const QString& schema );
2016-02-14 03:50:23 +01:00
//! Sets the SQL query
void setSql( const QString& sql );
2016-02-14 03:50:23 +01:00
//! Returns the host
QString host() const;
2016-02-14 03:50:23 +01:00
//! Returns the database
QString database() const;
2016-02-14 03:50:23 +01:00
//! Returns the port
QString port() const;
2016-02-14 03:50:23 +01:00
//! Returns the password
QString password() const;
2016-02-14 03:50:23 +01:00
//! Returns the SSL mode
SSLmode sslMode() const;
2016-02-14 03:50:23 +01:00
//! Returns the service name
QString service() const;
2016-02-14 03:50:23 +01:00
//! Returns the name of the (primary) key column
QString keyColumn() const;
2016-02-14 03:50:23 +01:00
//! Sets the name of the (primary) key column
void setKeyColumn( const QString& column );
/** The (old) wkb type.
@deprecated Will return QgsWKBTypes::Type in 3.0. Prefer newWkbType() in the meantime */
QGis::WkbType wkbType() const /Deprecated/;
/** The wkb type.
@note Will be removed in 3.0 */
QgsWKBTypes::Type newWkbType() const;
//! @deprecated See setWkbType( QgsWKBTypes::Type )
void setWkbType( QGis::WkbType type ) /Deprecated/;
//! Sets the wkb type
void setWkbType( QgsWKBTypes::Type type );
2016-02-14 03:50:23 +01:00
//! Returns the srid
QString srid() const;
2016-02-14 03:50:23 +01:00
//! Sets the srid
void setSrid( const QString& srid );
};