Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
100.00% covered (success)
100.00%
19 / 19
100.00% covered (success)
100.00%
2 / 2
CRAP
100.00% covered (success)
100.00%
1 / 1
Required
100.00% covered (success)
100.00%
19 / 19
100.00% covered (success)
100.00%
2 / 2
11
100.00% covered (success)
100.00%
1 / 1
 evaluate
100.00% covered (success)
100.00%
17 / 17
100.00% covered (success)
100.00%
1 / 1
9
 generateDefaultMessage
100.00% covered (success)
100.00%
2 / 2
100.00% covered (success)
100.00%
1 / 1
2
1<?php
2/**
3 * Pop PHP Framework (http://www.popphp.org/)
4 *
5 * @link       https://github.com/popphp/popphp-framework
6 * @author     Nick Sagona, III <dev@noladev.com>
7 * @copyright  Copyright (c) 2009-2025 NOLA Interactive, LLC.
8 * @license    http://www.popphp.org/license     New BSD License
9 */
10
11/**
12 * @namespace
13 */
14namespace Pop\Validator;
15
16/**
17 * Required validator class (alias class)
18 *
19 * @category   Pop
20 * @package    Pop\Validator
21 * @author     Nick Sagona, III <dev@noladev.com>
22 * @copyright  Copyright (c) 2009-2025 NOLA Interactive, LLC.
23 * @license    http://www.popphp.org/license     New BSD License
24 * @version    4.5.0
25 */
26class Required extends AbstractValidator
27{
28
29    /**
30     * Traits
31     */
32    use TraverseTrait;
33
34    /**
35     * Method to evaluate the validator
36     *
37     * @param  mixed $input
38     * @throws Exception
39     * @return bool
40     */
41    public function evaluate(mixed $input = null): bool
42    {
43        // Set the input, if passed
44        if ($input !== null) {
45            $this->input = $input;
46        }
47
48        // Set the default message
49
50        if (!$this->hasMessage()) {
51            $this->generateDefaultMessage();
52        }
53
54        if (!is_array($input)) {
55            throw new Exception('Error: The evaluated input must be an array.');
56        }
57        if (empty($this->value)) {
58            throw new Exception('Error: The evaluated value cannot be empty.');
59        }
60
61        if (!str_contains($this->value, '.')) {
62            return (array_key_exists($this->value, $this->input));
63        } else {
64            $parentValues = [];
65            $childValues  = [];
66
67            self::traverseData(substr($this->value, 0, strrpos($this->value, '.')), $this->input, $parentValues);
68            self::traverseData($this->value, $this->input, $childValues);
69
70            if (isset($parentValues[0][0])) {
71                $parentValues = $parentValues[0];
72            }
73            return (is_array($parentValues) && is_array($childValues) && (count($parentValues) == count($childValues)));
74        }
75    }
76
77    /**
78     * Generate default message
79
80     * @param  mixed $name
81     * @param  mixed $value
82     * @return string
83     */
84    public function generateDefaultMessage(mixed $name = null, mixed $value = null): string
85    {
86        $this->message = "The " . (($name !== null) ? "'" . $name . "'" : "value") . " is required.";
87        return $this->message;
88    }
89
90}