Mano Posted August 30, 2021 Share Posted August 30, 2021 Просмотр файла Webmoney Payment Gateway Webmoney Payment Gateway for Invision Community 4.6 Добавил the.bunin Добавлено 29.08.2021 Категория Коммерция Язык English by_ix 1 Quote Link to comment Share on other sites More sharing options...
by_ix Posted August 30, 2021 Share Posted August 30, 2021 проверить кто-нибудь ещё может? у меня ошибка вылезает на моменте нажатия кнопки "оплатить" на форуме. перекидывать в вм и пишет это: в логах мерчанта это: в логах запроса это: не передаётся сумма покупки. вопрос - почему? Quote Link to comment Share on other sites More sharing options...
Desti Posted August 30, 2021 Share Posted August 30, 2021 Я с нексой никогда не работал, у меня даже товары в корзину не хотят попадать:) cyr4x and by_ix 1 1 Quote Link to comment Share on other sites More sharing options...
by_ix Posted August 30, 2021 Share Posted August 30, 2021 33 минуты назад, Desti сказал: у меня даже товары в корзину не хотят попадать ошибка везде. и в подписках, и в пожертвованиях. Quote Link to comment Share on other sites More sharing options...
Desti Posted August 30, 2021 Share Posted August 30, 2021 Да у него в генах ошибка, он из коробки не запускается в dev-режиме by_ix 1 Quote Link to comment Share on other sites More sharing options...
by_ix Posted August 30, 2021 Share Posted August 30, 2021 так и что делать? само вм приложение не фиксится никак? Quote Link to comment Share on other sites More sharing options...
Desti Posted August 30, 2021 Share Posted August 30, 2021 Найди в webmoney/sources/Webmoney/Webmoney.php <input type="hidden" name="LMI_PAYMENT_AMOUNT" value="<?= $transactionAmount;?>"> и замени на <input type="hidden" name="LMI_PAYMENT_AMOUNT" value="<?= $transaction->amount->amountAsString();?>"> Не уверен, что это единственная ошибка, но вроде цену он теперь должен передавать правильно. by_ix 1 Quote Link to comment Share on other sites More sharing options...
Desti Posted August 30, 2021 Share Posted August 30, 2021 скорее всего там еще лажа с $transaction>id, надо поменять (везде в том же файле) на $transaction->invoice->id by_ix 1 Quote Link to comment Share on other sites More sharing options...
Desti Posted August 30, 2021 Share Posted August 30, 2021 Поля "customerNumber" и "cps_phone" вообще не нужны webmoney, зачем их добавили - непонятно. by_ix 1 Quote Link to comment Share on other sites More sharing options...
by_ix Posted August 30, 2021 Share Posted August 30, 2021 Desti спасибо, сдвинулись с места. теперь после подтверждения платежа кодом вылезает ошибка: на форуме вм есть подобная тема, там советуют проверить файл на доступ через один сайт. Result URL (/index.php?app=webmoney&module=webmoney&controller=controller) доступен: а вот Success и Fail (/index.php?app=webmoney&module=webmoney&controller=controller&success=1) выдают ошибку: нужно какие-то права на файл ставить? также, при прямом вызове через форуме лезет это: Спойлер Quote Link to comment Share on other sites More sharing options...
Desti Posted August 30, 2021 Share Posted August 30, 2021 39 минут назад, by_ix сказал: а вот Success и Fail (/index.php?app=webmoney&module=webmoney&controller=controller&success=1) выдают ошибку: Права - ерунда, ошибка программная. Вполне логично выдают, там не хватает параметра LMI_PAYMENT_NO, который должен приходить в ответе сервера на транзакцию. Где-то теряется:) Надо как-то поймать строку, которую сервер передает в контроллер, без этого дело не продвинется. У меня все запросы-подтверждения пишутся в базу, можно всегда найти пропущенный платеж. Cоздайте табличку 'debug' в базе, два поля, 'id', int(10) автоинкрементный и 'data', тип text. потом в нужных местах (в каждом условии в файле controller.php) поставьте \IPS\Db::i()->insert( 'debug', json_encode(\IPS\Request::i())); Попробуйте оплатить, потом посмотрите в табличку что за запрос он присылает. Сорри, \IPS\Db::i()->insert( 'debug', array('data' =>json_encode(\IPS\Request::i()))); by_ix 1 Quote Link to comment Share on other sites More sharing options...
by_ix Posted August 30, 2021 Share Posted August 30, 2021 Desti при каждой оплате только одна строка добавляется. я правильно понял, так же вставить? Спойлер <?php namespace IPS\webmoney\modules\front\webmoney; /* To prevent PHP errors (extending class does not exist) revealing path */ if ( !\defined( '\IPS\SUITE_UNIQUE_KEY' ) ) { header( ( isset( $_SERVER['SERVER_PROTOCOL'] ) ? $_SERVER['SERVER_PROTOCOL'] : 'HTTP/1.0' ) . ' 403 Forbidden' ); exit; } /** * controller */ class _controller extends \IPS\Dispatcher\Controller { /** * Execute * * @return void */ public function execute() { parent::execute(); } /** * ... * * @return void */ protected function manage() { if ( \IPS\Request::i()->fail ) { \IPS\Db::i()->insert( 'debug', array('data' =>json_encode(\IPS\Request::i()))); $transaction = \IPS\nexus\Transaction::load( \IPS\Request::i()->LMI_PAYMENT_NO ); \IPS\Output::i()->redirect( $transaction->invoice->checkoutUrl()->setQueryString( array( '_step' => 'checkout_pay', 'err' => $transaction->member->language()->addToStack('gateway_err') ) ) );//'� ���������, ������� ������ ���������� ��������!'); } if ( \IPS\Request::i()->LMI_PREREQUEST ) { \IPS\Db::i()->insert( 'debug', array('data' =>json_encode(\IPS\Request::i()))); $transaction = \IPS\nexus\Transaction::load( \IPS\Request::i()->LMI_PAYMENT_NO ); $settings = json_decode( $transaction->method->settings, TRUE ); if(\IPS\Request::i()->LMI_PAYMENT_AMOUNT==$transactionAmount &&\IPS\Request::i()->LMI_PAYEE_PURSE==($transaction->amount->currency=='RUB'?$settings['RWallet']:$settings['ZWallet'])) echo 'YES'; } if ( \IPS\Request::i()->LMI_HASH ) { \IPS\Db::i()->insert( 'debug', array('data' =>json_encode(\IPS\Request::i()))); $transaction = \IPS\nexus\Transaction::load( \IPS\Request::i()->LMI_PAYMENT_NO ); $settings = json_decode( $transaction->method->settings, TRUE ); $key = \IPS\Request::i()->LMI_PAYEE_PURSE . \IPS\Request::i()->LMI_PAYMENT_AMOUNT .\IPS\Request::i()->LMI_PAYMENT_NO .\IPS\Request::i()->LMI_MODE.\IPS\Request::i()->LMI_SYS_INVS_NO . \IPS\Request::i()->LMI_SYS_TRANS_NO .\IPS\Request::i()->LMI_SYS_TRANS_DATE . $settings['LMI_SECRET_KEY'].\IPS\Request::i()->LMI_PAYER_PURSE .\IPS\Request::i()->LMI_PAYER_WM; $sha256 = strtoupper(hash("sha256", $key)); if($sha256 == \IPS\Request::i()->LMI_HASH) { $transaction->gw_id = \IPS\Request::i()->LMI_SYS_TRANS_NO; $transaction->save(); $transaction->member = \IPS\Member::load( \IPS\Request::i()->customerNumber ); $maxMind = NULL; if ( \IPS\Settings::i()->maxmind_key ) { $maxMind = new \IPS\nexus\Fraud\MaxMind\Request; $maxMind->setTransaction( $transaction ); } $transaction->checkFraudRulesAndCapture( $maxMind ); } } if ( \IPS\Request::i()->success ) { \IPS\Db::i()->insert( 'debug', array('data' =>json_encode(\IPS\Request::i()))); $transaction = \IPS\nexus\Transaction::load( \IPS\Request::i()->LMI_PAYMENT_NO ); \IPS\Output::i()->redirect( $transaction->url() ); } } // Create new methods with the same name as the 'do' parameter which should execute it } 1 час назад, Desti сказал: LMI_PAYMENT_NO в логах мерчанта он есть. или это не то уже? Quote Link to comment Share on other sites More sharing options...
Desti Posted August 30, 2021 Share Posted August 30, 2021 6 минут назад, by_ix сказал: в логах мерчанта он есть. или это не то уже? После получения такого запросы сервер wm отвечает своим запросом, в котором должны быть определенные поля. Вставили правильно, давайте по другому попробуем. \IPS\Db::i()->insert( 'debug', array('data' =>json_encode(\IPS\Request::i()->LMI_PAYMENT_NO))); Можно не во все условия, а один раз над всеми. by_ix 1 Quote Link to comment Share on other sites More sharing options...
by_ix Posted August 30, 2021 Share Posted August 30, 2021 Desti Quote Link to comment Share on other sites More sharing options...
Desti Posted August 30, 2021 Share Posted August 30, 2021 Нормально, кстати. Сервер возвращает то, что надо, следовательно, проблема не в контроллере. Давайте для чистоты эксперимента вот такую конструкцию туда вставим.. \IPS\Db::i()->insert( 'debug', array('data' => json_encode(var_export(\IPS\Request::i(), true)) )); Должен быть полный ответ. Вам бы еще в табличку транзакций заглянуть, там вообще есть записи с такими индексами? by_ix 1 Quote Link to comment Share on other sites More sharing options...
Desti Posted August 30, 2021 Share Posted August 30, 2021 Какое отвратительное приложение... несуществующие переменные в коде, неправильные имена объектов, полный пц. Как такое дерьмо можно выкладывать в общий доступ (это не в адрес the.bunin , а в адрес автора этого чуда). by_ix 1 Quote Link to comment Share on other sites More sharing options...
Mano Posted August 30, 2021 Author Share Posted August 30, 2021 Desti ну да, солидарен) Так то меня просто попросил by_ix скачать ему, ну я и решил выложить ещё. А потом уже начались эти качели с кривизной. Знал бы, что такой косяк сплошной, не выкладывал бы вообще by_ix 1 Quote Link to comment Share on other sites More sharing options...
by_ix Posted August 30, 2021 Share Posted August 30, 2021 1 час назад, Desti сказал: Вам бы еще в табличку транзакций заглянуть, там вообще есть записи с такими индексами? не увидел этого. да, есть. 4 минуты назад, the.bunin сказал: А потом уже начались эти качели с кривизной. в первой версии всего этого, почему-то, не было. а на 4.6, она уже даже не добавляла способ оплаты в ац, эрроры летели. так бы на ней и остался. Quote Link to comment Share on other sites More sharing options...
Mano Posted August 30, 2021 Author Share Posted August 30, 2021 3 минуты назад, by_ix сказал: так бы на ней и остался. а бекапа то не осталось? Quote Link to comment Share on other sites More sharing options...
Desti Posted August 30, 2021 Share Posted August 30, 2021 да ладно, вполне починябельно, тем более, что уже понятно, что делать. я в режиме эмуляции запросов дошел до финала, так что не всё потеряно by_ix 1 Quote Link to comment Share on other sites More sharing options...
by_ix Posted August 30, 2021 Share Posted August 30, 2021 8 минут назад, the.bunin сказал: а бекапа то не осталось? бэкапа чего? я как обновился до 4.6, так версия приложения 1.0 сразу отвалилась. или даже на 4.4 перестала работать. уже помню. но на 4.2 точно она стояла. не откатывать же форум обратно на 4.2.) Quote Link to comment Share on other sites More sharing options...
Mano Posted August 30, 2021 Author Share Posted August 30, 2021 by_ix ааа, понял) думал просто в версии приложения только дело) Quote Link to comment Share on other sites More sharing options...
Desti Posted August 30, 2021 Share Posted August 30, 2021 Вах, починякалось : ) Из найденного: В файлах source/Webmoney/Webmoney.php и /modules/front/Checkout/Checkout.php заменить несуществующую переменную $transactionAmount на $transaction->amount->amountAsString(), это даст нам правильную сумму в запросе и в проверке ответа. В файле source/Webmoney/Webmoney.php после строки с echo 'YES' добавить строку die(); Сервер ждет в ответ YES, а получал YES и до кучи дефолтную страницу форума. После этого вроде всё заработало. by_ix, Zero108 and Mano 2 1 Quote Link to comment Share on other sites More sharing options...
by_ix Posted August 30, 2021 Share Posted August 30, 2021 (edited) the.bunin обнови шапку. и огроменское спасибо @Desti, как всегда лучший. Webmoney Payment Gateway 1.0.1.tar Edited August 30, 2021 by by_ix Mano 1 Quote Link to comment Share on other sites More sharing options...
Zero108 Posted November 17, 2021 Share Posted November 17, 2021 Друзья, как заполучить простому человеку с улицы, у которого есть подтвержденный аттестат на WM, данные для активации этого чуда, которое вы тут дружно допилили? Shop ID и Secret Key. И будет ли это возможно, если физическое лицо, без ИП или ООО. Техподдержка WM говорит непонятные слова. Что им ответить, я не знаю. Quote Link to comment Share on other sites More sharing options...
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.