JEMBOT MAWOT Bypass Shell

Current Path : /home/cinepatreb/billetterie/modules/ps_themecusto/controllers/admin/
Upload File :
Current File : /home/cinepatreb/billetterie/modules/ps_themecusto/controllers/admin/AdminPsThemeCustoAdvanced.php

<?php
/**
* 2007-2018 PrestaShop
*
* 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.txt.
* It is also available through the world-wide-web at this URL:
* http://opensource.org/licenses/osl-3.0.php
* 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 http://www.prestashop.com for more information.
*
* @author PrestaShop SA <contact@prestashop.com>
* @copyright 2007-2018 PrestaShop SA
* @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
* International Registered Trademark & Property of PrestaShop SA
**/
use PrestaShop\PrestaShop\Core\Addon\Theme\ThemeManager;
use PrestaShop\PrestaShop\Core\Addon\Theme\ThemeManagerBuilder;
use PrestaShop\PrestaShop\Core\Addon\Theme\ThemeRepository;
use Symfony\Component\Finder\Finder;

class AdminPsThemeCustoAdvancedController extends ModuleAdminController
{
    /**
     * @var string
     */
    public $skeleton_name;
    /**
     * @var string
     */
    public $childtheme_skeleton;
    /**
     * @var string
     */
    public $sandbox_path;
    /**
     * @var string
     */
    public $controller_quick_name;
    /**
     * @var ThemeManager
     */
    public $theme_manager;
    /**
     * @var ThemeRepository
     */
    public $theme_repository;

    public function __construct()
    {
        parent::__construct();

        $this->skeleton_name = 'childtheme_skeleton';
        $this->childtheme_skeleton = $this->getModule()->module_path . '/src/' . $this->skeleton_name . '.zip';
        $this->sandbox_path = _PS_CACHE_DIR_ . 'sandbox/';
        $this->controller_quick_name = 'advanced';
        $this->theme_manager = (new ThemeManagerBuilder($this->context, Db::getInstance()))->build();
        $this->theme_repository = (new ThemeManagerBuilder($this->context, Db::getInstance()))->buildRepository();
    }

    /**
     * Initialize the content by adding Boostrap and loading the TPL
     */
    public function initContent()
    {
        parent::initContent();

        $this->context->smarty->assign([
            'enable' => $this->getModule()->active,
            'moduleName' => $this->getModule()->displayName,
            'bootstrap' => 1,
            'configure_type' => $this->controller_quick_name,
            'images' => $this->getModule()->img_path . '/controllers/advanced/',
        ]);
        $aJsDef = [
            'admin_module_controller_psthemecusto' => $this->getModule()->controller_name[0],
            'admin_module_ajax_url_psthemecusto' => $this->getModule()->front_controller[0],
            'default_error_upload' => $this->trans('An error occured, please check your zip file'),
            'file_not_valid' => $this->trans('The file is not valid.'),
        ];
        $aJs = [
            $this->getModule()->js_path . '/controllers/' . $this->controller_quick_name . '/dropzone.js',
            $this->getModule()->js_path . '/controllers/' . $this->controller_quick_name . '/back.js',
        ];
        $aCss = [$this->getModule()->css_path . '/controllers/' . $this->controller_quick_name . '/back.css'];
        $this->getModule()->setMedia($aJsDef, $aJs, $aCss);

        $this->setTemplate($this->getModule()->template_dir . 'page.tpl');
    }

    /**
     * Clone a theme and modify the config to set the parent theme
     *
     * @return bool
     */
    public function ajaxProcessDownloadChildTheme()
    {
        $bPrepareChildtheme = self::prepareChildTheme(_THEME_NAME_, _PS_THEME_DIR_);

        if (!$bPrepareChildtheme) {
            exit(false);
        }

        $bCreateChildTheme = self::createChildTheme(_THEME_NAME_);

        if (!$bCreateChildTheme) {
            exit(false);
        }

        exit(self::getChildTheme(_THEME_NAME_, _PS_ROOT_DIR_));
    }

    /**
     * Prepare the child theme
     *
     * @param string $sParentThemeName
     * @param string $sParentThemeDir
     *
     * @return bool
     */
    private function prepareChildTheme($sParentThemeName, $sParentThemeDir)
    {
        Tools::ZipExtract($this->childtheme_skeleton, $this->sandbox_path);

        $aStringToReplace = [
            '{childtheme_parent}' => $sParentThemeName,
            '{childtheme_name}' => 'child_' . $sParentThemeName,
            '{childtheme_description}' => 'Child theme of ' . $sParentThemeName . '\'s theme',
        ];

        $sChildThemeConfigPath = $this->sandbox_path . '/' . $this->skeleton_name . '/config/theme.yml';

        $sConfigFile = @file_get_contents($sChildThemeConfigPath);

        foreach ($aStringToReplace as $sSearchElement => $sReplace) {
            $sConfigFile = str_replace($sSearchElement, $sReplace, $sConfigFile);
        }

        $bPutContents = @file_put_contents($sChildThemeConfigPath, $sConfigFile);

        if (!$bPutContents) {
            return false;
        }

        return @copy($sParentThemeDir . '/preview.png', $this->sandbox_path . '/' . $this->skeleton_name . '/preview.png');
    }

    /**
     * Create the child theme
     *
     * @param string $sParentThemeName
     *
     * @return bool
     */
    private function createChildTheme($sParentThemeName)
    {
        $sChildThemeFolderName = 'child_' . $sParentThemeName;

        $oZip = new ZipArchive();
        $oZip->open($this->sandbox_path . '/' . $sChildThemeFolderName . '.zip', ZipArchive::CREATE);
        $fileList = Finder::create()
            ->files()
            ->in($this->sandbox_path . '/' . $this->skeleton_name . '/');

        foreach ($fileList as $file) {
            $oZip->addFile($file->getRealpath(), $sChildThemeFolderName . '/' . $file->getRelativePathName());
        }

        return $oZip->close();
    }

    /**
     * Move the ZIP archive into Theme's folder and unlink all the files in sandbox
     *
     * @param string $sParentThemeName
     *
     * @return string
     */
    private function getChildTheme($sParentThemeName, $sPrestashopRootDir)
    {
        $sChildThemeZipName = 'child_' . $sParentThemeName . '.zip';

        @rename($this->sandbox_path . '/' . $sChildThemeZipName, $sPrestashopRootDir . '/themes/' . $sChildThemeZipName);

        self::recursiveDelete($this->sandbox_path . $this->skeleton_name);

        return $this->getModule()->ps_uri . '/themes/' . $sChildThemeZipName;
    }

    /**
     * AJAX getting a file attachment and will upload the file, install it, check if there's modules in it ...
     *
     * @return string
     */
    public function ajaxProcessUploadChildTheme()
    {
        $aChildThemeReturned = Tools::fileAttachment('file');
        $sZipPath = self::processUploadFileChild($aChildThemeReturned, $this->sandbox_path . $aChildThemeReturned['rename']);
        $bZipFormat = self::processCheckZipFormat($sZipPath);
        if (!$bZipFormat) {
            exit(json_encode([
                'state' => 0,
                'message' => $this->trans('Make sure you zip your edited theme files directly to the root of your child theme\'s folder before uploading it.'),
            ]));
        }

        $bUploadIsClean = self::processCheckFiles($sZipPath, $this->sandbox_path . rand());

        if (!$bUploadIsClean) {
            exit(json_encode([
                'state' => 0,
                'message' => $this->trans('There is some PHP files in your ZIP'),
            ]));
        }

        /** @var bool|string $sFolderPath */
        $sFolderPath = self::postProcessInstall($sZipPath);

        if ($sFolderPath === false) {
            @unlink($sZipPath);
            exit(json_encode([
                'state' => 0,
                'message' => $this->trans('The theme already exists or the parent name in the config file is wrong'),
            ]));
        }

        if (!self::checkIfIsChildTheme($sFolderPath)) {
            self::recursiveDelete($sFolderPath);
            exit(json_encode([
                'state' => 0,
                'message' => $this->trans('You must enter the parent theme name in the theme.yml file. Furthermore, the parent name must be the current parent theme.'),
            ]));
        }

        exit(json_encode([
            'state' => 1,
            'message' => $this->trans('The child theme has been added successfully.'),
        ]));
    }

    /**
     * Check upload file on upload
     *
     * @param array $aChildThemeReturned
     * @param string $dest
     *
     * @return string|bool
     */
    public function processUploadFileChild($aChildThemeReturned, $dest)
    {
        if (!$this->getModule()->hasEditRight()) {
            return $this->trans('You do not have permission to edit this.');
        }

        switch ($aChildThemeReturned['error']) {
            case UPLOAD_ERR_OK:
                break;
            case UPLOAD_ERR_INI_SIZE:
            case UPLOAD_ERR_FORM_SIZE:
                $this->errors[] = $this->trans('The uploaded file is too large.', [], 'Admin.Design.Notification');

                return false;
            default:
                $this->errors[] = $this->trans('Unknown error.', [], 'Admin.Notifications.Error');

                return false;
        }

        $tmp_name = $aChildThemeReturned['tmp_name'];
        $goodMimeType = false;

        $mimeType = self::processCheckMimeType($tmp_name);

        if (!empty($mimeType)) {
            preg_match('#application/zip#', $mimeType, $matches);
            if (!empty($matches)) {
                $goodMimeType = true;
            }
        }

        if (false === $goodMimeType) {
            $this->errors[] = $this->trans('Invalid file format.', [], 'Admin.Design.Notification');

            return false;
        }

        $name = $aChildThemeReturned['name'];
        if (!Validate::isFileName($name)) {
            $dest = _PS_ALL_THEMES_DIR_ . sha1_file($tmp_name) . '.zip';
        }

        if (!move_uploaded_file(
            $aChildThemeReturned['tmp_name'],
            $dest
        )) {
            $this->errors[] = $this->trans('Failed to move uploaded file.', [], 'Admin.Design.Notification');

            return false;
        }

        $bZipeFileIsValid = self::checkZipFile($aChildThemeReturned, $dest);

        if (!$bZipeFileIsValid) {
            $this->errors[] = $this->trans('Unknown error.', [], 'Admin.Notifications.Error');

            return false;
        }

        return $dest;
    }

    /**
     * Check zip file and modify it if necessary
     *
     * @param array $aChildThemeReturned
     * @param string $sZipPath
     *
     * @return bool
     */
    public function checkZipFile($aChildThemeReturned, $sZipPath)
    {
        $oZip = new ZipArchive();
        $oZip->open($sZipPath);
        $aHaveRootFolder = [];

        for ($i = 0; $i < $oZip->numFiles; ++$i) {
            $aZipElement = explode('/', $oZip->getNameIndex($i));
            $aHaveRootFolder[$i] = count($aZipElement);
            /* If we get 1 we can stop it because the zip architecture is valid */
            if ($aHaveRootFolder[$i] == 1) {
                break;
            }
        }

        /*
            if 1 : There is no root foler
            if no 1 : There is root folder
            The zip file has a root folder ? We must remove it
        */
        if (!in_array(1, $aHaveRootFolder)) {
            $oZip->extractTo($this->sandbox_path);
            $oZip->close();
            @unlink($sZipPath);
            $aFolderName = explode('.zip', $aChildThemeReturned['name']);
            $sFolderName = $aFolderName[0];
            $oZipCreate = new ZipArchive();
            $oZipCreate->open($this->sandbox_path . '/' . $aChildThemeReturned['rename'], ZipArchive::CREATE);
            $fileList = Finder::create()->in($this->sandbox_path . '/' . $sFolderName . '/');

            foreach ($fileList as $file) {
                if ($file->isDir()) {
                    $oZipCreate->addEmptyDir($file->getRelativePathName());
                } else {
                    $oZipCreate->addFile($file->getRealpath(), '' . $file->getRelativePathName());
                }
            }

            $bZipCreateClose = (bool) $oZipCreate->close();
            $bRecursiveDelete = (bool) self::recursiveDelete($this->sandbox_path . '/' . $sFolderName . '/');

            return $bZipCreateClose && $bRecursiveDelete;
        } else {
            return $oZip->close();
        }
    }

    /**
     * Get the mime type of the file
     *
     * @param string $tmp_name
     *
     * @return string
     */
    public function processCheckMimeType($tmp_name)
    {
        $mimeType = '';

        if (function_exists('finfo_open')) {
            $finfo = @finfo_open(FILEINFO_MIME);
            $mimeType = @finfo_file($finfo, $tmp_name);
            @finfo_close($finfo);
        } elseif (function_exists('mime_content_type')) {
            $mimeType = @mime_content_type($tmp_name);
        } elseif (function_exists('exec')) {
            $mimeType = trim(@exec('file -b --mime-type ' . escapeshellarg($tmp_name)));
            if (!$mimeType) {
                $mimeType = trim(@exec('file --mime ' . escapeshellarg($tmp_name)));
            }
            if (!$mimeType) {
                $mimeType = trim(@exec('file -bi ' . escapeshellarg($tmp_name)));
            }
        }

        return $mimeType;
    }

    /**
     * We check if the Zip is valid. The root folder must have all the theme element, we check it with the folder Config.
     *
     * @param string $sZipPath
     *
     * @return bool $bZipIsValid
     */
    public function processCheckZipFormat($sZipPath)
    {
        $oZip = new ZipArchive();
        $oZip->open($sZipPath);
        $aRootFilesAndFolders = [];

        for ($i = 0; $i < $oZip->numFiles; ++$i) {
            $aZipElement = array_filter(explode('/', $oZip->getNameIndex($i)));
            if (count($aZipElement) == 1) {
                $aRootFilesAndFolders[] = $aZipElement[0];
            }
        }

        $oZip->close();

        if (in_array('config', $aRootFilesAndFolders)) {
            $bZipIsValid = true;
        } else {
            $bZipIsValid = false;
            @unlink($sZipPath);
        }

        return $bZipIsValid;
    }

    /**
     * We unzip the child theme zip in a sandbox to check it
     *
     * @param string $sZipSource
     * @param string $sSandboxPath
     *
     * @return string|bool
     */
    public function processCheckFiles($sZipSource, $sSandboxPath)
    {
        if (!$this->getModule()->hasEditRight()) {
            return $this->trans('You do not have permission to edit this.');
        }

        Tools::ZipExtract($sZipSource, $sSandboxPath);

        $bCleanFiles = self::getDirPhpContents($sZipSource, $sSandboxPath);

        self::recursiveDelete($sSandboxPath);

        return $bCleanFiles;
    }

    /**
     * We check if there is some PHP files
     *
     * @param string $sZipSource
     * @param string $sSandboxPath
     *
     * @return bool
     */
    private function getDirPhpContents($sZipSource, $sSandboxPath)
    {
        $sPattern = '#[.\-\/](php)#';
        $sIndexPhpFile = Tools::getDefaultIndexContent();

        $zip = new ZipArchive();
        $it = new RecursiveDirectoryIterator($sSandboxPath, RecursiveDirectoryIterator::SKIP_DOTS);
        $files = new RecursiveIteratorIterator($it, RecursiveIteratorIterator::CHILD_FIRST);

        $zip->open($sZipSource);

        foreach ($files as $file) {
            if (!$file->isDir()) {
                $sSubject = $file->getFilename() . self::processCheckMimeType($file->getRealPath());
                if ($file->getFilename() === 'index.php') {
                    $sRealPathFile = str_replace($sSandboxPath . '/', '', $file->getRealPath());
                    $zip->deleteName($sRealPathFile);
                    $zip->addFromString($sRealPathFile, $sIndexPhpFile);
                } elseif (preg_match($sPattern, $sSubject)) {
                    $zip->close();

                    return false;
                }
            }
        }
        $zip->close();

        return true;
    }

    /**
     * We install the child theme and we return the folder child theme's name
     *
     * @param string $dest
     *
     * @return string|bool
     */
    public function postProcessInstall($dest)
    {
        if (!$this->getModule()->hasEditRight()) {
            return $this->trans('You do not have permission to edit this.');
        }
        $aFolder = [];

        try {
            $this->theme_manager->install($dest);
            @unlink($dest);
            $aFolderScan = @scandir(_PS_ALL_THEMES_DIR_);

            foreach ($aFolderScan as $key => $sObject) {
                $sDirThemeFolder = _PS_ALL_THEMES_DIR_ . $sObject;
                if (is_dir($sDirThemeFolder) && !in_array($sObject, ['.', '..'])) {
                    $aFolder[filemtime($sDirThemeFolder)] = $sDirThemeFolder;
                }
            }

            krsort($aFolder);
            $aChildthemeFolder = array_values($aFolder);

            return $aChildthemeFolder[0];
        } catch (Exception $e) {
            return false;
        }
    }

    /**
     * We check in theme.yml if this theme is a child theme of the current main theme.
     *
     * @param string $sFolderPath
     *
     * @return bool
     */
    public function checkIfIsChildTheme($sFolderPath)
    {
        $sFile = 'theme.yml';
        $aLines = file($sFolderPath . '/config/' . $sFile);
        $sSearchString = 'parent:';
        $bIsChildTheme = false;

        foreach ($aLines as $line) {
            if (strpos($line, $sSearchString) !== false) {
                $aParentThemeName = explode(':', $line);
                $sParentThemeName = trim($aParentThemeName[1]);
                if ($sParentThemeName == _THEME_NAME_) {
                    $bIsChildTheme = true;
                }
                break;
            }
        }

        return $bIsChildTheme;
    }

    /**
     * the child theme has modules. We can't keep it.
     *
     * @param string $sFolderPath
     *
     * @return bool
     */
    public function recursiveDelete($sFolderPath)
    {
        $it = new RecursiveDirectoryIterator($sFolderPath, RecursiveDirectoryIterator::SKIP_DOTS);
        $files = new RecursiveIteratorIterator($it, RecursiveIteratorIterator::CHILD_FIRST);
        foreach ($files as $file) {
            if ($file->isDir()) {
                @rmdir($file->getRealPath());
            } else {
                @unlink($file->getRealPath());
            }
        }

        return @rmdir($sFolderPath);
    }

    /**
     * @return ps_themecusto
     */
    private function getModule()
    {
        /* @phpstan-ignore-next-line */
        return $this->module;
    }
}

xxxxx1.0, XXX xxxx