-
Arno van der Vegt authoredArno van der Vegt authored
SimpleSAML\Database
Purpose
This document covers the SimpleSAML\Database class and is only relevant to anyone writing code for SimpleSAMLphp, including modules, that require a database connection.
The Database class provides a single class that can be used to connect to a database which can be shared by anything within SimpleSAMLphp.
Getting Started
If you are just using the already configured database, which would normally be the case, all you need to do is get the global instance of the Database class.
$db = \SimpleSAML\Database::getInstance();
If there is a requirement to connect to an alternate database server (ex. authenticating users that exist on a different SQL server or database) you can specify an alternate configuration.
$config = new \SimpleSAML\Configuration($myconfigarray, "mymodule/lib/Auth/Source/myauth.php");
$db = \SimpleSAML\Database::getInstance($config);
That will create a new instance of the database, separate from the global instance, specific to the configuration defined in $myconfigarray. If you are going to specify an alternate config, your configuration array must contain the same keys that exist in the master config (database.dsn, database.username, database.password, database.prefix, etc).
Database Prefix
Administrators can add a prefix to all the table names that this database classes accesses and you should take that in account when querying. Assuming that a prefix has been configured as "sp_":
$table = $db->applyPrefix("saml20_idp_hosted");
$table would be set to "sp_saml20_idp_hosted"
Querying The Database
You can query the database through two public functions read() and write() which are fairly self-explanitory when it comes to determining which one to use when querying.
Writing to The Database
Since the database class allows administrators to configure master and slave database servers, the write function will always use the master database connection.
The write function takes 2 parameters: SQL, params.
$table = $db->applyPrefix("test");
$values = [
'id' => 20,
'data' => 'Some data',
];
$query = $db->write("INSERT INTO $table (id, data) VALUES (:id, :data)", $values);