pierwsza transakcja
Niestety każdy provider (eSerice czy Polacrd) posiada własny standard przeprowadzania transakcji, stad w aplikacji IngenicoServer nie jesteśmy w stanie przygotować uniwersalnego procesu, jednak dołożyliśmy wszelkich starań aby proces był najbardziej jak to możliwe uniwersalny.
Transakcję przeprowadza się w 3 krokach:
- Sprawdzenie czy terminal nie jest w trakcie przeprowadzania innej transakcji
- Rozpoczęcie transakcji
- Pobranie wyniku
Za każdy z 3 kroków odpowiedzialny jest inny RESTpoint, a przykładowy film ilustrujący ich użycie można obejrzeć tu:
EService
W tym artykule pokażemy jak przeprowadzić transakcję w przypadku eService. Wszystkie kroki opisane poniżej znajdują się w postaci skryptów w katalogu /docs w paczce dystrybucyjnej.
Na początku weryfikujemy czy terminal jest gotowy na przyjęcie nowej transakcji:
1 |
curl -s -XGET "http://127.0.0.1:3020/eservice/v1/ingenico_status" -H 'Content-Type: application/json' |
Jeśli status to “Idle“, wówczas możemy rozpocząć transakcję, np na 20zł
1 2 3 4 5 6 |
curl -XPOST "http://127.0.0.1:3020/eservice/v1/ingenico_transaction?fulldebug=true" -H 'Content-Type: application/json' -d '{ "type": "purchase", "amount": 2000, "title": "Hello world", "sequenceNb" : "-" }' |
Pozostałe statusy jakie mogą zostać zwrócone:
- Idle – gotowy do rozpoczęcia transakcji,
- WaitCard – oczekiwanie aż klient użyje karty,
- WaitPIN – oczekiwania na podanie kodu PIN,
- WaitEMVApp –
- WaitHost – komunikacja z eService,
- WaitSign – oczekiwanie na potwierdzenie podpisu,
- WaitTrEnd – oczekiwanie na zakończenie transakcji,
- WaitNoCard – oczekiwanie aż klient usunie kartę z terminala,
- WaitBusy – terminal zajęty (inne operacje są wykonywane); należy poczekać aż status się zmieni
- InProgress – transakcja w trakcie procesowania,
- WaitCopy – oczekiwanie na akceptację wydruku kopii,
- WaitAuthCode – oczekiwanie na podanie kodu autoryzacyjnego,
- WaitAction – oczekiwanie na akcję klienta (polecenie pojawia się na wyświetlaczu terminala)
- BatchCompleted – zestawienie gotowe, terminal oczekuje aż dane zostaną odczytane
- DCCCurrency – użytkownik wybiera walutę sprzedaży,
- CashBackAmount – oczekiwania na podanie kwoty caskback,
- TransactionAccepted – status pojawia się w zależności od konfiguracji i tylko wówczas gdy terminal wie, że transakcja została zatwierdzona.
- WaitingForAmount – oczekiwanie na wprowadzenie kwoty. Status pojawia się w przypadku: cashback, transakcjach DCC lub napiwkach.
- WaitingForSelection – oczekiwanie na wybór pozycji z listy,
- AskingEcrToPrintData – terminal oczekuje na to że klientowi zostanie wyświetlony odpowiedni tekst. Tekst do wyświetlenia zwracany jest razem ze statusem.
- PresentingZenCardOffer – oczekiwanie na wyświetlenie oferty ZenCard,
- WaitingForFid
- AskingEcrToReceiveData – terminal oczekuje na pobranie danych. Status używany podczas obsługi ZenCard,
- ZencardContinue – status ten jest wysyłany po zakończeniu transakcji ZenCard; terminal kontynuuje przetwarzanie ZenCard
- ApplicationInErrorState – inne błędy, np gdy odczyt kart nie jest możliwy,
- AskingEcrToPrintDataStop
- TransactionAborted
- WaitPromptEnd
- WaitCutoffEnd
- WaitReportEnd
- ReconciliationNeeded – oczekiwanie na zamknięcie dnia
Teraz co pewien czas, np co 1s sprawdzamy status naszej transakcji:
1 |
curl -s -XGET "http://127.0.0.1:3020/eservice/v1/ingenico_status" -H 'Content-Type: application/json' |
Jak tylko status zmieni się na “WaitTrEnd“, wówczas możemy odczytać status naszej transakcji:
1 |
curl -XGET "http://127.0.0.1:3020/eservice/v1/ingenico_transaction_end" -H 'Content-Type: application/json' |
W response zwracanym w powyższym zapytaniu znajdują się informacje o numerze transakcji, jej typie (blik, contactless, itp.) oraz jej statusie, czyli czy płatność została poprawnie przeprocesowana.
Jest kilka możliwych wariantów zakończenia transakcji. Jeśli atrybut “ok” ma wartość “true”, wówczas uznaje się transakcję za poprawnie zakończoną i z pozostałych atrybutów można odczytać szczegółowe informacje. Jeśli atrybut “ok” ma wartość “false”, wówczas pole “error” zawiera szczegółowe informacje w postaci:
- Transaction refused
- No connection
- Transaction interrupted by the user
- Card is blacklisted
SPECJALNE INTEGRACJE
Terminale często używane są w specjalnych integracjach np. z systemami parkingowymi i z systemami obsługującymi transport publiczny. Wówczas przy rozpoczęciu transakcji należy wykorzystać dedykowane temu flagi. W typowych integracjach nie są one wykorzystywane. Aktualnie obsługiwane flagi to:
- Enable Token Generation – włączenie flagi przy wysłaniu kwoty sprzedaży spowoduje, że finalnie w odpowiedzi terminal wykona sprzedaż i przekaże ten token
- Enable Reference Number Generation – terminal podczas transakcji generuje dodatkowy numer referencyjny i zwraca go w zakończeniu transakcji w polu “referenceNumber”.
- Enable Transit Transaction Indicator – wspomaga integracje w środkach transportu publicznego. Terminal wówczas akceptuje nie tylko karty płatnicze ale również bilety elektroniczne (https://www.eservice.pl/aktualnosci/tag/transit-transaction)