summaryrefslogtreecommitdiff
path: root/vendor/SimpleValidator/Validators/Unique.php
blob: c20dbe11f5fb29186cc7ffeea36f789b26e3a0a5 (plain)
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
<?php

/*
 * This file is part of Simple Validator.
 *
 * (c) Frédéric Guillot <contact@fredericguillot.com>
 *
 * This source file is subject to the MIT license that is bundled
 * with this source code in the file LICENSE.
 */

namespace SimpleValidator\Validators;

use SimpleValidator\Base;

/**
 * @author Frédéric Guillot <contact@fredericguillot.com>
 */
class Unique extends Base
{
    private $pdo;
    private $primary_key;
    private $table;


    public function __construct($field, $error_message, \PDO $pdo, $table, $primary_key = 'id')
    {
        parent::__construct($field, $error_message);

        $this->pdo = $pdo;
        $this->primary_key = $primary_key;
        $this->table = $table;
    }


    public function execute(array $data)
    {
        if (isset($data[$this->field]) && $data[$this->field] !== '') {

            if (! isset($data[$this->primary_key])) {

                $rq = $this->pdo->prepare('SELECT COUNT(*) FROM '.$this->table.' WHERE '.$this->field.'=?');

                $rq->execute(array(
                    $data[$this->field]
                ));

                $result = $rq->fetch(\PDO::FETCH_NUM);

                if (isset($result[0]) && $result[0] === '1') {

                    return false;
                }
            }
            else {

                $rq = $this->pdo->prepare(
                    'SELECT COUNT(*) FROM '.$this->table.'
                    WHERE '.$this->field.'=? AND '.$this->primary_key.' != ?'
                );
                
                $rq->execute(array(
                    $data[$this->field], 
                    $data[$this->primary_key]
                ));
                
                $result = $rq->fetch(\PDO::FETCH_NUM);

                if (isset($result[0]) && $result[0] === '1') {

                    return false;
                }
            }
        }

        return true;
    }
}