Новости Joomla

‼️👩‍💻 Релиз безопасности Astroid 3.3.11 - шаблона-конструктора для Joomla.

‼️👩‍💻 Релиз безопасности Astroid 3.3.11 - шаблона-конструктора для Joomla.

14 часов назад (на момент публикации заметки) была обнаружена уязвимость в популярном шаблоне-конструкторе Astroid Framework. При атаке на сайт устанавливается бэкдор — системный плагин под названием plg_system_blpayload. Если вы обнаружили этот плагин на своем веб-сайте, значит, он скомпрометирован, и вам необходимо восстановить чистую резервную копию, созданную до установки плагина.

Уязвимость позволяет загружать файлы на сайт и в дальнейшем получить права администратора Joomla.
В рамках атаки (из-за которой и была обнаружена уязвимость) на сайт устанавливался плагин plg_system_blpayload, который при каждой загрузке страницы снаружи он скрытно связывается с (платформой для SEO, работающей на черном рынке (ссылку помещать не будем, просим поверить на слово). Получает список скрытых спам-ссылок (сайты азартных игр, фишинга, мошенничества), подобранный под ваш домен, затем внедряет эти ссылки в HTML-код вашей страницы непосредственно перед рендером - невидимые для посетителей, но полностью читаемые поисковыми роботами. Это называется "отравление SEO" ("отрпавление поисковой выдачи").

Однако, эта уязвимость может использоваться в других целях. Поэтому необходимо срочно проверить ваши сайты, где стоит Astroid Framework и обновить его до версии не ниже 3.3.11. Релиз безопасности выпущен 4 часа назад (на момент написания заметки).

Скачать релиз безопасности Astroid

@joomlafeed

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

alfonse

  • Захожу иногда
  • 64
  • 2 / 0
Как можно по умолчанию добавить все Настраиваемые поля к товару, что бы не нужно было их админу добавлять, а только вписать значения? Есть тема http://joomlaforum.ru/index.php/topic,230522.0.html но мне подойдет решение с добавлением сразу всех Настраиваемых полей.
« Последнее редактирование: 20.11.2013, 13:20:16 от alfonse »
*

alfonse

  • Захожу иногда
  • 64
  • 2 / 0
Проблему решил следующий образом: шаблон админки настраиваемых полей находится тут administrator/components/com_virtuemart/views/product/tmpl/product_edit_custom.php

Далее я нашёл jquery который выполняется при выборе поля в списке. Он выполнялся по событию change. Вот его код
Код
jQuery('select#customlist').chosen().change(function() {
selected = jQuery(this).find( 'option:selected').val();
//alert(selected);
jQuery.getJSON('<?php echo JURI::root(false)?>administrator/index.php?option=com_virtuemart&view=product&task=getData&format=json&type=fields&id='+selected+'&row='+nextCustom+'&virtuemart_product_id=<?php echo $this->product->virtuemart_product_id; ?>',
function(data) {
jQuery.each(data.value, function(index, value){
jQuery("#custom_field").append(value);
jQuery('#custom_field').trigger('sortupdate');
});
});
nextCustom++;
});
Как видно из кода отрабатывает JSON запрос(или как то так))) Переменная selected это есть id нашего поля. Что бы узнать его расcкомментируйте alert(selected); зайдите в админку и покликайте вручную по полям - запишите id(эти id нужно будет подставить вместо переменной select в строке jQuery.getJSON - fields&id='+selected+'&row). В итоге добавляем такой код ниже выше приведенного.
Код
jQuery.getJSON('<?php echo JURI::root(false)?>administrator/index.php?option=com_virtuemart&view=product&task=getData&format=json&type=fields&id=***&row='+nextCustom+'&virtuemart_product_id=<?php echo $this->product->virtuemart_product_id; ?>',
function(data) {
jQuery.each(data.value, function(index, value){
jQuery("#custom_field").append(value);
jQuery('#custom_field').trigger('sortupdate');
});
});
nextCustom++;
Где *** есть id вашего элемента в списке.
Вроде описал понятно)

Есть одна проблемка поля добавляются при каждом открытии товара, как добавить условие - если есть, то не добавлять?
« Последнее редактирование: 23.11.2013, 03:11:59 от alfonse »
*

kreker92

  • Захожу иногда
  • 390
  • 18 / 0
Есть одна проблемка поля добавляются при каждом открытии товара, как добавить условие - если есть, то не добавлять?

Попробуйте .length
Что-то типа:

Код: javascript
jQuery.getJSON('<?php echo JURI::root(false)?>administrator/index.php?option=com_virtuemart&view=product&task=getData&format=json&type=fields&id=***&row='+nextCustom+'&virtuemart_product_id=<?php echo $this->product->virtuemart_product_id; ?>',
function(data) {
jQuery.each(data.value, function(index, value){
if(jQuery("#custom_field").length == 0 && jQuery('#custom_field').length == 0) {
jQuery("#custom_field").append(value);
jQuery('#custom_field').trigger('sortupdate');
}
});
});
nextCustom++;

Все вопросы и предложения на почту.
*

alfonse

  • Захожу иногда
  • 64
  • 2 / 0
сделал так
Код
if(jQuery("#field0custom_value").length == 0){//если есть элемент с указанным id то не добавляем, нужно что бы при сохранении поля не добавлялись постоянно
jQuery.getJSON('<?php echo JURI::root(false)?>administrator/index.php?option=com_virtuemart&view=product&task=getData&format=json&type=fields&id=***&row='+nextCustom+'&virtuemart_product_id=<?php echo $this->product->virtuemart_product_id; ?>',
function(data) {
jQuery.each(data.value, function(index, value){
jQuery("#custom_field").append(value);
jQuery('#custom_field').trigger('sortupdate');
});
});
nextCustom++;
}
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться