Новости Joomla

‼️ 👩‍💻 Обновление безопасности для Tassos Framework!

‼️ 👩‍💻 Обновление безопасности для Tassos Framework!

7 января 2026 года греческому разработчику Тассосу Мариносу сообщили об уязвимости в системном плагине Tassos Framework, который входит в состав его расширений для Joomla.

⚠️ Проблема затрагивает следующие расширения:
- Convert Forms - конструктор форм обратной связи для Joomla
- EngageBox - конструктор всплывающих окон для Joomla
- Google Structured Data - пакет плагинов микроразметки для Joomla
- Advanced Custom Fields - пакет плагинов пользовательских полей (видео-сервисы, карты и иже с ними)
- Smile Pack - пакет расширений
- MailChimp Auto-Subscribe

Незамедлительно была проведена полная внутренняя проверка кода, внедрены дополнительные меры проверки и повышения безопасности, а также выпущены исправленные версии всех затронутых расширений. Проблема полностью решена.

👉 Суть уязвимости.
Уязвимость заключалась в том, как плагин Tassos Framework обрабатывал определенные AJAX-запросы через com_ajaxточку входа Joomla. При определенных условиях внутренняя функциональность фреймворка могла быть вызвана без надлежащих ограничений.

В худшем случае это могло позволить неавторизованному злоумышленнику читать файлы, доступные веб-серверу. Это также могло позволить удалять файлы с сервера при выполнении определенных условий.

При определенных обстоятельствах запросы к базе данных могли быть изменены для извлечения данных из базы данных Joomla. В совокупности эти возможности потенциально могли быть использованы для повышения уровня доступа и выполнения несанкционированного кода.

В настоящее время нет никаких доказательств того, что эта уязвимость была использована в реальных условиях.

Немедленно обновите расширения до безопасных версий (Joomla 4/5/6 | Joomla 3):
- Convert Forms - v5.1.1 / v.4.1.1
- EngageBox - v.7.1.1 / v,6,3,9
- Google Structured Data - v.6.1.1 / v.5.6.9
- Advanced Custom Fields - v.3.1.1 / v.2.8.10
- Smile Pack - v.2.1.1 / v.1.2.4.
- MailChimp Auto-Subscribe - v.5.1.1+ / v.5.0.4

Все указанные версии включают в себя релиз безопасности плагина Tassos Framework System Plugin v6.0.62.

Если у вас установлено несколько расширений Tassos, достаточно обновить только одно, чтобы применить патч. Однако всегда рекомендуется обновлять все расширения.

@joomlafeed

0 Пользователей и 1 Гость просматривают эту тему.
  • 2 Ответов
  • 4465 Просмотров

Подскажите, пожалуйста, как можно сделать, чтобы кнопка "Пересчитать" (Обновить) при просмотре корзины была не возле каждого товара, а внизу, и пересчитывала сразу все измененные поля. Спасибо.
« Последнее редактирование: 13.02.2007, 15:27:03 от konstant »

Вобщем-та, сделал все сам  ::)

Кому интересно:
1.\administrator\components\com_virtuemart\html\basket.php
Код
/* Quantity Box */
$product_rows[$i]['quantity_box'] = "<input type=\"text\" title=\"". $VM_LANG->_PHPSHOP_CART_UPDATE ."\" class=\"inputbox\" size=\"4\" maxlength=\"4\" name=\"quantity\" value=\"".$cart[$i]["quantity"]."\" />";
заменяем на
Код
/* Quantity Box */
$product_rows[$i]['quantity_box'] = "<input type=\"text\" title=\"". $VM_LANG->_PHPSHOP_CART_UPDATE ."\" class=\"inputbox\" size=\"4\" maxlength=\"4\" id=\"quantity".$i."\" name=\"quantity".$i."\" value=\"".$cart[$i]["quantity"]."\" onblur=\"document.getElementById('quantity1".$i."').value=this.value\"/>";

2. Здесь же:
В самый конец скрипта перед ?> вставляем:
Код
$single['update_form'] = "";
$action_url = $mm_action_url."index.php";

$single['update_form'] =  "<form action=\"$action_url\" method=\"post\" name=\"update\">\n<input type=\"hidden\" name=\"option\" value=\"com_virtuemart\" />\n";
$single['update_form'] =  $single['update_form'] . "<input type=\"hidden\" name=\"page\" value=\"". $_REQUEST['page'] ."\" />\n";
        $single['update_form'] =  $single['update_form'] . "<input type=\"hidden\" name=\"func\" value=\"cartUpdate\" />\n";

for ($i=0;$i<$cart["idx"];$i++) {

$product_rows[$i]['product_attributes'] = "";
if ($product_parent_id) {
$db_detail=$ps_product->attribute_sql($cart[$i]["product_id"],$product_parent_id);
while ($db_detail->next_record()) {
$product_rows[$i]['product_attributes'] .= "<br />" . $db_detail->f("attribute_name") . "&nbsp;";
$product_rows[$i]['product_attributes'] .= "(" . $db_detail->f("attribute_value") . ")";
}
}
$single['update_form'] =  $single['update_form'] . "<input type=\"hidden\" id=\"quantity1".$i."\" name=\"quantity1[]\" value=\"".$cart[$i]["quantity"]."\" />";
$single['update_form'] =  $single['update_form'] . "<input type=\"hidden\" id=\"product_id2\" name=\"product_id1[]\" value=\"". $_SESSION['cart'][$i]["product_id"] ."\" />\n";
        $single['update_form'] =  $single['update_form'] . "<input type=\"hidden\" name=\"Itemid\" value=\"". @$_REQUEST['Itemid'] ."\" />\n";
        $single['update_form'] =  $single['update_form'] . "<input type=\"hidden\" name=\"description\" value=\"". stripslashes($cart[$i]["description"])."\" /><center>\n";
        };
$single['update_form'] =  $single['update_form'] . "<input type=\"image\" name=\"update\" title=\"". $VM_LANG->_PHPSHOP_CART_UPDATE ."\" src=\"". IMAGEURL ."ps_image/edit_f1.png\" border=\"0\"  alt=\"". $VM_LANG->_PHPSHOP_UPDATE ."\" onmouseover='src=\"". IMAGEURL ."ps_image/edit_f2.png\"' onmouseout='src=\"". IMAGEURL ."ps_image/edit_f1.png\"'/>\n";
$single['update_form'] =  $single['update_form'] . "</center></form>\n";

3. \administrator\components\com_virtuemart\html\basket.php
В конце добавляем
echo $single['update_form'];

4. \administrator\components\com_virtuemart\html\templates\basket\basket_b2c.html.php (или какую вы там корзину используете)
Комментим строчку <?php echo $product['update_form'] ?> или вобще убираем.

5. Здесь же
Код
<form action="<?php echo $action_url ?>" method="post">
<input type="hidden" name="option" value="com_virtuemart" />
<?php echo $product['quantity_box'] ?>
изменяем до
Код
<form action="<?php echo $action_url ?>" method="post" name="source">
<input type="hidden" name="option" value="com_virtuemart" />
<?php echo $product['quantity_box'] ?></form>



6. Ну и можна закомментить в \administrator\components\com_virtuemart\html\basket.php код
Код
$action_url = $mm_action_url."index.php";
$product_rows[$i]['update_form'] = "<input type=\"hidden\" name=\"page\" value=\"". $_REQUEST['page'] ."\" />
        <input type=\"hidden\" name=\"func\" value=\"cartUpdate\" />
        <input type=\"hidden\" name=\"product_id\" value=\"". $_SESSION['cart'][$i]["product_id"] ."\" />
        <input type=\"hidden\" name=\"Itemid\" value=\"". @$_REQUEST['Itemid'] ."\" />
        <input type=\"hidden\" name=\"description\" value=\"". stripslashes($cart[$i]["description"])."\" /><center>
        <input type=\"image\" name=\"update\" title=\"". $VM_LANG->_PHPSHOP_CART_UPDATE ."\" src=\"". IMAGEURL ."ps_image/edit_f1.png\" border=\"0\"  alt=\"". $VM_LANG->_PHPSHOP_UPDATE ."\" onmouseover='src=\"". IMAGEURL ."ps_image/edit_f2.png\"' onmouseout='src=\"". IMAGEURL ."ps_image/edit_f1.png\"'/>
      </center></form>";
- он нам не нужен ;)

Вот в принципе и все  ^-^
« Последнее редактирование: 15.03.2007, 15:11:09 от konstant »
*

VIPersone

  • Захожу иногда
  • 55
  • 2 / 0
Обновляет окно, но не обновляет кол-во...
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться