aboutsummaryrefslogtreecommitdiffstats
path: root/vendor/sabre/dav/lib/DAV/Auth/Backend/PDOBasicAuth.php
blob: 39324e4db8a3d8af45f72858d24504bf1f71e33e (plain) (blame)
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
<?php

namespace Sabre\DAV\Auth\Backend;

/**
 * This is an authentication backend that uses a database to manage passwords.
 *
 * @copyright Copyright (C) fruux GmbH (https://fruux.com/)
 * @license http://sabre.io/license/ Modified BSD License
 */
class PDOBasicAuth extends AbstractBasic
{
    /**
     * Reference to PDO connection.
     *
     * @var PDO
     */
    protected $pdo;

    /**
     * PDO table name we'll be using.
     *
     * @var string
     */
    protected $tableName;

    /**
     * PDO digest column name we'll be using
     * (i.e. digest, password, password_hash).
     *
     * @var string
     */
    protected $digestColumn;

    /**
     * PDO uuid(unique user identifier) column name we'll be using
     * (i.e. username, email).
     *
     * @var string
     */
    protected $uuidColumn;

    /**
     * Digest prefix:
     * if the backend you are using for is prefixing
     * your password hashes set this option to your prefix to
     * cut it off before verfiying.
     *
     * @var string
     */
    protected $digestPrefix;

    /**
     * Creates the backend object.
     *
     * If the filename argument is passed in, it will parse out the specified file fist.
     */
    public function __construct(\PDO $pdo, array $options = [])
    {
        $this->pdo = $pdo;
        if (isset($options['tableName'])) {
            $this->tableName = $options['tableName'];
        } else {
            $this->tableName = 'users';
        }
        if (isset($options['digestColumn'])) {
            $this->digestColumn = $options['digestColumn'];
        } else {
            $this->digestColumn = 'digest';
        }
        if (isset($options['uuidColumn'])) {
            $this->uuidColumn = $options['uuidColumn'];
        } else {
            $this->uuidColumn = 'username';
        }
        if (isset($options['digestPrefix'])) {
            $this->digestPrefix = $options['digestPrefix'];
        }
    }

    /**
     * Validates a username and password.
     *
     * This method should return true or false depending on if login
     * succeeded.
     *
     * @param string $username
     * @param string $password
     *
     * @return bool
     */
    public function validateUserPass($username, $password)
    {
        $stmt = $this->pdo->prepare('SELECT '.$this->digestColumn.' FROM '.$this->tableName.' WHERE '.$this->uuidColumn.' = ?');
        $stmt->execute([$username]);
        $result = $stmt->fetchAll();

        if (!count($result)) {
            return false;
        } else {
            $digest = $result[0][$this->digestColumn];

            if (isset($this->digestPrefix)) {
                $digest = substr($digest, strlen($this->digestPrefix));
            }

            if (password_verify($password, $digest)) {
                return true;
            }

            return false;
        }
    }
}