<?php /** * CodeIgniter * * An open source application development framework for PHP * * This content is released under the MIT License (MIT) * * Copyright (c) 2014-2019 British Columbia Institute of Technology * Copyright (c) 2019-2020 CodeIgniter Foundation * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. * * @package CodeIgniter * @author CodeIgniter Dev Team * @copyright 2019-2020 CodeIgniter Foundation * @license https://opensource.org/licenses/MIT MIT License * @link https://codeigniter.com * @since Version 4.0.0 * @filesource */ /** * CodeIgniter Array Helpers * * @package CodeIgniter */ if (! function_exists('dot_array_search')) { /** * Searches an array through dot syntax. Supports * wildcard searches, like foo.*.bar * * @param string $index * @param array $array * * @return mixed|null */ function dot_array_search(string $index, array $array) { $segments = explode('.', rtrim(rtrim($index, '* '), '.')); return _array_search_dot($segments, $array); } } if (! function_exists('_array_search_dot')) { /** * Used by dot_array_search to recursively search the * array with wildcards. * * @param array $indexes * @param array $array * * @return mixed|null */ function _array_search_dot(array $indexes, array $array) { // Grab the current index $currentIndex = $indexes ? array_shift($indexes) : null; if ((empty($currentIndex) && intval($currentIndex) !== 0) || (! isset($array[$currentIndex]) && $currentIndex !== '*')) { return null; } // Handle Wildcard (*) if ($currentIndex === '*') { // If $array has more than 1 item, we have to loop over each. if (is_array($array)) { foreach ($array as $value) { $answer = _array_search_dot($indexes, $value); if ($answer !== null) { return $answer; } } // Still here after searching all child nodes? return null; } } // If this is the last index, make sure to return it now, // and not try to recurse through things. if (empty($indexes)) { return $array[$currentIndex]; } // Do we need to recursively search this value? if (is_array($array[$currentIndex]) && $array[$currentIndex]) { return _array_search_dot($indexes, $array[$currentIndex]); } // Otherwise we've found our match! return $array[$currentIndex]; } }