Вход Регистрация
Файл: vendor/laravel/framework/src/Illuminate/Support/ValidatedInput.php
Строк: 180
<?php

namespace IlluminateSupport;

use 
ArrayIterator;
use 
IlluminateContractsSupportValidatedData;
use 
stdClass;
use 
Traversable;

class 
ValidatedInput implements ValidatedData
{
    
/**
     * The underlying input.
     *
     * @var array
     */
    
protected $input;

    
/**
     * Create a new validated input container.
     *
     * @param  array  $input
     * @return void
     */
    
public function __construct(array $input)
    {
        
$this->input $input;
    }

    
/**
     * Determine if the validated input has one or more keys.
     *
     * @param  mixed  $keys
     * @return bool
     */
    
public function has($keys)
    {
        
$keys is_array($keys) ? $keys func_get_args();

        foreach (
$keys as $key) {
            if (! 
Arr::has($this->input$key)) {
                return 
false;
            }
        }

        return 
true;
    }

    
/**
     * Determine if the validated input is missing one or more keys.
     *
     * @param  mixed  $keys
     * @return bool
     */
    
public function missing($keys)
    {
        return ! 
$this->has($keys);
    }

    
/**
     * Get a subset containing the provided keys with values from the input data.
     *
     * @param  mixed  $keys
     * @return array
     */
    
public function only($keys)
    {
        
$results = [];

        
$input $this->input;

        
$placeholder = new stdClass;

        foreach (
is_array($keys) ? $keys func_get_args() as $key) {
            
$value data_get($input$key$placeholder);

            if (
$value !== $placeholder) {
                
Arr::set($results$key$value);
            }
        }

        return 
$results;
    }

    
/**
     * Get all of the input except for a specified array of items.
     *
     * @param  mixed  $keys
     * @return array
     */
    
public function except($keys)
    {
        
$keys is_array($keys) ? $keys func_get_args();

        
$results $this->input;

        
Arr::forget($results$keys);

        return 
$results;
    }

    
/**
     * Merge the validated input with the given array of additional data.
     *
     * @param  array  $items
     * @return static
     */
    
public function merge(array $items)
    {
        return new static(
array_merge($this->input$items));
    }

    
/**
     * Get the input as a collection.
     *
     * @return IlluminateSupportCollection
     */
    
public function collect()
    {
        return new 
Collection($this->input);
    }

    
/**
     * Get the raw, underlying input array.
     *
     * @return array
     */
    
public function all()
    {
        return 
$this->input;
    }

    
/**
     * Get the instance as an array.
     *
     * @return array
     */
    
public function toArray()
    {
        return 
$this->all();
    }

    
/**
     * Dynamically access input data.
     *
     * @param  string  $name
     * @return mixed
     */
    
public function __get($name)
    {
        return 
$this->input[$name];
    }

    
/**
     * Dynamically set input data.
     *
     * @param  string  $name
     * @param  mixed  $value
     * @return mixed
     */
    
public function __set($name$value)
    {
        
$this->input[$name] = $value;
    }

    
/**
     * Determine if an input key is set.
     *
     * @return bool
     */
    
public function __isset($name)
    {
        return isset(
$this->input[$name]);
    }

    
/**
     * Remove an input key.
     *
     * @param  string  $name
     * @return void
     */
    
public function __unset($name)
    {
        unset(
$this->input[$name]);
    }

    
/**
     * Determine if an item exists at an offset.
     *
     * @param  mixed  $key
     * @return bool
     */
    
public function offsetExists($key): bool
    
{
        return isset(
$this->input[$key]);
    }

    
/**
     * Get an item at a given offset.
     *
     * @param  mixed  $key
     * @return mixed
     */
    
public function offsetGet($key): mixed
    
{
        return 
$this->input[$key];
    }

    
/**
     * Set the item at a given offset.
     *
     * @param  mixed  $key
     * @param  mixed  $value
     * @return void
     */
    
public function offsetSet($key$value): void
    
{
        if (
is_null($key)) {
            
$this->input[] = $value;
        } else {
            
$this->input[$key] = $value;
        }
    }

    
/**
     * Unset the item at a given offset.
     *
     * @param  string  $key
     * @return void
     */
    
public function offsetUnset($key): void
    
{
        unset(
$this->input[$key]);
    }

    
/**
     * Get an iterator for the input.
     *
     * @return ArrayIterator
     */
    
public function getIterator(): Traversable
    
{
        return new 
ArrayIterator($this->input);
    }
}
Онлайн: 0
Реклама