@pabilo/sdk 0.1.4 → 0.1.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +635 -0
- package/dist/index.cjs +6 -0
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +6 -2
- package/dist/index.d.ts +6 -2
- package/dist/index.js +6 -0
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
package/README.md
ADDED
|
@@ -0,0 +1,635 @@
|
|
|
1
|
+
# @pabilo/sdk
|
|
2
|
+
|
|
3
|
+
TypeScript/JavaScript SDK for [pabilo.app](https://pabilo.app) — the Venezuelan payment platform.
|
|
4
|
+
|
|
5
|
+
- Dual ESM / CommonJS output
|
|
6
|
+
- Full TypeScript types with discriminated unions
|
|
7
|
+
- Zero runtime dependencies
|
|
8
|
+
- Works with Next.js, Node.js, and any modern JS runtime
|
|
9
|
+
|
|
10
|
+
## Installation
|
|
11
|
+
|
|
12
|
+
```bash
|
|
13
|
+
npm install @pabilo/sdk
|
|
14
|
+
# or
|
|
15
|
+
pnpm add @pabilo/sdk
|
|
16
|
+
```
|
|
17
|
+
|
|
18
|
+
## Quick start
|
|
19
|
+
|
|
20
|
+
```typescript
|
|
21
|
+
import { PabiloClient } from '@pabilo/sdk';
|
|
22
|
+
|
|
23
|
+
const pabilo = new PabiloClient({ apiKey: 'YOUR_API_KEY' });
|
|
24
|
+
```
|
|
25
|
+
|
|
26
|
+
The client exposes four namespaces:
|
|
27
|
+
|
|
28
|
+
| Namespace | Description |
|
|
29
|
+
|---|---|
|
|
30
|
+
| `pabilo.me` | Current user and plan info |
|
|
31
|
+
| `pabilo.bankAccounts` | Manage connected bank accounts |
|
|
32
|
+
| `pabilo.paymentLinks` | Create and manage payment links |
|
|
33
|
+
| `pabilo.payments` | Verify payments by bank reference |
|
|
34
|
+
|
|
35
|
+
---
|
|
36
|
+
|
|
37
|
+
## `pabilo.me`
|
|
38
|
+
|
|
39
|
+
### `me.getMe(): Promise<User>`
|
|
40
|
+
|
|
41
|
+
Returns the authenticated user's profile.
|
|
42
|
+
|
|
43
|
+
```typescript
|
|
44
|
+
const user = await pabilo.me.getMe();
|
|
45
|
+
|
|
46
|
+
console.log(user.id); // string
|
|
47
|
+
console.log(user.email); // string | undefined
|
|
48
|
+
console.log(user.name); // string | undefined
|
|
49
|
+
```
|
|
50
|
+
|
|
51
|
+
**Returns:** `User`
|
|
52
|
+
|
|
53
|
+
```typescript
|
|
54
|
+
interface User {
|
|
55
|
+
id: string;
|
|
56
|
+
email?: string;
|
|
57
|
+
name?: string;
|
|
58
|
+
}
|
|
59
|
+
```
|
|
60
|
+
|
|
61
|
+
---
|
|
62
|
+
|
|
63
|
+
### `me.getPlan(): Promise<Plan>`
|
|
64
|
+
|
|
65
|
+
Returns the current subscription plan for the authenticated account.
|
|
66
|
+
|
|
67
|
+
```typescript
|
|
68
|
+
const plan = await pabilo.me.getPlan();
|
|
69
|
+
|
|
70
|
+
console.log(plan.name); // e.g. 'basic', 'pro'
|
|
71
|
+
console.log(plan.planType); // string | undefined
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
**Returns:** `Plan`
|
|
75
|
+
|
|
76
|
+
```typescript
|
|
77
|
+
interface Plan {
|
|
78
|
+
name: string;
|
|
79
|
+
planType?: string;
|
|
80
|
+
}
|
|
81
|
+
```
|
|
82
|
+
|
|
83
|
+
---
|
|
84
|
+
|
|
85
|
+
## `pabilo.bankAccounts`
|
|
86
|
+
|
|
87
|
+
### `bankAccounts.list(): Promise<UserBank[]>`
|
|
88
|
+
|
|
89
|
+
Returns all bank accounts connected to the authenticated user.
|
|
90
|
+
|
|
91
|
+
```typescript
|
|
92
|
+
const banks = await pabilo.bankAccounts.list();
|
|
93
|
+
|
|
94
|
+
for (const bank of banks) {
|
|
95
|
+
console.log(bank.id); // MongoDB ObjectId string
|
|
96
|
+
console.log(bank.provider); // 'VE_BAN' | 'VE_BAN_EMP_V2' | 'BANK_TEST' | ...
|
|
97
|
+
console.log(bank.description); // display name set during creation
|
|
98
|
+
console.log(bank.bank_accounts); // BankAccountEntry[]
|
|
99
|
+
console.log(bank.to_trash); // boolean — true if soft-deleted
|
|
100
|
+
}
|
|
101
|
+
```
|
|
102
|
+
|
|
103
|
+
**Returns:** `UserBank[]`
|
|
104
|
+
|
|
105
|
+
```typescript
|
|
106
|
+
interface UserBank {
|
|
107
|
+
id: string;
|
|
108
|
+
description: string;
|
|
109
|
+
provider: string;
|
|
110
|
+
bank_accounts: BankAccountEntry[];
|
|
111
|
+
payment_link?: boolean;
|
|
112
|
+
to_trash?: boolean;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
interface BankAccountEntry {
|
|
116
|
+
account_number: string;
|
|
117
|
+
account_type: string; // e.g. 'AHORRO', 'CORRIENTE'
|
|
118
|
+
}
|
|
119
|
+
```
|
|
120
|
+
|
|
121
|
+
---
|
|
122
|
+
|
|
123
|
+
### `bankAccounts.create(req): Promise<UserBank>`
|
|
124
|
+
|
|
125
|
+
Creates a new bank account connection. Each provider has its own typed request — TypeScript enforces required fields per provider via a discriminated union on `bankProvider`.
|
|
126
|
+
|
|
127
|
+
**BDV personal — `VE_BAN`**
|
|
128
|
+
|
|
129
|
+
```typescript
|
|
130
|
+
const bank = await pabilo.bankAccounts.create({
|
|
131
|
+
bankProvider: 'VE_BAN',
|
|
132
|
+
description: 'Mi cuenta BDV personal',
|
|
133
|
+
userBankPhone: '04241234567',
|
|
134
|
+
userBankDni: '12345678',
|
|
135
|
+
username: 'usuario_portal_bdv',
|
|
136
|
+
password: 'contraseña_portal_bdv',
|
|
137
|
+
});
|
|
138
|
+
|
|
139
|
+
console.log(bank.id); // use this id when creating payment links
|
|
140
|
+
```
|
|
141
|
+
|
|
142
|
+
**BDV empresa — `VE_BAN_EMP_V2`**
|
|
143
|
+
|
|
144
|
+
The `accountNumber` and `apiKey` fields are mapped to `username` and `password` in the API — the SDK exposes semantic names.
|
|
145
|
+
|
|
146
|
+
```typescript
|
|
147
|
+
const bank = await pabilo.bankAccounts.create({
|
|
148
|
+
bankProvider: 'VE_BAN_EMP_V2',
|
|
149
|
+
description: 'Cuenta empresa BDV',
|
|
150
|
+
userBankPhone: '04241234567',
|
|
151
|
+
userBankDni: '12345678',
|
|
152
|
+
accountNumber: '01020000000000000000', // número de cuenta
|
|
153
|
+
apiKey: 'bdv_api_key_here',
|
|
154
|
+
metadata: [
|
|
155
|
+
{ key_name: 'SHOW_DATE_IN_GENERIC_MOVEMENTS', key_value: 'true' },
|
|
156
|
+
],
|
|
157
|
+
});
|
|
158
|
+
```
|
|
159
|
+
|
|
160
|
+
**Test bank — `BANK_TEST`**
|
|
161
|
+
|
|
162
|
+
A sandboxed bank for testing. Always has a payment with reference `67890` available.
|
|
163
|
+
|
|
164
|
+
```typescript
|
|
165
|
+
const bank = await pabilo.bankAccounts.create({ bankProvider: 'BANK_TEST' });
|
|
166
|
+
```
|
|
167
|
+
|
|
168
|
+
**Request types:**
|
|
169
|
+
|
|
170
|
+
```typescript
|
|
171
|
+
// Shared base (not needed for BANK_TEST)
|
|
172
|
+
interface BaseCreateUserBankRequest {
|
|
173
|
+
description: string;
|
|
174
|
+
userBankPhone: string;
|
|
175
|
+
userBankDni: string;
|
|
176
|
+
metadata?: UserBankMetadataEntry[]; // [{ key_name: string, key_value: string }]
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
interface CreateVeBanRequest extends BaseCreateUserBankRequest {
|
|
180
|
+
bankProvider: 'VE_BAN';
|
|
181
|
+
username: string;
|
|
182
|
+
password: string;
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
interface CreateVeBanEmpV2Request extends BaseCreateUserBankRequest {
|
|
186
|
+
bankProvider: 'VE_BAN_EMP_V2';
|
|
187
|
+
accountNumber: string;
|
|
188
|
+
apiKey: string;
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
interface CreateBankTestRequest {
|
|
192
|
+
bankProvider: 'BANK_TEST';
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
type CreateUserBankRequest =
|
|
196
|
+
| CreateVeBanRequest
|
|
197
|
+
| CreateVeBanEmpV2Request
|
|
198
|
+
| CreateBankTestRequest;
|
|
199
|
+
```
|
|
200
|
+
|
|
201
|
+
**Returns:** `UserBank` (same shape as `list()` entries)
|
|
202
|
+
|
|
203
|
+
---
|
|
204
|
+
|
|
205
|
+
### `bankAccounts.delete(id): Promise<void>`
|
|
206
|
+
|
|
207
|
+
Soft-deletes a bank account (moves it to trash). The bank no longer appears in `list()` results.
|
|
208
|
+
|
|
209
|
+
```typescript
|
|
210
|
+
await pabilo.bankAccounts.delete(bank.id);
|
|
211
|
+
```
|
|
212
|
+
|
|
213
|
+
| Parameter | Type | Description |
|
|
214
|
+
|---|---|---|
|
|
215
|
+
| `id` | `string` | The `UserBank.id` to delete |
|
|
216
|
+
|
|
217
|
+
---
|
|
218
|
+
|
|
219
|
+
## `pabilo.paymentLinks`
|
|
220
|
+
|
|
221
|
+
### `paymentLinks.create(req): Promise<PaymentLink>`
|
|
222
|
+
|
|
223
|
+
Creates a new payment link that customers can use to pay via Pago Móvil.
|
|
224
|
+
|
|
225
|
+
```typescript
|
|
226
|
+
const link = await pabilo.paymentLinks.create({
|
|
227
|
+
amount: 4000,
|
|
228
|
+
description: 'Orden #1234',
|
|
229
|
+
userBankId: bank.id,
|
|
230
|
+
// optional
|
|
231
|
+
name: 'Servicio mensual',
|
|
232
|
+
redirectUrl: 'https://myapp.com/gracias',
|
|
233
|
+
webhookUrl: 'https://myapp.com/webhook/pabilo',
|
|
234
|
+
notificationByWhatsapp: true,
|
|
235
|
+
isUsd: false,
|
|
236
|
+
currency: 'VES',
|
|
237
|
+
});
|
|
238
|
+
|
|
239
|
+
console.log(link.url); // https://pabilo.app/pay/... share this with the customer
|
|
240
|
+
console.log(link.id); // use for getInfo / isPaid / update
|
|
241
|
+
console.log(link.status); // 'pending' | 'active' | 'paid' | 'expired' | 'cancelled'
|
|
242
|
+
```
|
|
243
|
+
|
|
244
|
+
**Request fields:**
|
|
245
|
+
|
|
246
|
+
| Field | Type | Required | Description |
|
|
247
|
+
|---|---|---|---|
|
|
248
|
+
| `amount` | `number` | yes | Amount in the payment currency |
|
|
249
|
+
| `description` | `string` | yes | Internal description |
|
|
250
|
+
| `userBankId` | `string` | yes | ID of the bank account to receive payment |
|
|
251
|
+
| `name` | `string` | no | Customer-facing name shown on the payment page |
|
|
252
|
+
| `currency` | `string` | no | Defaults to `'VES'` |
|
|
253
|
+
| `isUsd` | `boolean` | no | Whether the amount is in USD |
|
|
254
|
+
| `redirectUrl` | `string` | no | URL to redirect after payment |
|
|
255
|
+
| `webhookUrl` | `string` | no | URL to receive payment event webhooks |
|
|
256
|
+
| `notificationByWhatsapp` | `boolean` | no | Send WhatsApp notification on payment |
|
|
257
|
+
| `metadata` | `Record<string, unknown>` | no | Arbitrary key/value data |
|
|
258
|
+
|
|
259
|
+
**Returns:** `PaymentLink`
|
|
260
|
+
|
|
261
|
+
```typescript
|
|
262
|
+
interface PaymentLink {
|
|
263
|
+
id: string;
|
|
264
|
+
url: string;
|
|
265
|
+
amount?: number;
|
|
266
|
+
status?: 'pending' | 'paid' | 'active' | 'expired' | 'cancelled';
|
|
267
|
+
type?: 'default' | 'fixed';
|
|
268
|
+
userId?: string;
|
|
269
|
+
name?: string;
|
|
270
|
+
description?: string;
|
|
271
|
+
isUsd?: boolean;
|
|
272
|
+
redirectUrl?: string;
|
|
273
|
+
webhookUrl?: string;
|
|
274
|
+
notificationByWhatsapp?: boolean;
|
|
275
|
+
expirationTime?: number;
|
|
276
|
+
paymentLinkOrigin?: string;
|
|
277
|
+
createdAt?: string;
|
|
278
|
+
updatedAt?: string;
|
|
279
|
+
}
|
|
280
|
+
```
|
|
281
|
+
|
|
282
|
+
---
|
|
283
|
+
|
|
284
|
+
### `paymentLinks.getInfo(id): Promise<PaymentLink>`
|
|
285
|
+
|
|
286
|
+
Fetches current state of a payment link (status, amount, etc.).
|
|
287
|
+
|
|
288
|
+
```typescript
|
|
289
|
+
const link = await pabilo.paymentLinks.getInfo('69d0083b691af50b78e07921');
|
|
290
|
+
|
|
291
|
+
console.log(link.status); // 'paid'
|
|
292
|
+
console.log(link.amount); // 4000
|
|
293
|
+
console.log(link.createdAt); // ISO date string
|
|
294
|
+
```
|
|
295
|
+
|
|
296
|
+
| Parameter | Type | Description |
|
|
297
|
+
|---|---|---|
|
|
298
|
+
| `id` | `string` | The `PaymentLink.id` |
|
|
299
|
+
|
|
300
|
+
---
|
|
301
|
+
|
|
302
|
+
### `paymentLinks.isPaid(id): Promise<boolean>`
|
|
303
|
+
|
|
304
|
+
Convenience method — returns `true` if the payment link's status is `'paid'`.
|
|
305
|
+
|
|
306
|
+
```typescript
|
|
307
|
+
const paid = await pabilo.paymentLinks.isPaid('69d0083b691af50b78e07921');
|
|
308
|
+
|
|
309
|
+
if (paid) {
|
|
310
|
+
// fulfill the order
|
|
311
|
+
}
|
|
312
|
+
```
|
|
313
|
+
|
|
314
|
+
| Parameter | Type | Description |
|
|
315
|
+
|---|---|---|
|
|
316
|
+
| `id` | `string` | The `PaymentLink.id` |
|
|
317
|
+
|
|
318
|
+
> Internally calls `getInfo()` and checks `status === 'paid'`.
|
|
319
|
+
|
|
320
|
+
---
|
|
321
|
+
|
|
322
|
+
### `paymentLinks.update(id, req): Promise<PaymentLink>`
|
|
323
|
+
|
|
324
|
+
Updates a payment link's amount, description, redirect URL, or currency.
|
|
325
|
+
|
|
326
|
+
```typescript
|
|
327
|
+
const updated = await pabilo.paymentLinks.update('69d0083b691af50b78e07921', {
|
|
328
|
+
amount: 5000,
|
|
329
|
+
description: 'Orden actualizada',
|
|
330
|
+
redirectUrl: 'https://myapp.com/nueva-ruta',
|
|
331
|
+
currency: 'VES',
|
|
332
|
+
});
|
|
333
|
+
|
|
334
|
+
console.log(updated.amount); // 5000
|
|
335
|
+
```
|
|
336
|
+
|
|
337
|
+
**Request fields (all optional):**
|
|
338
|
+
|
|
339
|
+
| Field | Type | Description |
|
|
340
|
+
|---|---|---|
|
|
341
|
+
| `amount` | `number` | New amount |
|
|
342
|
+
| `description` | `string` | New description |
|
|
343
|
+
| `redirectUrl` | `string` | New redirect URL |
|
|
344
|
+
| `currency` | `string` | New currency code |
|
|
345
|
+
|
|
346
|
+
---
|
|
347
|
+
|
|
348
|
+
## `pabilo.payments`
|
|
349
|
+
|
|
350
|
+
### `payments.verify(userBankId, req): Promise<VerifyPaymentResult>`
|
|
351
|
+
|
|
352
|
+
Checks whether a specific bank transfer exists in a connected bank account. Used to confirm that a customer's Pago Móvil transfer matches an expected payment.
|
|
353
|
+
|
|
354
|
+
```typescript
|
|
355
|
+
const result = await pabilo.payments.verify(bank.id, {
|
|
356
|
+
amount: 4000,
|
|
357
|
+
bankReference: '12345678',
|
|
358
|
+
movementType: 'GENERIC', // optional, defaults to 'GENERIC'
|
|
359
|
+
});
|
|
360
|
+
|
|
361
|
+
if (result.found) {
|
|
362
|
+
console.log(result.isNew); // true if first time this reference was seen
|
|
363
|
+
console.log(result.data.credit_cost);
|
|
364
|
+
console.log(result.data.is_new);
|
|
365
|
+
|
|
366
|
+
const payment = result.data.user_bank_payment;
|
|
367
|
+
if (payment) {
|
|
368
|
+
console.log(payment.id);
|
|
369
|
+
console.log(payment.amount);
|
|
370
|
+
console.log(payment.status); // 'paid'
|
|
371
|
+
console.log(payment.bank_reference_id);
|
|
372
|
+
console.log(payment.payment_params.fecha_pago);
|
|
373
|
+
console.log(payment.payment_params.banco_origen);
|
|
374
|
+
console.log(payment.payment_params.telefono_pagador);
|
|
375
|
+
}
|
|
376
|
+
} else {
|
|
377
|
+
// result.reason → 'BANK_NOT_AVAILABLE' | 'PAYMENT_NOT_FOUND'
|
|
378
|
+
if (result.reason === 'BANK_NOT_AVAILABLE') {
|
|
379
|
+
// bank is offline or credentials expired
|
|
380
|
+
}
|
|
381
|
+
if (result.reason === 'PAYMENT_NOT_FOUND') {
|
|
382
|
+
// transfer does not exist or does not match
|
|
383
|
+
}
|
|
384
|
+
}
|
|
385
|
+
```
|
|
386
|
+
|
|
387
|
+
**Request fields:**
|
|
388
|
+
|
|
389
|
+
| Field | Type | Required | Description |
|
|
390
|
+
|---|---|---|---|
|
|
391
|
+
| `userBankId` (first arg) | `string` | yes | ID of the bank account to search |
|
|
392
|
+
| `amount` | `number` | yes | Expected transfer amount |
|
|
393
|
+
| `bankReference` | `string` | yes | Bank transfer reference number |
|
|
394
|
+
| `movementType` | `string` | no | Defaults to `'GENERIC'` |
|
|
395
|
+
|
|
396
|
+
**Returns:** `VerifyPaymentResult` — a discriminated union on `found`:
|
|
397
|
+
|
|
398
|
+
```typescript
|
|
399
|
+
type VerifyPaymentResult =
|
|
400
|
+
| { found: false; reason: 'BANK_NOT_AVAILABLE' | 'PAYMENT_NOT_FOUND' }
|
|
401
|
+
| { found: true; isNew: boolean; data: PaymentData };
|
|
402
|
+
|
|
403
|
+
interface PaymentData {
|
|
404
|
+
is_new: boolean;
|
|
405
|
+
credit_cost: number;
|
|
406
|
+
user_bank_payment?: UserBankPayment;
|
|
407
|
+
user_credits_total?: number;
|
|
408
|
+
user_credits_total_in_usd?: number;
|
|
409
|
+
}
|
|
410
|
+
|
|
411
|
+
interface UserBankPayment {
|
|
412
|
+
id: string;
|
|
413
|
+
amount: number;
|
|
414
|
+
status: string;
|
|
415
|
+
user_id: string;
|
|
416
|
+
user_bank_id: string;
|
|
417
|
+
bank_reference_id: string;
|
|
418
|
+
confirmed_status: boolean;
|
|
419
|
+
credit_cost: number;
|
|
420
|
+
created_at: string;
|
|
421
|
+
updated_at: string;
|
|
422
|
+
payment_params: {
|
|
423
|
+
amount: number;
|
|
424
|
+
cedula_pagador: string | null;
|
|
425
|
+
telefono_pagador: string;
|
|
426
|
+
fecha_pago: string;
|
|
427
|
+
banco_origen: string;
|
|
428
|
+
cuenta_pagador: string;
|
|
429
|
+
invoice_number: string;
|
|
430
|
+
movement_type: string;
|
|
431
|
+
};
|
|
432
|
+
}
|
|
433
|
+
```
|
|
434
|
+
|
|
435
|
+
> The API returns HTTP 200 for `BANK_NOT_AVAILABLE` and `PAYMENT_NOT_FOUND`. The SDK handles this transparently — these cases are never thrown as errors.
|
|
436
|
+
|
|
437
|
+
---
|
|
438
|
+
|
|
439
|
+
## Error handling
|
|
440
|
+
|
|
441
|
+
All methods throw `PabiloError` on API errors (non-2xx HTTP responses) or network failures.
|
|
442
|
+
|
|
443
|
+
```typescript
|
|
444
|
+
import { PabiloClient, PabiloError } from '@pabilo/sdk';
|
|
445
|
+
|
|
446
|
+
try {
|
|
447
|
+
const link = await pabilo.paymentLinks.create({ ... });
|
|
448
|
+
} catch (err) {
|
|
449
|
+
if (err instanceof PabiloError) {
|
|
450
|
+
console.error(err.code); // PabiloErrorCode string
|
|
451
|
+
console.error(err.message); // human-readable message from the API
|
|
452
|
+
console.error(err.raw); // raw API response body
|
|
453
|
+
console.error(err.status); // HTTP status code (if available)
|
|
454
|
+
}
|
|
455
|
+
}
|
|
456
|
+
```
|
|
457
|
+
|
|
458
|
+
**Common error codes:**
|
|
459
|
+
|
|
460
|
+
| Code | Description |
|
|
461
|
+
|---|---|
|
|
462
|
+
| `BAD_REQUEST` | Invalid request body or parameters |
|
|
463
|
+
| `UNAUTHORIZED` | API key is missing or invalid |
|
|
464
|
+
| `NOT_FOUND` | Resource not found |
|
|
465
|
+
| `USER_BANK_ALREADY_EXISTS` | Bank account is already connected |
|
|
466
|
+
| `INTERNAL_SERVER_ERROR` | API server error |
|
|
467
|
+
| `NETWORK_ERROR` | Request could not reach the API |
|
|
468
|
+
| `REQUEST_FAILED` | HTTP error with no specific code |
|
|
469
|
+
|
|
470
|
+
---
|
|
471
|
+
|
|
472
|
+
## Testing with BANK_TEST
|
|
473
|
+
|
|
474
|
+
Use `BANK_TEST` to test the full payment flow without connecting a real bank. It has a pre-configured payment with reference `67890`.
|
|
475
|
+
|
|
476
|
+
```typescript
|
|
477
|
+
// 1. Create test bank
|
|
478
|
+
const bank = await pabilo.bankAccounts.create({ bankProvider: 'BANK_TEST' });
|
|
479
|
+
|
|
480
|
+
// 2. Create a payment link using the test bank
|
|
481
|
+
const link = await pabilo.paymentLinks.create({
|
|
482
|
+
amount: 100,
|
|
483
|
+
description: 'Test payment',
|
|
484
|
+
userBankId: bank.id,
|
|
485
|
+
});
|
|
486
|
+
|
|
487
|
+
// 3. Verify the test payment reference
|
|
488
|
+
const result = await pabilo.payments.verify(bank.id, {
|
|
489
|
+
amount: 0,
|
|
490
|
+
bankReference: '67890',
|
|
491
|
+
});
|
|
492
|
+
// result.found === true
|
|
493
|
+
|
|
494
|
+
// 4. Clean up
|
|
495
|
+
await pabilo.bankAccounts.delete(bank.id);
|
|
496
|
+
```
|
|
497
|
+
|
|
498
|
+
---
|
|
499
|
+
|
|
500
|
+
## Next.js usage
|
|
501
|
+
|
|
502
|
+
```typescript
|
|
503
|
+
// lib/pabilo.ts
|
|
504
|
+
import { PabiloClient } from '@pabilo/sdk';
|
|
505
|
+
|
|
506
|
+
export const pabilo = new PabiloClient({
|
|
507
|
+
apiKey: process.env.PABILO_API_KEY!,
|
|
508
|
+
});
|
|
509
|
+
```
|
|
510
|
+
|
|
511
|
+
```typescript
|
|
512
|
+
// app/api/checkout/route.ts
|
|
513
|
+
import { pabilo } from '@/lib/pabilo';
|
|
514
|
+
import { PabiloError } from '@pabilo/sdk';
|
|
515
|
+
|
|
516
|
+
export async function POST(req: Request) {
|
|
517
|
+
const { bankId, amount } = await req.json();
|
|
518
|
+
|
|
519
|
+
try {
|
|
520
|
+
const link = await pabilo.paymentLinks.create({
|
|
521
|
+
amount,
|
|
522
|
+
description: 'Checkout',
|
|
523
|
+
userBankId: bankId,
|
|
524
|
+
redirectUrl: `${process.env.NEXT_PUBLIC_URL}/gracias`,
|
|
525
|
+
webhookUrl: `${process.env.NEXT_PUBLIC_URL}/api/webhook/pabilo`,
|
|
526
|
+
});
|
|
527
|
+
|
|
528
|
+
return Response.json({ url: link.url, id: link.id });
|
|
529
|
+
} catch (err) {
|
|
530
|
+
if (err instanceof PabiloError) {
|
|
531
|
+
return Response.json({ error: err.message }, { status: 400 });
|
|
532
|
+
}
|
|
533
|
+
throw err;
|
|
534
|
+
}
|
|
535
|
+
}
|
|
536
|
+
```
|
|
537
|
+
|
|
538
|
+
```typescript
|
|
539
|
+
// app/api/webhook/pabilo/route.ts — poll-based alternative to webhooks
|
|
540
|
+
import { pabilo } from '@/lib/pabilo';
|
|
541
|
+
|
|
542
|
+
export async function GET(req: Request) {
|
|
543
|
+
const { searchParams } = new URL(req.url);
|
|
544
|
+
const linkId = searchParams.get('linkId')!;
|
|
545
|
+
|
|
546
|
+
const paid = await pabilo.paymentLinks.isPaid(linkId);
|
|
547
|
+
return Response.json({ paid });
|
|
548
|
+
}
|
|
549
|
+
```
|
|
550
|
+
|
|
551
|
+
---
|
|
552
|
+
|
|
553
|
+
## Advanced: custom HTTP client
|
|
554
|
+
|
|
555
|
+
The SDK accepts an `IHttpClient` implementation for logging, retries, or proxying requests.
|
|
556
|
+
|
|
557
|
+
```typescript
|
|
558
|
+
import { PabiloClient, FetchHttpClient, type IHttpClient, type RequestOptions } from '@pabilo/sdk';
|
|
559
|
+
|
|
560
|
+
class LoggingHttpClient extends FetchHttpClient {
|
|
561
|
+
async request<T>(opts: RequestOptions): Promise<T> {
|
|
562
|
+
console.log('[pabilo]', opts.method, opts.path);
|
|
563
|
+
return super.request<T>(opts);
|
|
564
|
+
}
|
|
565
|
+
}
|
|
566
|
+
|
|
567
|
+
const pabilo = new PabiloClient({
|
|
568
|
+
apiKey: 'YOUR_API_KEY',
|
|
569
|
+
httpClient: new LoggingHttpClient({ baseUrl: 'https://api.pabilo.app', apiKey: 'YOUR_API_KEY' }),
|
|
570
|
+
});
|
|
571
|
+
```
|
|
572
|
+
|
|
573
|
+
Custom base URL (e.g. staging):
|
|
574
|
+
|
|
575
|
+
```typescript
|
|
576
|
+
const pabilo = new PabiloClient({
|
|
577
|
+
apiKey: 'YOUR_API_KEY',
|
|
578
|
+
baseUrl: 'https://staging.api.pabilo.app',
|
|
579
|
+
});
|
|
580
|
+
```
|
|
581
|
+
|
|
582
|
+
---
|
|
583
|
+
|
|
584
|
+
## Types reference
|
|
585
|
+
|
|
586
|
+
```typescript
|
|
587
|
+
import type {
|
|
588
|
+
// Client
|
|
589
|
+
PabiloClientOptions,
|
|
590
|
+
|
|
591
|
+
// Resources
|
|
592
|
+
User,
|
|
593
|
+
Plan,
|
|
594
|
+
UserBank,
|
|
595
|
+
BankAccountEntry,
|
|
596
|
+
PaymentLink,
|
|
597
|
+
PaymentData,
|
|
598
|
+
UserBankPayment,
|
|
599
|
+
PaymentParams,
|
|
600
|
+
|
|
601
|
+
// Requests
|
|
602
|
+
CreateUserBankRequest,
|
|
603
|
+
CreateVeBanRequest,
|
|
604
|
+
CreateVeBanEmpV2Request,
|
|
605
|
+
CreateBankTestRequest,
|
|
606
|
+
UserBankMetadataEntry,
|
|
607
|
+
CreatePaymentLinkRequest,
|
|
608
|
+
UpdatePaymentLinkRequest,
|
|
609
|
+
VerifyPaymentRequest,
|
|
610
|
+
|
|
611
|
+
// Results
|
|
612
|
+
VerifyPaymentResult,
|
|
613
|
+
|
|
614
|
+
// Enums / literals
|
|
615
|
+
PaymentLinkStatus, // 'pending' | 'paid' | 'active' | 'expired' | 'cancelled'
|
|
616
|
+
PaymentLinkType, // 'default' | 'fixed'
|
|
617
|
+
BankProvider,
|
|
618
|
+
AccountType,
|
|
619
|
+
PabiloErrorCode,
|
|
620
|
+
|
|
621
|
+
// Ports (for DI / testing)
|
|
622
|
+
IHttpClient,
|
|
623
|
+
RequestOptions,
|
|
624
|
+
IBankAccountsPort,
|
|
625
|
+
IPaymentLinksPort,
|
|
626
|
+
IPaymentsPort,
|
|
627
|
+
IMePort,
|
|
628
|
+
} from '@pabilo/sdk';
|
|
629
|
+
```
|
|
630
|
+
|
|
631
|
+
---
|
|
632
|
+
|
|
633
|
+
## License
|
|
634
|
+
|
|
635
|
+
MIT
|
package/dist/index.cjs
CHANGED
|
@@ -108,6 +108,9 @@ var BankAccountsResource = class {
|
|
|
108
108
|
const raw = res["userbank"] ?? res["user_bank"] ?? res["data"] ?? res;
|
|
109
109
|
return normalizeUserBank(raw);
|
|
110
110
|
}
|
|
111
|
+
async delete(id) {
|
|
112
|
+
await this.http.request({ method: "DELETE", path: `/usersbank/${id}/to-trash` });
|
|
113
|
+
}
|
|
111
114
|
async list() {
|
|
112
115
|
const res = await this.http.request({
|
|
113
116
|
method: "GET",
|
|
@@ -137,6 +140,9 @@ function normalizeBankAccount(raw) {
|
|
|
137
140
|
};
|
|
138
141
|
}
|
|
139
142
|
function buildCreateBody(req, userId) {
|
|
143
|
+
if (req.bankProvider === "BANK_TEST") {
|
|
144
|
+
return { bank_provider: req.bankProvider, user_id: userId };
|
|
145
|
+
}
|
|
140
146
|
const body = {
|
|
141
147
|
bank_provider: req.bankProvider,
|
|
142
148
|
description: req.description,
|
package/dist/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/domain/errors.ts","../src/infrastructure/fetch-http-client.ts","../src/infrastructure/pabilo-http-client.ts","../src/resources/bank-accounts.resource.ts","../src/resources/payment-links.resource.ts","../src/resources/payments.resource.ts","../src/resources/me.resource.ts","../src/client.ts"],"names":["code"],"mappings":"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","file":"index.cjs","sourcesContent":["export class PabiloError extends Error {\n readonly code: string;\n readonly statusCode: number | undefined;\n readonly raw: unknown;\n\n constructor(opts: {\n message: string;\n code: string;\n statusCode?: number;\n raw?: unknown;\n }) {\n super(opts.message);\n this.name = 'PabiloError';\n this.code = opts.code;\n this.statusCode = opts.statusCode;\n this.raw = opts.raw;\n Object.setPrototypeOf(this, new.target.prototype);\n }\n}\n\nexport function parsePabiloError(body: unknown, statusCode: number): PabiloError {\n if (statusCode === 401) {\n return new PabiloError({ message: 'Unauthorized', code: 'UNAUTHORIZED', statusCode, raw: body });\n }\n if (statusCode === 404) {\n return new PabiloError({ message: 'Not found', code: 'NOT_FOUND', statusCode, raw: body });\n }\n\n if (body !== null && typeof body === 'object') {\n const b = body as Record<string, unknown>;\n const code = typeof b['error'] === 'string' ? b['error'] : resolveCodeFromStatus(statusCode);\n const message = typeof b['message'] === 'string' ? b['message'] : code;\n return new PabiloError({ message, code, statusCode, raw: body });\n }\n\n const code = resolveCodeFromStatus(statusCode);\n return new PabiloError({ message: code, code, statusCode, raw: body });\n}\n\nfunction resolveCodeFromStatus(statusCode: number): string {\n if (statusCode >= 500) return 'INTERNAL_SERVER_ERROR';\n if (statusCode === 400) return 'BAD_REQUEST';\n return 'REQUEST_FAILED';\n}\n","import type { IHttpClient, RequestOptions } from '../ports/http.js';\nimport { PabiloError, parsePabiloError } from '../domain/errors.js';\n\ntype FetchFn = typeof globalThis.fetch;\n\nexport class FetchHttpClient implements IHttpClient {\n private readonly fetchFn: FetchFn;\n\n constructor(fetchImpl?: FetchFn) {\n this.fetchFn = fetchImpl ?? globalThis.fetch.bind(globalThis);\n }\n\n async request<T>(options: RequestOptions): Promise<T> {\n const { method, path, body, headers = {} } = options;\n\n const init: RequestInit = { method, headers: { ...headers } };\n\n if (body !== undefined) {\n (init.headers as Record<string, string>)['content-type'] = 'application/json';\n init.body = JSON.stringify(body);\n }\n\n let response: Response;\n try {\n response = await this.fetchFn(path, init);\n } catch (cause) {\n throw new PabiloError({\n message: cause instanceof Error ? cause.message : 'Network request failed',\n code: 'NETWORK_ERROR',\n raw: cause,\n });\n }\n\n let responseBody: unknown;\n try {\n responseBody = await response.json();\n } catch {\n responseBody = null;\n }\n\n if (!response.ok) {\n throw parsePabiloError(responseBody, response.status);\n }\n\n return responseBody as T;\n }\n}\n","import type { IHttpClient, RequestOptions } from '../ports/http.js';\nimport { FetchHttpClient } from './fetch-http-client.js';\n\nexport interface PabiloHttpClientOptions {\n apiKey: string;\n baseUrl?: string;\n httpClient?: IHttpClient;\n}\n\nconst DEFAULT_BASE_URL = 'https://api.pabilo.app';\n\nexport class PabiloHttpClient implements IHttpClient {\n private readonly inner: IHttpClient;\n private readonly baseUrl: string;\n private readonly apiKey: string;\n\n constructor(options: PabiloHttpClientOptions) {\n this.apiKey = options.apiKey;\n this.baseUrl = (options.baseUrl ?? DEFAULT_BASE_URL).replace(/\\/$/, '');\n this.inner = options.httpClient ?? new FetchHttpClient();\n }\n\n request<T>(options: RequestOptions): Promise<T> {\n const url = `${this.baseUrl}${options.path}`;\n return this.inner.request<T>({\n ...options,\n path: url,\n headers: {\n ...options.headers,\n appKey: this.apiKey,\n },\n });\n }\n}\n","import type { IHttpClient } from '../ports/http.js';\nimport type { IBankAccountsPort } from '../ports/bank-accounts.js';\nimport type { UserBank, BankAccountEntry, CreateUserBankRequest } from '../domain/types.js';\n\nexport class BankAccountsResource implements IBankAccountsPort {\n constructor(private readonly http: IHttpClient) {}\n\n async create(req: CreateUserBankRequest): Promise<UserBank> {\n // API requires user_id in the body — fetch it transparently from /me\n const meRes = await this.http.request<Record<string, unknown>>({ method: 'GET', path: '/me' });\n const userId = String(\n (meRes['user'] as Record<string, unknown> | undefined)?.['id'] ?? meRes['id'] ?? ''\n );\n\n const body = buildCreateBody(req, userId);\n const res = await this.http.request<Record<string, unknown>>({\n method: 'POST',\n path: '/usersbank',\n body,\n });\n\n // Response: { message, userbank: {...} } | { user_bank: {...} } | { data: {...} } | root\n const raw = (res['userbank'] ?? res['user_bank'] ?? res['data'] ?? res) as Record<string, unknown>;\n return normalizeUserBank(raw);\n }\n\n async list(): Promise<UserBank[]> {\n const res = await this.http.request<Record<string, unknown>>({\n method: 'GET',\n path: '/me/usersbank',\n });\n\n const raw =\n Array.isArray(res['user_banks']) ? res['user_banks'] :\n Array.isArray(res['data']) ? res['data'] :\n [];\n\n return (raw as unknown[]).map(normalizeUserBank);\n }\n}\n\nfunction normalizeUserBank(raw: unknown): UserBank {\n const b = raw as Record<string, unknown>;\n const bankAccounts = Array.isArray(b['bank_accounts'])\n ? (b['bank_accounts'] as unknown[]).map(normalizeBankAccount)\n : [];\n\n return {\n id: String(b['id'] ?? ''),\n description: String(b['description'] ?? ''),\n provider: String(b['provider'] ?? ''),\n bank_accounts: bankAccounts,\n ...(typeof b['payment_link'] === 'boolean' ? { payment_link: b['payment_link'] } : {}),\n ...(typeof b['to_trash'] === 'boolean' ? { to_trash: b['to_trash'] } : {}),\n };\n}\n\nfunction normalizeBankAccount(raw: unknown): BankAccountEntry {\n const a = raw as Record<string, unknown>;\n return {\n account_number: String(a['account_number'] ?? ''),\n account_type: String(a['account_type'] ?? a['type'] ?? ''),\n };\n}\n\nfunction buildCreateBody(req: CreateUserBankRequest, userId: string): Record<string, unknown> {\n const body: Record<string, unknown> = {\n bank_provider: req.bankProvider,\n description: req.description,\n user_bank_phone: req.userBankPhone,\n user_bank_dni: req.userBankDni,\n user_id: userId,\n metadata: req.metadata ?? [],\n };\n\n switch (req.bankProvider) {\n case 'VE_BAN':\n body['username'] = req.username;\n body['password'] = req.password;\n break;\n case 'VE_BAN_EMP_V2':\n body['username'] = req.accountNumber;\n body['password'] = req.apiKey;\n break;\n }\n\n return body;\n}\n","import type { IHttpClient } from '../ports/http.js';\nimport type { IPaymentLinksPort } from '../ports/payment-links.js';\nimport type {\n PaymentLink,\n CreatePaymentLinkRequest,\n UpdatePaymentLinkRequest,\n} from '../domain/types.js';\n\nexport class PaymentLinksResource implements IPaymentLinksPort {\n constructor(private readonly http: IHttpClient) {}\n\n async create(req: CreatePaymentLinkRequest): Promise<PaymentLink> {\n const body: Record<string, unknown> = {\n amount: req.amount,\n description: req.description,\n user_bank_id: req.userBankId,\n currency: req.currency ?? 'VES',\n };\n if (req.redirectUrl !== undefined) body['redirect_url'] = req.redirectUrl;\n if (req.webhookUrl !== undefined) body['webhook_url'] = req.webhookUrl;\n if (req.notificationByWhatsapp !== undefined) body['notification_by_whastapp'] = req.notificationByWhatsapp;\n if (req.name !== undefined) body['name'] = req.name;\n if (req.isUsd !== undefined) body['is_usd'] = req.isUsd;\n if (req.metadata !== undefined) body['metadata'] = req.metadata;\n\n const res = await this.http.request<Record<string, unknown>>({\n method: 'POST',\n path: '/v1/paymentlink',\n body,\n });\n\n return normalizePaymentLink(res);\n }\n\n async update(id: string, req: UpdatePaymentLinkRequest): Promise<PaymentLink> {\n const body: Record<string, unknown> = {};\n if (req.amount !== undefined) body['amount'] = req.amount;\n if (req.description !== undefined) body['description'] = req.description;\n if (req.redirectUrl !== undefined) body['redirect_url'] = req.redirectUrl;\n if (req.currency !== undefined) body['currency'] = req.currency;\n\n const res = await this.http.request<Record<string, unknown>>({\n method: 'PATCH',\n path: `/paymentlink/${id}/patch`,\n body,\n });\n\n return normalizePaymentLink(res);\n }\n\n async isPaid(id: string): Promise<boolean> {\n const info = await this.getInfo(id);\n return info.status === 'paid';\n }\n\n async getInfo(id: string): Promise<PaymentLink> {\n const res = await this.http.request<Record<string, unknown>>({\n method: 'GET',\n path: `/paymentlink/${id}/info`,\n });\n return normalizePaymentLink(res);\n }\n}\n\nfunction normalizePaymentLink(raw: Record<string, unknown>): PaymentLink {\n // Shapes: { paymentlink: {...} } | { data: { payment_link: {...} } } | { data: {...} } | root\n const dataWrap = raw['data'] as Record<string, unknown> | undefined;\n const src =\n (raw['paymentlink'] as Record<string, unknown> | undefined) ??\n (dataWrap?.['payment_link'] as Record<string, unknown> | undefined) ??\n dataWrap ??\n raw;\n\n const userId = typeof src['user_id'] === 'string' ? src['user_id'] :\n typeof src['userId'] === 'string' ? src['userId'] : undefined;\n\n return {\n id: String(src['id'] ?? ''),\n url: String(src['url'] ?? ''),\n ...(typeof src['amount'] === 'number' ? { amount: src['amount'] } : {}),\n ...(typeof src['status'] === 'string' ? { status: src['status'] } : {}),\n ...(typeof src['type'] === 'string' ? { type: src['type'] } : {}),\n ...(userId !== undefined ? { userId } : {}),\n ...(typeof src['name'] === 'string' ? { name: src['name'] } : {}),\n ...(typeof src['description'] === 'string' ? { description: src['description'] } : {}),\n ...(typeof src['is_usd'] === 'boolean' ? { isUsd: src['is_usd'] } : {}),\n ...(typeof src['redirect_url'] === 'string' ? { redirectUrl: src['redirect_url'] } : {}),\n ...(typeof src['webhook_url'] === 'string' ? { webhookUrl: src['webhook_url'] } : {}),\n ...(typeof src['notification_by_whastapp'] === 'boolean' ? { notificationByWhatsapp: src['notification_by_whastapp'] } : {}),\n ...(typeof src['expiration_time'] === 'number' ? { expirationTime: src['expiration_time'] } : {}),\n ...(typeof src['payment_link_origin'] === 'string' ? { paymentLinkOrigin: src['payment_link_origin'] } : {}),\n ...(typeof src['created_at'] === 'string' ? { createdAt: src['created_at'] } : {}),\n ...(typeof src['updated_at'] === 'string' ? { updatedAt: src['updated_at'] } : {}),\n };\n}\n","import type { IHttpClient } from '../ports/http.js';\nimport type { IPaymentsPort } from '../ports/payments.js';\nimport type { VerifyPaymentRequest, VerifyPaymentResult, PaymentData } from '../domain/types.js';\n\nexport class PaymentsResource implements IPaymentsPort {\n constructor(private readonly http: IHttpClient) {}\n\n async verify(userBankId: string, req: VerifyPaymentRequest): Promise<VerifyPaymentResult> {\n // This endpoint returns HTTP 200 even for domain errors (BANK_NOT_AVAILABLE, PAYMENT_NOT_FOUND).\n // We read the raw response and interpret it ourselves instead of letting the HTTP client throw.\n const res = await this.http.request<Record<string, unknown>>({\n method: 'POST',\n path: `/userbankpayment/${userBankId}/betaserio`,\n body: {\n amount: req.amount,\n bank_reference: req.bankReference,\n movement_type: req.movementType ?? 'GENERIC',\n },\n });\n\n if (res['error'] === 'BANK_NOT_AVAILABLE') {\n return { found: false, reason: 'BANK_NOT_AVAILABLE' };\n }\n\n if (res['error'] === 'PAYMENT_NOT_FOUND') {\n return { found: false, reason: 'PAYMENT_NOT_FOUND' };\n }\n\n const data = res['data'] as Record<string, unknown> | undefined;\n if (data !== undefined) {\n return {\n found: true,\n isNew: data['is_new'] === true,\n data: data as PaymentData,\n };\n }\n\n return { found: false, reason: 'PAYMENT_NOT_FOUND' };\n }\n}\n","import type { IHttpClient } from '../ports/http.js';\nimport type { IMePort } from '../ports/me.js';\nimport type { User, Plan } from '../domain/types.js';\n\nexport class MeResource implements IMePort {\n constructor(private readonly http: IHttpClient) {}\n\n async getMe(): Promise<User> {\n const res = await this.http.request<Record<string, unknown>>({\n method: 'GET',\n path: '/me',\n });\n const u = (res['user'] ?? res) as Record<string, unknown>;\n return {\n id: String(u['id'] ?? ''),\n ...(typeof u['email'] === 'string' ? { email: u['email'] } : {}),\n ...(typeof u['name'] === 'string' ? { name: u['name'] } : {}),\n };\n }\n\n async getPlan(): Promise<Plan> {\n const res = await this.http.request<Record<string, unknown>>({\n method: 'GET',\n path: '/me/plan',\n });\n return {\n name: String(res['name'] ?? ''),\n ...(typeof res['planType'] === 'string' ? { planType: res['planType'] } : {}),\n };\n }\n}\n","import { PabiloHttpClient } from './infrastructure/pabilo-http-client.js';\nimport { BankAccountsResource } from './resources/bank-accounts.resource.js';\nimport { PaymentLinksResource } from './resources/payment-links.resource.js';\nimport { PaymentsResource } from './resources/payments.resource.js';\nimport { MeResource } from './resources/me.resource.js';\nimport type { IHttpClient } from './ports/http.js';\nimport type { IBankAccountsPort } from './ports/bank-accounts.js';\nimport type { IPaymentLinksPort } from './ports/payment-links.js';\nimport type { IPaymentsPort } from './ports/payments.js';\nimport type { IMePort } from './ports/me.js';\n\nexport interface PabiloClientOptions {\n apiKey: string;\n baseUrl?: string;\n httpClient?: IHttpClient;\n}\n\nexport class PabiloClient {\n readonly me: IMePort;\n readonly bankAccounts: IBankAccountsPort;\n readonly paymentLinks: IPaymentLinksPort;\n readonly payments: IPaymentsPort;\n\n constructor(options: PabiloClientOptions) {\n const http: IHttpClient = options.httpClient ?? new PabiloHttpClient({\n apiKey: options.apiKey,\n ...(options.baseUrl !== undefined ? { baseUrl: options.baseUrl } : {}),\n });\n\n this.me = new MeResource(http);\n this.bankAccounts = new BankAccountsResource(http);\n this.paymentLinks = new PaymentLinksResource(http);\n this.payments = new PaymentsResource(http);\n }\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/domain/errors.ts","../src/infrastructure/fetch-http-client.ts","../src/infrastructure/pabilo-http-client.ts","../src/resources/bank-accounts.resource.ts","../src/resources/payment-links.resource.ts","../src/resources/payments.resource.ts","../src/resources/me.resource.ts","../src/client.ts"],"names":["code"],"mappings":"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","file":"index.cjs","sourcesContent":["export class PabiloError extends Error {\n readonly code: string;\n readonly statusCode: number | undefined;\n readonly raw: unknown;\n\n constructor(opts: {\n message: string;\n code: string;\n statusCode?: number;\n raw?: unknown;\n }) {\n super(opts.message);\n this.name = 'PabiloError';\n this.code = opts.code;\n this.statusCode = opts.statusCode;\n this.raw = opts.raw;\n Object.setPrototypeOf(this, new.target.prototype);\n }\n}\n\nexport function parsePabiloError(body: unknown, statusCode: number): PabiloError {\n if (statusCode === 401) {\n return new PabiloError({ message: 'Unauthorized', code: 'UNAUTHORIZED', statusCode, raw: body });\n }\n if (statusCode === 404) {\n return new PabiloError({ message: 'Not found', code: 'NOT_FOUND', statusCode, raw: body });\n }\n\n if (body !== null && typeof body === 'object') {\n const b = body as Record<string, unknown>;\n const code = typeof b['error'] === 'string' ? b['error'] : resolveCodeFromStatus(statusCode);\n const message = typeof b['message'] === 'string' ? b['message'] : code;\n return new PabiloError({ message, code, statusCode, raw: body });\n }\n\n const code = resolveCodeFromStatus(statusCode);\n return new PabiloError({ message: code, code, statusCode, raw: body });\n}\n\nfunction resolveCodeFromStatus(statusCode: number): string {\n if (statusCode >= 500) return 'INTERNAL_SERVER_ERROR';\n if (statusCode === 400) return 'BAD_REQUEST';\n return 'REQUEST_FAILED';\n}\n","import type { IHttpClient, RequestOptions } from '../ports/http.js';\nimport { PabiloError, parsePabiloError } from '../domain/errors.js';\n\ntype FetchFn = typeof globalThis.fetch;\n\nexport class FetchHttpClient implements IHttpClient {\n private readonly fetchFn: FetchFn;\n\n constructor(fetchImpl?: FetchFn) {\n this.fetchFn = fetchImpl ?? globalThis.fetch.bind(globalThis);\n }\n\n async request<T>(options: RequestOptions): Promise<T> {\n const { method, path, body, headers = {} } = options;\n\n const init: RequestInit = { method, headers: { ...headers } };\n\n if (body !== undefined) {\n (init.headers as Record<string, string>)['content-type'] = 'application/json';\n init.body = JSON.stringify(body);\n }\n\n let response: Response;\n try {\n response = await this.fetchFn(path, init);\n } catch (cause) {\n throw new PabiloError({\n message: cause instanceof Error ? cause.message : 'Network request failed',\n code: 'NETWORK_ERROR',\n raw: cause,\n });\n }\n\n let responseBody: unknown;\n try {\n responseBody = await response.json();\n } catch {\n responseBody = null;\n }\n\n if (!response.ok) {\n throw parsePabiloError(responseBody, response.status);\n }\n\n return responseBody as T;\n }\n}\n","import type { IHttpClient, RequestOptions } from '../ports/http.js';\nimport { FetchHttpClient } from './fetch-http-client.js';\n\nexport interface PabiloHttpClientOptions {\n apiKey: string;\n baseUrl?: string;\n httpClient?: IHttpClient;\n}\n\nconst DEFAULT_BASE_URL = 'https://api.pabilo.app';\n\nexport class PabiloHttpClient implements IHttpClient {\n private readonly inner: IHttpClient;\n private readonly baseUrl: string;\n private readonly apiKey: string;\n\n constructor(options: PabiloHttpClientOptions) {\n this.apiKey = options.apiKey;\n this.baseUrl = (options.baseUrl ?? DEFAULT_BASE_URL).replace(/\\/$/, '');\n this.inner = options.httpClient ?? new FetchHttpClient();\n }\n\n request<T>(options: RequestOptions): Promise<T> {\n const url = `${this.baseUrl}${options.path}`;\n return this.inner.request<T>({\n ...options,\n path: url,\n headers: {\n ...options.headers,\n appKey: this.apiKey,\n },\n });\n }\n}\n","import type { IHttpClient } from '../ports/http.js';\nimport type { IBankAccountsPort } from '../ports/bank-accounts.js';\nimport type { UserBank, BankAccountEntry, CreateUserBankRequest } from '../domain/types.js';\n\nexport class BankAccountsResource implements IBankAccountsPort {\n constructor(private readonly http: IHttpClient) {}\n\n async create(req: CreateUserBankRequest): Promise<UserBank> {\n // API requires user_id in the body — fetch it transparently from /me\n const meRes = await this.http.request<Record<string, unknown>>({ method: 'GET', path: '/me' });\n const userId = String(\n (meRes['user'] as Record<string, unknown> | undefined)?.['id'] ?? meRes['id'] ?? ''\n );\n\n const body = buildCreateBody(req, userId);\n const res = await this.http.request<Record<string, unknown>>({\n method: 'POST',\n path: '/usersbank',\n body,\n });\n\n // Response: { message, userbank: {...} } | { user_bank: {...} } | { data: {...} } | root\n const raw = (res['userbank'] ?? res['user_bank'] ?? res['data'] ?? res) as Record<string, unknown>;\n return normalizeUserBank(raw);\n }\n\n async delete(id: string): Promise<void> {\n await this.http.request({ method: 'DELETE', path: `/usersbank/${id}/to-trash` });\n }\n\n async list(): Promise<UserBank[]> {\n const res = await this.http.request<Record<string, unknown>>({\n method: 'GET',\n path: '/me/usersbank',\n });\n\n const raw =\n Array.isArray(res['user_banks']) ? res['user_banks'] :\n Array.isArray(res['data']) ? res['data'] :\n [];\n\n return (raw as unknown[]).map(normalizeUserBank);\n }\n}\n\nfunction normalizeUserBank(raw: unknown): UserBank {\n const b = raw as Record<string, unknown>;\n const bankAccounts = Array.isArray(b['bank_accounts'])\n ? (b['bank_accounts'] as unknown[]).map(normalizeBankAccount)\n : [];\n\n return {\n id: String(b['id'] ?? ''),\n description: String(b['description'] ?? ''),\n provider: String(b['provider'] ?? ''),\n bank_accounts: bankAccounts,\n ...(typeof b['payment_link'] === 'boolean' ? { payment_link: b['payment_link'] } : {}),\n ...(typeof b['to_trash'] === 'boolean' ? { to_trash: b['to_trash'] } : {}),\n };\n}\n\nfunction normalizeBankAccount(raw: unknown): BankAccountEntry {\n const a = raw as Record<string, unknown>;\n return {\n account_number: String(a['account_number'] ?? ''),\n account_type: String(a['account_type'] ?? a['type'] ?? ''),\n };\n}\n\nfunction buildCreateBody(req: CreateUserBankRequest, userId: string): Record<string, unknown> {\n if (req.bankProvider === 'BANK_TEST') {\n return { bank_provider: req.bankProvider, user_id: userId };\n }\n\n const body: Record<string, unknown> = {\n bank_provider: req.bankProvider,\n description: req.description,\n user_bank_phone: req.userBankPhone,\n user_bank_dni: req.userBankDni,\n user_id: userId,\n metadata: req.metadata ?? [],\n };\n\n switch (req.bankProvider) {\n case 'VE_BAN':\n body['username'] = req.username;\n body['password'] = req.password;\n break;\n case 'VE_BAN_EMP_V2':\n body['username'] = req.accountNumber;\n body['password'] = req.apiKey;\n break;\n }\n\n return body;\n}\n","import type { IHttpClient } from '../ports/http.js';\nimport type { IPaymentLinksPort } from '../ports/payment-links.js';\nimport type {\n PaymentLink,\n CreatePaymentLinkRequest,\n UpdatePaymentLinkRequest,\n} from '../domain/types.js';\n\nexport class PaymentLinksResource implements IPaymentLinksPort {\n constructor(private readonly http: IHttpClient) {}\n\n async create(req: CreatePaymentLinkRequest): Promise<PaymentLink> {\n const body: Record<string, unknown> = {\n amount: req.amount,\n description: req.description,\n user_bank_id: req.userBankId,\n currency: req.currency ?? 'VES',\n };\n if (req.redirectUrl !== undefined) body['redirect_url'] = req.redirectUrl;\n if (req.webhookUrl !== undefined) body['webhook_url'] = req.webhookUrl;\n if (req.notificationByWhatsapp !== undefined) body['notification_by_whastapp'] = req.notificationByWhatsapp;\n if (req.name !== undefined) body['name'] = req.name;\n if (req.isUsd !== undefined) body['is_usd'] = req.isUsd;\n if (req.metadata !== undefined) body['metadata'] = req.metadata;\n\n const res = await this.http.request<Record<string, unknown>>({\n method: 'POST',\n path: '/v1/paymentlink',\n body,\n });\n\n return normalizePaymentLink(res);\n }\n\n async update(id: string, req: UpdatePaymentLinkRequest): Promise<PaymentLink> {\n const body: Record<string, unknown> = {};\n if (req.amount !== undefined) body['amount'] = req.amount;\n if (req.description !== undefined) body['description'] = req.description;\n if (req.redirectUrl !== undefined) body['redirect_url'] = req.redirectUrl;\n if (req.currency !== undefined) body['currency'] = req.currency;\n\n const res = await this.http.request<Record<string, unknown>>({\n method: 'PATCH',\n path: `/paymentlink/${id}/patch`,\n body,\n });\n\n return normalizePaymentLink(res);\n }\n\n async isPaid(id: string): Promise<boolean> {\n const info = await this.getInfo(id);\n return info.status === 'paid';\n }\n\n async getInfo(id: string): Promise<PaymentLink> {\n const res = await this.http.request<Record<string, unknown>>({\n method: 'GET',\n path: `/paymentlink/${id}/info`,\n });\n return normalizePaymentLink(res);\n }\n}\n\nfunction normalizePaymentLink(raw: Record<string, unknown>): PaymentLink {\n // Shapes: { paymentlink: {...} } | { data: { payment_link: {...} } } | { data: {...} } | root\n const dataWrap = raw['data'] as Record<string, unknown> | undefined;\n const src =\n (raw['paymentlink'] as Record<string, unknown> | undefined) ??\n (dataWrap?.['payment_link'] as Record<string, unknown> | undefined) ??\n dataWrap ??\n raw;\n\n const userId = typeof src['user_id'] === 'string' ? src['user_id'] :\n typeof src['userId'] === 'string' ? src['userId'] : undefined;\n\n return {\n id: String(src['id'] ?? ''),\n url: String(src['url'] ?? ''),\n ...(typeof src['amount'] === 'number' ? { amount: src['amount'] } : {}),\n ...(typeof src['status'] === 'string' ? { status: src['status'] } : {}),\n ...(typeof src['type'] === 'string' ? { type: src['type'] } : {}),\n ...(userId !== undefined ? { userId } : {}),\n ...(typeof src['name'] === 'string' ? { name: src['name'] } : {}),\n ...(typeof src['description'] === 'string' ? { description: src['description'] } : {}),\n ...(typeof src['is_usd'] === 'boolean' ? { isUsd: src['is_usd'] } : {}),\n ...(typeof src['redirect_url'] === 'string' ? { redirectUrl: src['redirect_url'] } : {}),\n ...(typeof src['webhook_url'] === 'string' ? { webhookUrl: src['webhook_url'] } : {}),\n ...(typeof src['notification_by_whastapp'] === 'boolean' ? { notificationByWhatsapp: src['notification_by_whastapp'] } : {}),\n ...(typeof src['expiration_time'] === 'number' ? { expirationTime: src['expiration_time'] } : {}),\n ...(typeof src['payment_link_origin'] === 'string' ? { paymentLinkOrigin: src['payment_link_origin'] } : {}),\n ...(typeof src['created_at'] === 'string' ? { createdAt: src['created_at'] } : {}),\n ...(typeof src['updated_at'] === 'string' ? { updatedAt: src['updated_at'] } : {}),\n };\n}\n","import type { IHttpClient } from '../ports/http.js';\nimport type { IPaymentsPort } from '../ports/payments.js';\nimport type { VerifyPaymentRequest, VerifyPaymentResult, PaymentData } from '../domain/types.js';\n\nexport class PaymentsResource implements IPaymentsPort {\n constructor(private readonly http: IHttpClient) {}\n\n async verify(userBankId: string, req: VerifyPaymentRequest): Promise<VerifyPaymentResult> {\n // This endpoint returns HTTP 200 even for domain errors (BANK_NOT_AVAILABLE, PAYMENT_NOT_FOUND).\n // We read the raw response and interpret it ourselves instead of letting the HTTP client throw.\n const res = await this.http.request<Record<string, unknown>>({\n method: 'POST',\n path: `/userbankpayment/${userBankId}/betaserio`,\n body: {\n amount: req.amount,\n bank_reference: req.bankReference,\n movement_type: req.movementType ?? 'GENERIC',\n },\n });\n\n if (res['error'] === 'BANK_NOT_AVAILABLE') {\n return { found: false, reason: 'BANK_NOT_AVAILABLE' };\n }\n\n if (res['error'] === 'PAYMENT_NOT_FOUND') {\n return { found: false, reason: 'PAYMENT_NOT_FOUND' };\n }\n\n const data = res['data'] as Record<string, unknown> | undefined;\n if (data !== undefined) {\n return {\n found: true,\n isNew: data['is_new'] === true,\n data: data as PaymentData,\n };\n }\n\n return { found: false, reason: 'PAYMENT_NOT_FOUND' };\n }\n}\n","import type { IHttpClient } from '../ports/http.js';\nimport type { IMePort } from '../ports/me.js';\nimport type { User, Plan } from '../domain/types.js';\n\nexport class MeResource implements IMePort {\n constructor(private readonly http: IHttpClient) {}\n\n async getMe(): Promise<User> {\n const res = await this.http.request<Record<string, unknown>>({\n method: 'GET',\n path: '/me',\n });\n const u = (res['user'] ?? res) as Record<string, unknown>;\n return {\n id: String(u['id'] ?? ''),\n ...(typeof u['email'] === 'string' ? { email: u['email'] } : {}),\n ...(typeof u['name'] === 'string' ? { name: u['name'] } : {}),\n };\n }\n\n async getPlan(): Promise<Plan> {\n const res = await this.http.request<Record<string, unknown>>({\n method: 'GET',\n path: '/me/plan',\n });\n return {\n name: String(res['name'] ?? ''),\n ...(typeof res['planType'] === 'string' ? { planType: res['planType'] } : {}),\n };\n }\n}\n","import { PabiloHttpClient } from './infrastructure/pabilo-http-client.js';\nimport { BankAccountsResource } from './resources/bank-accounts.resource.js';\nimport { PaymentLinksResource } from './resources/payment-links.resource.js';\nimport { PaymentsResource } from './resources/payments.resource.js';\nimport { MeResource } from './resources/me.resource.js';\nimport type { IHttpClient } from './ports/http.js';\nimport type { IBankAccountsPort } from './ports/bank-accounts.js';\nimport type { IPaymentLinksPort } from './ports/payment-links.js';\nimport type { IPaymentsPort } from './ports/payments.js';\nimport type { IMePort } from './ports/me.js';\n\nexport interface PabiloClientOptions {\n apiKey: string;\n baseUrl?: string;\n httpClient?: IHttpClient;\n}\n\nexport class PabiloClient {\n readonly me: IMePort;\n readonly bankAccounts: IBankAccountsPort;\n readonly paymentLinks: IPaymentLinksPort;\n readonly payments: IPaymentsPort;\n\n constructor(options: PabiloClientOptions) {\n const http: IHttpClient = options.httpClient ?? new PabiloHttpClient({\n apiKey: options.apiKey,\n ...(options.baseUrl !== undefined ? { baseUrl: options.baseUrl } : {}),\n });\n\n this.me = new MeResource(http);\n this.bankAccounts = new BankAccountsResource(http);\n this.paymentLinks = new PaymentLinksResource(http);\n this.payments = new PaymentsResource(http);\n }\n}\n"]}
|
package/dist/index.d.cts
CHANGED
|
@@ -135,11 +135,15 @@ interface CreateVeBanEmpV2Request extends BaseCreateUserBankRequest {
|
|
|
135
135
|
accountNumber: string;
|
|
136
136
|
apiKey: string;
|
|
137
137
|
}
|
|
138
|
-
|
|
138
|
+
interface CreateBankTestRequest {
|
|
139
|
+
bankProvider: 'BANK_TEST';
|
|
140
|
+
}
|
|
141
|
+
type CreateUserBankRequest = CreateVeBanRequest | CreateVeBanEmpV2Request | CreateBankTestRequest;
|
|
139
142
|
|
|
140
143
|
interface IBankAccountsPort {
|
|
141
144
|
list(): Promise<UserBank[]>;
|
|
142
145
|
create(req: CreateUserBankRequest): Promise<UserBank>;
|
|
146
|
+
delete(id: string): Promise<void>;
|
|
143
147
|
}
|
|
144
148
|
|
|
145
149
|
interface IPaymentLinksPort {
|
|
@@ -203,4 +207,4 @@ declare class PabiloHttpClient implements IHttpClient {
|
|
|
203
207
|
request<T>(options: RequestOptions): Promise<T>;
|
|
204
208
|
}
|
|
205
209
|
|
|
206
|
-
export { type AccountType, type BankAccountEntry, type BankProvider, type CreatePaymentLinkRequest, type CreateUserBankRequest, type CreateVeBanEmpV2Request, type CreateVeBanRequest, FetchHttpClient, type IBankAccountsPort, type IHttpClient, type IMePort, type IPaymentLinksPort, type IPaymentsPort, PabiloClient, type PabiloClientOptions, PabiloError, type PabiloErrorCode, PabiloHttpClient, type PabiloHttpClientOptions, type PaymentData, type PaymentLink, type PaymentLinkStatus, type PaymentLinkType, type PaymentParams, type Plan, type RequestOptions, type UpdatePaymentLinkRequest, type User, type UserBank, type UserBankMetadataEntry, type UserBankPayment, type VerifyPaymentRequest, type VerifyPaymentResult };
|
|
210
|
+
export { type AccountType, type BankAccountEntry, type BankProvider, type CreateBankTestRequest, type CreatePaymentLinkRequest, type CreateUserBankRequest, type CreateVeBanEmpV2Request, type CreateVeBanRequest, FetchHttpClient, type IBankAccountsPort, type IHttpClient, type IMePort, type IPaymentLinksPort, type IPaymentsPort, PabiloClient, type PabiloClientOptions, PabiloError, type PabiloErrorCode, PabiloHttpClient, type PabiloHttpClientOptions, type PaymentData, type PaymentLink, type PaymentLinkStatus, type PaymentLinkType, type PaymentParams, type Plan, type RequestOptions, type UpdatePaymentLinkRequest, type User, type UserBank, type UserBankMetadataEntry, type UserBankPayment, type VerifyPaymentRequest, type VerifyPaymentResult };
|
package/dist/index.d.ts
CHANGED
|
@@ -135,11 +135,15 @@ interface CreateVeBanEmpV2Request extends BaseCreateUserBankRequest {
|
|
|
135
135
|
accountNumber: string;
|
|
136
136
|
apiKey: string;
|
|
137
137
|
}
|
|
138
|
-
|
|
138
|
+
interface CreateBankTestRequest {
|
|
139
|
+
bankProvider: 'BANK_TEST';
|
|
140
|
+
}
|
|
141
|
+
type CreateUserBankRequest = CreateVeBanRequest | CreateVeBanEmpV2Request | CreateBankTestRequest;
|
|
139
142
|
|
|
140
143
|
interface IBankAccountsPort {
|
|
141
144
|
list(): Promise<UserBank[]>;
|
|
142
145
|
create(req: CreateUserBankRequest): Promise<UserBank>;
|
|
146
|
+
delete(id: string): Promise<void>;
|
|
143
147
|
}
|
|
144
148
|
|
|
145
149
|
interface IPaymentLinksPort {
|
|
@@ -203,4 +207,4 @@ declare class PabiloHttpClient implements IHttpClient {
|
|
|
203
207
|
request<T>(options: RequestOptions): Promise<T>;
|
|
204
208
|
}
|
|
205
209
|
|
|
206
|
-
export { type AccountType, type BankAccountEntry, type BankProvider, type CreatePaymentLinkRequest, type CreateUserBankRequest, type CreateVeBanEmpV2Request, type CreateVeBanRequest, FetchHttpClient, type IBankAccountsPort, type IHttpClient, type IMePort, type IPaymentLinksPort, type IPaymentsPort, PabiloClient, type PabiloClientOptions, PabiloError, type PabiloErrorCode, PabiloHttpClient, type PabiloHttpClientOptions, type PaymentData, type PaymentLink, type PaymentLinkStatus, type PaymentLinkType, type PaymentParams, type Plan, type RequestOptions, type UpdatePaymentLinkRequest, type User, type UserBank, type UserBankMetadataEntry, type UserBankPayment, type VerifyPaymentRequest, type VerifyPaymentResult };
|
|
210
|
+
export { type AccountType, type BankAccountEntry, type BankProvider, type CreateBankTestRequest, type CreatePaymentLinkRequest, type CreateUserBankRequest, type CreateVeBanEmpV2Request, type CreateVeBanRequest, FetchHttpClient, type IBankAccountsPort, type IHttpClient, type IMePort, type IPaymentLinksPort, type IPaymentsPort, PabiloClient, type PabiloClientOptions, PabiloError, type PabiloErrorCode, PabiloHttpClient, type PabiloHttpClientOptions, type PaymentData, type PaymentLink, type PaymentLinkStatus, type PaymentLinkType, type PaymentParams, type Plan, type RequestOptions, type UpdatePaymentLinkRequest, type User, type UserBank, type UserBankMetadataEntry, type UserBankPayment, type VerifyPaymentRequest, type VerifyPaymentResult };
|
package/dist/index.js
CHANGED
|
@@ -106,6 +106,9 @@ var BankAccountsResource = class {
|
|
|
106
106
|
const raw = res["userbank"] ?? res["user_bank"] ?? res["data"] ?? res;
|
|
107
107
|
return normalizeUserBank(raw);
|
|
108
108
|
}
|
|
109
|
+
async delete(id) {
|
|
110
|
+
await this.http.request({ method: "DELETE", path: `/usersbank/${id}/to-trash` });
|
|
111
|
+
}
|
|
109
112
|
async list() {
|
|
110
113
|
const res = await this.http.request({
|
|
111
114
|
method: "GET",
|
|
@@ -135,6 +138,9 @@ function normalizeBankAccount(raw) {
|
|
|
135
138
|
};
|
|
136
139
|
}
|
|
137
140
|
function buildCreateBody(req, userId) {
|
|
141
|
+
if (req.bankProvider === "BANK_TEST") {
|
|
142
|
+
return { bank_provider: req.bankProvider, user_id: userId };
|
|
143
|
+
}
|
|
138
144
|
const body = {
|
|
139
145
|
bank_provider: req.bankProvider,
|
|
140
146
|
description: req.description,
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/domain/errors.ts","../src/infrastructure/fetch-http-client.ts","../src/infrastructure/pabilo-http-client.ts","../src/resources/bank-accounts.resource.ts","../src/resources/payment-links.resource.ts","../src/resources/payments.resource.ts","../src/resources/me.resource.ts","../src/client.ts"],"names":["code"],"mappings":"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","file":"index.js","sourcesContent":["export class PabiloError extends Error {\n readonly code: string;\n readonly statusCode: number | undefined;\n readonly raw: unknown;\n\n constructor(opts: {\n message: string;\n code: string;\n statusCode?: number;\n raw?: unknown;\n }) {\n super(opts.message);\n this.name = 'PabiloError';\n this.code = opts.code;\n this.statusCode = opts.statusCode;\n this.raw = opts.raw;\n Object.setPrototypeOf(this, new.target.prototype);\n }\n}\n\nexport function parsePabiloError(body: unknown, statusCode: number): PabiloError {\n if (statusCode === 401) {\n return new PabiloError({ message: 'Unauthorized', code: 'UNAUTHORIZED', statusCode, raw: body });\n }\n if (statusCode === 404) {\n return new PabiloError({ message: 'Not found', code: 'NOT_FOUND', statusCode, raw: body });\n }\n\n if (body !== null && typeof body === 'object') {\n const b = body as Record<string, unknown>;\n const code = typeof b['error'] === 'string' ? b['error'] : resolveCodeFromStatus(statusCode);\n const message = typeof b['message'] === 'string' ? b['message'] : code;\n return new PabiloError({ message, code, statusCode, raw: body });\n }\n\n const code = resolveCodeFromStatus(statusCode);\n return new PabiloError({ message: code, code, statusCode, raw: body });\n}\n\nfunction resolveCodeFromStatus(statusCode: number): string {\n if (statusCode >= 500) return 'INTERNAL_SERVER_ERROR';\n if (statusCode === 400) return 'BAD_REQUEST';\n return 'REQUEST_FAILED';\n}\n","import type { IHttpClient, RequestOptions } from '../ports/http.js';\nimport { PabiloError, parsePabiloError } from '../domain/errors.js';\n\ntype FetchFn = typeof globalThis.fetch;\n\nexport class FetchHttpClient implements IHttpClient {\n private readonly fetchFn: FetchFn;\n\n constructor(fetchImpl?: FetchFn) {\n this.fetchFn = fetchImpl ?? globalThis.fetch.bind(globalThis);\n }\n\n async request<T>(options: RequestOptions): Promise<T> {\n const { method, path, body, headers = {} } = options;\n\n const init: RequestInit = { method, headers: { ...headers } };\n\n if (body !== undefined) {\n (init.headers as Record<string, string>)['content-type'] = 'application/json';\n init.body = JSON.stringify(body);\n }\n\n let response: Response;\n try {\n response = await this.fetchFn(path, init);\n } catch (cause) {\n throw new PabiloError({\n message: cause instanceof Error ? cause.message : 'Network request failed',\n code: 'NETWORK_ERROR',\n raw: cause,\n });\n }\n\n let responseBody: unknown;\n try {\n responseBody = await response.json();\n } catch {\n responseBody = null;\n }\n\n if (!response.ok) {\n throw parsePabiloError(responseBody, response.status);\n }\n\n return responseBody as T;\n }\n}\n","import type { IHttpClient, RequestOptions } from '../ports/http.js';\nimport { FetchHttpClient } from './fetch-http-client.js';\n\nexport interface PabiloHttpClientOptions {\n apiKey: string;\n baseUrl?: string;\n httpClient?: IHttpClient;\n}\n\nconst DEFAULT_BASE_URL = 'https://api.pabilo.app';\n\nexport class PabiloHttpClient implements IHttpClient {\n private readonly inner: IHttpClient;\n private readonly baseUrl: string;\n private readonly apiKey: string;\n\n constructor(options: PabiloHttpClientOptions) {\n this.apiKey = options.apiKey;\n this.baseUrl = (options.baseUrl ?? DEFAULT_BASE_URL).replace(/\\/$/, '');\n this.inner = options.httpClient ?? new FetchHttpClient();\n }\n\n request<T>(options: RequestOptions): Promise<T> {\n const url = `${this.baseUrl}${options.path}`;\n return this.inner.request<T>({\n ...options,\n path: url,\n headers: {\n ...options.headers,\n appKey: this.apiKey,\n },\n });\n }\n}\n","import type { IHttpClient } from '../ports/http.js';\nimport type { IBankAccountsPort } from '../ports/bank-accounts.js';\nimport type { UserBank, BankAccountEntry, CreateUserBankRequest } from '../domain/types.js';\n\nexport class BankAccountsResource implements IBankAccountsPort {\n constructor(private readonly http: IHttpClient) {}\n\n async create(req: CreateUserBankRequest): Promise<UserBank> {\n // API requires user_id in the body — fetch it transparently from /me\n const meRes = await this.http.request<Record<string, unknown>>({ method: 'GET', path: '/me' });\n const userId = String(\n (meRes['user'] as Record<string, unknown> | undefined)?.['id'] ?? meRes['id'] ?? ''\n );\n\n const body = buildCreateBody(req, userId);\n const res = await this.http.request<Record<string, unknown>>({\n method: 'POST',\n path: '/usersbank',\n body,\n });\n\n // Response: { message, userbank: {...} } | { user_bank: {...} } | { data: {...} } | root\n const raw = (res['userbank'] ?? res['user_bank'] ?? res['data'] ?? res) as Record<string, unknown>;\n return normalizeUserBank(raw);\n }\n\n async list(): Promise<UserBank[]> {\n const res = await this.http.request<Record<string, unknown>>({\n method: 'GET',\n path: '/me/usersbank',\n });\n\n const raw =\n Array.isArray(res['user_banks']) ? res['user_banks'] :\n Array.isArray(res['data']) ? res['data'] :\n [];\n\n return (raw as unknown[]).map(normalizeUserBank);\n }\n}\n\nfunction normalizeUserBank(raw: unknown): UserBank {\n const b = raw as Record<string, unknown>;\n const bankAccounts = Array.isArray(b['bank_accounts'])\n ? (b['bank_accounts'] as unknown[]).map(normalizeBankAccount)\n : [];\n\n return {\n id: String(b['id'] ?? ''),\n description: String(b['description'] ?? ''),\n provider: String(b['provider'] ?? ''),\n bank_accounts: bankAccounts,\n ...(typeof b['payment_link'] === 'boolean' ? { payment_link: b['payment_link'] } : {}),\n ...(typeof b['to_trash'] === 'boolean' ? { to_trash: b['to_trash'] } : {}),\n };\n}\n\nfunction normalizeBankAccount(raw: unknown): BankAccountEntry {\n const a = raw as Record<string, unknown>;\n return {\n account_number: String(a['account_number'] ?? ''),\n account_type: String(a['account_type'] ?? a['type'] ?? ''),\n };\n}\n\nfunction buildCreateBody(req: CreateUserBankRequest, userId: string): Record<string, unknown> {\n const body: Record<string, unknown> = {\n bank_provider: req.bankProvider,\n description: req.description,\n user_bank_phone: req.userBankPhone,\n user_bank_dni: req.userBankDni,\n user_id: userId,\n metadata: req.metadata ?? [],\n };\n\n switch (req.bankProvider) {\n case 'VE_BAN':\n body['username'] = req.username;\n body['password'] = req.password;\n break;\n case 'VE_BAN_EMP_V2':\n body['username'] = req.accountNumber;\n body['password'] = req.apiKey;\n break;\n }\n\n return body;\n}\n","import type { IHttpClient } from '../ports/http.js';\nimport type { IPaymentLinksPort } from '../ports/payment-links.js';\nimport type {\n PaymentLink,\n CreatePaymentLinkRequest,\n UpdatePaymentLinkRequest,\n} from '../domain/types.js';\n\nexport class PaymentLinksResource implements IPaymentLinksPort {\n constructor(private readonly http: IHttpClient) {}\n\n async create(req: CreatePaymentLinkRequest): Promise<PaymentLink> {\n const body: Record<string, unknown> = {\n amount: req.amount,\n description: req.description,\n user_bank_id: req.userBankId,\n currency: req.currency ?? 'VES',\n };\n if (req.redirectUrl !== undefined) body['redirect_url'] = req.redirectUrl;\n if (req.webhookUrl !== undefined) body['webhook_url'] = req.webhookUrl;\n if (req.notificationByWhatsapp !== undefined) body['notification_by_whastapp'] = req.notificationByWhatsapp;\n if (req.name !== undefined) body['name'] = req.name;\n if (req.isUsd !== undefined) body['is_usd'] = req.isUsd;\n if (req.metadata !== undefined) body['metadata'] = req.metadata;\n\n const res = await this.http.request<Record<string, unknown>>({\n method: 'POST',\n path: '/v1/paymentlink',\n body,\n });\n\n return normalizePaymentLink(res);\n }\n\n async update(id: string, req: UpdatePaymentLinkRequest): Promise<PaymentLink> {\n const body: Record<string, unknown> = {};\n if (req.amount !== undefined) body['amount'] = req.amount;\n if (req.description !== undefined) body['description'] = req.description;\n if (req.redirectUrl !== undefined) body['redirect_url'] = req.redirectUrl;\n if (req.currency !== undefined) body['currency'] = req.currency;\n\n const res = await this.http.request<Record<string, unknown>>({\n method: 'PATCH',\n path: `/paymentlink/${id}/patch`,\n body,\n });\n\n return normalizePaymentLink(res);\n }\n\n async isPaid(id: string): Promise<boolean> {\n const info = await this.getInfo(id);\n return info.status === 'paid';\n }\n\n async getInfo(id: string): Promise<PaymentLink> {\n const res = await this.http.request<Record<string, unknown>>({\n method: 'GET',\n path: `/paymentlink/${id}/info`,\n });\n return normalizePaymentLink(res);\n }\n}\n\nfunction normalizePaymentLink(raw: Record<string, unknown>): PaymentLink {\n // Shapes: { paymentlink: {...} } | { data: { payment_link: {...} } } | { data: {...} } | root\n const dataWrap = raw['data'] as Record<string, unknown> | undefined;\n const src =\n (raw['paymentlink'] as Record<string, unknown> | undefined) ??\n (dataWrap?.['payment_link'] as Record<string, unknown> | undefined) ??\n dataWrap ??\n raw;\n\n const userId = typeof src['user_id'] === 'string' ? src['user_id'] :\n typeof src['userId'] === 'string' ? src['userId'] : undefined;\n\n return {\n id: String(src['id'] ?? ''),\n url: String(src['url'] ?? ''),\n ...(typeof src['amount'] === 'number' ? { amount: src['amount'] } : {}),\n ...(typeof src['status'] === 'string' ? { status: src['status'] } : {}),\n ...(typeof src['type'] === 'string' ? { type: src['type'] } : {}),\n ...(userId !== undefined ? { userId } : {}),\n ...(typeof src['name'] === 'string' ? { name: src['name'] } : {}),\n ...(typeof src['description'] === 'string' ? { description: src['description'] } : {}),\n ...(typeof src['is_usd'] === 'boolean' ? { isUsd: src['is_usd'] } : {}),\n ...(typeof src['redirect_url'] === 'string' ? { redirectUrl: src['redirect_url'] } : {}),\n ...(typeof src['webhook_url'] === 'string' ? { webhookUrl: src['webhook_url'] } : {}),\n ...(typeof src['notification_by_whastapp'] === 'boolean' ? { notificationByWhatsapp: src['notification_by_whastapp'] } : {}),\n ...(typeof src['expiration_time'] === 'number' ? { expirationTime: src['expiration_time'] } : {}),\n ...(typeof src['payment_link_origin'] === 'string' ? { paymentLinkOrigin: src['payment_link_origin'] } : {}),\n ...(typeof src['created_at'] === 'string' ? { createdAt: src['created_at'] } : {}),\n ...(typeof src['updated_at'] === 'string' ? { updatedAt: src['updated_at'] } : {}),\n };\n}\n","import type { IHttpClient } from '../ports/http.js';\nimport type { IPaymentsPort } from '../ports/payments.js';\nimport type { VerifyPaymentRequest, VerifyPaymentResult, PaymentData } from '../domain/types.js';\n\nexport class PaymentsResource implements IPaymentsPort {\n constructor(private readonly http: IHttpClient) {}\n\n async verify(userBankId: string, req: VerifyPaymentRequest): Promise<VerifyPaymentResult> {\n // This endpoint returns HTTP 200 even for domain errors (BANK_NOT_AVAILABLE, PAYMENT_NOT_FOUND).\n // We read the raw response and interpret it ourselves instead of letting the HTTP client throw.\n const res = await this.http.request<Record<string, unknown>>({\n method: 'POST',\n path: `/userbankpayment/${userBankId}/betaserio`,\n body: {\n amount: req.amount,\n bank_reference: req.bankReference,\n movement_type: req.movementType ?? 'GENERIC',\n },\n });\n\n if (res['error'] === 'BANK_NOT_AVAILABLE') {\n return { found: false, reason: 'BANK_NOT_AVAILABLE' };\n }\n\n if (res['error'] === 'PAYMENT_NOT_FOUND') {\n return { found: false, reason: 'PAYMENT_NOT_FOUND' };\n }\n\n const data = res['data'] as Record<string, unknown> | undefined;\n if (data !== undefined) {\n return {\n found: true,\n isNew: data['is_new'] === true,\n data: data as PaymentData,\n };\n }\n\n return { found: false, reason: 'PAYMENT_NOT_FOUND' };\n }\n}\n","import type { IHttpClient } from '../ports/http.js';\nimport type { IMePort } from '../ports/me.js';\nimport type { User, Plan } from '../domain/types.js';\n\nexport class MeResource implements IMePort {\n constructor(private readonly http: IHttpClient) {}\n\n async getMe(): Promise<User> {\n const res = await this.http.request<Record<string, unknown>>({\n method: 'GET',\n path: '/me',\n });\n const u = (res['user'] ?? res) as Record<string, unknown>;\n return {\n id: String(u['id'] ?? ''),\n ...(typeof u['email'] === 'string' ? { email: u['email'] } : {}),\n ...(typeof u['name'] === 'string' ? { name: u['name'] } : {}),\n };\n }\n\n async getPlan(): Promise<Plan> {\n const res = await this.http.request<Record<string, unknown>>({\n method: 'GET',\n path: '/me/plan',\n });\n return {\n name: String(res['name'] ?? ''),\n ...(typeof res['planType'] === 'string' ? { planType: res['planType'] } : {}),\n };\n }\n}\n","import { PabiloHttpClient } from './infrastructure/pabilo-http-client.js';\nimport { BankAccountsResource } from './resources/bank-accounts.resource.js';\nimport { PaymentLinksResource } from './resources/payment-links.resource.js';\nimport { PaymentsResource } from './resources/payments.resource.js';\nimport { MeResource } from './resources/me.resource.js';\nimport type { IHttpClient } from './ports/http.js';\nimport type { IBankAccountsPort } from './ports/bank-accounts.js';\nimport type { IPaymentLinksPort } from './ports/payment-links.js';\nimport type { IPaymentsPort } from './ports/payments.js';\nimport type { IMePort } from './ports/me.js';\n\nexport interface PabiloClientOptions {\n apiKey: string;\n baseUrl?: string;\n httpClient?: IHttpClient;\n}\n\nexport class PabiloClient {\n readonly me: IMePort;\n readonly bankAccounts: IBankAccountsPort;\n readonly paymentLinks: IPaymentLinksPort;\n readonly payments: IPaymentsPort;\n\n constructor(options: PabiloClientOptions) {\n const http: IHttpClient = options.httpClient ?? new PabiloHttpClient({\n apiKey: options.apiKey,\n ...(options.baseUrl !== undefined ? { baseUrl: options.baseUrl } : {}),\n });\n\n this.me = new MeResource(http);\n this.bankAccounts = new BankAccountsResource(http);\n this.paymentLinks = new PaymentLinksResource(http);\n this.payments = new PaymentsResource(http);\n }\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/domain/errors.ts","../src/infrastructure/fetch-http-client.ts","../src/infrastructure/pabilo-http-client.ts","../src/resources/bank-accounts.resource.ts","../src/resources/payment-links.resource.ts","../src/resources/payments.resource.ts","../src/resources/me.resource.ts","../src/client.ts"],"names":["code"],"mappings":";AAAO,IAAM,WAAA,GAAN,cAA0B,KAAA,CAAM;AAAA,EAKrC,YAAY,IAAA,EAKT;AACD,IAAA,KAAA,CAAM,KAAK,OAAO,CAAA;AAClB,IAAA,IAAA,CAAK,IAAA,GAAO,aAAA;AACZ,IAAA,IAAA,CAAK,OAAO,IAAA,CAAK,IAAA;AACjB,IAAA,IAAA,CAAK,aAAa,IAAA,CAAK,UAAA;AACvB,IAAA,IAAA,CAAK,MAAM,IAAA,CAAK,GAAA;AAChB,IAAA,MAAA,CAAO,cAAA,CAAe,IAAA,EAAM,GAAA,CAAA,MAAA,CAAW,SAAS,CAAA;AAAA,EAClD;AACF;AAEO,SAAS,gBAAA,CAAiB,MAAe,UAAA,EAAiC;AAC/E,EAAA,IAAI,eAAe,GAAA,EAAK;AACtB,IAAA,OAAO,IAAI,WAAA,CAAY,EAAE,OAAA,EAAS,cAAA,EAAgB,MAAM,cAAA,EAAgB,UAAA,EAAY,GAAA,EAAK,IAAA,EAAM,CAAA;AAAA,EACjG;AACA,EAAA,IAAI,eAAe,GAAA,EAAK;AACtB,IAAA,OAAO,IAAI,WAAA,CAAY,EAAE,OAAA,EAAS,WAAA,EAAa,MAAM,WAAA,EAAa,UAAA,EAAY,GAAA,EAAK,IAAA,EAAM,CAAA;AAAA,EAC3F;AAEA,EAAA,IAAI,IAAA,KAAS,IAAA,IAAQ,OAAO,IAAA,KAAS,QAAA,EAAU;AAC7C,IAAA,MAAM,CAAA,GAAI,IAAA;AACV,IAAA,MAAMA,KAAAA,GAAO,OAAO,CAAA,CAAE,OAAO,CAAA,KAAM,WAAW,CAAA,CAAE,OAAO,CAAA,GAAI,qBAAA,CAAsB,UAAU,CAAA;AAC3F,IAAA,MAAM,OAAA,GAAU,OAAO,CAAA,CAAE,SAAS,MAAM,QAAA,GAAW,CAAA,CAAE,SAAS,CAAA,GAAIA,KAAAA;AAClE,IAAA,OAAO,IAAI,YAAY,EAAE,OAAA,EAAS,MAAAA,KAAAA,EAAM,UAAA,EAAY,GAAA,EAAK,IAAA,EAAM,CAAA;AAAA,EACjE;AAEA,EAAA,MAAM,IAAA,GAAO,sBAAsB,UAAU,CAAA;AAC7C,EAAA,OAAO,IAAI,YAAY,EAAE,OAAA,EAAS,MAAM,IAAA,EAAM,UAAA,EAAY,GAAA,EAAK,IAAA,EAAM,CAAA;AACvE;AAEA,SAAS,sBAAsB,UAAA,EAA4B;AACzD,EAAA,IAAI,UAAA,IAAc,KAAK,OAAO,uBAAA;AAC9B,EAAA,IAAI,UAAA,KAAe,KAAK,OAAO,aAAA;AAC/B,EAAA,OAAO,gBAAA;AACT;;;ACtCO,IAAM,kBAAN,MAA6C;AAAA,EAGlD,YAAY,SAAA,EAAqB;AAC/B,IAAA,IAAA,CAAK,OAAA,GAAU,SAAA,IAAa,UAAA,CAAW,KAAA,CAAM,KAAK,UAAU,CAAA;AAAA,EAC9D;AAAA,EAEA,MAAM,QAAW,OAAA,EAAqC;AACpD,IAAA,MAAM,EAAE,MAAA,EAAQ,IAAA,EAAM,MAAM,OAAA,GAAU,IAAG,GAAI,OAAA;AAE7C,IAAA,MAAM,OAAoB,EAAE,MAAA,EAAQ,SAAS,EAAE,GAAG,SAAQ,EAAE;AAE5D,IAAA,IAAI,SAAS,MAAA,EAAW;AACtB,MAAC,IAAA,CAAK,OAAA,CAAmC,cAAc,CAAA,GAAI,kBAAA;AAC3D,MAAA,IAAA,CAAK,IAAA,GAAO,IAAA,CAAK,SAAA,CAAU,IAAI,CAAA;AAAA,IACjC;AAEA,IAAA,IAAI,QAAA;AACJ,IAAA,IAAI;AACF,MAAA,QAAA,GAAW,MAAM,IAAA,CAAK,OAAA,CAAQ,IAAA,EAAM,IAAI,CAAA;AAAA,IAC1C,SAAS,KAAA,EAAO;AACd,MAAA,MAAM,IAAI,WAAA,CAAY;AAAA,QACpB,OAAA,EAAS,KAAA,YAAiB,KAAA,GAAQ,KAAA,CAAM,OAAA,GAAU,wBAAA;AAAA,QAClD,IAAA,EAAM,eAAA;AAAA,QACN,GAAA,EAAK;AAAA,OACN,CAAA;AAAA,IACH;AAEA,IAAA,IAAI,YAAA;AACJ,IAAA,IAAI;AACF,MAAA,YAAA,GAAe,MAAM,SAAS,IAAA,EAAK;AAAA,IACrC,CAAA,CAAA,MAAQ;AACN,MAAA,YAAA,GAAe,IAAA;AAAA,IACjB;AAEA,IAAA,IAAI,CAAC,SAAS,EAAA,EAAI;AAChB,MAAA,MAAM,gBAAA,CAAiB,YAAA,EAAc,QAAA,CAAS,MAAM,CAAA;AAAA,IACtD;AAEA,IAAA,OAAO,YAAA;AAAA,EACT;AACF;;;ACrCA,IAAM,gBAAA,GAAmB,wBAAA;AAElB,IAAM,mBAAN,MAA8C;AAAA,EAKnD,YAAY,OAAA,EAAkC;AAC5C,IAAA,IAAA,CAAK,SAAS,OAAA,CAAQ,MAAA;AACtB,IAAA,IAAA,CAAK,WAAW,OAAA,CAAQ,OAAA,IAAW,gBAAA,EAAkB,OAAA,CAAQ,OAAO,EAAE,CAAA;AACtE,IAAA,IAAA,CAAK,KAAA,GAAQ,OAAA,CAAQ,UAAA,IAAc,IAAI,eAAA,EAAgB;AAAA,EACzD;AAAA,EAEA,QAAW,OAAA,EAAqC;AAC9C,IAAA,MAAM,MAAM,CAAA,EAAG,IAAA,CAAK,OAAO,CAAA,EAAG,QAAQ,IAAI,CAAA,CAAA;AAC1C,IAAA,OAAO,IAAA,CAAK,MAAM,OAAA,CAAW;AAAA,MAC3B,GAAG,OAAA;AAAA,MACH,IAAA,EAAM,GAAA;AAAA,MACN,OAAA,EAAS;AAAA,QACP,GAAG,OAAA,CAAQ,OAAA;AAAA,QACX,QAAQ,IAAA,CAAK;AAAA;AACf,KACD,CAAA;AAAA,EACH;AACF;;;AC7BO,IAAM,uBAAN,MAAwD;AAAA,EAC7D,YAA6B,IAAA,EAAmB;AAAnB,IAAA,IAAA,CAAA,IAAA,GAAA,IAAA;AAAA,EAAoB;AAAA,EAEjD,MAAM,OAAO,GAAA,EAA+C;AAE1D,IAAA,MAAM,KAAA,GAAQ,MAAM,IAAA,CAAK,IAAA,CAAK,OAAA,CAAiC,EAAE,MAAA,EAAQ,KAAA,EAAO,IAAA,EAAM,KAAA,EAAO,CAAA;AAC7F,IAAA,MAAM,MAAA,GAAS,MAAA;AAAA,MACZ,MAAM,MAAM,CAAA,GAA4C,IAAI,CAAA,IAAK,KAAA,CAAM,IAAI,CAAA,IAAK;AAAA,KACnF;AAEA,IAAA,MAAM,IAAA,GAAO,eAAA,CAAgB,GAAA,EAAK,MAAM,CAAA;AACxC,IAAA,MAAM,GAAA,GAAM,MAAM,IAAA,CAAK,IAAA,CAAK,OAAA,CAAiC;AAAA,MAC3D,MAAA,EAAQ,MAAA;AAAA,MACR,IAAA,EAAM,YAAA;AAAA,MACN;AAAA,KACD,CAAA;AAGD,IAAA,MAAM,GAAA,GAAO,IAAI,UAAU,CAAA,IAAK,IAAI,WAAW,CAAA,IAAK,GAAA,CAAI,MAAM,CAAA,IAAK,GAAA;AACnE,IAAA,OAAO,kBAAkB,GAAG,CAAA;AAAA,EAC9B;AAAA,EAEA,MAAM,OAAO,EAAA,EAA2B;AACtC,IAAA,MAAM,IAAA,CAAK,IAAA,CAAK,OAAA,CAAQ,EAAE,MAAA,EAAQ,UAAU,IAAA,EAAM,CAAA,WAAA,EAAc,EAAE,CAAA,SAAA,CAAA,EAAa,CAAA;AAAA,EACjF;AAAA,EAEA,MAAM,IAAA,GAA4B;AAChC,IAAA,MAAM,GAAA,GAAM,MAAM,IAAA,CAAK,IAAA,CAAK,OAAA,CAAiC;AAAA,MAC3D,MAAA,EAAQ,KAAA;AAAA,MACR,IAAA,EAAM;AAAA,KACP,CAAA;AAED,IAAA,MAAM,MACJ,KAAA,CAAM,OAAA,CAAQ,IAAI,YAAY,CAAC,IAAI,GAAA,CAAI,YAAY,IACnD,KAAA,CAAM,OAAA,CAAQ,IAAI,MAAM,CAAC,IAAI,GAAA,CAAI,MAAM,IACvC,EAAC;AAEH,IAAA,OAAQ,GAAA,CAAkB,IAAI,iBAAiB,CAAA;AAAA,EACjD;AACF,CAAA;AAEA,SAAS,kBAAkB,GAAA,EAAwB;AACjD,EAAA,MAAM,CAAA,GAAI,GAAA;AACV,EAAA,MAAM,YAAA,GAAe,KAAA,CAAM,OAAA,CAAQ,CAAA,CAAE,eAAe,CAAC,CAAA,GAChD,CAAA,CAAE,eAAe,CAAA,CAAgB,GAAA,CAAI,oBAAoB,IAC1D,EAAC;AAEL,EAAA,OAAO;AAAA,IACL,EAAA,EAAI,MAAA,CAAO,CAAA,CAAE,IAAI,KAAK,EAAE,CAAA;AAAA,IACxB,WAAA,EAAa,MAAA,CAAO,CAAA,CAAE,aAAa,KAAK,EAAE,CAAA;AAAA,IAC1C,QAAA,EAAU,MAAA,CAAO,CAAA,CAAE,UAAU,KAAK,EAAE,CAAA;AAAA,IACpC,aAAA,EAAe,YAAA;AAAA,IACf,GAAI,OAAO,CAAA,CAAE,cAAc,CAAA,KAAM,SAAA,GAAY,EAAE,YAAA,EAAc,CAAA,CAAE,cAAc,CAAA,EAAE,GAAI,EAAC;AAAA,IACpF,GAAI,OAAO,CAAA,CAAE,UAAU,CAAA,KAAM,SAAA,GAAY,EAAE,QAAA,EAAU,CAAA,CAAE,UAAU,CAAA,EAAE,GAAI;AAAC,GAC1E;AACF;AAEA,SAAS,qBAAqB,GAAA,EAAgC;AAC5D,EAAA,MAAM,CAAA,GAAI,GAAA;AACV,EAAA,OAAO;AAAA,IACL,cAAA,EAAgB,MAAA,CAAO,CAAA,CAAE,gBAAgB,KAAK,EAAE,CAAA;AAAA,IAChD,YAAA,EAAc,OAAO,CAAA,CAAE,cAAc,KAAK,CAAA,CAAE,MAAM,KAAK,EAAE;AAAA,GAC3D;AACF;AAEA,SAAS,eAAA,CAAgB,KAA4B,MAAA,EAAyC;AAC5F,EAAA,IAAI,GAAA,CAAI,iBAAiB,WAAA,EAAa;AACpC,IAAA,OAAO,EAAE,aAAA,EAAe,GAAA,CAAI,YAAA,EAAc,SAAS,MAAA,EAAO;AAAA,EAC5D;AAEA,EAAA,MAAM,IAAA,GAAgC;AAAA,IACpC,eAAe,GAAA,CAAI,YAAA;AAAA,IACnB,aAAa,GAAA,CAAI,WAAA;AAAA,IACjB,iBAAiB,GAAA,CAAI,aAAA;AAAA,IACrB,eAAe,GAAA,CAAI,WAAA;AAAA,IACnB,OAAA,EAAS,MAAA;AAAA,IACT,QAAA,EAAU,GAAA,CAAI,QAAA,IAAY;AAAC,GAC7B;AAEA,EAAA,QAAQ,IAAI,YAAA;AAAc,IACxB,KAAK,QAAA;AACH,MAAA,IAAA,CAAK,UAAU,IAAI,GAAA,CAAI,QAAA;AACvB,MAAA,IAAA,CAAK,UAAU,IAAI,GAAA,CAAI,QAAA;AACvB,MAAA;AAAA,IACF,KAAK,eAAA;AACH,MAAA,IAAA,CAAK,UAAU,IAAI,GAAA,CAAI,aAAA;AACvB,MAAA,IAAA,CAAK,UAAU,IAAI,GAAA,CAAI,MAAA;AACvB,MAAA;AAAA;AAGJ,EAAA,OAAO,IAAA;AACT;;;ACvFO,IAAM,uBAAN,MAAwD;AAAA,EAC7D,YAA6B,IAAA,EAAmB;AAAnB,IAAA,IAAA,CAAA,IAAA,GAAA,IAAA;AAAA,EAAoB;AAAA,EAEjD,MAAM,OAAO,GAAA,EAAqD;AAChE,IAAA,MAAM,IAAA,GAAgC;AAAA,MACpC,QAAQ,GAAA,CAAI,MAAA;AAAA,MACZ,aAAa,GAAA,CAAI,WAAA;AAAA,MACjB,cAAc,GAAA,CAAI,UAAA;AAAA,MAClB,QAAA,EAAU,IAAI,QAAA,IAAY;AAAA,KAC5B;AACA,IAAA,IAAI,IAAI,WAAA,KAAgB,MAAA,EAAW,IAAA,CAAK,cAAc,IAAI,GAAA,CAAI,WAAA;AAC9D,IAAA,IAAI,IAAI,UAAA,KAAe,MAAA,EAAW,IAAA,CAAK,aAAa,IAAI,GAAA,CAAI,UAAA;AAC5D,IAAA,IAAI,IAAI,sBAAA,KAA2B,MAAA,EAAW,IAAA,CAAK,0BAA0B,IAAI,GAAA,CAAI,sBAAA;AACrF,IAAA,IAAI,IAAI,IAAA,KAAS,MAAA,EAAW,IAAA,CAAK,MAAM,IAAI,GAAA,CAAI,IAAA;AAC/C,IAAA,IAAI,IAAI,KAAA,KAAU,MAAA,EAAW,IAAA,CAAK,QAAQ,IAAI,GAAA,CAAI,KAAA;AAClD,IAAA,IAAI,IAAI,QAAA,KAAa,MAAA,EAAW,IAAA,CAAK,UAAU,IAAI,GAAA,CAAI,QAAA;AAEvD,IAAA,MAAM,GAAA,GAAM,MAAM,IAAA,CAAK,IAAA,CAAK,OAAA,CAAiC;AAAA,MAC3D,MAAA,EAAQ,MAAA;AAAA,MACR,IAAA,EAAM,iBAAA;AAAA,MACN;AAAA,KACD,CAAA;AAED,IAAA,OAAO,qBAAqB,GAAG,CAAA;AAAA,EACjC;AAAA,EAEA,MAAM,MAAA,CAAO,EAAA,EAAY,GAAA,EAAqD;AAC5E,IAAA,MAAM,OAAgC,EAAC;AACvC,IAAA,IAAI,IAAI,MAAA,KAAW,MAAA,EAAW,IAAA,CAAK,QAAQ,IAAI,GAAA,CAAI,MAAA;AACnD,IAAA,IAAI,IAAI,WAAA,KAAgB,MAAA,EAAW,IAAA,CAAK,aAAa,IAAI,GAAA,CAAI,WAAA;AAC7D,IAAA,IAAI,IAAI,WAAA,KAAgB,MAAA,EAAW,IAAA,CAAK,cAAc,IAAI,GAAA,CAAI,WAAA;AAC9D,IAAA,IAAI,IAAI,QAAA,KAAa,MAAA,EAAW,IAAA,CAAK,UAAU,IAAI,GAAA,CAAI,QAAA;AAEvD,IAAA,MAAM,GAAA,GAAM,MAAM,IAAA,CAAK,IAAA,CAAK,OAAA,CAAiC;AAAA,MAC3D,MAAA,EAAQ,OAAA;AAAA,MACR,IAAA,EAAM,gBAAgB,EAAE,CAAA,MAAA,CAAA;AAAA,MACxB;AAAA,KACD,CAAA;AAED,IAAA,OAAO,qBAAqB,GAAG,CAAA;AAAA,EACjC;AAAA,EAEA,MAAM,OAAO,EAAA,EAA8B;AACzC,IAAA,MAAM,IAAA,GAAO,MAAM,IAAA,CAAK,OAAA,CAAQ,EAAE,CAAA;AAClC,IAAA,OAAO,KAAK,MAAA,KAAW,MAAA;AAAA,EACzB;AAAA,EAEA,MAAM,QAAQ,EAAA,EAAkC;AAC9C,IAAA,MAAM,GAAA,GAAM,MAAM,IAAA,CAAK,IAAA,CAAK,OAAA,CAAiC;AAAA,MAC3D,MAAA,EAAQ,KAAA;AAAA,MACR,IAAA,EAAM,gBAAgB,EAAE,CAAA,KAAA;AAAA,KACzB,CAAA;AACD,IAAA,OAAO,qBAAqB,GAAG,CAAA;AAAA,EACjC;AACF,CAAA;AAEA,SAAS,qBAAqB,GAAA,EAA2C;AAEvE,EAAA,MAAM,QAAA,GAAW,IAAI,MAAM,CAAA;AAC3B,EAAA,MAAM,MACH,GAAA,CAAI,aAAa,KACjB,QAAA,GAAW,cAAc,KAC1B,QAAA,IACA,GAAA;AAEF,EAAA,MAAM,SAAS,OAAO,GAAA,CAAI,SAAS,CAAA,KAAM,WAAW,GAAA,CAAI,SAAS,CAAA,GAClD,OAAO,IAAI,QAAQ,CAAA,KAAM,QAAA,GAAW,GAAA,CAAI,QAAQ,CAAA,GAAI,MAAA;AAEnE,EAAA,OAAO;AAAA,IACL,EAAA,EAAI,MAAA,CAAO,GAAA,CAAI,IAAI,KAAK,EAAE,CAAA;AAAA,IAC1B,GAAA,EAAK,MAAA,CAAO,GAAA,CAAI,KAAK,KAAK,EAAE,CAAA;AAAA,IAC5B,GAAI,OAAO,GAAA,CAAI,QAAQ,CAAA,KAAM,QAAA,GAA2B,EAAE,MAAA,EAAQ,GAAA,CAAI,QAAQ,CAAA,EAAE,GAAgC,EAAC;AAAA,IACjH,GAAI,OAAO,GAAA,CAAI,QAAQ,CAAA,KAAM,QAAA,GAA2B,EAAE,MAAA,EAAQ,GAAA,CAAI,QAAQ,CAAA,EAAE,GAAgC,EAAC;AAAA,IACjH,GAAI,OAAO,GAAA,CAAI,MAAM,CAAA,KAAM,QAAA,GAA6B,EAAE,IAAA,EAAM,GAAA,CAAI,MAAM,CAAA,EAAE,GAAoC,EAAC;AAAA,IACjH,GAAI,MAAA,KAAW,MAAA,GAAyC,EAAE,MAAA,KAAuD,EAAC;AAAA,IAClH,GAAI,OAAO,GAAA,CAAI,MAAM,CAAA,KAAM,QAAA,GAA6B,EAAE,IAAA,EAAM,GAAA,CAAI,MAAM,CAAA,EAAE,GAAoC,EAAC;AAAA,IACjH,GAAI,OAAO,GAAA,CAAI,aAAa,CAAA,KAAM,QAAA,GAAsB,EAAE,WAAA,EAAa,GAAA,CAAI,aAAa,CAAA,EAAE,GAAsB,EAAC;AAAA,IACjH,GAAI,OAAO,GAAA,CAAI,QAAQ,CAAA,KAAM,SAAA,GAA2B,EAAE,KAAA,EAAO,GAAA,CAAI,QAAQ,CAAA,EAAE,GAAiC,EAAC;AAAA,IACjH,GAAI,OAAO,GAAA,CAAI,cAAc,CAAA,KAAM,QAAA,GAAqB,EAAE,WAAA,EAAa,GAAA,CAAI,cAAc,CAAA,EAAE,GAAqB,EAAC;AAAA,IACjH,GAAI,OAAO,GAAA,CAAI,aAAa,CAAA,KAAM,QAAA,GAAsB,EAAE,UAAA,EAAY,GAAA,CAAI,aAAa,CAAA,EAAE,GAAuB,EAAC;AAAA,IACjH,GAAI,OAAO,GAAA,CAAI,0BAA0B,CAAA,KAAM,SAAA,GAAY,EAAE,sBAAA,EAAwB,GAAA,CAAI,0BAA0B,CAAA,EAAE,GAAI,EAAC;AAAA,IAC1H,GAAI,OAAO,GAAA,CAAI,iBAAiB,CAAA,KAAM,QAAA,GAAkB,EAAE,cAAA,EAAgB,GAAA,CAAI,iBAAiB,CAAA,EAAE,GAAe,EAAC;AAAA,IACjH,GAAI,OAAO,GAAA,CAAI,qBAAqB,CAAA,KAAM,QAAA,GAAc,EAAE,iBAAA,EAAmB,GAAA,CAAI,qBAAqB,CAAA,EAAE,GAAO,EAAC;AAAA,IAChH,GAAI,OAAO,GAAA,CAAI,YAAY,CAAA,KAAM,QAAA,GAAuB,EAAE,SAAA,EAAW,GAAA,CAAI,YAAY,CAAA,EAAE,GAAwB,EAAC;AAAA,IAChH,GAAI,OAAO,GAAA,CAAI,YAAY,CAAA,KAAM,QAAA,GAAuB,EAAE,SAAA,EAAW,GAAA,CAAI,YAAY,CAAA,EAAE,GAAwB;AAAC,GAClH;AACF;;;AC1FO,IAAM,mBAAN,MAAgD;AAAA,EACrD,YAA6B,IAAA,EAAmB;AAAnB,IAAA,IAAA,CAAA,IAAA,GAAA,IAAA;AAAA,EAAoB;AAAA,EAEjD,MAAM,MAAA,CAAO,UAAA,EAAoB,GAAA,EAAyD;AAGxF,IAAA,MAAM,GAAA,GAAM,MAAM,IAAA,CAAK,IAAA,CAAK,OAAA,CAAiC;AAAA,MAC3D,MAAA,EAAQ,MAAA;AAAA,MACR,IAAA,EAAM,oBAAoB,UAAU,CAAA,UAAA,CAAA;AAAA,MACpC,IAAA,EAAM;AAAA,QACJ,QAAQ,GAAA,CAAI,MAAA;AAAA,QACZ,gBAAgB,GAAA,CAAI,aAAA;AAAA,QACpB,aAAA,EAAe,IAAI,YAAA,IAAgB;AAAA;AACrC,KACD,CAAA;AAED,IAAA,IAAI,GAAA,CAAI,OAAO,CAAA,KAAM,oBAAA,EAAsB;AACzC,MAAA,OAAO,EAAE,KAAA,EAAO,KAAA,EAAO,MAAA,EAAQ,oBAAA,EAAqB;AAAA,IACtD;AAEA,IAAA,IAAI,GAAA,CAAI,OAAO,CAAA,KAAM,mBAAA,EAAqB;AACxC,MAAA,OAAO,EAAE,KAAA,EAAO,KAAA,EAAO,MAAA,EAAQ,mBAAA,EAAoB;AAAA,IACrD;AAEA,IAAA,MAAM,IAAA,GAAO,IAAI,MAAM,CAAA;AACvB,IAAA,IAAI,SAAS,MAAA,EAAW;AACtB,MAAA,OAAO;AAAA,QACL,KAAA,EAAO,IAAA;AAAA,QACP,KAAA,EAAO,IAAA,CAAK,QAAQ,CAAA,KAAM,IAAA;AAAA,QAC1B;AAAA,OACF;AAAA,IACF;AAEA,IAAA,OAAO,EAAE,KAAA,EAAO,KAAA,EAAO,MAAA,EAAQ,mBAAA,EAAoB;AAAA,EACrD;AACF,CAAA;;;ACnCO,IAAM,aAAN,MAAoC;AAAA,EACzC,YAA6B,IAAA,EAAmB;AAAnB,IAAA,IAAA,CAAA,IAAA,GAAA,IAAA;AAAA,EAAoB;AAAA,EAEjD,MAAM,KAAA,GAAuB;AAC3B,IAAA,MAAM,GAAA,GAAM,MAAM,IAAA,CAAK,IAAA,CAAK,OAAA,CAAiC;AAAA,MAC3D,MAAA,EAAQ,KAAA;AAAA,MACR,IAAA,EAAM;AAAA,KACP,CAAA;AACD,IAAA,MAAM,CAAA,GAAK,GAAA,CAAI,MAAM,CAAA,IAAK,GAAA;AAC1B,IAAA,OAAO;AAAA,MACL,EAAA,EAAI,MAAA,CAAO,CAAA,CAAE,IAAI,KAAK,EAAE,CAAA;AAAA,MACxB,GAAI,OAAO,CAAA,CAAE,OAAO,CAAA,KAAM,QAAA,GAAW,EAAE,KAAA,EAAO,CAAA,CAAE,OAAO,CAAA,EAAE,GAAI,EAAC;AAAA,MAC9D,GAAI,OAAO,CAAA,CAAE,MAAM,CAAA,KAAM,QAAA,GAAW,EAAE,IAAA,EAAM,CAAA,CAAE,MAAM,CAAA,EAAE,GAAI;AAAC,KAC7D;AAAA,EACF;AAAA,EAEA,MAAM,OAAA,GAAyB;AAC7B,IAAA,MAAM,GAAA,GAAM,MAAM,IAAA,CAAK,IAAA,CAAK,OAAA,CAAiC;AAAA,MAC3D,MAAA,EAAQ,KAAA;AAAA,MACR,IAAA,EAAM;AAAA,KACP,CAAA;AACD,IAAA,OAAO;AAAA,MACL,IAAA,EAAM,MAAA,CAAO,GAAA,CAAI,MAAM,KAAK,EAAE,CAAA;AAAA,MAC9B,GAAI,OAAO,GAAA,CAAI,UAAU,CAAA,KAAM,QAAA,GAAW,EAAE,QAAA,EAAU,GAAA,CAAI,UAAU,CAAA,EAAE,GAAI;AAAC,KAC7E;AAAA,EACF;AACF,CAAA;;;ACbO,IAAM,eAAN,MAAmB;AAAA,EAMxB,YAAY,OAAA,EAA8B;AACxC,IAAA,MAAM,IAAA,GAAoB,OAAA,CAAQ,UAAA,IAAc,IAAI,gBAAA,CAAiB;AAAA,MACnE,QAAQ,OAAA,CAAQ,MAAA;AAAA,MAChB,GAAI,QAAQ,OAAA,KAAY,MAAA,GAAY,EAAE,OAAA,EAAS,OAAA,CAAQ,OAAA,EAAQ,GAAI;AAAC,KACrE,CAAA;AAED,IAAA,IAAA,CAAK,EAAA,GAAK,IAAI,UAAA,CAAW,IAAI,CAAA;AAC7B,IAAA,IAAA,CAAK,YAAA,GAAe,IAAI,oBAAA,CAAqB,IAAI,CAAA;AACjD,IAAA,IAAA,CAAK,YAAA,GAAe,IAAI,oBAAA,CAAqB,IAAI,CAAA;AACjD,IAAA,IAAA,CAAK,QAAA,GAAW,IAAI,gBAAA,CAAiB,IAAI,CAAA;AAAA,EAC3C;AACF","file":"index.js","sourcesContent":["export class PabiloError extends Error {\n readonly code: string;\n readonly statusCode: number | undefined;\n readonly raw: unknown;\n\n constructor(opts: {\n message: string;\n code: string;\n statusCode?: number;\n raw?: unknown;\n }) {\n super(opts.message);\n this.name = 'PabiloError';\n this.code = opts.code;\n this.statusCode = opts.statusCode;\n this.raw = opts.raw;\n Object.setPrototypeOf(this, new.target.prototype);\n }\n}\n\nexport function parsePabiloError(body: unknown, statusCode: number): PabiloError {\n if (statusCode === 401) {\n return new PabiloError({ message: 'Unauthorized', code: 'UNAUTHORIZED', statusCode, raw: body });\n }\n if (statusCode === 404) {\n return new PabiloError({ message: 'Not found', code: 'NOT_FOUND', statusCode, raw: body });\n }\n\n if (body !== null && typeof body === 'object') {\n const b = body as Record<string, unknown>;\n const code = typeof b['error'] === 'string' ? b['error'] : resolveCodeFromStatus(statusCode);\n const message = typeof b['message'] === 'string' ? b['message'] : code;\n return new PabiloError({ message, code, statusCode, raw: body });\n }\n\n const code = resolveCodeFromStatus(statusCode);\n return new PabiloError({ message: code, code, statusCode, raw: body });\n}\n\nfunction resolveCodeFromStatus(statusCode: number): string {\n if (statusCode >= 500) return 'INTERNAL_SERVER_ERROR';\n if (statusCode === 400) return 'BAD_REQUEST';\n return 'REQUEST_FAILED';\n}\n","import type { IHttpClient, RequestOptions } from '../ports/http.js';\nimport { PabiloError, parsePabiloError } from '../domain/errors.js';\n\ntype FetchFn = typeof globalThis.fetch;\n\nexport class FetchHttpClient implements IHttpClient {\n private readonly fetchFn: FetchFn;\n\n constructor(fetchImpl?: FetchFn) {\n this.fetchFn = fetchImpl ?? globalThis.fetch.bind(globalThis);\n }\n\n async request<T>(options: RequestOptions): Promise<T> {\n const { method, path, body, headers = {} } = options;\n\n const init: RequestInit = { method, headers: { ...headers } };\n\n if (body !== undefined) {\n (init.headers as Record<string, string>)['content-type'] = 'application/json';\n init.body = JSON.stringify(body);\n }\n\n let response: Response;\n try {\n response = await this.fetchFn(path, init);\n } catch (cause) {\n throw new PabiloError({\n message: cause instanceof Error ? cause.message : 'Network request failed',\n code: 'NETWORK_ERROR',\n raw: cause,\n });\n }\n\n let responseBody: unknown;\n try {\n responseBody = await response.json();\n } catch {\n responseBody = null;\n }\n\n if (!response.ok) {\n throw parsePabiloError(responseBody, response.status);\n }\n\n return responseBody as T;\n }\n}\n","import type { IHttpClient, RequestOptions } from '../ports/http.js';\nimport { FetchHttpClient } from './fetch-http-client.js';\n\nexport interface PabiloHttpClientOptions {\n apiKey: string;\n baseUrl?: string;\n httpClient?: IHttpClient;\n}\n\nconst DEFAULT_BASE_URL = 'https://api.pabilo.app';\n\nexport class PabiloHttpClient implements IHttpClient {\n private readonly inner: IHttpClient;\n private readonly baseUrl: string;\n private readonly apiKey: string;\n\n constructor(options: PabiloHttpClientOptions) {\n this.apiKey = options.apiKey;\n this.baseUrl = (options.baseUrl ?? DEFAULT_BASE_URL).replace(/\\/$/, '');\n this.inner = options.httpClient ?? new FetchHttpClient();\n }\n\n request<T>(options: RequestOptions): Promise<T> {\n const url = `${this.baseUrl}${options.path}`;\n return this.inner.request<T>({\n ...options,\n path: url,\n headers: {\n ...options.headers,\n appKey: this.apiKey,\n },\n });\n }\n}\n","import type { IHttpClient } from '../ports/http.js';\nimport type { IBankAccountsPort } from '../ports/bank-accounts.js';\nimport type { UserBank, BankAccountEntry, CreateUserBankRequest } from '../domain/types.js';\n\nexport class BankAccountsResource implements IBankAccountsPort {\n constructor(private readonly http: IHttpClient) {}\n\n async create(req: CreateUserBankRequest): Promise<UserBank> {\n // API requires user_id in the body — fetch it transparently from /me\n const meRes = await this.http.request<Record<string, unknown>>({ method: 'GET', path: '/me' });\n const userId = String(\n (meRes['user'] as Record<string, unknown> | undefined)?.['id'] ?? meRes['id'] ?? ''\n );\n\n const body = buildCreateBody(req, userId);\n const res = await this.http.request<Record<string, unknown>>({\n method: 'POST',\n path: '/usersbank',\n body,\n });\n\n // Response: { message, userbank: {...} } | { user_bank: {...} } | { data: {...} } | root\n const raw = (res['userbank'] ?? res['user_bank'] ?? res['data'] ?? res) as Record<string, unknown>;\n return normalizeUserBank(raw);\n }\n\n async delete(id: string): Promise<void> {\n await this.http.request({ method: 'DELETE', path: `/usersbank/${id}/to-trash` });\n }\n\n async list(): Promise<UserBank[]> {\n const res = await this.http.request<Record<string, unknown>>({\n method: 'GET',\n path: '/me/usersbank',\n });\n\n const raw =\n Array.isArray(res['user_banks']) ? res['user_banks'] :\n Array.isArray(res['data']) ? res['data'] :\n [];\n\n return (raw as unknown[]).map(normalizeUserBank);\n }\n}\n\nfunction normalizeUserBank(raw: unknown): UserBank {\n const b = raw as Record<string, unknown>;\n const bankAccounts = Array.isArray(b['bank_accounts'])\n ? (b['bank_accounts'] as unknown[]).map(normalizeBankAccount)\n : [];\n\n return {\n id: String(b['id'] ?? ''),\n description: String(b['description'] ?? ''),\n provider: String(b['provider'] ?? ''),\n bank_accounts: bankAccounts,\n ...(typeof b['payment_link'] === 'boolean' ? { payment_link: b['payment_link'] } : {}),\n ...(typeof b['to_trash'] === 'boolean' ? { to_trash: b['to_trash'] } : {}),\n };\n}\n\nfunction normalizeBankAccount(raw: unknown): BankAccountEntry {\n const a = raw as Record<string, unknown>;\n return {\n account_number: String(a['account_number'] ?? ''),\n account_type: String(a['account_type'] ?? a['type'] ?? ''),\n };\n}\n\nfunction buildCreateBody(req: CreateUserBankRequest, userId: string): Record<string, unknown> {\n if (req.bankProvider === 'BANK_TEST') {\n return { bank_provider: req.bankProvider, user_id: userId };\n }\n\n const body: Record<string, unknown> = {\n bank_provider: req.bankProvider,\n description: req.description,\n user_bank_phone: req.userBankPhone,\n user_bank_dni: req.userBankDni,\n user_id: userId,\n metadata: req.metadata ?? [],\n };\n\n switch (req.bankProvider) {\n case 'VE_BAN':\n body['username'] = req.username;\n body['password'] = req.password;\n break;\n case 'VE_BAN_EMP_V2':\n body['username'] = req.accountNumber;\n body['password'] = req.apiKey;\n break;\n }\n\n return body;\n}\n","import type { IHttpClient } from '../ports/http.js';\nimport type { IPaymentLinksPort } from '../ports/payment-links.js';\nimport type {\n PaymentLink,\n CreatePaymentLinkRequest,\n UpdatePaymentLinkRequest,\n} from '../domain/types.js';\n\nexport class PaymentLinksResource implements IPaymentLinksPort {\n constructor(private readonly http: IHttpClient) {}\n\n async create(req: CreatePaymentLinkRequest): Promise<PaymentLink> {\n const body: Record<string, unknown> = {\n amount: req.amount,\n description: req.description,\n user_bank_id: req.userBankId,\n currency: req.currency ?? 'VES',\n };\n if (req.redirectUrl !== undefined) body['redirect_url'] = req.redirectUrl;\n if (req.webhookUrl !== undefined) body['webhook_url'] = req.webhookUrl;\n if (req.notificationByWhatsapp !== undefined) body['notification_by_whastapp'] = req.notificationByWhatsapp;\n if (req.name !== undefined) body['name'] = req.name;\n if (req.isUsd !== undefined) body['is_usd'] = req.isUsd;\n if (req.metadata !== undefined) body['metadata'] = req.metadata;\n\n const res = await this.http.request<Record<string, unknown>>({\n method: 'POST',\n path: '/v1/paymentlink',\n body,\n });\n\n return normalizePaymentLink(res);\n }\n\n async update(id: string, req: UpdatePaymentLinkRequest): Promise<PaymentLink> {\n const body: Record<string, unknown> = {};\n if (req.amount !== undefined) body['amount'] = req.amount;\n if (req.description !== undefined) body['description'] = req.description;\n if (req.redirectUrl !== undefined) body['redirect_url'] = req.redirectUrl;\n if (req.currency !== undefined) body['currency'] = req.currency;\n\n const res = await this.http.request<Record<string, unknown>>({\n method: 'PATCH',\n path: `/paymentlink/${id}/patch`,\n body,\n });\n\n return normalizePaymentLink(res);\n }\n\n async isPaid(id: string): Promise<boolean> {\n const info = await this.getInfo(id);\n return info.status === 'paid';\n }\n\n async getInfo(id: string): Promise<PaymentLink> {\n const res = await this.http.request<Record<string, unknown>>({\n method: 'GET',\n path: `/paymentlink/${id}/info`,\n });\n return normalizePaymentLink(res);\n }\n}\n\nfunction normalizePaymentLink(raw: Record<string, unknown>): PaymentLink {\n // Shapes: { paymentlink: {...} } | { data: { payment_link: {...} } } | { data: {...} } | root\n const dataWrap = raw['data'] as Record<string, unknown> | undefined;\n const src =\n (raw['paymentlink'] as Record<string, unknown> | undefined) ??\n (dataWrap?.['payment_link'] as Record<string, unknown> | undefined) ??\n dataWrap ??\n raw;\n\n const userId = typeof src['user_id'] === 'string' ? src['user_id'] :\n typeof src['userId'] === 'string' ? src['userId'] : undefined;\n\n return {\n id: String(src['id'] ?? ''),\n url: String(src['url'] ?? ''),\n ...(typeof src['amount'] === 'number' ? { amount: src['amount'] } : {}),\n ...(typeof src['status'] === 'string' ? { status: src['status'] } : {}),\n ...(typeof src['type'] === 'string' ? { type: src['type'] } : {}),\n ...(userId !== undefined ? { userId } : {}),\n ...(typeof src['name'] === 'string' ? { name: src['name'] } : {}),\n ...(typeof src['description'] === 'string' ? { description: src['description'] } : {}),\n ...(typeof src['is_usd'] === 'boolean' ? { isUsd: src['is_usd'] } : {}),\n ...(typeof src['redirect_url'] === 'string' ? { redirectUrl: src['redirect_url'] } : {}),\n ...(typeof src['webhook_url'] === 'string' ? { webhookUrl: src['webhook_url'] } : {}),\n ...(typeof src['notification_by_whastapp'] === 'boolean' ? { notificationByWhatsapp: src['notification_by_whastapp'] } : {}),\n ...(typeof src['expiration_time'] === 'number' ? { expirationTime: src['expiration_time'] } : {}),\n ...(typeof src['payment_link_origin'] === 'string' ? { paymentLinkOrigin: src['payment_link_origin'] } : {}),\n ...(typeof src['created_at'] === 'string' ? { createdAt: src['created_at'] } : {}),\n ...(typeof src['updated_at'] === 'string' ? { updatedAt: src['updated_at'] } : {}),\n };\n}\n","import type { IHttpClient } from '../ports/http.js';\nimport type { IPaymentsPort } from '../ports/payments.js';\nimport type { VerifyPaymentRequest, VerifyPaymentResult, PaymentData } from '../domain/types.js';\n\nexport class PaymentsResource implements IPaymentsPort {\n constructor(private readonly http: IHttpClient) {}\n\n async verify(userBankId: string, req: VerifyPaymentRequest): Promise<VerifyPaymentResult> {\n // This endpoint returns HTTP 200 even for domain errors (BANK_NOT_AVAILABLE, PAYMENT_NOT_FOUND).\n // We read the raw response and interpret it ourselves instead of letting the HTTP client throw.\n const res = await this.http.request<Record<string, unknown>>({\n method: 'POST',\n path: `/userbankpayment/${userBankId}/betaserio`,\n body: {\n amount: req.amount,\n bank_reference: req.bankReference,\n movement_type: req.movementType ?? 'GENERIC',\n },\n });\n\n if (res['error'] === 'BANK_NOT_AVAILABLE') {\n return { found: false, reason: 'BANK_NOT_AVAILABLE' };\n }\n\n if (res['error'] === 'PAYMENT_NOT_FOUND') {\n return { found: false, reason: 'PAYMENT_NOT_FOUND' };\n }\n\n const data = res['data'] as Record<string, unknown> | undefined;\n if (data !== undefined) {\n return {\n found: true,\n isNew: data['is_new'] === true,\n data: data as PaymentData,\n };\n }\n\n return { found: false, reason: 'PAYMENT_NOT_FOUND' };\n }\n}\n","import type { IHttpClient } from '../ports/http.js';\nimport type { IMePort } from '../ports/me.js';\nimport type { User, Plan } from '../domain/types.js';\n\nexport class MeResource implements IMePort {\n constructor(private readonly http: IHttpClient) {}\n\n async getMe(): Promise<User> {\n const res = await this.http.request<Record<string, unknown>>({\n method: 'GET',\n path: '/me',\n });\n const u = (res['user'] ?? res) as Record<string, unknown>;\n return {\n id: String(u['id'] ?? ''),\n ...(typeof u['email'] === 'string' ? { email: u['email'] } : {}),\n ...(typeof u['name'] === 'string' ? { name: u['name'] } : {}),\n };\n }\n\n async getPlan(): Promise<Plan> {\n const res = await this.http.request<Record<string, unknown>>({\n method: 'GET',\n path: '/me/plan',\n });\n return {\n name: String(res['name'] ?? ''),\n ...(typeof res['planType'] === 'string' ? { planType: res['planType'] } : {}),\n };\n }\n}\n","import { PabiloHttpClient } from './infrastructure/pabilo-http-client.js';\nimport { BankAccountsResource } from './resources/bank-accounts.resource.js';\nimport { PaymentLinksResource } from './resources/payment-links.resource.js';\nimport { PaymentsResource } from './resources/payments.resource.js';\nimport { MeResource } from './resources/me.resource.js';\nimport type { IHttpClient } from './ports/http.js';\nimport type { IBankAccountsPort } from './ports/bank-accounts.js';\nimport type { IPaymentLinksPort } from './ports/payment-links.js';\nimport type { IPaymentsPort } from './ports/payments.js';\nimport type { IMePort } from './ports/me.js';\n\nexport interface PabiloClientOptions {\n apiKey: string;\n baseUrl?: string;\n httpClient?: IHttpClient;\n}\n\nexport class PabiloClient {\n readonly me: IMePort;\n readonly bankAccounts: IBankAccountsPort;\n readonly paymentLinks: IPaymentLinksPort;\n readonly payments: IPaymentsPort;\n\n constructor(options: PabiloClientOptions) {\n const http: IHttpClient = options.httpClient ?? new PabiloHttpClient({\n apiKey: options.apiKey,\n ...(options.baseUrl !== undefined ? { baseUrl: options.baseUrl } : {}),\n });\n\n this.me = new MeResource(http);\n this.bankAccounts = new BankAccountsResource(http);\n this.paymentLinks = new PaymentLinksResource(http);\n this.payments = new PaymentsResource(http);\n }\n}\n"]}
|