postgresql/auth: Fix that users cannot login when using PostgreSQL >= version 9.0
fixes #8251
This commit is contained in:
parent
d275bc0762
commit
2bd2f32b2e
|
@ -87,9 +87,16 @@ class DbUserBackend extends UserBackend
|
||||||
*/
|
*/
|
||||||
protected function getPasswordHash($username)
|
protected function getPasswordHash($username)
|
||||||
{
|
{
|
||||||
$stmt = $this->conn->getDbAdapter()->prepare(
|
if ($this->conn->getDbType() === 'pgsql') {
|
||||||
'SELECT password_hash FROM icingaweb_user WHERE name = :name AND active = 1'
|
// Since PostgreSQL version 9.0 the default value for bytea_output is 'hex' instead of 'escape'
|
||||||
);
|
$stmt = $this->conn->getDbAdapter()->prepare(
|
||||||
|
'SELECT ENCODE(password_hash, \'escape\') FROM icingaweb_user WHERE name = :name AND active = 1'
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
$stmt = $this->conn->getDbAdapter()->prepare(
|
||||||
|
'SELECT password_hash FROM icingaweb_user WHERE name = :name AND active = 1'
|
||||||
|
);
|
||||||
|
}
|
||||||
$stmt->execute(array(':name' => $username));
|
$stmt->execute(array(':name' => $username));
|
||||||
$stmt->bindColumn(1, $lob, PDO::PARAM_LOB);
|
$stmt->bindColumn(1, $lob, PDO::PARAM_LOB);
|
||||||
$stmt->fetch(PDO::FETCH_BOUND);
|
$stmt->fetch(PDO::FETCH_BOUND);
|
||||||
|
|
Loading…
Reference in New Issue