ICanBoogie/Validate v0.1.0
  • Namespace
  • Class

Namespaces

  • ICanBoogie
    • Validate
      • Reader
      • Validation
      • Validator
      • ValidatorProvider

Classes

  • AbstractComparisonValidator
  • AbstractRangeValidator
  • AbstractValidator
  • Between
  • BetweenLength
  • Blank
  • Boolean
  • Email
  • Equal
  • Identical
  • IsFalse
  • IsNull
  • IsTrue
  • JSON
  • Max
  • MaxLength
  • Min
  • MinLength
  • NotBetween
  • NotBetweenLength
  • NotBlank
  • NotEqual
  • NotIdentical
  • NotNull
  • Regex
  • Required
  • TimeZone
  • Type
  • URL
  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  79  80  81  82  83  84  85  86  87  88  89  90  91  92  93  94  95  96  97  98  99 100 101 102 103 104 
<?php

/*
 * This file is part of the ICanBoogie package.
 *
 * (c) Olivier Laviale <olivier.laviale@gmail.com>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace ICanBoogie\Validate\Validator;

use ICanBoogie\Validate\Context;

/**
 * Validates that a value is of a specific type.
 */
class Type extends AbstractValidator
{
    const ALIAS = 'type';
    const DEFAULT_MESSAGE = "should be of type {type}";

    const PARAM_TYPE = 'type';

    /**
     * Mapping for `is_*` and `ctype_*` functions.
     *
     * @var array
     */
    static private $mapping = [

        'is' => [ 'array', 'bool', 'double', 'float', 'int', 'integer', 'long',
            'null', 'numeric', 'object', 'real', 'resource', 'scalar', 'string' ],

        'ctype' => [ 'alnum', 'alpha', 'cntrl', 'digit', 'graph', 'lower',
            'print', 'punct', 'space', 'upper', 'xdigit' ]

    ];

    /**
     * @inheritdoc
     */
    public function validate($value, Context $context)
    {
        $context->message_args[self::PARAM_TYPE] = $type = $context->param(self::PARAM_TYPE);
        $callable = $this->resolve_callable($this->normalize_type($type));

        if ($callable)
        {
            return $callable($value);
        }

        return $value instanceof $type;
    }

    /**
     * @inheritdoc
     */
    protected function get_params_mapping()
    {
        return [ self::PARAM_TYPE ];
    }

    /**
     * Normalizes type.
     *
     * @param string $type
     *
     * @return string
     */
    protected function normalize_type($type)
    {
        $type = strtolower($type);

        if ($type == 'boolean')
        {
            $type = 'bool';
        }

        return $type;
    }

    /**
     * Resolves callable to validate type.
     *
     * @param string $type
     *
     * @return string|null
     */
    protected function resolve_callable($type)
    {
        foreach (self::$mapping as $prefix => $types)
        {
            if (in_array($type, $types))
            {
                return "{$prefix}_{$type}";
            }
        }

        return null;
    }
}
ICanBoogie/Validate v0.1.0 API documentation generated by ApiGen