pecunia-root 0.1.0 → 0.1.2

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 (47) hide show
  1. package/dist/adapters/drizzle-adapter/index.mjs +4 -1
  2. package/dist/adapters/drizzle-adapter/index.mjs.map +1 -1
  3. package/dist/adapters/prisma-adapter/index.d.mts +1 -1
  4. package/dist/adapters/prisma-adapter/index.mjs +1 -1
  5. package/dist/adapters/prisma-adapter/index.mjs.map +1 -1
  6. package/dist/index.d.mts +1 -2
  7. package/dist/index.mjs +1 -2
  8. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/column-builder.mjs +108 -0
  9. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/column-builder.mjs.map +1 -0
  10. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/column.mjs +55 -0
  11. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/column.mjs.map +1 -0
  12. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/entity.mjs +18 -0
  13. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/entity.mjs.map +1 -0
  14. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/pg-core/columns/common.mjs +183 -0
  15. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/pg-core/columns/common.mjs.map +1 -0
  16. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/pg-core/columns/enum.mjs +35 -0
  17. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/pg-core/columns/enum.mjs.map +1 -0
  18. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/pg-core/foreign-keys.mjs +68 -0
  19. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/pg-core/foreign-keys.mjs.map +1 -0
  20. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/pg-core/unique-constraint.mjs +56 -0
  21. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/pg-core/unique-constraint.mjs.map +1 -0
  22. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/pg-core/utils/array.mjs +65 -0
  23. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/pg-core/utils/array.mjs.map +1 -0
  24. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/sql/expressions/conditions.mjs +69 -0
  25. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/sql/expressions/conditions.mjs.map +1 -0
  26. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/sql/expressions/select.mjs +13 -0
  27. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/sql/expressions/select.mjs.map +1 -0
  28. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/sql/functions/aggregate.mjs +10 -0
  29. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/sql/functions/aggregate.mjs.map +1 -0
  30. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/sql/sql.mjs +366 -0
  31. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/sql/sql.mjs.map +1 -0
  32. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/subquery.mjs +22 -0
  33. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/subquery.mjs.map +1 -0
  34. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/table.mjs +62 -0
  35. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/table.mjs.map +1 -0
  36. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/table.utils.mjs +6 -0
  37. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/table.utils.mjs.map +1 -0
  38. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/tracing-utils.mjs +8 -0
  39. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/tracing-utils.mjs.map +1 -0
  40. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/tracing.mjs +8 -0
  41. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/tracing.mjs.map +1 -0
  42. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/view-common.mjs +6 -0
  43. package/dist/node_modules/.pnpm/drizzle-orm@0.41.0_@prisma_client@5.22.0_prisma@5.22.0__@types_better-sqlite3@7.6.13_@t_b8c798d02fdf3681c336f03696200539/node_modules/drizzle-orm/view-common.mjs.map +1 -0
  44. package/package.json +2 -54
  45. package/dist/adapters/mongodb-adapter/index.d.mts +0 -35
  46. package/dist/adapters/mongodb-adapter/index.mjs +0 -313
  47. package/dist/adapters/mongodb-adapter/index.mjs.map +0 -1
@@ -1,35 +0,0 @@
1
- import { DBAdapter, DBAdapterDebugLogOption, PecuniaOptions } from "pecunia-core";
2
- import { Db, MongoClient } from "mongodb";
3
-
4
- //#region src/adapters/mongodb-adapter/index.d.ts
5
- interface MongoDBAdapterConfig {
6
- /**
7
- * MongoDB client instance
8
- * If not provided, Database transactions won't be enabled.
9
- */
10
- client?: MongoClient | undefined;
11
- /**
12
- * Enable debug logs for the adapter
13
- *
14
- * @default false
15
- */
16
- debugLogs?: DBAdapterDebugLogOption | undefined;
17
- /**
18
- * Use plural table names
19
- *
20
- * @default false
21
- */
22
- usePlural?: boolean | undefined;
23
- /**
24
- * Whether to execute multiple operations in a transaction.
25
- *
26
- * If the database doesn't support transactions,
27
- * set this to `false` and operations will be executed sequentially.
28
- * @default false
29
- */
30
- transaction?: boolean | undefined;
31
- }
32
- declare const mongodbAdapter: (db: Db, config?: MongoDBAdapterConfig | undefined) => (options: PecuniaOptions) => DBAdapter<PecuniaOptions>;
33
- //#endregion
34
- export { MongoDBAdapterConfig, mongodbAdapter };
35
- //# sourceMappingURL=index.d.mts.map
@@ -1,313 +0,0 @@
1
- import { createAdapterFactory } from "pecunia-core";
2
- import { ObjectId } from "mongodb";
3
-
4
- //#region src/adapters/mongodb-adapter/index.ts
5
- const mongodbAdapter = (db, config) => {
6
- let lazyOptions;
7
- const createCustomAdapter = (db$1, session) => ({ getFieldName, schema, getDefaultModelName, options }) => {
8
- function serializeID({ field, value, model }) {
9
- model = getDefaultModelName(model);
10
- if (field === "id" || field === "_id" || schema[model].fields[field]?.references?.field === "id") {
11
- if (value === null || value === void 0) return value;
12
- if (typeof value !== "string") {
13
- if (value instanceof ObjectId) return value;
14
- if (Array.isArray(value)) return value.map((v) => {
15
- if (v === null || v === void 0) return v;
16
- if (typeof v === "string") try {
17
- return new ObjectId(v);
18
- } catch {
19
- return v;
20
- }
21
- if (v instanceof ObjectId) return v;
22
- throw new Error("Invalid id value, received: " + JSON.stringify(v));
23
- });
24
- throw new Error("Invalid id value, received: " + JSON.stringify(value));
25
- }
26
- try {
27
- return new ObjectId(value);
28
- } catch {
29
- return value;
30
- }
31
- }
32
- return value;
33
- }
34
- function convertWhereClause({ where, model }) {
35
- if (!where.length) return {};
36
- const conditions = where.map((w) => {
37
- const { field: field_, value, operator = "eq", connector = "AND" } = w;
38
- let condition;
39
- let field = getFieldName({
40
- model,
41
- field: field_
42
- });
43
- if (field === "id") field = "_id";
44
- switch (operator.toLowerCase()) {
45
- case "eq":
46
- condition = { [field]: serializeID({
47
- field,
48
- value,
49
- model
50
- }) };
51
- break;
52
- case "in":
53
- condition = { [field]: { $in: Array.isArray(value) ? value.map((v) => serializeID({
54
- field,
55
- value: v,
56
- model
57
- })) : [serializeID({
58
- field,
59
- value,
60
- model
61
- })] } };
62
- break;
63
- case "not_in":
64
- condition = { [field]: { $nin: Array.isArray(value) ? value.map((v) => serializeID({
65
- field,
66
- value: v,
67
- model
68
- })) : [serializeID({
69
- field,
70
- value,
71
- model
72
- })] } };
73
- break;
74
- case "gt":
75
- condition = { [field]: { $gt: serializeID({
76
- field,
77
- value,
78
- model
79
- }) } };
80
- break;
81
- case "gte":
82
- condition = { [field]: { $gte: serializeID({
83
- field,
84
- value,
85
- model
86
- }) } };
87
- break;
88
- case "lt":
89
- condition = { [field]: { $lt: serializeID({
90
- field,
91
- value,
92
- model
93
- }) } };
94
- break;
95
- case "lte":
96
- condition = { [field]: { $lte: serializeID({
97
- field,
98
- value,
99
- model
100
- }) } };
101
- break;
102
- case "ne":
103
- condition = { [field]: { $ne: serializeID({
104
- field,
105
- value,
106
- model
107
- }) } };
108
- break;
109
- case "contains":
110
- condition = { [field]: { $regex: `.*${escapeForMongoRegex(value)}.*` } };
111
- break;
112
- case "starts_with":
113
- condition = { [field]: { $regex: `^${escapeForMongoRegex(value)}` } };
114
- break;
115
- case "ends_with":
116
- condition = { [field]: { $regex: `${escapeForMongoRegex(value)}$` } };
117
- break;
118
- default: throw new Error(`Unsupported operator: ${operator}`);
119
- }
120
- return {
121
- condition,
122
- connector
123
- };
124
- });
125
- if (conditions.length === 1) return conditions[0].condition;
126
- const andConditions = conditions.filter((c) => c.connector === "AND").map((c) => c.condition);
127
- const orConditions = conditions.filter((c) => c.connector === "OR").map((c) => c.condition);
128
- let clause = {};
129
- if (andConditions.length) clause = {
130
- ...clause,
131
- $and: andConditions
132
- };
133
- if (orConditions.length) clause = {
134
- ...clause,
135
- $or: orConditions
136
- };
137
- return clause;
138
- }
139
- return {
140
- async create({ model, data: values }) {
141
- return {
142
- _id: (await db$1.collection(model).insertOne(values, { session })).insertedId.toString(),
143
- ...values
144
- };
145
- },
146
- async findOne({ model, where, select }) {
147
- const pipeline = [where ? { $match: convertWhereClause({
148
- where,
149
- model
150
- }) } : { $match: {} }];
151
- if (select) {
152
- const projection = {};
153
- select.forEach((field) => {
154
- projection[getFieldName({
155
- field,
156
- model
157
- })] = 1;
158
- });
159
- pipeline.push({ $project: projection });
160
- }
161
- pipeline.push({ $limit: 1 });
162
- const res = await db$1.collection(model).aggregate(pipeline, { session }).toArray();
163
- if (!res || res.length === 0) return null;
164
- return res[0];
165
- },
166
- async findMany({ model, where, limit, offset, sortBy }) {
167
- const pipeline = [where ? { $match: convertWhereClause({
168
- where,
169
- model
170
- }) } : { $match: {} }];
171
- if (sortBy) pipeline.push({ $sort: { [getFieldName({
172
- field: sortBy.field,
173
- model
174
- })]: sortBy.direction === "desc" ? -1 : 1 } });
175
- if (offset) pipeline.push({ $skip: offset });
176
- if (limit) pipeline.push({ $limit: limit });
177
- return await db$1.collection(model).aggregate(pipeline, { session }).toArray();
178
- },
179
- async count({ model, where }) {
180
- const pipeline = [where ? { $match: convertWhereClause({
181
- where,
182
- model
183
- }) } : { $match: {} }, { $count: "total" }];
184
- const res = await db$1.collection(model).aggregate(pipeline, { session }).toArray();
185
- if (!res || res.length === 0) return 0;
186
- return res[0]?.total ?? 0;
187
- },
188
- async update({ model, where, update: values }) {
189
- const clause = convertWhereClause({
190
- where,
191
- model
192
- });
193
- const doc = (await db$1.collection(model).findOneAndUpdate(clause, { $set: values }, {
194
- session,
195
- returnDocument: "after",
196
- includeResultMetadata: true
197
- }))?.value ?? null;
198
- if (!doc) return null;
199
- return doc;
200
- },
201
- async updateMany({ model, where, update: values }) {
202
- const clause = convertWhereClause({
203
- where,
204
- model
205
- });
206
- return (await db$1.collection(model).updateMany(clause, { $set: values }, { session })).modifiedCount;
207
- },
208
- async delete({ model, where }) {
209
- const clause = convertWhereClause({
210
- where,
211
- model
212
- });
213
- await db$1.collection(model).deleteOne(clause, { session });
214
- },
215
- async deleteMany({ model, where }) {
216
- const clause = convertWhereClause({
217
- where,
218
- model
219
- });
220
- return (await db$1.collection(model).deleteMany(clause, { session })).deletedCount;
221
- }
222
- };
223
- };
224
- let lazyAdapter = null;
225
- let adapterOptions = null;
226
- adapterOptions = {
227
- config: {
228
- adapterId: "mongodb-adapter",
229
- adapterName: "MongoDB Adapter",
230
- usePlural: config?.usePlural ?? false,
231
- mapKeysTransformInput: { id: "_id" },
232
- mapKeysTransformOutput: { _id: "id" },
233
- supportsArrays: true,
234
- supportsNumericIds: false,
235
- transaction: config?.client && (config?.transaction ?? true) ? async (cb) => {
236
- if (!config.client) return cb(lazyAdapter(lazyOptions));
237
- const session = config.client.startSession();
238
- try {
239
- session.startTransaction();
240
- const result = await cb(createAdapterFactory({
241
- config: adapterOptions.config,
242
- adapter: createCustomAdapter(db, session)
243
- })(lazyOptions));
244
- await session.commitTransaction();
245
- return result;
246
- } catch (err) {
247
- await session.abortTransaction();
248
- throw err;
249
- } finally {
250
- await session.endSession();
251
- }
252
- } : false,
253
- customTransformInput({ action, data, field, fieldAttributes, options }) {
254
- if (field === "_id" || fieldAttributes.references?.field === "id") {
255
- if (action !== "create") return data;
256
- if (Array.isArray(data)) return data.map((v) => {
257
- if (typeof v === "string") try {
258
- return new ObjectId(v);
259
- } catch {
260
- return v;
261
- }
262
- return v;
263
- });
264
- if (typeof data === "string") try {
265
- return new ObjectId(data);
266
- } catch {
267
- return data;
268
- }
269
- if (fieldAttributes?.references?.field === "id" && !fieldAttributes?.required && data === null) return null;
270
- return new ObjectId();
271
- }
272
- return data;
273
- },
274
- customTransformOutput({ data, field, fieldAttributes }) {
275
- if (field === "id" || fieldAttributes.references?.field === "id") {
276
- if (data instanceof ObjectId) return data.toHexString();
277
- if (Array.isArray(data)) return data.map((v) => {
278
- if (v instanceof ObjectId) return v.toHexString();
279
- return v;
280
- });
281
- return data;
282
- }
283
- return data;
284
- },
285
- customIdGenerator() {
286
- return new ObjectId().toString();
287
- }
288
- },
289
- adapter: createCustomAdapter(db)
290
- };
291
- lazyAdapter = createAdapterFactory(adapterOptions);
292
- return (options) => {
293
- lazyOptions = options;
294
- return lazyAdapter(options);
295
- };
296
- };
297
- /**
298
- * Safely escape user input for use in a MongoDB regex.
299
- * This ensures the resulting pattern is treated as literal text,
300
- * and not as a regex with special syntax.
301
- *
302
- * @param input - The input string to escape. Any type that isn't a string will be converted to an empty string.
303
- * @param maxLength - The maximum length of the input string to escape. Defaults to 256. This is to prevent DOS attacks.
304
- * @returns The escaped string.
305
- */
306
- function escapeForMongoRegex(input, maxLength = 256) {
307
- if (typeof input !== "string") return "";
308
- return input.slice(0, maxLength).replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
309
- }
310
-
311
- //#endregion
312
- export { mongodbAdapter };
313
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.mjs","names":["db"],"sources":["../../../src/adapters/mongodb-adapter/index.ts"],"sourcesContent":["import type { PecuniaOptions } from \"pecunia-core\";\nimport type {\n AdapterFactoryCreator,\n AdapterFactoryOptions,\n DBAdapter,\n DBAdapterDebugLogOption,\n Where,\n} from \"pecunia-core\";\nimport { createAdapterFactory } from \"pecunia-core\";\nimport type { ClientSession, Db, MongoClient } from \"mongodb\";\nimport { ObjectId } from \"mongodb\";\n\nexport interface MongoDBAdapterConfig {\n /**\n * MongoDB client instance\n * If not provided, Database transactions won't be enabled.\n */\n client?: MongoClient | undefined;\n /**\n * Enable debug logs for the adapter\n *\n * @default false\n */\n debugLogs?: DBAdapterDebugLogOption | undefined;\n /**\n * Use plural table names\n *\n * @default false\n */\n usePlural?: boolean | undefined;\n /**\n * Whether to execute multiple operations in a transaction.\n *\n * If the database doesn't support transactions,\n * set this to `false` and operations will be executed sequentially.\n * @default false\n */\n transaction?: boolean | undefined;\n}\n\nexport const mongodbAdapter = (\n db: Db,\n config?: MongoDBAdapterConfig | undefined,\n) => {\n let lazyOptions: PecuniaOptions | null;\n\n const createCustomAdapter =\n (db: Db, session?: ClientSession | undefined): AdapterFactoryCreator =>\n ({ getFieldName, schema, getDefaultModelName, options }) => {\n function serializeID({\n field,\n value,\n model,\n }: {\n field: string;\n value: any;\n model: string;\n }) {\n model = getDefaultModelName(model);\n\n if (\n field === \"id\" ||\n field === \"_id\" ||\n schema[model]!.fields[field]?.references?.field === \"id\"\n ) {\n if (value === null || value === undefined) return value;\n\n if (typeof value !== \"string\") {\n if (value instanceof ObjectId) return value;\n\n if (Array.isArray(value)) {\n return value.map((v) => {\n if (v === null || v === undefined) return v;\n\n if (typeof v === \"string\") {\n try {\n return new ObjectId(v);\n } catch {\n return v;\n }\n }\n\n if (v instanceof ObjectId) return v;\n\n throw new Error(\n \"Invalid id value, received: \" + JSON.stringify(v),\n );\n });\n }\n\n throw new Error(\n \"Invalid id value, received: \" + JSON.stringify(value),\n );\n }\n\n try {\n return new ObjectId(value);\n } catch {\n return value;\n }\n }\n\n return value;\n }\n\n function convertWhereClause({\n where,\n model,\n }: {\n where: Where[];\n model: string;\n }) {\n if (!where.length) return {};\n\n const conditions = where.map((w) => {\n const {\n field: field_,\n value,\n operator = \"eq\",\n connector = \"AND\",\n } = w;\n\n let condition: any;\n let field = getFieldName({ model, field: field_ });\n if (field === \"id\") field = \"_id\";\n\n switch (operator.toLowerCase()) {\n case \"eq\":\n condition = {\n [field]: serializeID({ field, value, model }),\n };\n break;\n\n case \"in\":\n condition = {\n [field]: {\n $in: Array.isArray(value)\n ? value.map((v) => serializeID({ field, value: v, model }))\n : [serializeID({ field, value, model })],\n },\n };\n break;\n\n case \"not_in\":\n condition = {\n [field]: {\n $nin: Array.isArray(value)\n ? value.map((v) => serializeID({ field, value: v, model }))\n : [serializeID({ field, value, model })],\n },\n };\n break;\n\n case \"gt\":\n condition = {\n [field]: { $gt: serializeID({ field, value, model }) },\n };\n break;\n\n case \"gte\":\n condition = {\n [field]: { $gte: serializeID({ field, value, model }) },\n };\n break;\n\n case \"lt\":\n condition = {\n [field]: { $lt: serializeID({ field, value, model }) },\n };\n break;\n\n case \"lte\":\n condition = {\n [field]: { $lte: serializeID({ field, value, model }) },\n };\n break;\n\n case \"ne\":\n condition = {\n [field]: { $ne: serializeID({ field, value, model }) },\n };\n break;\n\n case \"contains\":\n condition = {\n [field]: {\n $regex: `.*${escapeForMongoRegex(value as string)}.*`,\n },\n };\n break;\n\n case \"starts_with\":\n condition = {\n [field]: {\n $regex: `^${escapeForMongoRegex(value as string)}`,\n },\n };\n break;\n\n case \"ends_with\":\n condition = {\n [field]: {\n $regex: `${escapeForMongoRegex(value as string)}$`,\n },\n };\n break;\n\n default:\n throw new Error(`Unsupported operator: ${operator}`);\n }\n\n return { condition, connector };\n });\n\n if (conditions.length === 1) {\n return conditions[0]!.condition;\n }\n\n const andConditions = conditions\n .filter((c) => c.connector === \"AND\")\n .map((c) => c.condition);\n\n const orConditions = conditions\n .filter((c) => c.connector === \"OR\")\n .map((c) => c.condition);\n\n let clause: any = {};\n if (andConditions.length) clause = { ...clause, $and: andConditions };\n if (orConditions.length) clause = { ...clause, $or: orConditions };\n\n return clause;\n }\n\n return {\n async create({ model, data: values }) {\n const res = await db.collection(model).insertOne(values, { session });\n const insertedData = { _id: res.insertedId.toString(), ...values };\n return insertedData as any;\n },\n\n async findOne({ model, where, select }) {\n const matchStage = where\n ? { $match: convertWhereClause({ where, model }) }\n : { $match: {} };\n\n const pipeline: any[] = [matchStage];\n\n if (select) {\n const projection: any = {};\n select.forEach((field) => {\n projection[getFieldName({ field, model })] = 1;\n });\n pipeline.push({ $project: projection });\n }\n\n pipeline.push({ $limit: 1 });\n\n const res = await db\n .collection(model)\n .aggregate(pipeline, { session })\n .toArray();\n\n if (!res || res.length === 0) return null;\n return res[0] as any;\n },\n\n async findMany({ model, where, limit, offset, sortBy }) {\n const matchStage = where\n ? { $match: convertWhereClause({ where, model }) }\n : { $match: {} };\n\n const pipeline: any[] = [matchStage];\n\n if (sortBy) {\n pipeline.push({\n $sort: {\n [getFieldName({ field: sortBy.field, model })]:\n sortBy.direction === \"desc\" ? -1 : 1,\n },\n });\n }\n\n if (offset) {\n pipeline.push({ $skip: offset });\n }\n\n if (limit) {\n pipeline.push({ $limit: limit });\n }\n\n const res = await db\n .collection(model)\n .aggregate(pipeline, { session })\n .toArray();\n\n return res as any;\n },\n\n async count({ model, where }) {\n const matchStage = where\n ? { $match: convertWhereClause({ where, model }) }\n : { $match: {} };\n\n const pipeline: any[] = [matchStage, { $count: \"total\" }];\n\n const res = await db\n .collection(model)\n .aggregate(pipeline, { session })\n .toArray();\n\n if (!res || res.length === 0) return 0;\n return res[0]?.total ?? 0;\n },\n\n async update({ model, where, update: values }) {\n const clause = convertWhereClause({ where, model });\n\n const res = await db.collection(model).findOneAndUpdate(\n clause,\n { $set: values as any },\n {\n session,\n returnDocument: \"after\",\n includeResultMetadata: true,\n },\n );\n\n const doc = (res as any)?.value ?? null;\n if (!doc) return null;\n return doc as any;\n },\n\n async updateMany({ model, where, update: values }) {\n const clause = convertWhereClause({ where, model });\n\n const res = await db\n .collection(model)\n .updateMany(clause, { $set: values as any }, { session });\n\n return res.modifiedCount;\n },\n\n async delete({ model, where }) {\n const clause = convertWhereClause({ where, model });\n await db.collection(model).deleteOne(clause, { session });\n },\n\n async deleteMany({ model, where }) {\n const clause = convertWhereClause({ where, model });\n const res = await db\n .collection(model)\n .deleteMany(clause, { session });\n return res.deletedCount;\n },\n };\n };\n\n let lazyAdapter:\n | ((options: PecuniaOptions) => DBAdapter<PecuniaOptions>)\n | null = null;\n\n let adapterOptions: AdapterFactoryOptions | null = null;\n\n adapterOptions = {\n config: {\n adapterId: \"mongodb-adapter\",\n adapterName: \"MongoDB Adapter\",\n usePlural: config?.usePlural ?? false,\n mapKeysTransformInput: {\n id: \"_id\",\n },\n mapKeysTransformOutput: {\n _id: \"id\",\n },\n supportsArrays: true,\n supportsNumericIds: false,\n transaction:\n config?.client && (config?.transaction ?? true)\n ? async (cb) => {\n if (!config.client) {\n return cb(lazyAdapter!(lazyOptions!));\n }\n\n const session = config.client.startSession();\n\n try {\n session.startTransaction();\n\n const adapter = createAdapterFactory({\n config: adapterOptions!.config,\n adapter: createCustomAdapter(db, session),\n })(lazyOptions!);\n\n const result = await cb(adapter);\n\n await session.commitTransaction();\n return result;\n } catch (err) {\n await session.abortTransaction();\n throw err;\n } finally {\n await session.endSession();\n }\n }\n : false,\n customTransformInput({ action, data, field, fieldAttributes, options }) {\n if (field === \"_id\" || fieldAttributes.references?.field === \"id\") {\n if (action !== \"create\") return data;\n\n if (Array.isArray(data)) {\n return data.map((v) => {\n if (typeof v === \"string\") {\n try {\n return new ObjectId(v);\n } catch {\n return v;\n }\n }\n return v;\n });\n }\n\n if (typeof data === \"string\") {\n try {\n return new ObjectId(data);\n } catch {\n return data;\n }\n }\n\n if (\n fieldAttributes?.references?.field === \"id\" &&\n !fieldAttributes?.required &&\n data === null\n ) {\n return null;\n }\n\n return new ObjectId();\n }\n\n return data;\n },\n customTransformOutput({ data, field, fieldAttributes }) {\n if (field === \"id\" || fieldAttributes.references?.field === \"id\") {\n if (data instanceof ObjectId) return data.toHexString();\n\n if (Array.isArray(data)) {\n return data.map((v) => {\n if (v instanceof ObjectId) return v.toHexString();\n return v;\n });\n }\n\n return data;\n }\n\n return data;\n },\n customIdGenerator() {\n return new ObjectId().toString();\n },\n },\n adapter: createCustomAdapter(db),\n };\n\n lazyAdapter = createAdapterFactory(adapterOptions);\n\n return (options: PecuniaOptions): DBAdapter<PecuniaOptions> => {\n lazyOptions = options;\n return lazyAdapter(options);\n };\n};\n\n/**\n * Safely escape user input for use in a MongoDB regex.\n * This ensures the resulting pattern is treated as literal text,\n * and not as a regex with special syntax.\n *\n * @param input - The input string to escape. Any type that isn't a string will be converted to an empty string.\n * @param maxLength - The maximum length of the input string to escape. Defaults to 256. This is to prevent DOS attacks.\n * @returns The escaped string.\n */\nfunction escapeForMongoRegex(input: string, maxLength = 256): string {\n if (typeof input !== \"string\") return \"\";\n\n // Escape all PCRE special characters\n // Source: PCRE docs — https://www.pcre.org/original/doc/html/pcrepattern.html\n return input.slice(0, maxLength).replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\");\n}\n"],"mappings":"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"}