summaryrefslogtreecommitdiff
path: root/vendor/SimpleValidator/Validators/Unique.php
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/SimpleValidator/Validators/Unique.php')
-rw-r--r--vendor/SimpleValidator/Validators/Unique.php78
1 files changed, 78 insertions, 0 deletions
diff --git a/vendor/SimpleValidator/Validators/Unique.php b/vendor/SimpleValidator/Validators/Unique.php
new file mode 100644
index 00000000..c20dbe11
--- /dev/null
+++ b/vendor/SimpleValidator/Validators/Unique.php
@@ -0,0 +1,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;
+ }
+} \ No newline at end of file