GhostManSec
Server: LiteSpeed
System: Linux premium197.web-hosting.com 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User: parhudrw (1725)
PHP: 7.4.33
Disabled: NONE
Upload Files
File: //home/parhudrw/ve.anqa.it/wp-content/plugins/depicter/vendor/averta/core/src/Utility/Arr.php
<?php
namespace Averta\Core\Utility;

use RecursiveArrayIterator;
use RecursiveIteratorIterator;

class Arr
{

	/**
     * Whether keys exist or not
     *
     * @param array $keys   An array of keys to search for
     * @param array $array  The array to search in
     *
     * @return bool
     */
    public static function keysExist( array $keys, array $array )
    {
        return ! array_diff_key( array_flip( $keys ), $array );
    }


	/**
     * camelCase keys of an array
     *
     * @param array   $array        The array or object to check
	 * @param string  $separator    The character that should be removed
     * @param array   $ignoreKeys   The list of keys to ignore
     * @param bool    $recursive    Whether to loop in indented arrays recursively or not
	 *
     * @return mixed
     */
    public static function camelizeKeys( $array, $separator = '_', $ignoreKeys = [], $recursive = false ) {

    	if( is_object( $array ) ){
    		$array = (array) $array;
		}

		if( ! is_array( $array ) ){
			return $array;
		}

		$result = [];

		foreach( $array as $key => $value ) {
			if( ! in_array( $key, $ignoreKeys ) ){
				$key = Str::camelize( $key, $separator );
			}

			if( $recursive && is_array( $value ) ){
				$value = self::camelizeKeys( $value );
			}

			$result[ $key ] = $value;
		}

		return $result;
	}

	/**
	 * Merges the defined arguments into defaults array.
	 *
	 * @param array|object $args     Value to merge with $defaults.
	 * @param array $defaults        Array that serves as the defaults.
	 *
	 * @return array
	 */
	public static function merge( $args, $defaults = [] ) {
		if ( is_object( $args ) ) {
			$args = get_object_vars( $args );
		}

		if ( is_array( $defaults ) && $defaults ) {
			return array_merge( $defaults, $args );
		}

		return $args;
	}

    /**
     * Merges the defined arguments into defaults array recursively.
     *
     * @param array $array    Value to merge with $defaults.
     * @param array $defaults Array that serves as the defaults.
     *
     * @return array
     */
    public static function mergeDeep(array $array, array $defaults) {
        $merged = $defaults;

        foreach ($array as $key => $value) {
            if (is_array($value) && isset($merged[$key]) && is_array($merged[$key])) {
                $merged[$key] = static::mergeDeep($value, $merged[$key]);
            } else {
                $merged[$key] = $value;
            }
        }

        return $merged;
    }

	/**
	 *  Applies the callback to the elements of the given arrays recursively
	 *
	 * @param array $array
	 * @param       $callback
	 */
	public static function mapDeep( $array, $callback ){
		if ( ! empty( $array ) ) {
			foreach ( $array as $index => $value ) {
				call_user_func( $callback, $value, $index );
				if ( is_array( $value ) ) {
					static::mapDeep( $value, $callback );
				}
			}
		}
	}

	/**
	 * Searches the array for a given key and returns the first corresponding value if successful
	 *
	 * @param $haystack
	 * @param $needle
	 *
	 * @return mixed|null
	 */
	public static function searchKeyDeep( $haystack, $needle ){
		$iterator  = new RecursiveArrayIterator( $haystack );
		$recursive = new RecursiveIteratorIterator(
			$iterator,
			RecursiveIteratorIterator::SELF_FIRST
		);
		foreach ( $recursive as $key => $value ) {
			if ( $key === $needle ) {
				return $value;
			}
		}
		return null;
	}

    /**
     * Ensures the value in $args[ $key ] is array
     *
     * @param array  $args
     * @param string $key        The key of array to be checked
     * @param mixed  $default    The default value if item was not set in the array. Pass null to skip setting a value.
     * @param string $separator  Separator in text-separated string
     * @return void
     */
    public static function ensureItemIsArray( &$args, $key, $default = null, $separator = ',' ){
        if ( isset( $args[ $key ] ) ) {
            if ( !is_array( $args[ $key ] ) ) {
                $args[ $key ] = Str::toArray( $args[ $key ], $separator );
            }
        } elseif( ! is_null( $default ) ) {
            $args[ $key ] = $default;
        }
    }

}