• Resolved mpatzekov

    (@razmzk)


    Привет и поздравления за плъгина!

    Наистина е много полезен и ние успяхме да го вържем към нашия онлайн магазин. Сега обаче изпитваме малко затруднение, понеже не се ъпдейтват наличностите на продаваните стоки. Нека представя следния сценарий.

    1. Клиент влиза в онлайн магазина;
    2. Избира продукт, попълва всички полета за доставка;
    3. От методите за плащане, избира еPay.bg;
    4. Извършва се редирект към сайта на ePay.bg;
    5. Информацията като: име на търговец, сума и т.н – всичко това излиза коректно;
    6. Клиентът въвежда потребителски си данни за системата на ePay.bg;
    7. ePay обработва плащането и връща, че е извършено успешно;
    8. Появява се бутон за редирект обратно към уеб сайта на търговеца;
    9. Клиентът попада отново в нашия сайта, като се връща съобщение:
    Благодарим Ви, поръчката е извършена успешно.

    НО! В Woocommerce в orders поръчката пристига “Pending payment “, а не със статус “Processing”. Най-вероятно и то тук не се ъпдейтва наличността.

    Дали при всички е така и изобщо някой тествал ли е този сценарий? И като цяло – всякакви идеи как да разрешим този проблем са добре дошли!

    Поздрави.

    https://www.ads-software.com/plugins/woocommerce-epaybg/

Viewing 15 replies - 1 through 15 (of 17 total)
  • Thread Starter mpatzekov

    (@razmzk)

    UPDATE: интересно нещо се случва ??

    Не знам защо, но log файлът не се пълни с никаква информация, въпреки че е включена опцията за запис в него. Сега видях, че логът ми записал информация от преди няколко дена (не знам защо само за този времеви отрязък от 1 час) и там се вижда следната нередност:

    06-08-2015 @ 23:59:37 – PAYLOGIN: ERROR: IPN response incorrect hash
    06-09-2015 @ 00:03:47 – PAYLOGIN: ERROR: IPN response incorrect hash
    06-09-2015 @ 00:03:49 – PAYLOGIN: ERROR: IPN response incorrect hash
    06-09-2015 @ 00:28:02 – PAYLOGIN: ERROR: IPN response incorrect hash
    06-09-2015 @ 00:29:30 – PAYLOGIN: ERROR: IPN response incorrect hash
    06-09-2015 @ 00:29:31 – PAYLOGIN: ERROR: IPN response incorrect hash
    06-09-2015 @ 00:30:24 – PAYLOGIN: ERROR: IPN response incorrect hash
    06-09-2015 @ 00:33:41 – PAYLOGIN: ERROR: IPN response incorrect hash

    Разбирам, че hash-a, който е генериран в IPN Callback не съответства на този, който е вкаран в системата на ePay.bg. Това обаче не е така – същите са 1:1.

    Забелязвам и още нещо интересно. В админ секцията пише:

    Value of the field depends of Customer Number, so if it is changed then change also this URL.
    Copy and paste this value in your profile under URL for receiving notifications

    Исках да сменя този hash и да пробвам с нов. Пробвах да променям името на клиента, секретния ключ, изктрих плъгина и го качих наново, изтрих стойностите от базата данни дори, но въпреки всичко това, IPN Callback никога не се промени. Стои си един и същ и се записва в базата един и същ независимо какви промени правя.

    Къде може да има някаква нередност и защо поръчките пристигат като pending payment, а не като processing?

    Много ще се радвам, ако някой сподели идея какво може да причинява тези неща.

    Thread Starter mpatzekov

    (@razmzk)

    Прикачвам и линк към скриншот, където се виждат настройките.

    ЦЪК.

    Plugin Author dimitrov.adrian

    (@dimitrovadrian)

    Здравйте,

    Мисля, че открих проблема. Обновете към версия 1.1 и опитайте да презапиште настройките. IPN url-a би трябвало да се промени, използвайте него в ePay.bg настройките на профила.

    Thread Starter mpatzekov

    (@razmzk)

    Привет Адриан,

    Благодаря ти за фикса! В тестов режим работи. Утре се надявам да мине и при live плащанията.

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

    Та, нещото е следното. В нашия сайт 301 редиректваме всички http рекуести към https версията. Когато ползваме https, IPN адрес за известяване се генерира с http. Аз пробвах при демо плащанията да вкарам “URL за известяване” само с http(така, както е генериран). Тогава ситуацията беше същата – плащанията минаваха, но наличностите не се ъпдейтваха и поръчките идваха “pending” поради PAYLOGIN: ERROR: IPN response incorrect hash.

    Когато, обаче, в “URL за известяване” вкарах същия генериран URL за “IPN адрес за известяване”, но с https – тогава всичко минава коректно. Поръчките влизат като “processing” и складовите наличности се ъпдейтват!

    Надявам се да съм бил полезен!

    Поздрави и отново благодаря!

    Plugin Author dimitrov.adrian

    (@dimitrovadrian)

    Здравейте,

    По принцип използвам същия метод за генериране на URL адреза за IPN известяване както и останалите методи за разплащане. Ако сайтът е настроен да използва HTTPS то и адреса ще бъде с https. Редиректи, които не стават през WP не съм сигурен точно как може да се прихванат.

    Поздрави!

    Thread Starter mpatzekov

    (@razmzk)

    Вероятно сте прав. За момента методът работи безупречно, за което сме много щастливи ??

    Projekt43

    (@projekt43)

    Здравейте,

    I’ll post in english as I’m not native Bulgarian… =)
    First thank you Adrian for this plugin wich is really helpfull!!!

    I’m facing the same problem : PAYLOGIN: ERROR: IPN response incorrect hash… And all its consequences….

    All my site is in https (http is redirected to https @ Hosting), all IPN url is set up with https @ ePay.bg (demo).

    Plugin is in demo mode.

    Any idea?

    Projekt43

    (@projekt43)

    Also, something interesting which may (I have no idea!) be implied :

    Time in the logs is one hour upfront :
    11-06-2015 @ 18:02:39 - PAYLOGIN: ERROR: IPN response incorrect hash
    For a payment processed @ 17:02 BG time…

    Edit : No, time setting on the server is not affecting the error :
    11-06-2015 @ 17:09:56 - PAYLOGIN: ERROR: IPN response incorrect hash

    Plugin Author dimitrov.adrian

    (@dimitrovadrian)

    Hi Projekt43,

    About the problem with the IPN check you could follows:
    1. if the URL is the same as you use in ePay.bg as the URL in the plugin is changing depending of client ID
    2. As I understand you use HTTPS so check if your WC has option set Force SSL on checkout pages.

    If you still has a problem you could send me a mail with the log, and your WP and WC versions numbers.

    Or you could try Disable IPN hash key check in 1.3

    About the issue with the dates in the log. This is something that is related to WC directly, because the plugin using the WC’s error wrapper, so I can’t help here.

    Projekt43

    (@projekt43)

    Hi Adrian,

    Thanks for you prompt answer & update of the plugin. You are amazingly fast!! =)

    1. Yes IPN Callbacks are identical (same hash). The URL that I inserted in demo.epay.bg is the one generated by your code after I saved the MIN & Secret Key given by demo.epay.bg.

    2. WC “force HTTPS Checkou” option was not enabled at the time of my first post (because all traffic to the site is redirected through HTTPS), but I tried enabling it with no luck…

    Also, after a bit of monkeying, it looks like my $_GET is empty in class-wc-gateway-epaybg.php > function epaybg_ipn_response()
    I made this changes :

    public function epaybg_ipn_response() {
    
        if (empty($_GET['hash']) || $_GET['hash'] != $this->ipn_key) {
          // TODO: incorrect key
    
          // DBUG C43
    	  $DBG_Hash = $this->ipn_key;
    	  $DBG_GHash = $_GET['hash'];
    	  empty($DBG_GHash) ? $DBG_GHash = 'Empty GET hash' : $DBG_GHash = 'NOK GET';
    
          if (empty($_POST['encoded'])) {
            $this->log('ERROR: IPN response incorrect hash' . ' - Custom DeBug S2!!! Hash = ' . $DBG_Hash . ' GHash = ' . $DBG_GHash );
          }
          return 0;
        }
    ...

    And I’m gettting this in the log :

    11-06-2015 @ 21:55:15 - PAYLOGIN: ERROR: IPN response incorrect hash - Custom DeBug S2!!! Hash = THE_CORRECT_VALUE_OF_THE_CALLBACK_HASH GHash = Empty GET hash

    Then, “forcing” $_GET['hash'] = $this->ipn_key; before the first IF
    just send me to the next error :

    11-06-2015 @ 22:01:26 - PAYLOGIN: ERROR: IPN response missing encoded post data.
    11-06-2015 @ 22:01:26 - PAYLOGIN: ERROR: IPN response missing checksum post data.

    3. Just installing 1.3 and will come back with a fedback.

    BTW : WP 4.3.1 & WC 2.4.8 all up to date
    But PHP 5.3.29!! Can it be this?

    Thank you again!!!

    Projekt43

    (@projekt43)

    Nope…

    Disabling IPN hash key check in 1.3 is not fixing the problem…
    EDIT : It looks like it’s not taken into account.

    Still hash error :

    11-06-2015 @ 23:34:22 - PAYLOGIN: ERROR: IPN response incorrect hash
    11-06-2015 @ 23:34:34 - PAYLOGIN: ERROR: IPN response incorrect hash

    As you suggested, I can send you a mail with logs, but there is nothing more than what I posted already. And in the PHP logs of the server only traces of my mistakes when I was monkeying this afternoon…
    Maybe better to give you admin access to WP?!

    I’ve no moreideas for tonight…

    Thnx!

    Projekt43

    (@projekt43)

    Just created you an account.
    You should have received info in you mail.

    Plugin Author dimitrov.adrian

    (@dimitrovadrian)

    It seems your system recieve or trim some of the required data POST and GET.

    I am not sure how and why without make an investigate (it could be a plugin or theme) but it also could be because the PHP version, as WC requires at least 5.4

    Projekt43

    (@projekt43)

    Yes, I think too.
    I’ll investigate in this direction and keep you updated here.
    Thank you again for your time =)

    Projekt43

    (@projekt43)

    Trying some things…
    And set you account down to Customer, let me know if you wish it back to admin.
    Also saw your mods for “richer” logs! Thanx.

Viewing 15 replies - 1 through 15 (of 17 total)
  • The topic ‘Update Stock Quantity’ is closed to new replies.