Spamworldpro Mini Shell
Spamworldpro


Server : Apache
System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64
User : corals ( 1002)
PHP Version : 7.4.33
Disable Function : exec,passthru,shell_exec,system
Directory :  /home/corals/old/vendor/magento/module-security/Setup/Patch/Data/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/corals/old/vendor/magento/module-security/Setup/Patch/Data/SessionIDColumnCleanUp.php
<?php
/**
 * Copyright © Magento, Inc. All rights reserved.
 * See COPYING.txt for license details.
 */
declare(strict_types=1);
namespace Magento\Security\Setup\Patch\Data;

use Magento\Framework\DB\Adapter\Pdo\Mysql;
use Magento\Framework\Setup\ModuleDataSetupInterface;
use Magento\Framework\Setup\Patch\DataPatchInterface;
use Psr\Log\LoggerInterface;

/**
 * Class Clean Up Data Removes unused data
 */
class SessionIDColumnCleanUp implements DataPatchInterface
{
    /**
     * @var ModuleDataSetupInterface
     */
    private $moduleDataSetup;

    /**
     * @var LoggerInterface
     */
    private $logger;

    /**
     * RemoveData constructor.
     * @param ModuleDataSetupInterface $moduleDataSetup
     * @param LoggerInterface $logger
     */
    public function __construct(
        ModuleDataSetupInterface $moduleDataSetup,
        LoggerInterface $logger
    ) {
        $this->moduleDataSetup = $moduleDataSetup;
        $this->logger = $logger;
    }

    /**
     * @inheritdoc
     */
    public function apply()
    {
        try {
            $this->cleanAdminUserSessionTable();
        } catch (\Throwable $e) {
            $this->logger->warning(
                'Security module SessionIDColumnCleanUp patch experienced an error and could not be completed.'
                . ' Please submit a support ticket or email us at [email protected].'
            );

            return $this;
        }

        return $this;
    }

    /**
     * Remove session id from admin_user_session table.
     *
     * @throws \Zend_Db_Statement_Exception
     */
    private function cleanAdminUserSessionTable()
    {
        $tableName = $this->moduleDataSetup->getTable('admin_user_session');
        // phpcs:ignore Magento2.SQL.RawQuery
        $rawQuery = sprintf(
            'UPDATE %s SET session_id = NULL WHERE session_id IS NOT NULL LIMIT 1000',
            $tableName
        );

        $adapter = $this->moduleDataSetup->getConnection();
        if ($adapter instanceof Mysql) {
            do {
                $result = $adapter->rawQuery($rawQuery)->rowCount();
            } while ($result > 0);
        } else {
            do {
                $result = $adapter->query($rawQuery)->rowCount();
            } while ($result > 0);
        }
    }

    /**
     * @inheritdoc
     */
    public static function getDependencies()
    {
        return [];
    }

    /**
     * @inheritdoc
     */
    public function getAliases()
    {
        return [];
    }
}

Spamworldpro Mini