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.
- package/dist/adapters/drizzle-adapter/index.mjs +4 -1
- package/dist/adapters/drizzle-adapter/index.mjs.map +1 -1
- package/dist/adapters/prisma-adapter/index.d.mts +1 -1
- package/dist/adapters/prisma-adapter/index.mjs +1 -1
- package/dist/adapters/prisma-adapter/index.mjs.map +1 -1
- package/dist/index.d.mts +1 -2
- package/dist/index.mjs +1 -2
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- package/package.json +2 -54
- package/dist/adapters/mongodb-adapter/index.d.mts +0 -35
- package/dist/adapters/mongodb-adapter/index.mjs +0 -313
- 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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"}
|