@develit-services/bank 0.0.43 → 0.1.0

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.
Files changed (41) hide show
  1. package/dist/database/schema.cjs +1 -1
  2. package/dist/database/schema.d.cts +1 -1
  3. package/dist/database/schema.d.mts +1 -1
  4. package/dist/database/schema.d.ts +1 -1
  5. package/dist/database/schema.mjs +1 -1
  6. package/dist/export/worker.cjs +115 -567
  7. package/dist/export/worker.d.cts +86 -19
  8. package/dist/export/worker.d.mts +87 -18
  9. package/dist/export/worker.d.ts +86 -19
  10. package/dist/export/worker.mjs +107 -556
  11. package/dist/export/workflows.cjs +21 -0
  12. package/dist/export/workflows.d.cts +2 -0
  13. package/dist/export/workflows.d.mts +2 -0
  14. package/dist/export/workflows.d.ts +2 -0
  15. package/dist/export/workflows.mjs +15 -0
  16. package/dist/export/wrangler.cjs +7 -0
  17. package/dist/export/wrangler.d.cts +5 -0
  18. package/dist/export/wrangler.d.mts +5 -0
  19. package/dist/export/wrangler.d.ts +5 -0
  20. package/dist/export/wrangler.mjs +7 -0
  21. package/dist/shared/{bank.BVzOzXdX.cjs → bank.3YYIj-n6.cjs} +11 -9
  22. package/dist/shared/{bank.6WoCPIFy.mjs → bank.B72e0ibs.mjs} +1 -1
  23. package/dist/shared/{bank.BPcrbUBa.cjs → bank.BgpXGC_1.cjs} +1 -1
  24. package/dist/shared/{bank.B7uB4cyW.d.cts → bank.BriEYREq.d.cts} +6 -6
  25. package/dist/shared/{bank.B7uB4cyW.d.mts → bank.BriEYREq.d.mts} +6 -6
  26. package/dist/shared/{bank.B7uB4cyW.d.ts → bank.BriEYREq.d.ts} +6 -6
  27. package/dist/shared/bank.CH22Zrdv.d.cts +20 -0
  28. package/dist/shared/bank.CH22Zrdv.d.mts +20 -0
  29. package/dist/shared/bank.CH22Zrdv.d.ts +20 -0
  30. package/dist/shared/{bank.BWcFhTu1.mjs → bank.CcKNlFRd.mjs} +11 -9
  31. package/dist/shared/{bank.C9Z9B0Po.d.ts → bank.DSZbtb1J.d.mts} +40 -36
  32. package/dist/shared/{bank.B_JR9YGK.d.cts → bank.Ddhhr_rz.d.ts} +40 -36
  33. package/dist/shared/{bank.Dadvg35r.d.mts → bank.DqRaP8LS.d.cts} +40 -36
  34. package/dist/shared/bank.GMK4QNvo.cjs +276 -0
  35. package/dist/shared/bank.jyyw3_3-.mjs +267 -0
  36. package/dist/types.cjs +2 -2
  37. package/dist/types.d.cts +16 -9
  38. package/dist/types.d.mts +16 -9
  39. package/dist/types.d.ts +16 -9
  40. package/dist/types.mjs +2 -2
  41. package/package.json +6 -1
@@ -1,16 +1,16 @@
1
1
  'use strict';
2
2
 
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
3
+ const export_workflows = require('../shared/bank.GMK4QNvo.cjs');
5
4
  const backendSdk = require('@develit-io/backend-sdk');
6
5
  const cloudflare_workers = require('cloudflare:workers');
7
6
  const d1 = require('drizzle-orm/d1');
8
- const database_schema = require('../shared/bank.BVzOzXdX.cjs');
7
+ const database_schema = require('../shared/bank.3YYIj-n6.cjs');
9
8
  require('jose');
10
9
  const generalCodes = require('@develit-io/general-codes');
11
10
  const zod = require('zod');
12
11
  const drizzleOrm = require('drizzle-orm');
13
- const mockCobs_connector = require('../shared/bank.BPcrbUBa.cjs');
12
+ require('cloudflare:workflows');
13
+ require('../shared/bank.BgpXGC_1.cjs');
14
14
  require('drizzle-orm/sqlite-core');
15
15
  require('date-fns');
16
16
  require('drizzle-zod');
@@ -30,18 +30,6 @@ const upsertAccountCommand = (db, { account }) => {
30
30
  };
31
31
  };
32
32
 
33
- const createPaymentCommand = (db, { payment }) => {
34
- return {
35
- command: db.insert(database_schema.tables.payment).values(payment).returning()
36
- };
37
- };
38
-
39
- const updatePaymentCommand = (db, { payment }) => {
40
- return {
41
- command: db.update(database_schema.tables.payment).set(payment).where(drizzleOrm.eq(database_schema.tables.payment.id, payment.id)).returning()
42
- };
43
- };
44
-
45
33
  const upsertBatchCommand = (db, { batch }) => {
46
34
  const id = batch.id || backendSdk.uuidv4();
47
35
  const command = db.insert(database_schema.tables.batch).values({
@@ -102,23 +90,10 @@ const deleteAccountCredentialsCommand = (db, { accountId }) => {
102
90
  };
103
91
  };
104
92
 
105
- const updateAccountLastSyncCommand = (db, { lastSyncedAt, accountId }) => {
106
- const command = db.update(database_schema.tables.account).set({
107
- lastSyncedAt
108
- }).where(drizzleOrm.eq(database_schema.tables.account.id, accountId)).returning();
109
- return {
110
- command
111
- };
112
- };
113
-
114
93
  const getAccountByIbanQuery = async (db, { iban }) => {
115
94
  return await db.select().from(database_schema.tables.account).where(drizzleOrm.eq(database_schema.tables.account.iban, iban)).get();
116
95
  };
117
96
 
118
- const getAccountByIdQuery = async (db, { accountId }) => {
119
- return await db.select().from(database_schema.tables.account).where(drizzleOrm.eq(database_schema.tables.account.id, accountId)).get();
120
- };
121
-
122
97
  const getAllAccountsQuery = async (db) => {
123
98
  const accountsWithExpiration = await db.select().from(database_schema.tables.account).leftJoin(
124
99
  database_schema.tables.accountCredentials,
@@ -228,11 +203,6 @@ const getBatchesQuery = async (db, {
228
203
  };
229
204
  };
230
205
 
231
- const getCredentialsByAccountId = async (db, { accountId }) => {
232
- const cred = await db.select().from(database_schema.tables.accountCredentials).where(drizzleOrm.eq(database_schema.tables.accountCredentials.accountId, accountId)).get();
233
- return cred;
234
- };
235
-
236
206
  const getAccountOpenBatchesQuery = async (db, { accountId }) => {
237
207
  return await db.select().from(database_schema.tables.batch).where(
238
208
  drizzleOrm.and(
@@ -251,82 +221,6 @@ const getPaymentByRefIdQuery = async (db, { refId }) => {
251
221
  return payment;
252
222
  };
253
223
 
254
- const getPaymentsByBankRefIdsQuery = async (db, { ids }) => {
255
- return await db.select().from(database_schema.tables.payment).where(drizzleOrm.inArray(database_schema.tables.payment.bankRefId, ids));
256
- };
257
-
258
- class CreditasConnector extends database_schema.FinbricksConnector {
259
- constructor(config) {
260
- super("CREDITAS", config);
261
- }
262
- }
263
-
264
- class FioConnector extends database_schema.FinbricksConnector {
265
- constructor(config) {
266
- super("FIO", config);
267
- }
268
- }
269
-
270
- class MonetaConnector extends database_schema.FinbricksConnector {
271
- constructor(config) {
272
- super("MONETA", config);
273
- }
274
- }
275
-
276
- const initiateConnector = ({
277
- bank,
278
- env,
279
- connectedAccounts
280
- }) => {
281
- switch (bank) {
282
- case "ERSTE":
283
- return new database_schema.ErsteConnector({
284
- API_KEY: env.ERSTE_API_KEY,
285
- CLIENT_ID: env.ERSTE_CLIENT_ID,
286
- CLIENT_SECRET: env.ERSTE_CLIENT_SECRET,
287
- REDIRECT_URI: env.REDIRECT_URI,
288
- AUTH_URI: env.ERSTE_AUTH_URI,
289
- PAYMENTS_URI: env.ERSTE_PAYMENTS_URI,
290
- ACCOUNTS_URI: env.ERSTE_ACCOUNTS_URI,
291
- connectedAccounts
292
- });
293
- case "CREDITAS":
294
- return new CreditasConnector({
295
- BASE_URI: env.FINBRICKS_BASE_URI,
296
- MERCHANT_ID: env.FINBRICKS_MERCHANT_ID,
297
- PRIVATE_KEY_PEM: env.FINBRICKS_PRIVATE_KEY_PEM,
298
- REDIRECT_URI: env.REDIRECT_URI,
299
- connectedAccounts
300
- });
301
- case "MOCK_COBS":
302
- return new mockCobs_connector.MockCobsConnector({
303
- BASE_URI: env.FINBRICKS_BASE_URI,
304
- MERCHANT_ID: env.FINBRICKS_MERCHANT_ID,
305
- PRIVATE_KEY_PEM: env.FINBRICKS_PRIVATE_KEY_PEM,
306
- REDIRECT_URI: env.REDIRECT_URI,
307
- connectedAccounts
308
- });
309
- case "FIO":
310
- return new FioConnector({
311
- BASE_URI: env.FINBRICKS_BASE_URI,
312
- MERCHANT_ID: env.FINBRICKS_MERCHANT_ID,
313
- PRIVATE_KEY_PEM: env.FINBRICKS_PRIVATE_KEY_PEM,
314
- REDIRECT_URI: env.REDIRECT_URI,
315
- connectedAccounts
316
- });
317
- case "MONETA":
318
- return new MonetaConnector({
319
- BASE_URI: env.FINBRICKS_BASE_URI,
320
- MERCHANT_ID: env.FINBRICKS_MERCHANT_ID,
321
- PRIVATE_KEY_PEM: env.FINBRICKS_PRIVATE_KEY_PEM,
322
- REDIRECT_URI: env.REDIRECT_URI,
323
- connectedAccounts
324
- });
325
- default:
326
- return new database_schema.MockConnector();
327
- }
328
- };
329
-
330
224
  const seperateSupportedPayments = (mappedPayments, accounts) => {
331
225
  const [supportedPayments, unsupportedPayments] = mappedPayments.reduce(
332
226
  ([valid, invalid], payment) => {
@@ -440,6 +334,26 @@ const getPaymentsInputSchema = zod.z.object({
440
334
  const syncAccountInputSchema = zod.z.object({
441
335
  accountId: zod.z.uuid()
442
336
  });
337
+ zod.z.object({
338
+ instanceId: zod.z.string(),
339
+ details: backendSdk.workflowInstanceStatusSchema
340
+ });
341
+
342
+ const syncAccountStatusInputSchema = zod.z.object({
343
+ accountId: zod.z.uuid()
344
+ });
345
+ zod.z.object({
346
+ instanceId: zod.z.string(),
347
+ details: backendSdk.workflowInstanceStatusSchema
348
+ });
349
+
350
+ const syncAccountRestartInputSchema = zod.z.object({
351
+ accountId: zod.z.uuid()
352
+ });
353
+ zod.z.object({
354
+ instanceId: zod.z.string(),
355
+ details: backendSdk.workflowInstanceStatusSchema
356
+ });
443
357
 
444
358
  const updateAccountInputSchema = zod.z.object({
445
359
  account: database_schema.accountInsertSchema
@@ -475,13 +389,21 @@ let BankServiceBase = class extends backendSdk.develitWorker(cloudflare_workers.
475
389
  for (const account of accounts.filter(
476
390
  (acc) => acc.connectorKey === connectorKey
477
391
  )) {
392
+ if (!account.lastSyncedAt) {
393
+ this.log({
394
+ message: `Skipping account ${account.id} as it has no lastSyncedAt date.`
395
+ });
396
+ continue;
397
+ }
478
398
  const payments = await this.bankConnector.getAllAccountPayments({
479
399
  db: this.db,
480
- env: this.env.ENVIRONMENT,
481
- account
400
+ environment: this.env.ENVIRONMENT,
401
+ account,
402
+ filter: {
403
+ dateFrom: account.lastSyncedAt
404
+ }
482
405
  });
483
406
  if (!payments || payments.length === 0) continue;
484
- this.log(payments);
485
407
  payments.forEach((payment) => {
486
408
  payment.direction = database_schema.getPaymentDirection(payment, account.iban);
487
409
  });
@@ -490,22 +412,48 @@ let BankServiceBase = class extends backendSdk.develitWorker(cloudflare_workers.
490
412
  }
491
413
  if (allFetchedPayments.length < 1) return;
492
414
  const bankRefIds = allFetchedPayments.map((payment) => payment.bankRefId).filter(Boolean);
493
- const alreadyExistingPayments = await getPaymentsByBankRefIdsQuery(
415
+ const alreadyExistingPayments = await export_workflows.getPaymentsByBankRefIdsQuery(
494
416
  this.db,
495
417
  {
496
418
  ids: bankRefIds
497
419
  }
498
420
  );
421
+ const eventsToPush = [];
499
422
  const paymentsCommands = allFetchedPayments.map((payment) => {
500
423
  const isAlreadyExisting = alreadyExistingPayments.some(
501
424
  (existingPayment) => existingPayment.bankRefId === payment.bankRefId
502
425
  );
503
- if (isAlreadyExisting)
504
- return updatePaymentCommand(this.db, { payment }).command;
505
- return createPaymentCommand(this.db, { payment }).command;
426
+ if (isAlreadyExisting) {
427
+ eventsToPush.push({
428
+ eventType: "BANK_PAYMENT",
429
+ eventSignal: "paymentUpdated",
430
+ bankPayment: payment,
431
+ metadata: {
432
+ correlationId: payment.correlationId,
433
+ entityId: payment.id,
434
+ idempotencySuffix: payment.status,
435
+ timestamp: (/* @__PURE__ */ new Date()).toDateString()
436
+ }
437
+ });
438
+ return export_workflows.updatePaymentCommand(this.db, { payment }).command;
439
+ }
440
+ eventsToPush.push({
441
+ eventType: "BANK_PAYMENT",
442
+ eventSignal: "paymentCreated",
443
+ bankPayment: payment,
444
+ metadata: {
445
+ correlationId: payment.correlationId,
446
+ entityId: payment.id,
447
+ timestamp: (/* @__PURE__ */ new Date()).toDateString()
448
+ }
449
+ });
450
+ return export_workflows.createPaymentCommand(this.db, { payment }).command;
506
451
  });
507
452
  await this.db.batch([paymentsCommands[0], ...paymentsCommands.slice(1)]);
508
- console.log("FETCHEDPAYMANETS TO SYNC", allFetchedPayments.length);
453
+ await this.pushToQueue(
454
+ this.env.QUEUE_BUS_QUEUE,
455
+ eventsToPush
456
+ );
509
457
  for (const account of accounts) {
510
458
  const paymentsForAccount = allFetchedPayments.filter(
511
459
  (payment) => (payment.direction === "OUTGOING" ? payment.debtorIban : payment.creditorIban) === account.iban
@@ -520,24 +468,12 @@ let BankServiceBase = class extends backendSdk.develitWorker(cloudflare_workers.
520
468
  )[0];
521
469
  }
522
470
  if (lastSyncPayment.createdAt) {
523
- await updateAccountLastSyncCommand(this.db, {
471
+ await export_workflows.updateAccountLastSyncCommand(this.db, {
524
472
  accountId: account.id,
525
473
  lastSyncedAt: lastSyncPayment.createdAt
526
474
  }).command.execute();
527
475
  }
528
476
  }
529
- await this.pushToQueue(
530
- this.env.QUEUE_BUS_QUEUE,
531
- allFetchedPayments.map((payment) => ({
532
- eventType: "BANK_PAYMENT",
533
- eventSignal: "created",
534
- bankPayment: payment,
535
- metadata: {
536
- correlationId: backendSdk.uuidv4(),
537
- timestamp: (/* @__PURE__ */ new Date()).toDateString()
538
- }
539
- }))
540
- );
541
477
  }
542
478
  async _initiateBankConnector({
543
479
  connectorKey,
@@ -554,7 +490,7 @@ let BankServiceBase = class extends backendSdk.develitWorker(cloudflare_workers.
554
490
  );
555
491
  const accountsWithCredentials = await Promise.all(
556
492
  accountsForConnector.map(async (acc) => {
557
- const credentials = await getCredentialsByAccountId(this.db, {
493
+ const credentials = await export_workflows.getCredentialsByAccountId(this.db, {
558
494
  accountId: acc.id
559
495
  });
560
496
  if (!credentials) {
@@ -571,7 +507,7 @@ let BankServiceBase = class extends backendSdk.develitWorker(cloudflare_workers.
571
507
  };
572
508
  })
573
509
  );
574
- this.bankConnector = initiateConnector({
510
+ this.bankConnector = export_workflows.initiateConnector({
575
511
  bank: connectorKey,
576
512
  connectedAccounts: accountsWithCredentials,
577
513
  env: this.env
@@ -603,18 +539,45 @@ let BankServiceBase = class extends backendSdk.develitWorker(cloudflare_workers.
603
539
  async syncAccount(input) {
604
540
  return this.handleAction(
605
541
  { data: input, schema: syncAccountInputSchema },
606
- { successMessage: "Account synchronized successfully" },
542
+ { successMessage: "Account sync workflow started" },
607
543
  async ({ accountId }) => {
608
- const account = await getAccountByIdQuery(this.db, {
609
- accountId
544
+ const instance = await this.env.SYNC_ACCOUNT_PAYMENTS_WORKFLOW.create({
545
+ id: accountId,
546
+ params: {
547
+ accountId
548
+ }
610
549
  });
611
- if (!account)
612
- throw backendSdk.createInternalError(null, {
613
- code: "NOT_FOUND",
614
- message: "Account not found",
615
- status: 404
616
- });
617
- await this._saveOrUpdatePayments([account]);
550
+ return {
551
+ instanceId: instance.id,
552
+ details: await instance.status()
553
+ };
554
+ }
555
+ );
556
+ }
557
+ async syncAccountStatus(input) {
558
+ return this.handleAction(
559
+ { data: input, schema: syncAccountStatusInputSchema },
560
+ { successMessage: "Account sync workflow status retrieved" },
561
+ async ({ accountId }) => {
562
+ const instance = await this.env.SYNC_ACCOUNT_PAYMENTS_WORKFLOW.get(accountId);
563
+ return {
564
+ instanceId: instance.id,
565
+ details: await instance.status()
566
+ };
567
+ }
568
+ );
569
+ }
570
+ async syncAccountRestart(input) {
571
+ return this.handleAction(
572
+ { data: input, schema: syncAccountRestartInputSchema },
573
+ { successMessage: "Account sync workflow restarted" },
574
+ async ({ accountId }) => {
575
+ const instance = await this.env.SYNC_ACCOUNT_PAYMENTS_WORKFLOW.get(accountId);
576
+ await instance.restart();
577
+ return {
578
+ instanceId: instance.id,
579
+ details: await instance.status()
580
+ };
618
581
  }
619
582
  );
620
583
  }
@@ -740,14 +703,15 @@ let BankServiceBase = class extends backendSdk.develitWorker(cloudflare_workers.
740
703
  this.env.QUEUE_BUS_QUEUE,
741
704
  unsupportedPayments.map((unsupported) => ({
742
705
  eventType: "BANK_PAYMENT",
706
+ eventSignal: "paymentFailed",
743
707
  bankPayment: {
744
708
  ...unsupported,
745
709
  status: "FAILED",
746
710
  statusReason: "UNSUPPORTED_ACCOUNT"
747
711
  },
748
- eventSignal: "failed",
749
712
  metadata: {
750
713
  correlationId: unsupported.correlationId,
714
+ entityId: unsupported.id,
751
715
  timestamp: (/* @__PURE__ */ new Date()).toDateString()
752
716
  }
753
717
  }))
@@ -853,7 +817,7 @@ let BankServiceBase = class extends backendSdk.develitWorker(cloudflare_workers.
853
817
  ...preparedBatch.failedPayments,
854
818
  ...preparedBatch.newlyPreparedPayments
855
819
  ].map(
856
- (p) => createPaymentCommand(this.db, { payment: p }).command.execute()
820
+ (p) => export_workflows.createPaymentCommand(this.db, { payment: p }).command.execute()
857
821
  )
858
822
  ]);
859
823
  await upsertBatchCommand(this.db, {
@@ -890,7 +854,7 @@ let BankServiceBase = class extends backendSdk.develitWorker(cloudflare_workers.
890
854
  }
891
855
  });
892
856
  const updatePayments = payments.map(
893
- (payment) => updatePaymentCommand(this.db, {
857
+ (payment) => export_workflows.updatePaymentCommand(this.db, {
894
858
  payment: { ...payment, status: "INITIALIZED" }
895
859
  }).command
896
860
  );
@@ -1067,15 +1031,16 @@ let BankServiceBase = class extends backendSdk.develitWorker(cloudflare_workers.
1067
1031
  debtor,
1068
1032
  debtorIban: debtor.iban
1069
1033
  };
1070
- const { command } = createPaymentCommand(this.db, { payment });
1034
+ const { command } = export_workflows.createPaymentCommand(this.db, { payment });
1071
1035
  const createdPayment = await command.execute().then(backendSdk.first);
1072
1036
  this.logQueuePush({ payment, isPaymentExecuted: true });
1073
1037
  await this.pushToQueue(this.env.QUEUE_BUS_QUEUE, {
1074
1038
  eventType: "BANK_PAYMENT",
1075
- eventSignal: "completed",
1039
+ eventSignal: "paymentCompleted",
1076
1040
  bankPayment: createdPayment,
1077
1041
  metadata: {
1078
1042
  correlationId: createdPayment.correlationId,
1043
+ entityId: createdPayment.id,
1079
1044
  timestamp: (/* @__PURE__ */ new Date()).toDateString()
1080
1045
  }
1081
1046
  });
@@ -1097,7 +1062,7 @@ let BankServiceBase = class extends backendSdk.develitWorker(cloudflare_workers.
1097
1062
  message: "Account for this organization does not exist."
1098
1063
  });
1099
1064
  }
1100
- await updateAccountLastSyncCommand(this.db, {
1065
+ await export_workflows.updateAccountLastSyncCommand(this.db, {
1101
1066
  accountId: account.id,
1102
1067
  lastSyncedAt
1103
1068
  }).command.execute();
@@ -1216,422 +1181,5 @@ function defineBankService({
1216
1181
  };
1217
1182
  }
1218
1183
 
1219
- const BankService = defineBankService({
1220
- config: {
1221
- allowedProviders: []
1222
- // {
1223
- // connectorKey: 'MOCK_COBS',
1224
- // id: 'staging-czk',
1225
- // identification: {
1226
- // number: '1234567890',
1227
- // bankCode: '5051',
1228
- // iban: 'CZ0350510000000000000449',
1229
- // holderName: 'Devizová Burza a.s.',
1230
- // },
1231
- // fallbackLastSync: monthAgo,
1232
- // currency: 'CZK',
1233
- // production: false,
1234
- // },
1235
- // {
1236
- // connectorKey: 'MOCK_COBS',
1237
- // id: 'staging-eur',
1238
- // identification: {
1239
- // number: '2345678901',
1240
- // bankCode: '5051',
1241
- // iban: 'CZ0750510000000000000668',
1242
- // holderName: 'Devizová Burza a.s.',
1243
- // },
1244
- // fallbackLastSync: monthAgo,
1245
- // currency: 'EUR',
1246
- // production: false,
1247
- // },
1248
- // {
1249
- // connectorKey: 'FIO',
1250
- // id: 'kleinpetr-test',
1251
- // identification: {
1252
- // number: '2502130437',
1253
- // bankCode: '2010',
1254
- // iban: 'CZ8520100000002502130437',
1255
- // holderName: 'Petr Klein',
1256
- // },
1257
- // fallbackLastSync: monthAgo,
1258
- // currency: 'CZK',
1259
- // production: true,
1260
- // },
1261
- // {
1262
- // connectorKey: 'MOCK',
1263
- // id: 'id-test',
1264
- // identification: {
1265
- // number: '777777777',
1266
- // bankCode: '0800',
1267
- // iban: 'PL0000000000002444430437',
1268
- // holderName: 'Test Test',
1269
- // },
1270
- // fallbackLastSync: monthAgo,
1271
- // currency: 'PLN',
1272
- // production: false,
1273
- // },
1274
- // {
1275
- // connectorKey: 'MOCK_COBS',
1276
- // id: 'staging-usd',
1277
- // identification: {
1278
- // iban: 'CZ3456789012345678901234',
1279
- // accountNumberWithBankCode: '3456789012/3456',
1280
- // },
1281
- // currency: 'USD',
1282
- // bankCode: '0800',
1283
- // accountNumber: '3456789012',
1284
- // production: false,
1285
- // },
1286
- // ],
1287
- // productionAccounts: [
1288
- // // Banka CREDITAS (2250)
1289
- // {
1290
- // connectorKey: 'CREDITAS',
1291
- // id: '2250-CZK',
1292
- // identification: {
1293
- // number: '100602391',
1294
- // bankCode: '2250',
1295
- // iban: 'CZ5122500000000100602391',
1296
- // holderName: 'Devizová Burza a.s.',
1297
- // },
1298
- // fallbackLastSync: monthAgo,
1299
- // currency: 'CZK',
1300
- // production: true,
1301
- // },
1302
- // {
1303
- // connectorKey: 'CREDITAS',
1304
- // id: '2250-EUR',
1305
- // identification: {
1306
- // number: '100602404',
1307
- // bankCode: '2250',
1308
- // iban: 'CZ8822500000000100602404',
1309
- // holderName: 'Devizová Burza a.s.',
1310
- // },
1311
- // fallbackLastSync: monthAgo,
1312
- // currency: 'EUR',
1313
- // production: true,
1314
- // },
1315
- // {
1316
- // connectorKey: 'CREDITAS',
1317
- // id: '2250-USD',
1318
- // identification: {
1319
- // number: '100602412',
1320
- // bankCode: '2250',
1321
- // iban: 'CZ6622500000000100602412',
1322
- // holderName: 'Devizová Burza a.s.',
1323
- // },
1324
- // fallbackLastSync: monthAgo,
1325
- // currency: 'USD',
1326
- // production: true,
1327
- // },
1328
- // {
1329
- // connectorKey: 'CREDITAS',
1330
- // id: '2250-GBP',
1331
- // identification: {
1332
- // number: '100602420',
1333
- // bankCode: '2250',
1334
- // iban: 'CZ4422500000000100602420',
1335
- // holderName: 'Devizová Burza a.s.',
1336
- // },
1337
- // fallbackLastSync: monthAgo,
1338
- // currency: 'GBP',
1339
- // production: true,
1340
- // },
1341
- // {
1342
- // connectorKey: 'CREDITAS',
1343
- // id: '2250-CHF',
1344
- // identification: {
1345
- // number: '100602439',
1346
- // bankCode: '2250',
1347
- // iban: 'CZ1622500000000100602439',
1348
- // holderName: 'Devizová Burza a.s.',
1349
- // },
1350
- // fallbackLastSync: monthAgo,
1351
- // currency: 'CHF',
1352
- // production: true,
1353
- // },
1354
- // {
1355
- // connectorKey: 'CREDITAS',
1356
- // id: '2250-PLN',
1357
- // identification: {
1358
- // number: '100602447',
1359
- // bankCode: '2250',
1360
- // iban: 'CZ9122500000000100602447',
1361
- // holderName: 'Devizová Burza a.s.',
1362
- // },
1363
- // fallbackLastSync: monthAgo,
1364
- // currency: 'PLN',
1365
- // production: true,
1366
- // },
1367
- // // Fio banka (2010)
1368
- // {
1369
- // connectorKey: 'FINBRICKS',
1370
- // id: '2010-CZK',
1371
- // identification: {
1372
- // number: '2500845869',
1373
- // bankCode: '2010',
1374
- // iban: 'CZ0420100000002500845869',
1375
- // holderName: 'Devizová Burza a.s.',
1376
- // },
1377
- // fallbackLastSync: monthAgo,
1378
- // currency: 'CZK',
1379
- // production: true,
1380
- // },
1381
- // {
1382
- // connectorKey: 'FINBRICKS',
1383
- // id: '2010-EUR',
1384
- // identification: {
1385
- // number: '2600884128',
1386
- // bankCode: '2010',
1387
- // iban: 'CZ0820100000002600884128',
1388
- // holderName: 'Devizová Burza a.s.',
1389
- // },
1390
- // fallbackLastSync: monthAgo,
1391
- // currency: 'EUR',
1392
- // production: true,
1393
- // },
1394
- // {
1395
- // connectorKey: 'FINBRICKS',
1396
- // id: '2010-USD',
1397
- // identification: {
1398
- // number: '2700884133',
1399
- // bankCode: '2010',
1400
- // iban: 'CZ1420100000002700884133',
1401
- // holderName: 'Devizová Burza a.s.',
1402
- // },
1403
- // fallbackLastSync: monthAgo,
1404
- // currency: 'USD',
1405
- // production: true,
1406
- // },
1407
- // {
1408
- // connectorKey: 'FINBRICKS',
1409
- // id: '2010-CHF',
1410
- // identification: {
1411
- // number: '2401098351',
1412
- // bankCode: '2010',
1413
- // iban: 'CZ0920100000002401098351',
1414
- // holderName: 'Devizová Burza a.s.',
1415
- // },
1416
- // fallbackLastSync: monthAgo,
1417
- // currency: 'CHF',
1418
- // production: true,
1419
- // },
1420
- // {
1421
- // connectorKey: 'FINBRICKS',
1422
- // id: '2010-GBP',
1423
- // identification: {
1424
- // number: '2400884131',
1425
- // bankCode: '2010',
1426
- // iban: 'CZ3320100000002400884131',
1427
- // holderName: 'Devizová Burza a.s.',
1428
- // },
1429
- // fallbackLastSync: monthAgo,
1430
- // currency: 'GBP',
1431
- // production: true,
1432
- // },
1433
- // {
1434
- // connectorKey: 'FINBRICKS',
1435
- // id: '2010-PLN',
1436
- // identification: {
1437
- // number: '2701098353',
1438
- // bankCode: '2010',
1439
- // iban: 'CZ8720100000002701098353',
1440
- // holderName: 'Devizová Burza a.s.',
1441
- // },
1442
- // fallbackLastSync: monthAgo,
1443
- // currency: 'PLN',
1444
- // production: true,
1445
- // },
1446
- // {
1447
- // connectorKey: 'FINBRICKS',
1448
- // id: '2010-CAD',
1449
- // identification: {
1450
- // number: '2701478102',
1451
- // bankCode: '2010',
1452
- // iban: 'CZ5520100000002701478102',
1453
- // holderName: 'Devizová Burza a.s.',
1454
- // },
1455
- // fallbackLastSync: monthAgo,
1456
- // currency: 'CAD',
1457
- // production: true,
1458
- // },
1459
- // // Komerční banka (0100)
1460
- // {
1461
- // connectorKey: 'FINBRICKS',
1462
- // id: '0100-CZK',
1463
- // identification: {
1464
- // number: '115-1483630297',
1465
- // bankCode: '0100',
1466
- // iban: 'CZ5901000001151483630297',
1467
- // holderName: 'Devizová Burza a.s.',
1468
- // },
1469
- // fallbackLastSync: monthAgo,
1470
- // currency: 'CZK',
1471
- // production: true,
1472
- // },
1473
- // {
1474
- // connectorKey: 'FINBRICKS',
1475
- // id: '0100-EUR',
1476
- // identification: {
1477
- // number: '115-1484940297',
1478
- // bankCode: '0100',
1479
- // iban: 'CZ4201000001151484940297',
1480
- // holderName: 'Devizová Burza a.s.',
1481
- // },
1482
- // fallbackLastSync: monthAgo,
1483
- // currency: 'EUR',
1484
- // production: true,
1485
- // },
1486
- // {
1487
- // connectorKey: 'FINBRICKS',
1488
- // id: '0100-USD',
1489
- // identification: {
1490
- // number: '115-1483960237',
1491
- // bankCode: '0100',
1492
- // iban: 'CZ6201000001151483960237',
1493
- // holderName: 'Devizová Burza a.s.',
1494
- // },
1495
- // fallbackLastSync: monthAgo,
1496
- // currency: 'USD',
1497
- // production: true,
1498
- // },
1499
- // {
1500
- // connectorKey: 'FINBRICKS',
1501
- // id: '0100-PLN',
1502
- // identification: {
1503
- // number: '115-6674290267',
1504
- // bankCode: '0100',
1505
- // iban: 'CZ3501000001156674290267',
1506
- // holderName: 'Devizová Burza a.s.',
1507
- // },
1508
- // fallbackLastSync: monthAgo,
1509
- // currency: 'PLN',
1510
- // production: true,
1511
- // },
1512
- // {
1513
- // connectorKey: 'FINBRICKS',
1514
- // id: '0100-SEK',
1515
- // identification: {
1516
- // number: '115-9578110207',
1517
- // bankCode: '0100',
1518
- // iban: 'CZ2401000001159578110207',
1519
- // holderName: 'Devizová Burza a.s.',
1520
- // },
1521
- // fallbackLastSync: monthAgo,
1522
- // currency: 'SEK',
1523
- // production: true,
1524
- // },
1525
- // // Česká spořitelna (0800)
1526
- // {
1527
- // connectorKey: 'ERSTE',
1528
- // id: '0800-CZK',
1529
- // identification: {
1530
- // number: '4413926379',
1531
- // bankCode: '0800',
1532
- // iban: 'CZ7908000000004413926379',
1533
- // holderName: 'Devizová Burza a.s.',
1534
- // },
1535
- // fallbackLastSync: monthAgo,
1536
- // currency: 'CZK',
1537
- // production: true,
1538
- // },
1539
- // {
1540
- // connectorKey: 'ERSTE',
1541
- // id: '0800-EUR',
1542
- // identification: {
1543
- // number: '1966646293',
1544
- // bankCode: '0800',
1545
- // iban: 'CZ2308000000001966646293',
1546
- // holderName: 'Devizová Burza a.s.',
1547
- // },
1548
- // fallbackLastSync: monthAgo,
1549
- // currency: 'EUR',
1550
- // production: true,
1551
- // },
1552
- // {
1553
- // connectorKey: 'ERSTE',
1554
- // id: '0800-USD',
1555
- // identification: {
1556
- // number: '1978982243',
1557
- // bankCode: '0800',
1558
- // iban: 'CZ1908000000001978982243',
1559
- // holderName: 'Devizová Burza a.s.',
1560
- // },
1561
- // fallbackLastSync: monthAgo,
1562
- // currency: 'USD',
1563
- // production: true,
1564
- // },
1565
- // {
1566
- // connectorKey: 'ERSTE',
1567
- // id: '0800-HUF',
1568
- // identification: {
1569
- // number: '13461252',
1570
- // bankCode: '0800',
1571
- // iban: 'CZ1908000000000013461252',
1572
- // holderName: 'Devizová Burza a.s.',
1573
- // },
1574
- // fallbackLastSync: monthAgo,
1575
- // currency: 'HUF',
1576
- // production: true,
1577
- // },
1578
- // // MONETA Money Bank (0600)
1579
- // {
1580
- // connectorKey: 'FINBRICKS',
1581
- // id: '0600-CZK',
1582
- // identification: {
1583
- // number: '224252186',
1584
- // bankCode: '0600',
1585
- // iban: 'CZ5906000000000224252186',
1586
- // holderName: 'Devizová Burza a.s.',
1587
- // },
1588
- // fallbackLastSync: monthAgo,
1589
- // currency: 'CZK',
1590
- // production: true,
1591
- // },
1592
- // {
1593
- // connectorKey: 'FINBRICKS',
1594
- // id: '0600-EUR',
1595
- // identification: {
1596
- // number: '224252231',
1597
- // bankCode: '0600',
1598
- // iban: 'CZ0806000000000224252231',
1599
- // holderName: 'Devizová Burza a.s.',
1600
- // },
1601
- // fallbackLastSync: monthAgo,
1602
- // currency: 'EUR',
1603
- // production: true,
1604
- // },
1605
- // {
1606
- // connectorKey: 'FINBRICKS',
1607
- // id: '0600-USD',
1608
- // identification: {
1609
- // number: '224252290',
1610
- // bankCode: '0600',
1611
- // iban: 'CZ6406000000000224252290',
1612
- // holderName: 'Devizová Burza a.s.',
1613
- // },
1614
- // fallbackLastSync: monthAgo,
1615
- // currency: 'USD',
1616
- // production: true,
1617
- // },
1618
- // // NEY spořitelní družstvo (2260)
1619
- // {
1620
- // connectorKey: 'FINBRICKS',
1621
- // id: '2260-CZK',
1622
- // identification: {
1623
- // number: '1702700014',
1624
- // bankCode: '2260',
1625
- // iban: 'CZ7422600000001702700014',
1626
- // holderName: 'Devizová Burza a.s.',
1627
- // },
1628
- // fallbackLastSync: monthAgo,
1629
- // currency: 'CZK',
1630
- // production: true,
1631
- // },
1632
- // ],
1633
- }
1634
- });
1635
-
1636
- exports.default = BankService;
1184
+ exports.BankWorkflows = export_workflows.workflows;
1637
1185
  exports.defineBankService = defineBankService;