Новости 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

👩‍💻 Joomla включена в программу Google Summer of Code 2026.

👩‍💻 Joomla включена в программу Google Summer of Code 2026.

Google Summer of Code (GSoC) - программа компании Google, которая позволяет участникам программы под руководством опытных наставников писать код для организаций, занимающейся открытым исходным кодом. Joomla принимает участие в этой программе не в первый раз и в 2026 году снова включена в список GSoC. Для программы утверждается список "идей", воплотить которые должны участники под руководством наставников.

Проекты Joomla в рамках программы GSoC 2026.

Проект I: Ajax-бэкенд.
- Действия в административной панели без необходимости обновлять страницу.
- Автоматическое сохранение содержимого во время редактирования.
- Расширенный фильтр - поиск и фильтрация по пользовательским полям.

Проект II: Автоматизация рабочих процессов (workflow + task scheduler).
Joomla имеет функцию процессов и планировщика задач. Теперь эти две функции следует объединить, чтобы пользователь мог настраивать назначенные рабочие процессы таким образом, чтобы переходы выполнялись автоматически, с возможностью точного определения времени. Должна быть возможность создавать циклы или прямые запланированные рабочие процессы. Предполагается, что интерфейс должен учитывать хороший пользовательский опыт, удобство использования и современные стандарты доступности. Ожидается, что будет добавлен интерфейс для управления процессами и их расписанием на страницах категорий и материалов. Так же ожидается, что сторонние компоненты также смогут воспользоваться этим функционалом.

Проект III: Мультикатегории.
В настоящее время Joomla! не позволяет назначать один элемент нескольким категориям. Хотя система тегов часто используется в качестве замены, существует острая потребность в нативной поддержке нескольких категорий, чтобы привести Joomla! в соответствие с другими современными системами управления контентом.

Проект IV: Обучение с подкреплением на основе отзывов переводчиков.
Joomla собирается использовать автоматический перевод документации. В каждом языке есть свои специфические слова, характерные для Joomla. Предполагается обучать языковые модели, используя обратную связь от переводчиков, чтобы постоянно улучшать качество переводов и учитывать специфические языковые особенности Joomla.

Принять участие GSoC 2026
Подробнее о проектах Joomla GSoC 2026
Чат GSoC в Mattermost (международное сообщество Joomla)

Вышли релизы Joomla 6.0.3 и Joomla 5.4.3

Релиз Joomla 6.0.3 и Joomla 5.4.3

Проект Joomla рад сообщить о выпуске Joomla 6.0.3 и Joomla 5.4.3. Это релиз исправлений ошибок и улучшений для серии Joomla 6.0 и Joomla 5.4.

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

misteri27

  • Захожу иногда
  • 490
  • 0 / 0
Всем привет.
Столкнулся с проблемой. На сайте стоит оплата через мерченд альфа банка. Все работала периехели на новый сервер и установили php7 и теперь при переходе на catalog/checkout/step6 выскакивает 404 ошибка.
Может кто уже натыкался на такие грабли то прошу ответить :)
*

SeBun

  • BanMaster
  • 4030
  • 259 / 5
  • @SeBun48
Причин может быть много, выделю две наиболее вероятные: при переносе что то не перенесли и что ваше расширение не работает на версии php7. А может и с путями что то не так. Смотрите, что в логах у вас, тогда и станет понятно.
Оказываю услуги по Joomla | Миграция/Обновление | Сопровождение | IT-аутсорсинг | Недорогие домены и хостинг
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
при переносе что то не перенесли и что ваше расширение не работает на версии php7
я больше за первую версию. потому что если бы не работало на 7-ке, то была бы скорее ошибка 500, а не 404. хотя конечно этот вариант полностью отбрасывать тоже не стоит, проверить и его надо...
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

misteri27

  • Захожу иногда
  • 490
  • 0 / 0
Перенесли точно все. Так как переключив на 5,6 в настройках, все фурычит. Ночью будет меньше народу на сайте, буду экспериментировать. Выложу тогда больше данных.
*

misteri27

  • Захожу иногда
  • 490
  • 0 / 0
Смотрите, что в логах у вас, тогда и станет понятно.
В логах ошибок пусто по этому поводу. Видимо 404 не является ошибкой которую пишет в логи error . В логах access указано
Код
"GET /test/images/logo.png HTTP/1.0" 404 475 "http://site.ru/catalog/checkout/step6" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/52.0.2743.116 Safari/537.36 Edge/15.15063"
Блин прикол какой то.
*

misteri27

  • Захожу иногда
  • 490
  • 0 / 0
Другие методы оплаты работают.
Видимо что-то в коде обработчика конфликтует с php7 другого варианта реально не вижу.
Код
<?php
defined('_JEXEC') or die('Restricted access');
class pm_alfabank extends PaymentRoot {
   
    function showPaymentForm($params, $pmconfigs) {
        include(dirname(__FILE__)."/paymentform.php");
    }

    function showAdminFormParams($params) {
        $jmlThisDocument = JFactory::getDocument();
        switch ($jmlThisDocument->language) {
            case 'en-gb': include(JPATH_SITE.'/administrator/components/com_jshopping/lang/en-GB_alfabank.php'); $language = 'en'; break;
            case 'ru-ru': include(JPATH_SITE.'/administrator/components/com_jshopping/lang/ru-RU_alfabank.php'); $language = 'ru'; break;
            default: include(JPATH_SITE.'/administrator/components/com_jshopping/lang/ru-RU_alfabank.php');
        }
       
        $array_params = array('testmode', 'email_received', 'transaction_end_status', 'transaction_pending_status', 'transaction_failed_status', 'mecrchant_pass', 'login');
       
        foreach ($array_params as $key)
            if (!isset($params[$key]))
                $params[$key] = '';
        $orders = JModelLegacy ::getInstance('orders', 'JshoppingModel');
        $currency = JModelLegacy ::getInstance('currencies', 'JshoppingModel');
       
        include(dirname(__FILE__)."/adminparamsform.php");
       
        jimport('joomla.html.pane');
    }

    function checkTransaction($pmconfigs, $order, $act){
//get bank order Id
$q = "SELECT #__jshopping_order_pm_alfa.ab_order_id FROM #__jshopping_order_pm_alfa WHERE #__jshopping_order_pm_alfa.js_order_id = '".$order->order_id."'";
$db = JFactory::getDBO();
$db->setQuery($q);
$orderId = $db->loadResult();

if ($orderId != '') {
// check order status
$mecrchant_login = $pmconfigs['login'];
$mecrchant_pass = $pmconfigs['mecrchant_pass'];
$curlParams = Array(
'userName' => $mecrchant_login,
'password' => $mecrchant_pass,
'orderId' => $orderId,
);
        if ($pmconfigs['testmode']) {
            $host = "https://web.rbsuat.com/ab/rest/getOrderStatus.do";
        } else {
            $host = "https://engine.paymentgate.ru/payment/rest/getOrderStatus.do";
        }
       
$alfaCurl = curl_init();
curl_setopt_array($alfaCurl, array(
    CURLOPT_URL => $host,
    CURLOPT_RETURNTRANSFER => true,
    CURLOPT_POST => true,
    CURLOPT_POSTFIELDS => http_build_query($curlParams),
));

$transactiondata = curl_exec($alfaCurl);
curl_close($alfaCurl);

$transactiondata = json_decode($transactiondata, true);

$res = '';
foreach ($response as $k=>$data) {
$res .= '['.$k.'=>'.$data.'], ';
}
saveToLog("payment.log", "Order ID ".$order->order_number."; Response: ".$res);
        $transaction = $transactiondata['ErrorMessage'];
$errorCode = $transactiondata['ErrorCode'];
$orderStatus = $transactiondata['OrderStatus'];

if (($errorCode != '0') && ($orderStatus != '2')) {
//error in pocessing
$orderStatus = '2';
} else {
//processing without error
$orderStatus = '1';
}

} else {
$orderStatus = '0';
}

return array($orderStatus, '', $transaction, $transactiondata);
    }
   
function showEndForm($pmconfigs, $order) {
        $jshopConfig = JSFactory::getConfig();       
        $item_name = sprintf(_JSHOP_PAYMENT_NUMBER, $order->order_number);
        $jmlThisDocument = JFactory::getDocument();
        switch ($jmlThisDocument->language) {
            case 'en-gb': include(JPATH_SITE.'/administrator/components/com_jshopping/lang/en-GB_alfabank.php'); $language = 'en'; break;
            case 'ru-ru': include(JPATH_SITE.'/administrator/components/com_jshopping/lang/ru-RU_alfabank.php'); $language = 'ru'; break;
            default: include(JPATH_SITE.'/administrator/components/com_jshopping/lang/ru-RU_alfabank.php');
        }

        if ($pmconfigs['testmode']) {
            $host = "https://web.rbsuat.com/ab/rest/register.do";
        } else {
            $host = "https://engine.paymentgate.ru/payment/rest/register.do";
        }

//redirect if paymant complite
        $notify_url = JURI::root()."index.php?option=com_jshopping&controller=checkout&task=step7&act=return&js_paymentclass=pm_alfabank&order_id=".$order->order_id;
//redirect if paymant error
        $cancel_return = JURI::root()."index.php?option=com_jshopping&controller=checkout&task=step7&act=cancel&js_paymentclass=pm_alfabank";
               
       
        // params
$mecrchant_login = $pmconfigs['login'];
$mecrchant_pass = $pmconfigs['mecrchant_pass'];
$order_desc = _JHOP_ALFABANK_ORDER_PAY." ".$order->order_number;
// prepare curl option
$args = Array(
'userName' => $mecrchant_login,
'password' => $mecrchant_pass,
'amount' => $order->order_total * 100,
'currency' => '810',
'orderNumber' => $order->order_number,
'description' => $order_desc,
'returnUrl' => $notify_url,
'failUrl' => $cancel_return,
);

//curl
$alfaCurl = curl_init();
curl_setopt_array($alfaCurl, array(
    CURLOPT_URL => $host,
    CURLOPT_RETURNTRANSFER => true,
    CURLOPT_POST => true,
    CURLOPT_POSTFIELDS => http_build_query($args)
));

$response = curl_exec($alfaCurl);
curl_close($alfaCurl);
$response = json_decode($response, true);
$errorCode = $response['errorCode'];
$alfaOrderId = $response['orderId'];
if ($errorCode == 0) {
$html = _JSHOP_ALFABANK_HTML;
$html  .= '<p>'._JSHOP_ALFABANK_HTML_ORDER.$order->order_number._JSHOP_ALFABANK_SUMM.$order->order_total.'RUB</p>';
$html  .= '<a class="button cancel" href="'.$response['formUrl'].'">'._JSHOP_ALFABANK_PAYNOW.'</a>';
$html  .= '<a class="button cancel" href="'.$response['formUrl'].'">'._JSHOP_ALFABANK_PAYNOW.'</a>';
$db = JFactory::getDBO();
$jshop_order_summ = $order->order_total * 100;
$sql_order_data = "INSERT INTO `#__jshopping_order_pm_alfa` VALUES ('', '".$order->order_id."', '".$order->order_number."', 'RUR', '".$order->order_total."', 'created', '".$alfaOrderId."', '', 'registred');";
$db->setQuery($sql_order_data);
if(!$db->query()) {
    echo __LINE__.$db->stderr();
}
} else {
$html = 'Error #'.$errorCode.': '.$response['errorMessage'];
}
$q = "SELECT #__jshopping_order_pm_alfa.ab_order_id FROM #__jshopping_order_pm_alfa WHERE #__jshopping_order_pm_alfa.js_order_id = '".$order->order_id."'";
$db = JFactory::getDBO();
$db->setQuery($q);
$orderId = $db->loadResult();

?>
        <html>
        <head>
            <meta http-equiv="content-type" content="text/html; charset=utf-8" />           
        </head>
        <body>
        <?php echo '<div style="text-align: center;">'.$html.'</div>'; ?>
</body>
<?php
die();
}

    function getUrlParams($pmconfigs) {
        $params = array();
        $params['order_id'] = JRequest::getInt("order_id");
        $params['hash'] = "";
        $params['checkHash'] = 0;
        $params['checkReturnParams'] = 1;
        return $params;
    }

   
}
?>
*

Linfuby

  • Завсегдатай
  • 1242
  • 176 / 0
  • Всё просто...
Вы серьезно пользуетесь данным сервисом?
https://engine.paymentgate.ru/bpcservlet/BPC/index.jsp
Немного воображения и логики, и любая проблема становится решенной.
Кривые решения - дают кривой результат!
Решения для JoomShopping
Благодарности и поддержка принимаются по след. реквизитам:
Яндекс.Деньги - 41001751720054
*

ProtectYourSite

  • Живу я здесь
  • 2368
  • 139 / 4
  • Безопасность вебсайтов
Debug и в админке в настройках уровень ошибок на максимум.
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Вы серьезно пользуетесь данным сервисом?
насколько мне известно это на самом деле официальный гейт альфабанка.
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

misteri27

  • Захожу иногда
  • 490
  • 0 / 0
Вы серьезно пользуетесь данным сервисом?
https://engine.paymentgate.ru/bpcservlet/BPC/index.jsp
Да это альфа банк.
*

misteri27

  • Захожу иногда
  • 490
  • 0 / 0
Блин вывод ошибок и консоль ничего не дают. Просто переходит на страницу 404 . Консоль выдавала предупреждения по livetex и clickfrog но я их удалял пользы с этого не было. Можно конечно остаться на 5,6 но зараза на 7 сайт в два раза шустрее :)
*

ProtectYourSite

  • Живу я здесь
  • 2368
  • 139 / 4
  • Безопасность вебсайтов
Смотрите по запросам, где переходит на 404 и можно поискать по скрипту, при каких действиях там на 404 переходит.
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
видимых причин для 404 в коде плагина оплаты я не увидел. вероятно проблема все таки не в самом плагине.
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

ProtectYourSite

  • Живу я здесь
  • 2368
  • 139 / 4
  • Безопасность вебсайтов
Та же форма инклюдится, может быть дело не только в этом файле. А пока играем в угадайку
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
не, showPaymentForm вызывается только в админке. на фронте при переходе на оплату работает только showEndForm, а там нет ничего такого, что могло бы вызывать 404.

ТС, ну проверьте на всякий случай, установлено ли у вас расширение CURL на php7. может быть там не 404 вовсе, а просто показывает так...
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
А код других файлов: paymentform.php, adminparamsform.php? Может быть, не грузится какое-нибудь фото:
"GET /test/images/logo.png HTTP/1.0" 404 475
Не будь паразитом, сделай что-нибудь самостоятельно!
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
А код других файлов: paymentform.php, adminparamsform.php?
они не важны при переходе на оплату. первый срабатывает раньше, еще на шаге выбора способа оплаты, второй только в админке. я бы все таки проверил версию с неправильным ответом сервера, посмотрел установленные расширения. в частности CURL
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Да, скорее всего, не то
Может быть, не грузится какое-нибудь фото
Ведь не работает только на PHP 7, а тут ничего такого не вижу.
Не будь паразитом, сделай что-нибудь самостоятельно!
*

misteri27

  • Захожу иногда
  • 490
  • 0 / 0
CURL
Вы как всегда правы :) . Проблема была именно в CURL. Его автоматом не поставило в php 7.
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
ну значит вам еще предстоит разобраться, почему у вас 404 возвращалось вместо 500 :)
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

misteri27

  • Захожу иногда
  • 490
  • 0 / 0
Всем доброй ночи.
Нарисовалась еще одна проблема с этой оплатой. Короче не формируется файл pdf и не отправляется сообщение о заказе . В чем может быть загвоздка?
Когда идет оплата, то приходит только сообщение о смене статуса на Оплачено, а если не закончить оплату то просто заказ в админке есть, а на почте пусто. И в админке на против заказ нету иконки Печать.
« Последнее редактирование: 27.08.2017, 00:51:31 от misteri27 »
*

misteri27

  • Захожу иногда
  • 490
  • 0 / 0
На сколько я понимаю за все это отвечает файл /components/com_jshopping/models/checkout.php Но вот почему заказ формируется, в админке он есть, но сообщения нету и файл pdf не создается?
В логах пишет при заказе
Код
"POST /administrator/index.php?option=com_jshopping&controller=orders HTTP/1.0" 200 12623 "http://site.ru/administrator/index.php?option=com_jshopping&controller=orders" "Mozilla/5.0 (Windows NT 10.0; WOW64; rv:55.0) Gecko/20100101 Firefox/55.0"
Может кто подскажет что может мешать ?
*

misteri27

  • Захожу иногда
  • 490
  • 0 / 0
Заметил что в заказах в админке нету "Дата счета-фактуры: " Если ее добавить счет появляется в админке.
Видимо в коде
Код
<?php
defined('_JEXEC') or die('Restricted access');
class pm_alfabank extends PaymentRoot {
   
    function showPaymentForm($params, $pmconfigs) {
        include(dirname(__FILE__)."/paymentform.php");
    }

    function showAdminFormParams($params) {
        $jmlThisDocument = JFactory::getDocument();
        switch ($jmlThisDocument->language) {
            case 'en-gb': include(JPATH_SITE.'/administrator/components/com_jshopping/lang/en-GB_alfabank.php'); $language = 'en'; break;
            case 'ru-ru': include(JPATH_SITE.'/administrator/components/com_jshopping/lang/ru-RU_alfabank.php'); $language = 'ru'; break;
            default: include(JPATH_SITE.'/administrator/components/com_jshopping/lang/ru-RU_alfabank.php');
        }
       
        $array_params = array('testmode', 'email_received', 'transaction_end_status', 'transaction_pending_status', 'transaction_failed_status', 'mecrchant_pass', 'login');
       
        foreach ($array_params as $key)
            if (!isset($params[$key]))
                $params[$key] = '';
        $orders = JModelLegacy ::getInstance('orders', 'JshoppingModel');
        $currency = JModelLegacy ::getInstance('currencies', 'JshoppingModel');
       
        include(dirname(__FILE__)."/adminparamsform.php");
       
        jimport('joomla.html.pane');
    }

    function checkTransaction($pmconfigs, $order, $act){
//get bank order Id
$q = "SELECT #__jshopping_order_pm_alfa.ab_order_id FROM #__jshopping_order_pm_alfa WHERE #__jshopping_order_pm_alfa.js_order_id = '".$order->order_id."'";
$db = JFactory::getDBO();
$db->setQuery($q);
$orderId = $db->loadResult();

if ($orderId != '') {
// check order status
$mecrchant_login = $pmconfigs['login'];
$mecrchant_pass = $pmconfigs['mecrchant_pass'];
$curlParams = Array(
'userName' => $mecrchant_login,
'password' => $mecrchant_pass,
'orderId' => $orderId,
);
        if ($pmconfigs['testmode']) {
            $host = "https://web.rbsuat.com/ab/rest/getOrderStatus.do";
        } else {
            $host = "https://engine.paymentgate.ru/payment/rest/getOrderStatus.do";
        }
       
$alfaCurl = curl_init();
curl_setopt_array($alfaCurl, array(
    CURLOPT_URL => $host,
    CURLOPT_RETURNTRANSFER => true,
    CURLOPT_POST => true,
    CURLOPT_POSTFIELDS => http_build_query($curlParams),
));

$transactiondata = curl_exec($alfaCurl);
curl_close($alfaCurl);

$transactiondata = json_decode($transactiondata, true);

$res = '';
foreach ($response as $k=>$data) {
$res .= '['.$k.'=>'.$data.'], ';
}
saveToLog("payment.log", "Order ID ".$order->order_number."; Response: ".$res);
        $transaction = $transactiondata['ErrorMessage'];
$errorCode = $transactiondata['ErrorCode'];
$orderStatus = $transactiondata['OrderStatus'];

if (($errorCode != '0') && ($orderStatus != '2')) {
//error in pocessing
$orderStatus = '2';
} else {
//processing without error
$orderStatus = '1';
}

} else {
$orderStatus = '0';
}

return array($orderStatus, '', $transaction, $transactiondata);
    }
   
function showEndForm($pmconfigs, $order) {
        $jshopConfig = JSFactory::getConfig();       
        $item_name = sprintf(_JSHOP_PAYMENT_NUMBER, $order->order_number);
        $jmlThisDocument = JFactory::getDocument();
        switch ($jmlThisDocument->language) {
            case 'en-gb': include(JPATH_SITE.'/administrator/components/com_jshopping/lang/en-GB_alfabank.php'); $language = 'en'; break;
            case 'ru-ru': include(JPATH_SITE.'/administrator/components/com_jshopping/lang/ru-RU_alfabank.php'); $language = 'ru'; break;
            default: include(JPATH_SITE.'/administrator/components/com_jshopping/lang/ru-RU_alfabank.php');
        }

        if ($pmconfigs['testmode']) {
            $host = "https://web.rbsuat.com/ab/rest/register.do";
        } else {
            $host = "https://engine.paymentgate.ru/payment/rest/register.do";
        }

//redirect if paymant complite
        $notify_url = JURI::root()."index.php?option=com_jshopping&controller=checkout&task=step7&act=return&js_paymentclass=pm_alfabank&order_id=".$order->order_id;
//redirect if paymant error
        $cancel_return = JURI::root()."index.php?option=com_jshopping&controller=checkout&task=step7&act=cancel&js_paymentclass=pm_alfabank";
               
       
        // params
$mecrchant_login = $pmconfigs['login'];
$mecrchant_pass = $pmconfigs['mecrchant_pass'];
$order_desc = _JHOP_ALFABANK_ORDER_PAY." ".$order->order_number;
// prepare curl option
$args = Array(
'userName' => $mecrchant_login,
'password' => $mecrchant_pass,
'amount' => $order->order_total * 100,
'currency' => '810',
'orderNumber' => $order->order_number,
'description' => $order_desc,
'returnUrl' => $notify_url,
'failUrl' => $cancel_return,
);

//curl
$alfaCurl = curl_init();
curl_setopt_array($alfaCurl, array(
    CURLOPT_URL => $host,
    CURLOPT_RETURNTRANSFER => true,
    CURLOPT_POST => true,
    CURLOPT_POSTFIELDS => http_build_query($args)
));

$response = curl_exec($alfaCurl);
curl_close($alfaCurl);
$response = json_decode($response, true);
$errorCode = $response['errorCode'];
$alfaOrderId = $response['orderId'];
if ($errorCode == 0) {
$html = _JSHOP_ALFABANK_HTML;
$html  .= '<p>'._JSHOP_ALFABANK_HTML_ORDER.$order->order_number._JSHOP_ALFABANK_SUMM.$order->order_total.'RUB</p>';
$html  .= '<a class="button cancel" href="'.$response['formUrl'].'">'._JSHOP_ALFABANK_PAYNOW.'</a>';
$html  .= '<a class="button cancel" href="'.$response['formUrl'].'">'._JSHOP_ALFABANK_PAYNOW.'</a>';
$db = JFactory::getDBO();
$jshop_order_summ = $order->order_total * 100;
$sql_order_data = "INSERT INTO `#__jshopping_order_pm_alfa` VALUES ('', '".$order->order_id."', '".$order->order_number."', 'RUR', '".$order->order_total."', 'created', '".$alfaOrderId."', '', 'registred');";
$db->setQuery($sql_order_data);
if(!$db->query()) {
    echo __LINE__.$db->stderr();
}
} else {
$html = 'Error #'.$errorCode.': '.$response['errorMessage'];
}
$q = "SELECT #__jshopping_order_pm_alfa.ab_order_id FROM #__jshopping_order_pm_alfa WHERE #__jshopping_order_pm_alfa.js_order_id = '".$order->order_id."'";
$db = JFactory::getDBO();
$db->setQuery($q);
$orderId = $db->loadResult();

?>
        <html>
        <head>
            <meta http-equiv="content-type" content="text/html; charset=utf-8" />           
        </head>
        <body>
        <?php echo '<div style="text-align: center;">'.$html.'</div>'; ?>
</body>
<?php
die();
}

    function getUrlParams($pmconfigs) {
        $params = array();
        $params['order_id'] = JRequest::getInt("order_id");
        $params['hash'] = "";
        $params['checkHash'] = 0;
        $params['checkReturnParams'] = 1;
        return $params;
    }

   
}
?>
Редактировать сообщение
Есть ошибка которая не создает дату ?
*

misteri27

  • Захожу иногда
  • 490
  • 0 / 0
Нужно исправить плагин оплаты что бы он работал нормально. Кто может пишите обсудим цену.
*

SeBun

  • BanMaster
  • 4030
  • 259 / 5
  • @SeBun48
Нужно исправить плагин оплаты что бы он работал нормально. Кто может пишите обсудим цену.
Пишите запрос в коммерческий раздел, опишите задачу, сроки и назначьте бюджет согласно правилам форума. Быстрее исполнителя найдете.
Оказываю услуги по Joomla | Миграция/Обновление | Сопровождение | IT-аутсорсинг | Недорогие домены и хостинг
*

misteri27

  • Захожу иногда
  • 490
  • 0 / 0
Да все же хочется докопаться самому до сути :)
Стоит оформление заказа на одной странице. И там выбрано всегда заканчивать заказ. Если отключить функцию заканчивать, то заказ не будет завершен и будет в админке как незавершенный.
Понял так же уже что на тестовом режиме все работает и заказ заканчивает. Не работает только на боевом режиме . За это отвечает код
Код
function checkTransaction($pmconfigs, $order, $act){
//get bank order Id
$q = "SELECT #__jshopping_order_pm_alfa.ab_order_id FROM #__jshopping_order_pm_alfa WHERE #__jshopping_order_pm_alfa.js_order_id = '".$order->order_id."'";
$db = JFactory::getDBO();
$db->setQuery($q);
$orderId = $db->loadResult();

if ($orderId != '') {
// check order status
$mecrchant_login = $pmconfigs['login'];
$mecrchant_pass = $pmconfigs['mecrchant_pass'];
$curlParams = Array(
'userName' => $mecrchant_login,
'password' => $mecrchant_pass,
'orderId' => $orderId,
);
        if ($pmconfigs['testmode']) {
            $host = "https://web.rbsuat.com/ab/rest/getOrderStatus.do";
        } else {
            $host = "https://engine.paymentgate.ru/payment/rest/getOrderStatus.do";
        }
       
$alfaCurl = curl_init();
curl_setopt_array($alfaCurl, array(
    CURLOPT_URL => $host,
    CURLOPT_RETURNTRANSFER => true,
    CURLOPT_POST => true,
    CURLOPT_POSTFIELDS => http_build_query($curlParams),
));

$transactiondata = curl_exec($alfaCurl);
curl_close($alfaCurl);

$transactiondata = json_decode($transactiondata, true);

$res = '';
foreach ($response as $k=>$data) {
$res .= '['.$k.'=>'.$data.'], ';
}
saveToLog("payment.log", "Order ID ".$order->order_number."; Response: ".$res);
        $transaction = $transactiondata['ErrorMessage'];
$errorCode = $transactiondata['ErrorCode'];
$orderStatus = $transactiondata['OrderStatus'];

if (($errorCode != '0') && ($orderStatus != '2')) {
//error in pocessing
$orderStatus = '2';
} else {
//processing without error
$orderStatus = '1';
}

} else {
$orderStatus = '0';
}

return array($orderStatus, '', $transaction, $transactiondata);
    }
Но разницы между двумя режимами только ссылка. Видимо выходит что дело в ответе сервера Альфы . Если не прав мож поправит кто?
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
видимо в ответе. на боевом режиме ответ не приходит, или неправильно приходит, или неправильно трактуется плагином оплаты, или еще много вариантов... надо смотреть ответ, сравнивать с документацией, и т.п.
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

ProtectYourSite

  • Живу я здесь
  • 2368
  • 139 / 4
  • Безопасность вебсайтов
По идее да, а что в лог пишется? или просто вывести, что в curl приходит и сравнить ответы?
*

misteri27

  • Захожу иногда
  • 490
  • 0 / 0
По идее да, а что в лог пишется? или просто вывести, что в curl приходит и сравнить ответы?
Файл логов payment.log пустой вообще. А как можно вывести ответ сервера от альфы. А то им написал но они пока не ответили ничего.
*

misteri27

  • Захожу иногда
  • 490
  • 0 / 0
Если человек не перешел на страницу оплаты и просто закрыл окно или перезагрузил страницу перехода его статус заказа меняется на  установленный "Незаконченная транзакция". И если отключить "Всегда завершать заказ" то он остается не завершенным.
А вот при переходе на страницу банка - либо нету вообще ответа, либо он не такой как нужно :)
« Последнее редактирование: 29.08.2017, 12:00:23 от misteri27 »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Не работает lightbox в JoomShopping

Автор d13v555

Ответов: 6
Просмотров: 3841
Последний ответ 08.10.2025, 15:34:46
от kit2m2
Не работает интернет-эквайринг на сайте

Автор Bommbba

Ответов: 2
Просмотров: 1088
Последний ответ 10.03.2023, 14:57:06
от IgorGeneralov
Не работает регистрация

Автор Alex199466

Ответов: 25
Просмотров: 3142
Последний ответ 30.12.2020, 16:22:32
от sterveo
Создаю плагин Joomla для JoomShopping, не работает, что я не так делаю?

Автор Ragnarok

Ответов: 10
Просмотров: 876
Последний ответ 08.11.2020, 22:22:42
от draff
Joomla user Synchro с официального сайта разраба каким образом работает?

Автор dss

Ответов: 0
Просмотров: 749
Последний ответ 03.11.2020, 10:31:14
от dss