@develit-services/bank 0.3.60 → 0.4.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.
- package/dist/database/schema.cjs +9 -9
- package/dist/database/schema.d.cts +4 -5
- package/dist/database/schema.d.mts +4 -5
- package/dist/database/schema.d.ts +4 -5
- package/dist/database/schema.mjs +3 -3
- package/dist/export/worker.cjs +91 -85
- package/dist/export/worker.d.cts +23 -766
- package/dist/export/worker.d.mts +23 -766
- package/dist/export/worker.d.ts +23 -766
- package/dist/export/worker.mjs +72 -66
- package/dist/export/workflows.cjs +215 -211
- package/dist/export/workflows.d.cts +4 -4
- package/dist/export/workflows.d.mts +4 -4
- package/dist/export/workflows.d.ts +4 -4
- package/dist/export/workflows.mjs +210 -206
- package/dist/export/wrangler.d.cts +3 -1
- package/dist/export/wrangler.d.mts +3 -1
- package/dist/export/wrangler.d.ts +3 -1
- package/dist/shared/bank.B51e8oDT.mjs +104 -0
- package/dist/shared/{bank.Dh_H_5rC.d.cts → bank.BJvgLwyZ.d.cts} +2 -0
- package/dist/shared/{bank.Dh_H_5rC.d.mts → bank.BJvgLwyZ.d.mts} +2 -0
- package/dist/shared/{bank.Dh_H_5rC.d.ts → bank.BJvgLwyZ.d.ts} +2 -0
- package/dist/shared/bank.BUSlmr6r.mjs +13 -0
- package/dist/shared/{bank.CMbfx0u7.cjs → bank.BeIpkWR-.cjs} +3 -14
- package/dist/shared/bank.Bg3Pdwm4.cjs +44 -0
- package/dist/shared/bank.CDoYUKBx.d.cts +748 -0
- package/dist/shared/bank.CDoYUKBx.d.mts +748 -0
- package/dist/shared/bank.CDoYUKBx.d.ts +748 -0
- package/dist/shared/{bank.CNEv3Rac.cjs → bank.CfSZTfWS.cjs} +634 -179
- package/dist/shared/{bank.XJJV8p4b.d.cts → bank.CsJuzqZH.d.cts} +2401 -2117
- package/dist/shared/{bank.XJJV8p4b.d.mts → bank.CsJuzqZH.d.mts} +2401 -2117
- package/dist/shared/{bank.XJJV8p4b.d.ts → bank.CsJuzqZH.d.ts} +2401 -2117
- package/dist/shared/bank.DEvSNsEs.cjs +114 -0
- package/dist/shared/{bank.DgGcjhmM.mjs → bank.DinCwx0P.mjs} +627 -179
- package/dist/shared/bank.Dpx6PvkA.mjs +33 -0
- package/dist/shared/bank.c38V_FCq.cjs +15 -0
- package/dist/shared/{bank.BqGzJNC6.mjs → bank.qc8ALZwm.mjs} +4 -14
- package/dist/types.cjs +51 -33
- package/dist/types.d.cts +164 -39
- package/dist/types.d.mts +164 -39
- package/dist/types.d.ts +164 -39
- package/dist/types.mjs +4 -3
- package/package.json +7 -10
- package/dist/shared/bank.CXpc8168.cjs +0 -212
- package/dist/shared/bank.DSsVeR3F.mjs +0 -202
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const backendSdk = require('@develit-io/backend-sdk');
|
|
4
|
+
const drizzleOrm = require('drizzle-orm');
|
|
5
|
+
const database_schema = require('./bank.c38V_FCq.cjs');
|
|
6
|
+
require('date-fns');
|
|
7
|
+
require('@develit-io/general-codes');
|
|
8
|
+
require('jose');
|
|
9
|
+
require('./bank.BeIpkWR-.cjs');
|
|
10
|
+
const node_crypto = require('node:crypto');
|
|
11
|
+
|
|
12
|
+
const createPaymentCommand = (db, { payment }) => {
|
|
13
|
+
return {
|
|
14
|
+
command: db.insert(tables.payment).values({
|
|
15
|
+
...payment,
|
|
16
|
+
creditorIban: payment.creditor.iban,
|
|
17
|
+
debtorIban: payment.debtor.iban
|
|
18
|
+
}).returning()
|
|
19
|
+
};
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
const upsertBatchCommand = (db, { batch }) => {
|
|
23
|
+
const id = batch.id || backendSdk.uuidv4();
|
|
24
|
+
const command = db.insert(tables.batch).values({
|
|
25
|
+
...batch,
|
|
26
|
+
id
|
|
27
|
+
}).onConflictDoUpdate({
|
|
28
|
+
target: tables.batch.id,
|
|
29
|
+
set: {
|
|
30
|
+
...batch
|
|
31
|
+
}
|
|
32
|
+
}).returning();
|
|
33
|
+
return {
|
|
34
|
+
id,
|
|
35
|
+
command
|
|
36
|
+
};
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
const getAccountByIdQuery = async (db, { accountId }) => {
|
|
40
|
+
return await db.select().from(tables.account).where(drizzleOrm.eq(tables.account.id, accountId)).get();
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
const getBatchByIdQuery = async (db, { batchId }) => {
|
|
44
|
+
return await db.select().from(tables.batch).where(drizzleOrm.eq(tables.batch.id, batchId)).get();
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
const getCredentialsByAccountId = async (db, encryptionKey, { accountId }) => {
|
|
48
|
+
const cred = await db.select().from(tables.accountCredentials).where(drizzleOrm.eq(tables.accountCredentials.accountId, accountId)).get();
|
|
49
|
+
return cred ? {
|
|
50
|
+
...cred,
|
|
51
|
+
value: await decrypt(cred.value, encryptionKey)
|
|
52
|
+
} : void 0;
|
|
53
|
+
};
|
|
54
|
+
|
|
55
|
+
async function importAesKey(base64Key) {
|
|
56
|
+
const raw = Uint8Array.from(atob(base64Key), (c) => c.charCodeAt(0));
|
|
57
|
+
return await crypto.subtle.importKey("raw", raw, { name: "AES-GCM" }, false, [
|
|
58
|
+
"encrypt",
|
|
59
|
+
"decrypt"
|
|
60
|
+
]);
|
|
61
|
+
}
|
|
62
|
+
async function encrypt(value, key) {
|
|
63
|
+
const encoder = new TextEncoder();
|
|
64
|
+
const iv = crypto.getRandomValues(new Uint8Array(12));
|
|
65
|
+
const ciphertext = await crypto.subtle.encrypt(
|
|
66
|
+
{ name: "AES-GCM", iv },
|
|
67
|
+
key,
|
|
68
|
+
encoder.encode(value)
|
|
69
|
+
);
|
|
70
|
+
const combined = new Uint8Array(iv.length + ciphertext.byteLength);
|
|
71
|
+
combined.set(iv, 0);
|
|
72
|
+
combined.set(new Uint8Array(ciphertext), iv.length);
|
|
73
|
+
return btoa(String.fromCharCode(...combined));
|
|
74
|
+
}
|
|
75
|
+
async function decrypt(base64, key) {
|
|
76
|
+
const raw = Uint8Array.from(atob(base64), (c) => c.charCodeAt(0));
|
|
77
|
+
const iv = raw.slice(0, 12);
|
|
78
|
+
const ciphertext = raw.slice(12);
|
|
79
|
+
const decrypted = await crypto.subtle.decrypt(
|
|
80
|
+
{ name: "AES-GCM", iv },
|
|
81
|
+
key,
|
|
82
|
+
ciphertext
|
|
83
|
+
);
|
|
84
|
+
return new TextDecoder().decode(decrypted);
|
|
85
|
+
}
|
|
86
|
+
function canonicalize(value) {
|
|
87
|
+
if (value === null || typeof value !== "object") return value;
|
|
88
|
+
if (Array.isArray(value)) {
|
|
89
|
+
return value.map(canonicalize);
|
|
90
|
+
}
|
|
91
|
+
const obj = value;
|
|
92
|
+
const sorted = Object.keys(obj).sort().reduce((acc, key) => {
|
|
93
|
+
acc[key] = canonicalize(obj[key]);
|
|
94
|
+
return acc;
|
|
95
|
+
}, {});
|
|
96
|
+
return sorted;
|
|
97
|
+
}
|
|
98
|
+
function checksum(input) {
|
|
99
|
+
const canonical = canonicalize(input);
|
|
100
|
+
const json = JSON.stringify(canonical);
|
|
101
|
+
return node_crypto.createHash("sha256").update(json).digest("hex");
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
const tables = database_schema.schema;
|
|
105
|
+
|
|
106
|
+
exports.checksum = checksum;
|
|
107
|
+
exports.createPaymentCommand = createPaymentCommand;
|
|
108
|
+
exports.encrypt = encrypt;
|
|
109
|
+
exports.getAccountByIdQuery = getAccountByIdQuery;
|
|
110
|
+
exports.getBatchByIdQuery = getBatchByIdQuery;
|
|
111
|
+
exports.getCredentialsByAccountId = getCredentialsByAccountId;
|
|
112
|
+
exports.importAesKey = importAesKey;
|
|
113
|
+
exports.tables = tables;
|
|
114
|
+
exports.upsertBatchCommand = upsertBatchCommand;
|