Abstract_Validator   A
last analyzed

Complexity

Total Complexity 4

Size/Duplication

Total Lines 55
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
wmc 4
eloc 8
c 1
b 0
f 0
dl 0
loc 55
rs 10

4 Methods

Rating   Name   Duplication   Size   Complexity  
A get_errors() 0 2 1
A reset_errors() 0 3 1
A has_errors() 0 2 1
A add_error() 0 3 1
1
<?php
2
3
declare(strict_types=1);
4
5
/**
6
 * Validates a Post Type model.
7
 *
8
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
9
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
10
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
11
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
12
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
13
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
14
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
15
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
16
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
17
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
18
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
19
 *
20
 * @author Glynn Quelch <[email protected]>
21
 * @license http://www.opensource.org/licenses/mit-license.html  MIT License
22
 * @package PinkCrab\Registerables\Validator
23
 */
24
25
namespace PinkCrab\Registerables\Validator;
26
27
use PinkCrab\Registerables\Module\Middleware\Registerable;
28
29
abstract class Abstract_Validator {
30
31
	/**
32
	 * All errors found during validation
33
	 *
34
	 * @var string[]
35
	 */
36
	protected array $errors = array();
37
38
	/**
39
	 * Checks if errors set.
40
	 *
41
	 * @return bool
42
	 */
43
	public function has_errors(): bool {
44
		return count( $this->errors ) >= 1;
45
	}
46
47
	/**
48
	 * Returns all errors.
49
	 *
50
	 * @return string[]
51
	 */
52
	public function get_errors(): array {
53
		return $this->errors;
54
	}
55
56
	/**
57
	 * Adds an error to the collection.
58
	 *
59
	 * @param string $error
60
	 * @return self
61
	 */
62
	public function add_error( string $error ): self {
63
		$this->errors[] = $error;
64
		return $this;
65
	}
66
67
	/**
68
	 * Reset the error collection
69
	 *
70
	 * @return self
71
	 */
72
	public function reset_errors(): self {
73
		$this->errors = array();
74
		return $this;
75
	}
76
77
	/**
78
	 * Validates the class passed.
79
	 *
80
	 * @param \PinkCrab\Registerables\Module\Middleware\Registerable $object_instance
81
	 * @return bool
82
	 */
83
	abstract public function validate( Registerable $object_instance ): bool;
84
}
85