File size: 1,277 Bytes
e4f4821
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
<?php

namespace SimpleValidator\Validators;

use PDO;

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 ($this->isFieldNotEmpty($data)) {
            if (! isset($data[$this->primary_key])) {
                $rq = $this->pdo->prepare('SELECT 1 FROM '.$this->table.' WHERE '.$this->field.'=?');
                $rq->execute(array($data[$this->field]));
            }
            else {

                $rq = $this->pdo->prepare(
                    'SELECT 1 FROM '.$this->table.'
                    WHERE '.$this->field.'=? AND '.$this->primary_key.' != ?'
                );

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

            $result = $rq->fetchColumn();

            if ($result == 1) { // Postgresql returns an integer but other database returns a string '1'
                return false;
            }
        }

        return true;
    }
}