summaryrefslogtreecommitdiffstats
path: root/3rdparty/Sabre/DAV/Auth/Backend/PDO.php
diff options
context:
space:
mode:
authorGeorg Ehrke <dev@georgswebsite.de>2012-08-09 17:32:45 +0200
committerGeorg Ehrke <dev@georgswebsite.de>2012-08-09 17:34:19 +0200
commit6e922035e1cb7b6f99f32c60dcc5eca8c3d52e7c (patch)
treee78b2cefcc3d086a9815566d821642d1a6233a6f /3rdparty/Sabre/DAV/Auth/Backend/PDO.php
parent4e85848c927896b4d9084fd9019478baaee4507b (diff)
downloadnextcloud-server-6e922035e1cb7b6f99f32c60dcc5eca8c3d52e7c.tar.gz
nextcloud-server-6e922035e1cb7b6f99f32c60dcc5eca8c3d52e7c.zip
add SabreDav 1.6.4
Diffstat (limited to '3rdparty/Sabre/DAV/Auth/Backend/PDO.php')
-rwxr-xr-x3rdparty/Sabre/DAV/Auth/Backend/PDO.php65
1 files changed, 65 insertions, 0 deletions
diff --git a/3rdparty/Sabre/DAV/Auth/Backend/PDO.php b/3rdparty/Sabre/DAV/Auth/Backend/PDO.php
new file mode 100755
index 00000000000..eac18a23fbb
--- /dev/null
+++ b/3rdparty/Sabre/DAV/Auth/Backend/PDO.php
@@ -0,0 +1,65 @@
+<?php
+
+/**
+ * This is an authentication backend that uses a file to manage passwords.
+ *
+ * The backend file must conform to Apache's htdigest format
+ *
+ * @package Sabre
+ * @subpackage DAV
+ * @copyright Copyright (C) 2007-2012 Rooftop Solutions. All rights reserved.
+ * @author Evert Pot (http://www.rooftopsolutions.nl/)
+ * @license http://code.google.com/p/sabredav/wiki/License Modified BSD License
+ */
+class Sabre_DAV_Auth_Backend_PDO extends Sabre_DAV_Auth_Backend_AbstractDigest {
+
+ /**
+ * Reference to PDO connection
+ *
+ * @var PDO
+ */
+ protected $pdo;
+
+ /**
+ * PDO table name we'll be using
+ *
+ * @var string
+ */
+ protected $tableName;
+
+
+ /**
+ * Creates the backend object.
+ *
+ * If the filename argument is passed in, it will parse out the specified file fist.
+ *
+ * @param PDO $pdo
+ * @param string $tableName The PDO table name to use
+ */
+ public function __construct(PDO $pdo, $tableName = 'users') {
+
+ $this->pdo = $pdo;
+ $this->tableName = $tableName;
+
+ }
+
+ /**
+ * Returns the digest hash for a user.
+ *
+ * @param string $realm
+ * @param string $username
+ * @return string|null
+ */
+ public function getDigestHash($realm,$username) {
+
+ $stmt = $this->pdo->prepare('SELECT username, digesta1 FROM '.$this->tableName.' WHERE username = ?');
+ $stmt->execute(array($username));
+ $result = $stmt->fetchAll();
+
+ if (!count($result)) return;
+
+ return $result[0]['digesta1'];
+
+ }
+
+}