Your IP : 216.73.216.220


Current Path : /var/www/html/vendor/magento/module-store/Model/StoreSwitcher/
Upload File :
Current File : /var/www/html/vendor/magento/module-store/Model/StoreSwitcher/CleanTargetUrl.php

<?php
/**
 * Copyright © Magento, Inc. All rights reserved.
 * See COPYING.txt for license details.
 */
declare(strict_types=1);

namespace Magento\Store\Model\StoreSwitcher;

use Magento\Store\Api\Data\StoreInterface;
use Magento\Store\Api\StoreResolverInterface;
use Magento\Store\Model\StoreSwitcherInterface;
use Magento\Framework\Url\Helper\Data as UrlHelper;

/**
 * Remove SID, from_store, store from target url.
 *
 * Used in store-switching process in HTML frontend.
 */
class CleanTargetUrl implements StoreSwitcherInterface
{
    /**
     * @var UrlHelper
     */
    private $urlHelper;

    /**
     * @param UrlHelper $urlHelper
     */
    public function __construct(
        UrlHelper $urlHelper
    ) {
        $this->urlHelper = $urlHelper;
    }

    /**
     * Generate target URL to switch stores through other mechanism then via URL params.
     *
     * @param StoreInterface $fromStore store where we came from
     * @param StoreInterface $targetStore store where to go to
     * @param string $redirectUrl original url requested for redirect after switching
     * @return string redirect url
     * @SuppressWarnings(PHPMD.UnusedFormalParameter)
     */
    public function switch(StoreInterface $fromStore, StoreInterface $targetStore, string $redirectUrl): string
    {
        $targetUrl = $redirectUrl;
        $targetUrl = $this->urlHelper->removeRequestParam($targetUrl, '___from_store');
        $targetUrl = $this->urlHelper->removeRequestParam($targetUrl, StoreResolverInterface::PARAM_NAME);

        return $targetUrl;
    }
}