Current File : //var/www/vinorea/src/Core/Search/Builder/RequestFiltersBuilder.php
<?php
/**
 * Copyright since 2007 PrestaShop SA and Contributors
 * PrestaShop is an International Registered Trademark & Property of PrestaShop SA
 *
 * NOTICE OF LICENSE
 *
 * This source file is subject to the Open Software License (OSL 3.0)
 * that is bundled with this package in the file LICENSE.md.
 * It is also available through the world-wide-web at this URL:
 * https://opensource.org/licenses/OSL-3.0
 * If you did not receive a copy of the license and are unable to
 * obtain it through the world-wide-web, please send an email
 * to license@prestashop.com so we can send you a copy immediately.
 *
 * DISCLAIMER
 *
 * Do not edit or add to this file if you wish to upgrade PrestaShop to newer
 * versions in the future. If you wish to customize PrestaShop for your
 * needs please refer to https://devdocs.prestashop.com/ for more information.
 *
 * @author    PrestaShop SA and Contributors <contact@prestashop.com>
 * @copyright Since 2007 PrestaShop SA and Contributors
 * @license   https://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
 */

namespace PrestaShop\PrestaShop\Core\Search\Builder;

use PrestaShop\PrestaShop\Core\Search\Filters;
use Symfony\Component\HttpFoundation\Request;

/**
 * This builder builds a Filters instance from the request, it is able to fetch the
 * parameters from both GET and POST requests. If the built filter has a filterId
 * it filters the request parameters in a scope (e.g: ?language[limit]=10 instead of
 * ?limit=10)
 * The filterId can be set
 *  - from the builder config
 *  - from the provided filter which class has a default filterId
 *  - from the provided filter which has been manually instantiated with a filterId
 */
final class RequestFiltersBuilder extends AbstractFiltersBuilder
{
    /** @var Request */
    private $request;

    /**
     * {@inheritdoc}
     */
    public function setConfig(array $config)
    {
        $this->request = isset($config['request']) ? $config['request'] : null;

        return parent::setConfig($config);
    }

    /**
     * {@inheritdoc}
     */
    public function buildFilters(Filters $filters = null)
    {
        if (null === $this->request) {
            return $filters;
        }

        $filterId = $this->getFilterId($filters);
        $queryParams = $this->request->query->all();
        $requestParams = $this->request->request->all();

        //If filters have a filterId then parameters are sent in a namespace (eg: grid_id[limit]=10 instead of limit=10)
        if (!empty($filterId)) {
            $queryParams = isset($queryParams[$filterId]) ? $queryParams[$filterId] : [];
            $requestParams = isset($requestParams[$filterId]) ? $requestParams[$filterId] : [];
        }

        $parameters = [];
        foreach (self::FILTER_TYPES as $type) {
            if (isset($queryParams[$type])) {
                $parameters[$type] = $queryParams[$type];
            } elseif (isset($requestParams[$type])) {
                $parameters[$type] = $requestParams[$type];
            }
        }

        if (null !== $filters) {
            $filters->add($parameters);
        } else {
            $filters = new Filters($parameters, $filterId);
        }

        return $filters;
    }
}