@delmaredigital/payload-better-auth 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.
- package/LICENSE +21 -0
- package/README.md +734 -0
- package/dist/adapter/index.d.mts +70 -0
- package/dist/adapter/index.d.ts +70 -0
- package/dist/adapter/index.js +368 -0
- package/dist/adapter/index.js.map +1 -0
- package/dist/adapter/index.mjs +366 -0
- package/dist/adapter/index.mjs.map +1 -0
- package/dist/client.d.mts +1 -0
- package/dist/client.d.ts +1 -0
- package/dist/client.js +12 -0
- package/dist/client.js.map +1 -0
- package/dist/client.mjs +3 -0
- package/dist/client.mjs.map +1 -0
- package/dist/index.d.mts +120 -0
- package/dist/index.d.ts +120 -0
- package/dist/index.js +611 -0
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +603 -0
- package/dist/index.mjs.map +1 -0
- package/dist/plugin/index.d.mts +78 -0
- package/dist/plugin/index.d.ts +78 -0
- package/dist/plugin/index.js +86 -0
- package/dist/plugin/index.js.map +1 -0
- package/dist/plugin/index.mjs +82 -0
- package/dist/plugin/index.mjs.map +1 -0
- package/package.json +73 -0
|
@@ -0,0 +1,366 @@
|
|
|
1
|
+
// src/adapter/index.ts
|
|
2
|
+
var DEFAULT_COLLECTIONS = {
|
|
3
|
+
user: "users",
|
|
4
|
+
session: "sessions",
|
|
5
|
+
account: "accounts",
|
|
6
|
+
verification: "verifications"
|
|
7
|
+
};
|
|
8
|
+
function payloadAdapter({
|
|
9
|
+
payloadClient,
|
|
10
|
+
adapterConfig
|
|
11
|
+
}) {
|
|
12
|
+
const { collections = {}, enableDebugLogs = false, idType } = adapterConfig;
|
|
13
|
+
const finalCollections = { ...DEFAULT_COLLECTIONS, ...collections };
|
|
14
|
+
const log = (...args) => {
|
|
15
|
+
if (enableDebugLogs) console.log("[payload-adapter]", ...args);
|
|
16
|
+
};
|
|
17
|
+
async function resolvePayloadClient() {
|
|
18
|
+
return typeof payloadClient === "function" ? await payloadClient() : payloadClient;
|
|
19
|
+
}
|
|
20
|
+
function getCollection(model) {
|
|
21
|
+
return finalCollections[model] ?? model;
|
|
22
|
+
}
|
|
23
|
+
function transformFieldName(fieldName) {
|
|
24
|
+
if (fieldName.endsWith("Id") && fieldName !== "id" && fieldName !== "accountId" && fieldName !== "providerId") {
|
|
25
|
+
return fieldName.slice(0, -2);
|
|
26
|
+
}
|
|
27
|
+
return fieldName;
|
|
28
|
+
}
|
|
29
|
+
function convertWhere(where) {
|
|
30
|
+
if (!where || where.length === 0) return {};
|
|
31
|
+
if (where.length === 1) {
|
|
32
|
+
const w = where[0];
|
|
33
|
+
return {
|
|
34
|
+
[transformFieldName(w.field)]: convertOperator(w.operator, w.value)
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
const andConditions = where.filter((w) => w.connector !== "OR");
|
|
38
|
+
const orConditions = where.filter((w) => w.connector === "OR");
|
|
39
|
+
const result = {};
|
|
40
|
+
if (andConditions.length > 0) {
|
|
41
|
+
result.and = andConditions.map((w) => ({
|
|
42
|
+
[transformFieldName(w.field)]: convertOperator(w.operator, w.value)
|
|
43
|
+
}));
|
|
44
|
+
}
|
|
45
|
+
if (orConditions.length > 0) {
|
|
46
|
+
result.or = orConditions.map((w) => ({
|
|
47
|
+
[transformFieldName(w.field)]: convertOperator(w.operator, w.value)
|
|
48
|
+
}));
|
|
49
|
+
}
|
|
50
|
+
return result;
|
|
51
|
+
}
|
|
52
|
+
function convertOperator(operator, value) {
|
|
53
|
+
switch (operator) {
|
|
54
|
+
case "eq":
|
|
55
|
+
return { equals: value };
|
|
56
|
+
case "ne":
|
|
57
|
+
return { not_equals: value };
|
|
58
|
+
case "gt":
|
|
59
|
+
return { greater_than: value };
|
|
60
|
+
case "gte":
|
|
61
|
+
return { greater_than_equal: value };
|
|
62
|
+
case "lt":
|
|
63
|
+
return { less_than: value };
|
|
64
|
+
case "lte":
|
|
65
|
+
return { less_than_equal: value };
|
|
66
|
+
case "in":
|
|
67
|
+
return { in: value };
|
|
68
|
+
case "contains":
|
|
69
|
+
return { contains: value };
|
|
70
|
+
case "starts_with":
|
|
71
|
+
return { like: `${value}%` };
|
|
72
|
+
case "ends_with":
|
|
73
|
+
return { like: `%${value}` };
|
|
74
|
+
default:
|
|
75
|
+
return { equals: value };
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
function extractSingleId(where) {
|
|
79
|
+
if ("and" in where || "or" in where) return null;
|
|
80
|
+
const idCondition = where.id;
|
|
81
|
+
if (idCondition && typeof idCondition === "object" && "equals" in idCondition) {
|
|
82
|
+
const value = idCondition.equals;
|
|
83
|
+
if (typeof value === "string" || typeof value === "number") {
|
|
84
|
+
return value;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
return null;
|
|
88
|
+
}
|
|
89
|
+
function transformInput(data) {
|
|
90
|
+
const result = {};
|
|
91
|
+
for (const [key, value] of Object.entries(data)) {
|
|
92
|
+
if (key.endsWith("Id") && key !== "id" && key !== "accountId" && key !== "providerId") {
|
|
93
|
+
const fieldName = key.slice(0, -2);
|
|
94
|
+
if (idType === "number" && typeof value === "string") {
|
|
95
|
+
const num = parseInt(value, 10);
|
|
96
|
+
result[fieldName] = isNaN(num) ? value : num;
|
|
97
|
+
} else {
|
|
98
|
+
result[fieldName] = value;
|
|
99
|
+
}
|
|
100
|
+
} else {
|
|
101
|
+
result[key] = value;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
return result;
|
|
105
|
+
}
|
|
106
|
+
function transformOutput(doc) {
|
|
107
|
+
if (!doc || typeof doc !== "object") return doc;
|
|
108
|
+
const result = { ...doc };
|
|
109
|
+
if ("id" in result && result.id !== void 0) {
|
|
110
|
+
result.id = String(result.id);
|
|
111
|
+
}
|
|
112
|
+
for (const [key, value] of Object.entries(result)) {
|
|
113
|
+
if (value && typeof value === "object" && "id" in value) {
|
|
114
|
+
result[`${key}Id`] = String(value.id);
|
|
115
|
+
delete result[key];
|
|
116
|
+
} else if (typeof value === "string" && /^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}/.test(value)) {
|
|
117
|
+
result[key] = new Date(value);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
return result;
|
|
121
|
+
}
|
|
122
|
+
function convertId(id) {
|
|
123
|
+
if (idType === "number" && typeof id === "string") {
|
|
124
|
+
const num = parseInt(id, 10);
|
|
125
|
+
return isNaN(num) ? id : num;
|
|
126
|
+
}
|
|
127
|
+
if (idType === "text" && typeof id === "number") {
|
|
128
|
+
return String(id);
|
|
129
|
+
}
|
|
130
|
+
return id;
|
|
131
|
+
}
|
|
132
|
+
async function handleJoins(payload, doc, model, join) {
|
|
133
|
+
const result = { ...doc };
|
|
134
|
+
for (const [joinKey, joinConfig] of Object.entries(join)) {
|
|
135
|
+
if (!joinConfig) continue;
|
|
136
|
+
const limit = typeof joinConfig === "object" ? joinConfig.limit : void 0;
|
|
137
|
+
log("handleJoins", { model, joinKey, docId: doc.id });
|
|
138
|
+
if (model === "user" && joinKey === "account") {
|
|
139
|
+
const accounts = await payload.find({
|
|
140
|
+
collection: getCollection("account"),
|
|
141
|
+
where: { user: { equals: doc.id } },
|
|
142
|
+
limit: limit ?? 100,
|
|
143
|
+
depth: 0
|
|
144
|
+
});
|
|
145
|
+
result[joinKey] = accounts.docs.map((a) => transformOutput(a));
|
|
146
|
+
} else if (model === "session" && joinKey === "user") {
|
|
147
|
+
const userId = doc.userId;
|
|
148
|
+
if (userId) {
|
|
149
|
+
try {
|
|
150
|
+
const user = await payload.findByID({
|
|
151
|
+
collection: getCollection("user"),
|
|
152
|
+
id: userId,
|
|
153
|
+
depth: 0
|
|
154
|
+
});
|
|
155
|
+
result[joinKey] = transformOutput(user);
|
|
156
|
+
} catch {
|
|
157
|
+
result[joinKey] = null;
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
} else if (model === "account" && joinKey === "user") {
|
|
161
|
+
const userId = doc.userId;
|
|
162
|
+
if (userId) {
|
|
163
|
+
try {
|
|
164
|
+
const user = await payload.findByID({
|
|
165
|
+
collection: getCollection("user"),
|
|
166
|
+
id: userId,
|
|
167
|
+
depth: 0
|
|
168
|
+
});
|
|
169
|
+
result[joinKey] = transformOutput(user);
|
|
170
|
+
} catch {
|
|
171
|
+
result[joinKey] = null;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
return result;
|
|
177
|
+
}
|
|
178
|
+
return (_options) => {
|
|
179
|
+
log("Adapter initialized", { collections: finalCollections });
|
|
180
|
+
return {
|
|
181
|
+
id: "payload-adapter",
|
|
182
|
+
async create({
|
|
183
|
+
model,
|
|
184
|
+
data
|
|
185
|
+
}) {
|
|
186
|
+
const payload = await resolvePayloadClient();
|
|
187
|
+
const collection = getCollection(model);
|
|
188
|
+
const transformedData = transformInput(data);
|
|
189
|
+
log("create", { collection, data: transformedData });
|
|
190
|
+
try {
|
|
191
|
+
const result = await payload.create({
|
|
192
|
+
collection,
|
|
193
|
+
data: transformedData,
|
|
194
|
+
depth: 0
|
|
195
|
+
});
|
|
196
|
+
return transformOutput(result);
|
|
197
|
+
} catch (error) {
|
|
198
|
+
console.error("[payload-adapter] create failed:", {
|
|
199
|
+
collection,
|
|
200
|
+
model,
|
|
201
|
+
error: error instanceof Error ? error.message : error
|
|
202
|
+
});
|
|
203
|
+
throw error;
|
|
204
|
+
}
|
|
205
|
+
},
|
|
206
|
+
async findOne({
|
|
207
|
+
model,
|
|
208
|
+
where,
|
|
209
|
+
select: _select,
|
|
210
|
+
join
|
|
211
|
+
}) {
|
|
212
|
+
try {
|
|
213
|
+
const payload = await resolvePayloadClient();
|
|
214
|
+
const collection = getCollection(model);
|
|
215
|
+
const payloadWhere = convertWhere(where);
|
|
216
|
+
const id = extractSingleId(payloadWhere);
|
|
217
|
+
if (id) {
|
|
218
|
+
try {
|
|
219
|
+
const result2 = await payload.findByID({
|
|
220
|
+
collection,
|
|
221
|
+
id: convertId(id),
|
|
222
|
+
depth: 1
|
|
223
|
+
});
|
|
224
|
+
let doc2 = transformOutput(result2);
|
|
225
|
+
if (join) {
|
|
226
|
+
doc2 = await handleJoins(payload, doc2, model, join);
|
|
227
|
+
}
|
|
228
|
+
return doc2;
|
|
229
|
+
} catch (error) {
|
|
230
|
+
if (error instanceof Error && "status" in error && error.status === 404) {
|
|
231
|
+
return null;
|
|
232
|
+
}
|
|
233
|
+
throw error;
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
const result = await payload.find({
|
|
237
|
+
collection,
|
|
238
|
+
where: payloadWhere,
|
|
239
|
+
limit: 1,
|
|
240
|
+
depth: 1
|
|
241
|
+
});
|
|
242
|
+
let doc = result.docs[0] ? transformOutput(result.docs[0]) : null;
|
|
243
|
+
if (doc && join) {
|
|
244
|
+
doc = await handleJoins(payload, doc, model, join);
|
|
245
|
+
}
|
|
246
|
+
return doc;
|
|
247
|
+
} catch (error) {
|
|
248
|
+
console.error("[payload-adapter] findOne FAILED", {
|
|
249
|
+
model,
|
|
250
|
+
where,
|
|
251
|
+
error
|
|
252
|
+
});
|
|
253
|
+
throw error;
|
|
254
|
+
}
|
|
255
|
+
},
|
|
256
|
+
async findMany({
|
|
257
|
+
model,
|
|
258
|
+
where,
|
|
259
|
+
limit,
|
|
260
|
+
offset,
|
|
261
|
+
sortBy
|
|
262
|
+
}) {
|
|
263
|
+
const payload = await resolvePayloadClient();
|
|
264
|
+
const collection = getCollection(model);
|
|
265
|
+
const payloadWhere = convertWhere(where);
|
|
266
|
+
const result = await payload.find({
|
|
267
|
+
collection,
|
|
268
|
+
where: payloadWhere,
|
|
269
|
+
limit: limit ?? 100,
|
|
270
|
+
page: offset ? Math.floor(offset / (limit ?? 100)) + 1 : 1,
|
|
271
|
+
sort: sortBy ? `${sortBy.direction === "desc" ? "-" : ""}${sortBy.field}` : void 0,
|
|
272
|
+
depth: 1
|
|
273
|
+
});
|
|
274
|
+
return result.docs.map((doc) => transformOutput(doc));
|
|
275
|
+
},
|
|
276
|
+
async update({
|
|
277
|
+
model,
|
|
278
|
+
where,
|
|
279
|
+
update: data
|
|
280
|
+
}) {
|
|
281
|
+
const payload = await resolvePayloadClient();
|
|
282
|
+
const collection = getCollection(model);
|
|
283
|
+
const payloadWhere = convertWhere(where);
|
|
284
|
+
const transformedData = transformInput(data);
|
|
285
|
+
const id = extractSingleId(payloadWhere);
|
|
286
|
+
if (id) {
|
|
287
|
+
const result2 = await payload.update({
|
|
288
|
+
collection,
|
|
289
|
+
id: convertId(id),
|
|
290
|
+
data: transformedData,
|
|
291
|
+
depth: 1
|
|
292
|
+
});
|
|
293
|
+
return transformOutput(result2);
|
|
294
|
+
}
|
|
295
|
+
const result = await payload.update({
|
|
296
|
+
collection,
|
|
297
|
+
where: payloadWhere,
|
|
298
|
+
data: transformedData,
|
|
299
|
+
depth: 1
|
|
300
|
+
});
|
|
301
|
+
return result.docs[0] ? transformOutput(result.docs[0]) : null;
|
|
302
|
+
},
|
|
303
|
+
async updateMany({
|
|
304
|
+
model,
|
|
305
|
+
where,
|
|
306
|
+
update: data
|
|
307
|
+
}) {
|
|
308
|
+
const payload = await resolvePayloadClient();
|
|
309
|
+
const collection = getCollection(model);
|
|
310
|
+
const payloadWhere = convertWhere(where);
|
|
311
|
+
const transformedData = transformInput(data);
|
|
312
|
+
const result = await payload.update({
|
|
313
|
+
collection,
|
|
314
|
+
where: payloadWhere,
|
|
315
|
+
data: transformedData,
|
|
316
|
+
depth: 0
|
|
317
|
+
});
|
|
318
|
+
return result.docs.length;
|
|
319
|
+
},
|
|
320
|
+
async delete({ model, where }) {
|
|
321
|
+
const payload = await resolvePayloadClient();
|
|
322
|
+
const collection = getCollection(model);
|
|
323
|
+
const payloadWhere = convertWhere(where);
|
|
324
|
+
const id = extractSingleId(payloadWhere);
|
|
325
|
+
if (id) {
|
|
326
|
+
await payload.delete({ collection, id: convertId(id) });
|
|
327
|
+
return;
|
|
328
|
+
}
|
|
329
|
+
await payload.delete({ collection, where: payloadWhere });
|
|
330
|
+
},
|
|
331
|
+
async deleteMany({
|
|
332
|
+
model,
|
|
333
|
+
where
|
|
334
|
+
}) {
|
|
335
|
+
const payload = await resolvePayloadClient();
|
|
336
|
+
const collection = getCollection(model);
|
|
337
|
+
const payloadWhere = convertWhere(where);
|
|
338
|
+
const result = await payload.delete({
|
|
339
|
+
collection,
|
|
340
|
+
where: payloadWhere
|
|
341
|
+
});
|
|
342
|
+
return result.docs.length;
|
|
343
|
+
},
|
|
344
|
+
async count({
|
|
345
|
+
model,
|
|
346
|
+
where
|
|
347
|
+
}) {
|
|
348
|
+
const payload = await resolvePayloadClient();
|
|
349
|
+
const collection = getCollection(model);
|
|
350
|
+
const payloadWhere = convertWhere(where);
|
|
351
|
+
const result = await payload.count({
|
|
352
|
+
collection,
|
|
353
|
+
where: payloadWhere
|
|
354
|
+
});
|
|
355
|
+
return result.totalDocs;
|
|
356
|
+
},
|
|
357
|
+
async transaction(callback) {
|
|
358
|
+
return callback(this);
|
|
359
|
+
}
|
|
360
|
+
};
|
|
361
|
+
};
|
|
362
|
+
}
|
|
363
|
+
|
|
364
|
+
export { payloadAdapter };
|
|
365
|
+
//# sourceMappingURL=index.mjs.map
|
|
366
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/adapter/index.ts"],"names":["result","doc"],"mappings":"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","file":"index.mjs","sourcesContent":["/**\n * Payload CMS Adapter for Better Auth\n *\n * A clean adapter that bridges Better Auth to Payload collections.\n * Follows the same factory pattern as payload-auth for compatibility.\n *\n * @packageDocumentation\n */\n\nimport type { Adapter, BetterAuthOptions, Where } from 'better-auth'\nimport type { BasePayload, Where as PayloadWhere, CollectionSlug } from 'payload'\n\nexport type PayloadAdapterConfig = {\n /**\n * The Payload instance or a function that returns it.\n * Use a function for lazy initialization.\n */\n payloadClient: BasePayload | (() => Promise<BasePayload>)\n\n /**\n * Adapter configuration options\n */\n adapterConfig: {\n /**\n * Map Better Auth model names to Payload collection slugs.\n * Defaults: { user: 'users', session: 'sessions', account: 'accounts', verification: 'verifications' }\n */\n collections?: Record<string, string>\n\n /**\n * Enable debug logging for troubleshooting\n */\n enableDebugLogs?: boolean\n\n /**\n * ID type used by Payload\n * - 'number' for SERIAL/auto-increment (recommended - Payload default)\n * - 'text' for UUID (requires idType: 'uuid' in Payload's db adapter)\n */\n idType: 'number' | 'text'\n }\n}\n\nconst DEFAULT_COLLECTIONS: Record<string, string> = {\n user: 'users',\n session: 'sessions',\n account: 'accounts',\n verification: 'verifications',\n}\n\n/**\n * Creates a Better Auth adapter that uses Payload CMS as the database.\n *\n * Returns a factory function that Better Auth calls with its options.\n * This matches the pattern used by other Better Auth adapters.\n *\n * @example\n * ```ts\n * import { payloadAdapter } from '@delmare/payload-better-auth/adapter'\n *\n * const auth = betterAuth({\n * database: payloadAdapter({\n * payloadClient: payload,\n * adapterConfig: {\n * idType: 'number', // Use Payload's default SERIAL IDs\n * collections: { user: 'users' },\n * },\n * }),\n * // Required when using serial/integer IDs\n * advanced: {\n * database: {\n * generateId: 'serial',\n * },\n * },\n * })\n * ```\n */\nexport function payloadAdapter({\n payloadClient,\n adapterConfig,\n}: PayloadAdapterConfig): (options: BetterAuthOptions) => Adapter {\n const { collections = {}, enableDebugLogs = false, idType } = adapterConfig\n const finalCollections = { ...DEFAULT_COLLECTIONS, ...collections }\n\n const log = (...args: unknown[]) => {\n if (enableDebugLogs) console.log('[payload-adapter]', ...args)\n }\n\n async function resolvePayloadClient(): Promise<BasePayload> {\n return typeof payloadClient === 'function'\n ? await payloadClient()\n : payloadClient\n }\n\n function getCollection(model: string): CollectionSlug {\n return (finalCollections[model] ?? model) as CollectionSlug\n }\n\n /**\n * Transform field name for where clause (Better Auth → Payload)\n * Converts relationship fields like `userId` to `user`\n */\n function transformFieldName(fieldName: string): string {\n if (\n fieldName.endsWith('Id') &&\n fieldName !== 'id' &&\n fieldName !== 'accountId' &&\n fieldName !== 'providerId'\n ) {\n return fieldName.slice(0, -2)\n }\n return fieldName\n }\n\n /**\n * Convert Better Auth where clause to Payload where clause\n */\n function convertWhere(where?: Where[]): PayloadWhere {\n if (!where || where.length === 0) return {}\n\n if (where.length === 1) {\n const w = where[0]\n return {\n [transformFieldName(w.field)]: convertOperator(w.operator, w.value),\n }\n }\n\n const andConditions = where.filter((w) => w.connector !== 'OR')\n const orConditions = where.filter((w) => w.connector === 'OR')\n\n const result: PayloadWhere = {}\n\n if (andConditions.length > 0) {\n result.and = andConditions.map((w) => ({\n [transformFieldName(w.field)]: convertOperator(w.operator, w.value),\n }))\n }\n\n if (orConditions.length > 0) {\n result.or = orConditions.map((w) => ({\n [transformFieldName(w.field)]: convertOperator(w.operator, w.value),\n }))\n }\n\n return result\n }\n\n function convertOperator(\n operator: string | undefined,\n value: unknown\n ): Record<string, unknown> {\n switch (operator) {\n case 'eq':\n return { equals: value }\n case 'ne':\n return { not_equals: value }\n case 'gt':\n return { greater_than: value }\n case 'gte':\n return { greater_than_equal: value }\n case 'lt':\n return { less_than: value }\n case 'lte':\n return { less_than_equal: value }\n case 'in':\n return { in: value }\n case 'contains':\n return { contains: value }\n case 'starts_with':\n return { like: `${value}%` }\n case 'ends_with':\n return { like: `%${value}` }\n default:\n return { equals: value }\n }\n }\n\n function extractSingleId(where: PayloadWhere): string | number | null {\n if ('and' in where || 'or' in where) return null\n\n const idCondition = where.id\n if (\n idCondition &&\n typeof idCondition === 'object' &&\n 'equals' in idCondition\n ) {\n const value = idCondition.equals\n if (typeof value === 'string' || typeof value === 'number') {\n return value\n }\n }\n\n return null\n }\n\n /**\n * Transform input data (Better Auth → Payload field names)\n * Also converts relationship IDs to the correct type based on idType\n */\n function transformInput(\n data: Record<string, unknown>\n ): Record<string, unknown> {\n const result: Record<string, unknown> = {}\n\n for (const [key, value] of Object.entries(data)) {\n if (\n key.endsWith('Id') &&\n key !== 'id' &&\n key !== 'accountId' &&\n key !== 'providerId'\n ) {\n // Transform userId -> user and convert to correct ID type for relationships\n const fieldName = key.slice(0, -2)\n if (idType === 'number' && typeof value === 'string') {\n const num = parseInt(value, 10)\n result[fieldName] = isNaN(num) ? value : num\n } else {\n result[fieldName] = value\n }\n } else {\n result[key] = value\n }\n }\n\n return result\n }\n\n /**\n * Transform output data (Payload → Better Auth field names)\n */\n function transformOutput<T>(doc: T): T {\n if (!doc || typeof doc !== 'object') return doc\n\n const result = { ...doc } as Record<string, unknown>\n\n if ('id' in result && result.id !== undefined) {\n result.id = String(result.id)\n }\n\n for (const [key, value] of Object.entries(result)) {\n if (value && typeof value === 'object' && 'id' in value) {\n result[`${key}Id`] = String((value as { id: unknown }).id)\n delete result[key]\n } else if (\n typeof value === 'string' &&\n /^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}/.test(value)\n ) {\n result[key] = new Date(value)\n }\n }\n\n return result as T\n }\n\n function convertId(id: string | number): string | number {\n if (idType === 'number' && typeof id === 'string') {\n const num = parseInt(id, 10)\n return isNaN(num) ? id : num\n }\n if (idType === 'text' && typeof id === 'number') {\n return String(id)\n }\n return id\n }\n\n /**\n * Handle join requests - fetch related data\n */\n async function handleJoins(\n payload: BasePayload,\n doc: Record<string, unknown>,\n model: string,\n join: Record<string, boolean | { limit?: number }>\n ): Promise<Record<string, unknown>> {\n const result = { ...doc }\n\n for (const [joinKey, joinConfig] of Object.entries(join)) {\n if (!joinConfig) continue\n\n const limit = typeof joinConfig === 'object' ? joinConfig.limit : undefined\n\n log('handleJoins', { model, joinKey, docId: doc.id })\n\n if (model === 'user' && joinKey === 'account') {\n const accounts = await payload.find({\n collection: getCollection('account'),\n where: { user: { equals: doc.id } },\n limit: limit ?? 100,\n depth: 0,\n })\n result[joinKey] = accounts.docs.map((a) => transformOutput(a))\n } else if (model === 'session' && joinKey === 'user') {\n const userId = doc.userId as string\n if (userId) {\n try {\n const user = await payload.findByID({\n collection: getCollection('user'),\n id: userId,\n depth: 0,\n })\n result[joinKey] = transformOutput(user)\n } catch {\n result[joinKey] = null\n }\n }\n } else if (model === 'account' && joinKey === 'user') {\n const userId = doc.userId as string\n if (userId) {\n try {\n const user = await payload.findByID({\n collection: getCollection('user'),\n id: userId,\n depth: 0,\n })\n result[joinKey] = transformOutput(user)\n } catch {\n result[joinKey] = null\n }\n }\n }\n // Extensibility: Add more join patterns here for plugins\n }\n\n return result\n }\n\n return (_options: BetterAuthOptions): Adapter => {\n log('Adapter initialized', { collections: finalCollections })\n\n return {\n id: 'payload-adapter',\n\n async create<T extends Record<string, unknown>, R = T>({\n model,\n data,\n }: {\n model: string\n data: Omit<T, 'id'>\n select?: string[]\n forceAllowId?: boolean\n }): Promise<R> {\n const payload = await resolvePayloadClient()\n const collection = getCollection(model)\n const transformedData = transformInput(data as Record<string, unknown>)\n\n log('create', { collection, data: transformedData })\n\n try {\n const result = await payload.create({\n collection,\n data: transformedData,\n depth: 0,\n })\n return transformOutput(result) as R\n } catch (error) {\n console.error('[payload-adapter] create failed:', {\n collection,\n model,\n error: error instanceof Error ? error.message : error,\n })\n throw error\n }\n },\n\n async findOne<T>({\n model,\n where,\n select: _select,\n join,\n }: {\n model: string\n where: Where[]\n select?: string[]\n join?: Record<string, boolean | { limit?: number }>\n }): Promise<T | null> {\n try {\n const payload = await resolvePayloadClient()\n const collection = getCollection(model)\n const payloadWhere = convertWhere(where)\n\n const id = extractSingleId(payloadWhere)\n if (id) {\n try {\n const result = await payload.findByID({\n collection,\n id: convertId(id),\n depth: 1,\n })\n let doc = transformOutput(result) as unknown as Record<\n string,\n unknown\n >\n if (join) {\n doc = await handleJoins(payload, doc, model, join)\n }\n return doc as unknown as T\n } catch (error) {\n if (\n error instanceof Error &&\n 'status' in error &&\n (error as Error & { status: number }).status === 404\n ) {\n return null\n }\n throw error\n }\n }\n\n const result = await payload.find({\n collection,\n where: payloadWhere,\n limit: 1,\n depth: 1,\n })\n\n let doc: Record<string, unknown> | null = result.docs[0]\n ? (transformOutput(result.docs[0]) as unknown as Record<\n string,\n unknown\n >)\n : null\n\n if (doc && join) {\n doc = await handleJoins(payload, doc, model, join)\n }\n\n return doc as unknown as T | null\n } catch (error) {\n console.error('[payload-adapter] findOne FAILED', {\n model,\n where,\n error,\n })\n throw error\n }\n },\n\n async findMany<T>({\n model,\n where,\n limit,\n offset,\n sortBy,\n }: {\n model: string\n where?: Where[]\n limit?: number\n sortBy?: { field: string; direction: 'asc' | 'desc' }\n offset?: number\n join?: Record<string, boolean | { limit?: number }>\n }): Promise<T[]> {\n const payload = await resolvePayloadClient()\n const collection = getCollection(model)\n const payloadWhere = convertWhere(where)\n\n const result = await payload.find({\n collection,\n where: payloadWhere,\n limit: limit ?? 100,\n page: offset ? Math.floor(offset / (limit ?? 100)) + 1 : 1,\n sort: sortBy\n ? `${sortBy.direction === 'desc' ? '-' : ''}${sortBy.field}`\n : undefined,\n depth: 1,\n })\n\n return result.docs.map((doc) => transformOutput(doc)) as T[]\n },\n\n async update<T>({\n model,\n where,\n update: data,\n }: {\n model: string\n where: Where[]\n update: Record<string, unknown>\n }): Promise<T | null> {\n const payload = await resolvePayloadClient()\n const collection = getCollection(model)\n const payloadWhere = convertWhere(where)\n const transformedData = transformInput(data)\n\n const id = extractSingleId(payloadWhere)\n if (id) {\n const result = await payload.update({\n collection,\n id: convertId(id),\n data: transformedData,\n depth: 1,\n })\n return transformOutput(result) as T\n }\n\n const result = await payload.update({\n collection,\n where: payloadWhere,\n data: transformedData,\n depth: 1,\n })\n\n return result.docs[0] ? (transformOutput(result.docs[0]) as T) : null\n },\n\n async updateMany({\n model,\n where,\n update: data,\n }: {\n model: string\n where: Where[]\n update: Record<string, unknown>\n }): Promise<number> {\n const payload = await resolvePayloadClient()\n const collection = getCollection(model)\n const payloadWhere = convertWhere(where)\n const transformedData = transformInput(data)\n\n const result = await payload.update({\n collection,\n where: payloadWhere,\n data: transformedData,\n depth: 0,\n })\n\n return result.docs.length\n },\n\n async delete({ model, where }: { model: string; where: Where[] }): Promise<void> {\n const payload = await resolvePayloadClient()\n const collection = getCollection(model)\n const payloadWhere = convertWhere(where)\n\n const id = extractSingleId(payloadWhere)\n if (id) {\n await payload.delete({ collection, id: convertId(id) })\n return\n }\n\n await payload.delete({ collection, where: payloadWhere })\n },\n\n async deleteMany({\n model,\n where,\n }: {\n model: string\n where: Where[]\n }): Promise<number> {\n const payload = await resolvePayloadClient()\n const collection = getCollection(model)\n const payloadWhere = convertWhere(where)\n\n const result = await payload.delete({\n collection,\n where: payloadWhere,\n })\n\n return result.docs.length\n },\n\n async count({\n model,\n where,\n }: {\n model: string\n where?: Where[]\n }): Promise<number> {\n const payload = await resolvePayloadClient()\n const collection = getCollection(model)\n const payloadWhere = convertWhere(where)\n\n const result = await payload.count({\n collection,\n where: payloadWhere,\n })\n\n return result.totalDocs\n },\n\n async transaction(callback) {\n return callback(this)\n },\n }\n }\n}\n\nexport type { Adapter, BetterAuthOptions }\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { createAuthClient } from 'better-auth/react';
|
package/dist/client.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { createAuthClient } from 'better-auth/react';
|
package/dist/client.js
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var react = require('better-auth/react');
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "createAuthClient", {
|
|
8
|
+
enumerable: true,
|
|
9
|
+
get: function () { return react.createAuthClient; }
|
|
10
|
+
});
|
|
11
|
+
//# sourceMappingURL=client.js.map
|
|
12
|
+
//# sourceMappingURL=client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":"","file":"client.js","sourcesContent":[]}
|
package/dist/client.mjs
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":"","file":"client.mjs","sourcesContent":[]}
|
package/dist/index.d.mts
ADDED
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
export { PayloadAdapterConfig, payloadAdapter } from './adapter/index.mjs';
|
|
2
|
+
import { CollectionConfig, Plugin, BasePayload } from 'payload';
|
|
3
|
+
import { BetterAuthOptions } from 'better-auth';
|
|
4
|
+
export { Auth, BetterAuthPluginOptions, BetterAuthStrategyOptions, CreateAuthFunction, PayloadWithAuth, betterAuthStrategy, createBetterAuthPlugin, resetAuthInstance } from './plugin/index.mjs';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Auto-generate Payload collections from Better Auth schema
|
|
8
|
+
*
|
|
9
|
+
* @packageDocumentation
|
|
10
|
+
*/
|
|
11
|
+
|
|
12
|
+
type BetterAuthCollectionsOptions = {
|
|
13
|
+
/**
|
|
14
|
+
* Better Auth options. Pass the same options you use for betterAuth().
|
|
15
|
+
* The plugin reads the schema to generate collections.
|
|
16
|
+
*/
|
|
17
|
+
betterAuthOptions?: BetterAuthOptions;
|
|
18
|
+
/**
|
|
19
|
+
* Override collection slugs (e.g., { user: 'users', session: 'sessions' })
|
|
20
|
+
*/
|
|
21
|
+
slugOverrides?: Record<string, string>;
|
|
22
|
+
/**
|
|
23
|
+
* Collections to skip (they already exist in your config)
|
|
24
|
+
* Default: ['user'] - assumes you have a Users collection
|
|
25
|
+
*/
|
|
26
|
+
skipCollections?: string[];
|
|
27
|
+
/**
|
|
28
|
+
* Admin group name for generated collections
|
|
29
|
+
* Default: 'Auth'
|
|
30
|
+
*/
|
|
31
|
+
adminGroup?: string;
|
|
32
|
+
/**
|
|
33
|
+
* Custom access control for generated collections.
|
|
34
|
+
* By default, only admins can read/delete, and create/update are disabled.
|
|
35
|
+
*/
|
|
36
|
+
access?: CollectionConfig['access'];
|
|
37
|
+
};
|
|
38
|
+
/**
|
|
39
|
+
* Payload plugin that auto-generates collections from Better Auth schema.
|
|
40
|
+
*
|
|
41
|
+
* @example
|
|
42
|
+
* ```ts
|
|
43
|
+
* import { betterAuthCollections } from '@delmare/payload-better-auth'
|
|
44
|
+
*
|
|
45
|
+
* export default buildConfig({
|
|
46
|
+
* plugins: [
|
|
47
|
+
* betterAuthCollections({
|
|
48
|
+
* betterAuthOptions: { ... },
|
|
49
|
+
* skipCollections: ['user'], // Define Users yourself
|
|
50
|
+
* }),
|
|
51
|
+
* ],
|
|
52
|
+
* })
|
|
53
|
+
* ```
|
|
54
|
+
*/
|
|
55
|
+
declare function betterAuthCollections(options?: BetterAuthCollectionsOptions): Plugin;
|
|
56
|
+
|
|
57
|
+
/**
|
|
58
|
+
* Server-side session utilities
|
|
59
|
+
*
|
|
60
|
+
* @packageDocumentation
|
|
61
|
+
*/
|
|
62
|
+
|
|
63
|
+
type Session = {
|
|
64
|
+
user: {
|
|
65
|
+
id: string;
|
|
66
|
+
email: string;
|
|
67
|
+
name?: string;
|
|
68
|
+
image?: string;
|
|
69
|
+
[key: string]: unknown;
|
|
70
|
+
};
|
|
71
|
+
session: {
|
|
72
|
+
id: string;
|
|
73
|
+
expiresAt: Date;
|
|
74
|
+
[key: string]: unknown;
|
|
75
|
+
};
|
|
76
|
+
};
|
|
77
|
+
/**
|
|
78
|
+
* Get the current session from headers.
|
|
79
|
+
*
|
|
80
|
+
* @example
|
|
81
|
+
* ```ts
|
|
82
|
+
* import { headers } from 'next/headers'
|
|
83
|
+
* import { getServerSession } from '@delmare/payload-better-auth'
|
|
84
|
+
*
|
|
85
|
+
* export default async function Page() {
|
|
86
|
+
* const headersList = await headers()
|
|
87
|
+
* const session = await getServerSession(payload, headersList)
|
|
88
|
+
*
|
|
89
|
+
* if (!session) {
|
|
90
|
+
* redirect('/login')
|
|
91
|
+
* }
|
|
92
|
+
*
|
|
93
|
+
* return <div>Hello {session.user.name}</div>
|
|
94
|
+
* }
|
|
95
|
+
* ```
|
|
96
|
+
*/
|
|
97
|
+
declare function getServerSession(payload: BasePayload, headers: Headers): Promise<Session | null>;
|
|
98
|
+
/**
|
|
99
|
+
* Get the current user from the session.
|
|
100
|
+
*
|
|
101
|
+
* @example
|
|
102
|
+
* ```ts
|
|
103
|
+
* import { headers } from 'next/headers'
|
|
104
|
+
* import { getServerUser } from '@delmare/payload-better-auth'
|
|
105
|
+
*
|
|
106
|
+
* export default async function Page() {
|
|
107
|
+
* const headersList = await headers()
|
|
108
|
+
* const user = await getServerUser(payload, headersList)
|
|
109
|
+
*
|
|
110
|
+
* if (!user) {
|
|
111
|
+
* redirect('/login')
|
|
112
|
+
* }
|
|
113
|
+
*
|
|
114
|
+
* return <div>Hello {user.name}</div>
|
|
115
|
+
* }
|
|
116
|
+
* ```
|
|
117
|
+
*/
|
|
118
|
+
declare function getServerUser(payload: BasePayload, headers: Headers): Promise<Session['user'] | null>;
|
|
119
|
+
|
|
120
|
+
export { type BetterAuthCollectionsOptions, type Session, betterAuthCollections, getServerSession, getServerUser };
|