⚝
One Hat Cyber Team
⚝
Your IP:
216.73.216.1
Server IP:
185.238.29.86
Server:
Linux server2 6.8.12-6-pve #1 SMP PREEMPT_DYNAMIC PMX 6.8.12-6 (2024-12-19T19:05Z) x86_64
Server Software:
nginx/1.18.0
PHP Version:
8.1.31
Buat File
|
Buat Folder
Eksekusi
Dir :
~
/
var
/
www
/
olasjoys
/
src
/
Core
/
Hook
/
Generator
/
View File Name :
HookDescriptionGenerator.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\Hook\Generator; use PrestaShop\PrestaShop\Core\Hook\HookDescription; use PrestaShop\PrestaShop\Core\Util\String\StringModifierInterface; use PrestaShop\PrestaShop\Core\Util\String\StringValidatorInterface; /** * Generates description for hook names. */ final class HookDescriptionGenerator implements HookDescriptionGeneratorInterface { /** * @var array */ private $hookDescriptions; /** * @var StringValidatorInterface */ private $stringValidator; /** * @var StringModifierInterface */ private $stringModifier; /** * @param array $hookDescriptions * @param StringValidatorInterface $stringValidator * @param StringModifierInterface $stringModifier */ public function __construct( array $hookDescriptions, StringValidatorInterface $stringValidator, StringModifierInterface $stringModifier ) { $this->hookDescriptions = $hookDescriptions; $this->stringValidator = $stringValidator; $this->stringModifier = $stringModifier; } /** * {@inheritdoc} */ public function generate($hookName) { foreach ($this->hookDescriptions as $hookPlaceholder => $hookDescription) { $prefix = isset($hookDescription['prefix']) ? $hookDescription['prefix'] : ''; $suffix = isset($hookDescription['suffix']) ? $hookDescription['suffix'] : ''; if ($this->stringValidator->startsWithAndEndsWith($hookName, $prefix, $suffix) && !$this->stringValidator->doesContainsWhiteSpaces($hookName) ) { $hookId = $this->extractHookId($hookName, $prefix, $suffix); return new HookDescription( $hookName, $this->getTextWithHookId($hookDescription['title'], $hookId), $this->getTextWithHookId($hookDescription['description'], $hookId) ); } } return new HookDescription( $hookName, '', '' ); } /** * Removes from hook name id prefix and suffix. * * @param string $hookName * @param string $prefix * @param string $suffix * * @return string */ private function extractHookId($hookName, $prefix, $suffix) { return str_replace([$prefix, $suffix], '', $hookName); } /** * Gets text with replaced hook id. * * @param string $description * @param string $hookId * * @return string */ private function getTextWithHookId($description, $hookId) { if (!$this->doesHookDescriptionContainsPlaceholder($description)) { return $description; } $hookIdSplitByCamelCase = $this->stringModifier->splitByCamelCase($hookId); $isPlaceholderAsFirstValueInString = $this->doesPlaceholderIsTheFirstElementOfTheDescription($description); if ($isPlaceholderAsFirstValueInString) { $hookIdSplitByCamelCase = ucfirst($hookIdSplitByCamelCase); } else { $hookIdSplitByCamelCase = strtolower($hookIdSplitByCamelCase); } return sprintf($description, $hookIdSplitByCamelCase); } /** * Checks if hook description contains placeholder value. * * @param string $description * * @return bool */ private function doesHookDescriptionContainsPlaceholder($description) { return false !== strpos($description, '%s'); } /** * Checks if placeholder is the first element of the string. * * @param string $description * * @return bool */ private function doesPlaceholderIsTheFirstElementOfTheDescription($description) { return 0 === strncmp($description, '%s', 2); } }