Logging
TatrapayPlusLogger
TatrapayPlusLogger je jednoduchý a prispôsobiteľný HTTP logger pre TBPlusSDK.
Pomáha vám ladiť volania API zaznamenávaním odchádzajúcich požiadaviek a prichádzajúcich odpovedí a zároveň bezpečne maskuje citlivé údaje.
Funkcie
- Zaznamenáva metadáta žiadostí a odpovedí
- Vstavané maskovanie polí
- Rozšíriteľné pomocou
write_line()
Maskované polia
Logger maskuje citlivé hodnoty pred ich výstupom:
- Headers:
Authorization - Body fields (reqest and response):
client_id,client_secret,access_token
Príklad maskovaného výstupu: client_secret=abcde*************uvxyz
Maskovanie môžete zakázať nastavením parametra mask_sensitive_data=False počas inicializácie loggeru:
const logger = new TBPlusLogger(false);
Príklad použitia
Krok 1: Vytvorenie podtriedy Loggeru
import { TBPlusLogger } from "./logger";
class ConsoleLogger extends TBPlusLogger {
protected writeLine(line: string): void {
console.log("[ConsoleLogger]", line);
}
}
}
Krok 2: Vloženie loggeru do klienta
import { TBPlusSDK } from "tbplus-sdk";
const logger = new ConsoleLogger();
const sdk = new TBPlusSDK(
API_KEY,
API_SECRET,
"192.0.2.123",
{},
logger
);
Prispôsobenie
Maskovacie polia si môžete prispôsobiť:
logger.maskSensitiveData = true;
logger.maskBodyFields = ["client_id", "client_secret", "access_token"];
logger.maskHeaderFields = ["authorization"];
Príklad výstupu
[ConsoleLogger] Request: POST https://api.tatrabanka.sk/tatrapayplus/sandbox/v1/payments
[ConsoleLogger] Headers:
{
"authorization": "Beare*********************************70d69",
"content-type": "application/json",
"x-request-id": "df7f30e8-6cde-4c76-b377-a2e83fd937dd"
}
[ConsoleLogger] Body:
{
"basePayment": {
"instructedAmount": {
"amountValue": 120,
"currency": "EUR"
},
"endToEnd": "ORDER123456"
},
"bankTransfer": {}
}
[ConsoleLogger] Response Status: 201
[ConsoleLogger] Response:
{
"paymentId": "baf651a5-1582-4b92-9a59-dacd61f65a51",
"tatraPayPlusUrl": "https://api.tatrabanka.sk/...&client_id=l7ba7f*****4955f54&hmac=bf17*****3479a2",
"availablePaymentMethods": [
{
"paymentMethod": "BANK_TRANSFER",
"isAvailable": true
},
...
]
}