Skip to content
Menu

Szybki przelew

Szybki przelew (PayByLink) to znana w Polsce metoda płatności, która umożliwia klientom płacenie za zakupy w Internecie za pomocą konta bankowego. SIBS Payment Gateway zapewnia interfejs API umożliwiający integrację z usługami szybkiego przelewu poprzez wzorzec Web Redirect.

Interfejs API umożliwia przedstawienie klientowi płatności ze wszystkimi adresowalnymi podmiotami. Gdy klient wybierze podmiot, którego chce użyć, wystarczy wywołać API, które poda Ci odpowiedni adres URL przekierowania.

Płatność Szybkim przelewem – przykład desktopowego i mobilnego interfejsu użytkownika.
Metoda płatnościKategoriaKrajeWalutyFunkcjonalnościIntegracje
Szybki przelew (PayByLink)Bankowość onlinePolskaPLNZwroty kosztów
Anulowanie
API
Formularz Płatności
Wtyczka Prestashop
Wtyczka WooCommerce
Wtyczka Magento

Jak to działa

Zanim zaczniesz, powinieneś utworzyć żądanie zamówienia z PayByLink (Szybkim przelewem) jako metodą płatności.

Następnie należy wykonać następujące kroki:

Krok 1: Uzyskaj listę wszystkich podmiotów PayByLink i przedstaw je klientowi
Krok 2: Wywołaj API, aby uzyskać Listę Regulacji
Krok 3: Wywołaj API, aby uzyskać ważny Link do płatności dla wybranego podmiotu
Krok 4: Uzyskaj status płatności, aby poznać wynik płatności

Krok 1: Uzyskaj listę podmiotów Szybkiego przelewu i przedstaw je klientowi

Możesz sprawdzić listę wszystkich podmiotów PayByLink (Szybkiego przelewu) składających żądanie GET.

Należy pamiętać, że żądanie wymaga nagłówka autoryzacji ze znakiem mark, transactionsSignature zwróconym z operacji realizacji transakcji.

Sprawdź poniżej jak uzyskać listę kanałów płatności:

OperacjaTyp operacjiMetoda działania i punkt końcowyOpis operacjiObserwacje
Uzyskaj listę kanałów płatnościPołączenie synchronicznePOST https://{{APIHost}}/api/v1/paymentChannelsWykonaj transakcję i zgłoś Listę kanałów płatności.Content-Type: application/x-www-form-urlencoded
LokalizacjaElement danychTypStanOpis
Nagłówek HTTPAutoryzacjaCiągOpcjonalnyPrzykład: Nośnik *accessToken*
Token dostępu użytkownika. Musi to być schemat na okaziciela. Nie dotyczy płatności hybrydowych.
Nagłówek/autoryzacja HTTPIdentyfikator klientaKlucz APIObowiązkowyIdentyfikator klienta projektu. Należy podać w nagłówku każdego żądania.
Nagłówek/autoryzacja HTTPClient-SecretKlucz APIObowiązkowySekret klienta projektu. Należy podać w nagłówku każdego żądania.
Notification

W tym żądaniu token okaziciela zostaje zastąpiony przez odpowiedź z kasy transactionSignature.

 

countryCode(opcjonalne) – Pole wyjściowe informujące do jakiego kraju należy dany bank.

Oczekiwana odpowiedź:

Pomyślna odpowiedź techniczna składa się ze statusu HTTP-200 i returnStatus.statusCode=”000″.

W przypadku pomyślnych odpowiedzi otrzymasz następujące dodatkowe dane:

Lista Payment Channels (Kanałów Płatności):
"paymentChannels": [
		{
		"gatewayId": "PBL Gateway ID",
		"gatewayName": "Name to present to customer",
		"gatewayType": "PBL",
		"bankName": "technical bank name",
		"iconURL" : "https://paybylink.bank.pl/grafika/pbl.gif",
                "statusDate": "2023-10-03T14:35:01"
		}
]

Krok 2: Wywołaj API, aby uzyskać Listę Regulacji

Po uzyskaniu listy dostępnych podmiotów dla Szybkiego przelewu należy wykonać żądanie POST w celu otrzymania listy regulacji dla wybranego banku.

Element danychTypWarunekOpis
gatewayId StringObowiązkowyIdentyfikator Kanału Płatności (Payment Channel), dla kanału, którego Klient będzie używał do dokonywania płatności.

W tym żądaniu token okaziciela zostaje zastąpiony odpowiedzią kasy „transactionSignature”.

Oto przykład:
Adres URL żądania:
https://stargate.qly.site1.sibs.pt/api/v1/regulations
Nagłówki żądań:
Authorization: Digest {transactionSignature}
X-IBM-Client-Id: b4480347-9fc8-4790-b359-100a99c60ea3
Content-Type: application/json
{
    "body": {
        "gatewayId": "106"
     }
}

Po zakończeniu operacji odpowiedź API będzie zawierać identyfikator regulacji (regulation ID): 

  • unikalny identyfikator konkretnej regulacji
  • Adres URL zawierający bardziej szczegółowe informacje o regulacji, do której użytkownik może uzyskać dostęp
  • rodzaj regulacji
  • inputLabel, który wskazuje, czy z tą regulacją jest powiązana jakakolwiek etykieta wejściowa (input label).
Poniżej przykład odpowiedzi:
{
   "transactionStatus": "ACTC",
   "returnStatus": {
       "statusCode": "000",
       "statusMsg": "Success",
       "statusDescription": "Success"
   },
   "regulations": [
       {
           "regulationId": "11984",
           "url": "https://testpay.autopay.eu/webapi/regulation?ServiceID=903463&MessageID=e263bda2bc47536670569a1be8f691bd&Type=DEFAULT&Language=PL&Hash=6ab4a5df336351bdcb31c747ae46c54b3c554c2ddfed289584a4a53049ff3088",
           "type": "DEFAULT",
           "inputLabel": "null"
       }
   ]
}

Krok 3: Wywołaj API, aby uzyskać ważny Link do płatności dla wybranego podmiotu

Pamiętaj, że poniższe żądanie wymaga nagłówka autoryzacji z podpisem transakcji zwróconym z operacji realizacji transakcji i powinieneś uwzględnić te dwa elementy poniżej:

Element danychTypWarunekOpis
gatewayId CiągObowiązkowyIdentyfikator kanału płatności dla kanału, którego klient zamierza użyć do dokonania płatności.
userAcceptanceIndicatorWartość logicznaObowiązkowyWskazuje, czy użytkownik zaakceptował Regulamin w celu kontynuowania płatności.

W tym żądaniu token okaziciela zostaje zastąpiony odpowiedzią kasy „transactionSignature”.

Oto przykład:
Adres URL żądania:
https://stargate.qly.site1.sibs.pt/api/v1/payments/{transactionID}/pbl/payment-link
Nagłówki żądań:
Authorization: Digest {transactionSignature}
X-IBM-Client-Id: b4480347-9fc8-4790-b359-100a99c60ea3
Content-Type: application/json
{
    "info": {
        "deviceInfo": {
            "browserAcceptHeader": "application/json, text/plain, */*",
            "browserJavaEnabled": "false",
            "browserLanguage": "en",
            "browserColorDepth": "24",
            "browserScreenHeight": "1080",
            "browserScreenWidth": "1920",
            "browserTZ": "-60",
            "browserUserAgent": "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/106.0.0.0 Safari/537.36",
            "geoLocalization": "Lat: 38.7350528 | Long: -9.2143616",
            "systemFamily": "Windows",
            "systemVersion": "Windows",
            "deviceID": "498bfd4c3a3645b38667a7037b616c18",
            "applicationName": "Chrome",
            "applicationVersion": "106"
        },
        "customerInfo": [
            {
                "key": "customerName",
                "value": "Test Name"
            },
            {
                "key": "customerEmail",
                "value": "email@provider.com"
            }
        ]
    },
    "gatewayId": "106",
    "userAcceptanceIndicator": true,
    "merchant": {
        "merchantURL": "https://egadget2.azurewebsites.net/#/returns?id={{transactionId}}"
    }
}

Po zakończeniu operacji powinieneś otrzymać status oczekującej płatności.

Użytkownik zostanie przekierowany do środowiska PBL w celu potwierdzenia płatności, a następnie z powrotem na adres URL sprzedawcy.

{
    "transactionID": "q6Gb8jFT7Ag0UGCTApMM",
    "execution": {
        "startTime": "2025-01-09T16:47:45.754Z",
        "endTime": "2025-01-09T16:47:48.840Z"
    },
    "paymentStatus": "Pending",
    "returnStatus": {
        "statusCode": "000",
        "statusMsg": "Success",
        "statusDescription": "Success"
    },
    "redirectURL": "https://testpay.autopay.eu/web/payment/continue/AX7B553VIB/1BHFTSH9K"
}

Krok 4: Uzyskaj status płatności, aby poznać wynik płatności

Po całkowitym przetworzeniu płatności możesz sprawdzić status swojej transakcji, wysyłając żądanie GET.

Nagłówek HTTP autoryzacji jest ustawiony na token okaziciela, tak jak był używany podczas początkowej realizacji transakcji.

OperacjaTyp operacjiMetoda działania i punkt końcowyOpis operacji
Uzyskaj status płatnościPołączenie synchroniczneGET
/api/v1/payment/{transactionId}/status
Uzyskaj status płatności
Body:
LokalizacjaElement danychTypWarunekOpis
Parametr zapytaniatransactionIdCiągObowiązkowyIdentyfikacja płatności.
Przykład: 9078fbb0-fced-4606-95c7-4989f06ee253
Nagłówek HTTPAutoryzacjaCiągOpcjonalnyPrzykład: Nośnik *accessToken*
Token dostępu użytkownika. Musi to być schemat na okaziciela. Nie dotyczy płatności hybrydowych.
Nagłówek/autoryzacja HTTPIdentyfikator klientaKlucz APIObowiązkowyIdentyfikator klienta projektu. Należy podać w nagłówku każdego żądania.
Nagłówek/autoryzacja HTTPClient-SecretKlucz APIObowiązkowySekret klienta projektu. Należy podać w nagłówku każdego żądania.
Oczekiwana odpowiedź pomyślna:
{
    "merchant": {
        "terminalId": "101778",
        "merchantTransactionId": "Order Id: r7cxvi0saj"
    },
    "transactionID": "J120XDzUq2u4UwVDSZBt",
    "amount": {
        "currency": "PLN",
        "value": "50.50"
    },
    "paymentType": "PURS",
    "paymentStatus": "Success",
    "paymentMethod": "PAY_BY_LINK",
    "execution": {
        "endTime": "2023-06-20T10:07:27.771Z",
        "startTime": "2023-06-20T10:07:27.701Z"
    },
    "returnStatus": {
        "statusCode": "000",
        "statusMsg": "Success",
        "statusDescription": "Success"
    }
}

Pomyślna odpowiedź techniczna składa się ze statusu HTTP-200 i wartości returnStatus.statusCode=”000″.

Oto kilka przykładów możliwych kodów wyników:

Result CodestatusMsgDescriptionAction
HTTP-200SuccessSuccess responseN/A
HTTP-400Bad RequestThe JSON payload is not matching the API definition or some mandatory HTTP headers are missing.Please check in API Market for the correct syntax.
HTTP-401UnauthorizedOn the Authorization, Bearer token is invalid/expired or not associated with the Terminal used.Please check in SIBS Backoffice under the Credentials if the token is valid and create a new one if needed.
HTTP-403ForbiddenThe ClientID set on the X-IBM-Client-Id HTTP header is not valid or does not possess a valid subscription to the API.Please check in SIBS Backoffice under the SPG APP 2.0 if the ClientID is correct. If the problem persists contact SIBS Gateway support for a ClientID reset.
HTTP-405Method Not AllowedThe HTTP Method used is not matching any of the API definitions available.Please check in API Market for the correct HTTP Method.
HTTP-429Too Many RequestsThe API calls rate limit has been exceeded.Please check in API Market for information on the rate limits that apply to the API.
HTTP-500Internal Server ErrorThe API call has failed… and its most likely on our side.You should retry the operation, and if the problem persists contact SIBS Gateway support for assistance.
HTTP-503Service UnavailableThe API call is not currently available. Usually we are always on, but short availability issues may occur during scheduled maintenance.You should wait and try again later.
Przegląd prywatności

Ta strona korzysta z ciasteczek, aby zapewnić Ci najlepszą możliwą obsługę. Informacje o ciasteczkach są przechowywane w przeglądarce i wykonują funkcje takie jak rozpoznawanie Cię po powrocie na naszą stronę internetową i pomaganie naszemu zespołowi w zrozumieniu, które sekcje witryny są dla Ciebie najbardziej interesujące i przydatne.

Ściśle niezbędne ciasteczka

Niezbędne ciasteczka powinny być zawsze włączone, abyśmy mogli zapisać twoje preferencje dotyczące ustawień ciasteczek.