@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 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,
@@ -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
- type CreateUserBankRequest = CreateVeBanRequest | CreateVeBanEmpV2Request;
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
- type CreateUserBankRequest = CreateVeBanRequest | CreateVeBanEmpV2Request;
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":"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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 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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pabilo/sdk",
3
- "version": "0.1.4",
3
+ "version": "0.1.6",
4
4
  "description": "Official TypeScript SDK for the Pabilo payment platform",
5
5
  "license": "MIT",
6
6
  "keywords": ["pabilo", "payments", "venezuela", "pago-movil", "sdk"],