opacacms 0.1.21 → 0.2.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/README.md +792 -50
- package/dist/admin/auth-client.d.ts +39 -39
- package/dist/admin/index.js +2360 -1392
- package/dist/admin/react.d.ts +1 -1
- package/dist/admin/react.js +8 -0
- package/dist/admin/router.d.ts +1 -0
- package/dist/admin/stores/ui.d.ts +10 -0
- package/dist/admin/ui/admin-layout.d.ts +4 -4
- package/dist/admin/ui/components/DataDetailView.d.ts +1 -1
- package/dist/admin/ui/components/DetailSheet.d.ts +19 -0
- package/dist/admin/ui/components/PluginSettingsForm.d.ts +11 -0
- package/dist/admin/ui/components/fields/BooleanField.d.ts +2 -1
- package/dist/admin/ui/components/fields/DateField.d.ts +1 -1
- package/dist/admin/ui/components/fields/FieldLabel.d.ts +11 -0
- package/dist/admin/ui/components/fields/FileField.d.ts +1 -1
- package/dist/admin/ui/components/fields/NumberField.d.ts +1 -1
- package/dist/admin/ui/components/fields/RadioField.d.ts +1 -1
- package/dist/admin/ui/components/fields/RelationshipField.d.ts +3 -1
- package/dist/admin/ui/components/fields/SelectField.d.ts +1 -1
- package/dist/admin/ui/components/fields/TextAreaField.d.ts +1 -1
- package/dist/admin/ui/components/fields/TextField.d.ts +1 -1
- package/dist/admin/ui/components/fields/VirtualField.d.ts +1 -0
- package/dist/admin/ui/components/fields/index.d.ts +16 -16
- package/dist/admin/ui/components/fields/richtext-editor/index.d.ts +1 -1
- package/dist/admin/ui/components/media/AssetManagerModal.d.ts +1 -1
- package/dist/admin/ui/components/toast.d.ts +1 -1
- package/dist/admin/ui/components/ui/accordion.d.ts +1 -1
- package/dist/admin/ui/components/ui/button.d.ts +1 -1
- package/dist/admin/ui/components/ui/collapsible.d.ts +1 -1
- package/dist/admin/ui/components/ui/dialog.d.ts +1 -1
- package/dist/admin/ui/components/ui/group.d.ts +1 -1
- package/dist/admin/ui/components/ui/index.d.ts +17 -17
- package/dist/admin/ui/components/ui/input.d.ts +1 -1
- package/dist/admin/ui/components/ui/label.d.ts +1 -1
- package/dist/admin/ui/components/ui/radio-group.d.ts +1 -1
- package/dist/admin/ui/components/ui/relationship.d.ts +4 -4
- package/dist/admin/ui/components/ui/select.d.ts +1 -1
- package/dist/admin/ui/components/ui/sheet.d.ts +1 -1
- package/dist/admin/ui/components/ui/tabs.d.ts +1 -1
- package/dist/admin/ui/components/versions-sheet.d.ts +11 -0
- package/dist/admin/ui/views/media-registry-view.d.ts +1 -1
- package/dist/admin/ui/views/settings-view.d.ts +2 -2
- package/dist/admin/vue.js +8 -0
- package/dist/admin/webcomponent.js +2 -2
- package/dist/admin.css +1 -1
- package/dist/auth/index.d.ts +101 -41
- package/dist/{chunk-0sdceeys.js → chunk-0bq155dy.js} +86 -6
- package/dist/{chunk-59sg3pw9.js → chunk-0gtxnxmd.js} +90 -7
- package/dist/{chunk-v521d72w.js → chunk-3rdhbedb.js} +1 -1
- package/dist/chunk-51z3x7kq.js +20 -0
- package/dist/{chunk-7fyepksb.js → chunk-526a3gqx.js} +1 -1
- package/dist/{chunk-wmvjvn7b.js → chunk-6qq3ne6b.js} +39 -1
- package/dist/{chunk-0am1m47g.js → chunk-6v1fw7q7.js} +5 -5
- package/dist/{chunk-t9v845m2.js → chunk-7y1nbmw6.js} +34 -3
- package/dist/chunk-8scgdznr.js +44 -0
- package/dist/{chunk-mycmsjd9.js → chunk-b3kr8w41.js} +57 -6
- package/dist/chunk-bexcv7xe.js +36 -0
- package/dist/{chunk-16vgcf3k.js → chunk-byq8g0rd.js} +1 -1
- package/dist/{chunk-fqastxq9.js → chunk-d1asgtke.js} +86 -6
- package/dist/{chunk-cpw2y3pn.js → chunk-dykn5hr6.js} +7 -7
- package/dist/{chunk-61kwqve4.js → chunk-esrg9qj0.js} +90 -9
- package/dist/chunk-fj19qccp.js +78 -0
- package/dist/{chunk-ekxkvqjm.js → chunk-gmee4mdc.js} +90 -9
- package/dist/{chunk-xa7rjsn2.js → chunk-j53pz21t.js} +2 -2
- package/dist/{chunk-xrfhhz85.js → chunk-kc4jfnv7.js} +480 -85
- package/dist/chunk-mkn49zmy.js +102 -0
- package/dist/{chunk-n1xraw7j.js → chunk-qb6ztvw9.js} +1 -1
- package/dist/{chunk-2kyhqvhc.js → chunk-qxt9vge8.js} +1 -1
- package/dist/chunk-r39em4yj.js +29 -0
- package/dist/chunk-rqyjjqgy.js +91 -0
- package/dist/chunk-rsf0tpy1.js +8 -0
- package/dist/chunk-swtcpvhf.js +2442 -0
- package/dist/chunk-t0zg026p.js +71 -0
- package/dist/chunk-twpvxfce.js +64 -0
- package/dist/{chunk-ybbbqj63.js → chunk-v9z61v3g.js} +15 -0
- package/dist/{chunk-jwjk85ze.js → chunk-ywm4t2gm.js} +6 -2
- package/dist/cli/commands/plugin-build.d.ts +1 -0
- package/dist/cli/commands/plugin-init.d.ts +1 -0
- package/dist/cli/commands/plugin-sync.d.ts +1 -0
- package/dist/cli/index.js +24 -6
- package/dist/config-utils.d.ts +1 -1
- package/dist/config.d.ts +21 -4
- package/dist/db/better-sqlite.d.ts +1 -1
- package/dist/db/better-sqlite.js +5 -5
- package/dist/db/bun-sqlite.d.ts +1 -1
- package/dist/db/bun-sqlite.js +5 -5
- package/dist/db/d1.d.ts +1 -1
- package/dist/db/d1.js +5 -5
- package/dist/db/index.js +9 -9
- package/dist/db/postgres.d.ts +1 -1
- package/dist/db/postgres.js +5 -5
- package/dist/db/sqlite.d.ts +1 -1
- package/dist/db/sqlite.js +5 -5
- package/dist/index.js +4 -3
- package/dist/plugins/index.d.ts +1 -0
- package/dist/plugins/ui-bridge.d.ts +12 -0
- package/dist/plugins/utils.d.ts +5 -0
- package/dist/runtimes/bun.js +13 -7
- package/dist/runtimes/cloudflare-workers.js +5 -5
- package/dist/runtimes/next.js +5 -5
- package/dist/runtimes/node.js +13 -7
- package/dist/schema/collection.d.ts +9 -26
- package/dist/schema/fields/base.d.ts +3 -2
- package/dist/schema/fields/index.d.ts +12 -0
- package/dist/schema/fields/validation.test.d.ts +1 -0
- package/dist/schema/global.d.ts +10 -7
- package/dist/schema/index.js +22 -6
- package/dist/server/admin-router.d.ts +2 -2
- package/dist/server/admin.d.ts +2 -1
- package/dist/server/collection-router.d.ts +1 -1
- package/dist/server/handlers.d.ts +10 -0
- package/dist/server/middlewares/admin.d.ts +2 -2
- package/dist/server/middlewares/auth.d.ts +1 -1
- package/dist/server/middlewares/context.d.ts +2 -0
- package/dist/server/middlewares/rate-limit.d.ts +1 -1
- package/dist/server/openapi.d.ts +2 -0
- package/dist/server/plugins-loader.d.ts +6 -0
- package/dist/server/router.d.ts +3 -3
- package/dist/server/routers/admin.d.ts +2 -2
- package/dist/server/routers/auth.d.ts +1 -1
- package/dist/server/routers/collections.d.ts +1 -1
- package/dist/server/routers/plugins.d.ts +18 -0
- package/dist/server/setup-middlewares.d.ts +2 -2
- package/dist/server/system-router.d.ts +1 -1
- package/dist/server.js +11 -7
- package/dist/storage/adapters/local.d.ts +1 -1
- package/dist/storage/adapters/s3.d.ts +1 -1
- package/dist/types.d.ts +222 -15
- package/dist/utils/logger.d.ts +13 -35
- package/dist/validation.d.ts +40 -0
- package/dist/validator.d.ts +1 -1
- package/package.json +21 -7
- package/dist/admin/ui/components/DataDetailSheet.d.ts +0 -13
- package/dist/admin/ui/components/ui/relationship-detail-sheet.d.ts +0 -9
- package/dist/chunk-62ev8gnc.js +0 -41
- package/dist/chunk-j4d50hrx.js +0 -20
- package/dist/chunk-nb7ctdg8.js +0 -311
package/dist/chunk-nb7ctdg8.js
DELETED
|
@@ -1,311 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
__require
|
|
3
|
-
} from "./chunk-8sqjbsgt.js";
|
|
4
|
-
|
|
5
|
-
// src/cli/seeding.ts
|
|
6
|
-
import { faker } from "@faker-js/faker";
|
|
7
|
-
var defaultFieldGenerators = {
|
|
8
|
-
text: () => faker.lorem.words(3),
|
|
9
|
-
textarea: () => faker.lorem.paragraph(),
|
|
10
|
-
number: () => faker.number.int({ min: 1, max: 1000 }),
|
|
11
|
-
richtext: () => JSON.stringify({
|
|
12
|
-
root: {
|
|
13
|
-
children: [
|
|
14
|
-
{
|
|
15
|
-
children: [
|
|
16
|
-
{
|
|
17
|
-
detail: 0,
|
|
18
|
-
format: 0,
|
|
19
|
-
mode: "normal",
|
|
20
|
-
style: "",
|
|
21
|
-
text: faker.lorem.sentence(),
|
|
22
|
-
type: "text",
|
|
23
|
-
version: 1
|
|
24
|
-
}
|
|
25
|
-
],
|
|
26
|
-
direction: "ltr",
|
|
27
|
-
format: "",
|
|
28
|
-
indent: 0,
|
|
29
|
-
type: "heading",
|
|
30
|
-
tag: "h1",
|
|
31
|
-
version: 1
|
|
32
|
-
},
|
|
33
|
-
{
|
|
34
|
-
children: [
|
|
35
|
-
{
|
|
36
|
-
detail: 0,
|
|
37
|
-
format: 0,
|
|
38
|
-
mode: "normal",
|
|
39
|
-
style: "",
|
|
40
|
-
text: faker.lorem.paragraphs(2),
|
|
41
|
-
type: "text",
|
|
42
|
-
version: 1
|
|
43
|
-
}
|
|
44
|
-
],
|
|
45
|
-
direction: "ltr",
|
|
46
|
-
format: "",
|
|
47
|
-
indent: 0,
|
|
48
|
-
type: "paragraph",
|
|
49
|
-
version: 1
|
|
50
|
-
}
|
|
51
|
-
],
|
|
52
|
-
direction: "ltr",
|
|
53
|
-
format: "",
|
|
54
|
-
indent: 0,
|
|
55
|
-
type: "root",
|
|
56
|
-
version: 1
|
|
57
|
-
}
|
|
58
|
-
}),
|
|
59
|
-
boolean: () => faker.datatype.boolean(),
|
|
60
|
-
date: () => faker.date.recent().toISOString(),
|
|
61
|
-
email: () => faker.internet.email(),
|
|
62
|
-
json: () => ({ [faker.lorem.word()]: faker.lorem.sentence() }),
|
|
63
|
-
select: () => faker.lorem.word(),
|
|
64
|
-
radio: () => faker.lorem.word(),
|
|
65
|
-
blocks: () => []
|
|
66
|
-
};
|
|
67
|
-
async function getRandomIds(db, relationTo, count = 1) {
|
|
68
|
-
try {
|
|
69
|
-
const result = await db.find(relationTo, {}, { limit: 50 });
|
|
70
|
-
const docs = result.docs || [];
|
|
71
|
-
if (docs.length === 0) {
|
|
72
|
-
if (!relationTo.startsWith("_")) {
|
|
73
|
-
console.warn(`[Seeding] No documents found in '${relationTo}' for relationship.`);
|
|
74
|
-
}
|
|
75
|
-
return [];
|
|
76
|
-
}
|
|
77
|
-
const shuffled = [...docs].sort(() => 0.5 - Math.random());
|
|
78
|
-
const selected = shuffled.slice(0, count).map((doc) => doc.id);
|
|
79
|
-
return selected;
|
|
80
|
-
} catch (e) {
|
|
81
|
-
console.error(`[Seeding] Failed to fetch random IDs for ${relationTo}:`, e);
|
|
82
|
-
return [];
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
async function generateDataForFields(fields, db, locales = []) {
|
|
86
|
-
const record = {};
|
|
87
|
-
for (const field of fields) {
|
|
88
|
-
if (field.type === "row" || field.type === "collapsible") {
|
|
89
|
-
Object.assign(record, await generateDataForFields(field.fields, db, locales));
|
|
90
|
-
continue;
|
|
91
|
-
}
|
|
92
|
-
if (field.type === "tabs") {
|
|
93
|
-
for (const tab of field.tabs) {
|
|
94
|
-
Object.assign(record, await generateDataForFields(tab.fields, db, locales));
|
|
95
|
-
}
|
|
96
|
-
continue;
|
|
97
|
-
}
|
|
98
|
-
if (field.type === "group" && field.name) {
|
|
99
|
-
record[field.name] = await generateDataForFields(field.fields, db, locales);
|
|
100
|
-
continue;
|
|
101
|
-
}
|
|
102
|
-
if (field.name) {
|
|
103
|
-
const isLocalized = !!field.localized && locales.length > 0;
|
|
104
|
-
const generateFieldValue = async () => {
|
|
105
|
-
if (field.type === "relationship" && "relationTo" in field) {
|
|
106
|
-
if (field.hasMany) {
|
|
107
|
-
const count = faker.number.int({ min: 1, max: 3 });
|
|
108
|
-
return await getRandomIds(db, field.relationTo, count);
|
|
109
|
-
}
|
|
110
|
-
const ids = await getRandomIds(db, field.relationTo, 1);
|
|
111
|
-
return ids[0] || null;
|
|
112
|
-
}
|
|
113
|
-
if (field.type === "blocks" && field.blocks) {
|
|
114
|
-
const blockCount = faker.number.int({ min: 1, max: 3 });
|
|
115
|
-
const generatedBlocks = [];
|
|
116
|
-
for (let i = 0;i < blockCount; i++) {
|
|
117
|
-
const blockType = field.blocks[faker.number.int({ min: 0, max: field.blocks.length - 1 })];
|
|
118
|
-
if (!blockType)
|
|
119
|
-
continue;
|
|
120
|
-
const blockData = await generateDataForFields(blockType.fields, db, locales);
|
|
121
|
-
generatedBlocks.push({
|
|
122
|
-
...blockData,
|
|
123
|
-
blockType: blockType.slug,
|
|
124
|
-
id: faker.string.uuid()
|
|
125
|
-
});
|
|
126
|
-
}
|
|
127
|
-
return generatedBlocks;
|
|
128
|
-
}
|
|
129
|
-
const generator = defaultFieldGenerators[field.type];
|
|
130
|
-
if (generator) {
|
|
131
|
-
if (field.type === "select" || field.type === "radio") {
|
|
132
|
-
const options = field.options;
|
|
133
|
-
const choices = options?.choices || [];
|
|
134
|
-
if (choices.length > 0) {
|
|
135
|
-
const choice = choices[Math.floor(Math.random() * choices.length)];
|
|
136
|
-
return typeof choice === "string" ? choice : choice.value;
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
return generator();
|
|
140
|
-
}
|
|
141
|
-
return null;
|
|
142
|
-
};
|
|
143
|
-
if (isLocalized) {
|
|
144
|
-
const localizedValue = {};
|
|
145
|
-
for (const locale of locales) {
|
|
146
|
-
localizedValue[locale] = await generateFieldValue();
|
|
147
|
-
}
|
|
148
|
-
record[field.name] = localizedValue;
|
|
149
|
-
} else {
|
|
150
|
-
record[field.name] = await generateFieldValue();
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
|
-
return record;
|
|
155
|
-
}
|
|
156
|
-
async function generateRecord(db, collection, locales = []) {
|
|
157
|
-
return generateDataForFields(collection.fields, db, locales);
|
|
158
|
-
}
|
|
159
|
-
function sortCollections(collections) {
|
|
160
|
-
const sorted = [];
|
|
161
|
-
const visited = new Set;
|
|
162
|
-
const visiting = new Set;
|
|
163
|
-
const visit = (collection) => {
|
|
164
|
-
if (visited.has(collection.slug))
|
|
165
|
-
return;
|
|
166
|
-
if (visiting.has(collection.slug)) {
|
|
167
|
-
throw new Error(`Circular dependency detected: ${collection.slug}`);
|
|
168
|
-
}
|
|
169
|
-
visiting.add(collection.slug);
|
|
170
|
-
const deps = [];
|
|
171
|
-
const findDeps = (fields) => {
|
|
172
|
-
for (const f of fields) {
|
|
173
|
-
if (f.type === "relationship") {
|
|
174
|
-
deps.push(f.relationTo);
|
|
175
|
-
} else if (f.type === "blocks" && f.blocks) {
|
|
176
|
-
for (const b of f.blocks) {
|
|
177
|
-
findDeps(b.fields);
|
|
178
|
-
}
|
|
179
|
-
} else if ("fields" in f && f.fields) {
|
|
180
|
-
findDeps(f.fields);
|
|
181
|
-
} else if ("tabs" in f && f.tabs) {
|
|
182
|
-
for (const t of f.tabs) {
|
|
183
|
-
findDeps(t.fields);
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
};
|
|
188
|
-
findDeps(collection.fields);
|
|
189
|
-
for (const depSlug of deps) {
|
|
190
|
-
const depColl = collections.find((c) => c.slug === depSlug);
|
|
191
|
-
if (depColl)
|
|
192
|
-
visit(depColl);
|
|
193
|
-
}
|
|
194
|
-
visiting.delete(collection.slug);
|
|
195
|
-
visited.add(collection.slug);
|
|
196
|
-
sorted.push(collection);
|
|
197
|
-
};
|
|
198
|
-
for (const collection of collections) {
|
|
199
|
-
visit(collection);
|
|
200
|
-
}
|
|
201
|
-
return sorted;
|
|
202
|
-
}
|
|
203
|
-
async function autoSeed(config, countPerCollection = 10, reset = false, type = "all") {
|
|
204
|
-
const { collections, db, globals, storages, serverURL } = config;
|
|
205
|
-
console.log(`\uD83C\uDF31 Starting automatic seed (${countPerCollection} records per collection)...`);
|
|
206
|
-
const { getSystemCollections } = await import("./chunk-v521d72w.js");
|
|
207
|
-
const systemCollections = getSystemCollections().filter((c) => c.slug === "_opaca_assets");
|
|
208
|
-
const allCollections = [...systemCollections, ...collections];
|
|
209
|
-
let collectionsToSeed = sortCollections(allCollections);
|
|
210
|
-
if (type === "assets") {
|
|
211
|
-
collectionsToSeed = collectionsToSeed.filter((c) => c.slug === "_opaca_assets");
|
|
212
|
-
console.log("\uD83D\uDCC1 Seeding only assets...");
|
|
213
|
-
} else if (type === "collections") {
|
|
214
|
-
collectionsToSeed = collectionsToSeed.filter((c) => c.slug !== "_opaca_assets");
|
|
215
|
-
console.log("\uD83D\uDCDA Seeding only user collections...");
|
|
216
|
-
}
|
|
217
|
-
await db.connect();
|
|
218
|
-
await db.migrate(allCollections, globals || []);
|
|
219
|
-
try {
|
|
220
|
-
if (reset) {
|
|
221
|
-
console.log("\uD83E\uDDF9 Resetting data (deleting existing records)...");
|
|
222
|
-
const reversed = [...collectionsToSeed].reverse();
|
|
223
|
-
for (const collection of reversed) {
|
|
224
|
-
console.log(`Cleaning ${collection.slug}...`);
|
|
225
|
-
await db.deleteMany?.(collection.slug, {});
|
|
226
|
-
}
|
|
227
|
-
}
|
|
228
|
-
const storageAdapter = storages?.default || storages;
|
|
229
|
-
const locales = config.i18n?.locales || [];
|
|
230
|
-
for (const collection of collectionsToSeed) {
|
|
231
|
-
console.log(`Seeding ${collection.slug}...`);
|
|
232
|
-
const isAssetCollection = collection.slug === "_opaca_assets";
|
|
233
|
-
for (let i = 0;i < countPerCollection; i++) {
|
|
234
|
-
let data;
|
|
235
|
-
if (isAssetCollection) {
|
|
236
|
-
const id = faker.string.uuid();
|
|
237
|
-
const width = faker.number.int({ min: 400, max: 1200 });
|
|
238
|
-
const height = faker.number.int({ min: 300, max: 800 });
|
|
239
|
-
const color = faker.color.rgb({ prefix: "" });
|
|
240
|
-
const textColor = faker.color.rgb({ prefix: "" });
|
|
241
|
-
const usePicsum = Math.random() > 0.5;
|
|
242
|
-
let imageUrl = "";
|
|
243
|
-
if (usePicsum) {
|
|
244
|
-
const categories = ["nature", "city", "tech", "people", "animals", "architecture"];
|
|
245
|
-
const category = faker.helpers.arrayElement(categories);
|
|
246
|
-
imageUrl = `https://picsum.photos/seed/${category}-${id}/${width}/${height}`;
|
|
247
|
-
} else {
|
|
248
|
-
imageUrl = `https://placehold.co/${width}x${height}/${color}/${textColor}.png?text=Seed+${i}`;
|
|
249
|
-
}
|
|
250
|
-
const res = await fetch(imageUrl);
|
|
251
|
-
if (!res.ok) {
|
|
252
|
-
throw new Error(`Failed to fetch placeholder image: ${imageUrl}`);
|
|
253
|
-
}
|
|
254
|
-
const arrayBuffer = await res.arrayBuffer();
|
|
255
|
-
const mime_type = res.headers.get("content-type")?.split(";")[0] || "image/png";
|
|
256
|
-
const extMap = {
|
|
257
|
-
"image/jpeg": "jpg",
|
|
258
|
-
"image/png": "png",
|
|
259
|
-
"image/webp": "webp",
|
|
260
|
-
"image/gif": "gif",
|
|
261
|
-
"image/svg+xml": "svg"
|
|
262
|
-
};
|
|
263
|
-
const ext = extMap[mime_type] || "png";
|
|
264
|
-
const fileRecord = {
|
|
265
|
-
filename: `seed-image-${i}.${ext}`,
|
|
266
|
-
original_filename: `seed-image-${i}.${ext}`,
|
|
267
|
-
mime_type,
|
|
268
|
-
filesize: arrayBuffer.byteLength,
|
|
269
|
-
buffer: new Uint8Array(arrayBuffer)
|
|
270
|
-
};
|
|
271
|
-
if (!storageAdapter || typeof storageAdapter.upload !== "function") {
|
|
272
|
-
throw new Error("Storage adapter is required for seeding assets and must have an 'upload' method.");
|
|
273
|
-
}
|
|
274
|
-
const uploaded = await storageAdapter.upload(fileRecord, {
|
|
275
|
-
generateUniqueName: true,
|
|
276
|
-
customMetadata: {
|
|
277
|
-
sourceUrl: imageUrl
|
|
278
|
-
}
|
|
279
|
-
});
|
|
280
|
-
data = {
|
|
281
|
-
id,
|
|
282
|
-
key: uploaded.filename,
|
|
283
|
-
filename: uploaded.filename,
|
|
284
|
-
originalFilename: fileRecord.original_filename,
|
|
285
|
-
mimeType: uploaded.mime_type,
|
|
286
|
-
filesize: uploaded.filesize,
|
|
287
|
-
width,
|
|
288
|
-
height,
|
|
289
|
-
bucket: "default",
|
|
290
|
-
url: uploaded.url,
|
|
291
|
-
thumbnailUrl: uploaded.url,
|
|
292
|
-
altText: faker.lorem.sentence()
|
|
293
|
-
};
|
|
294
|
-
const baseURL = serverURL || "http://localhost:8787";
|
|
295
|
-
console.log(`[Asset] Source: ${imageUrl}`);
|
|
296
|
-
console.log(`[Asset] Seeded: ${baseURL}/api/assets/${id}/view (${uploaded.filename})`);
|
|
297
|
-
} else {
|
|
298
|
-
data = await generateRecord(db, collection, locales);
|
|
299
|
-
}
|
|
300
|
-
await db.create(collection.slug, data);
|
|
301
|
-
}
|
|
302
|
-
}
|
|
303
|
-
console.log("✅ Seeding completed.");
|
|
304
|
-
} finally {}
|
|
305
|
-
}
|
|
306
|
-
export {
|
|
307
|
-
sortCollections,
|
|
308
|
-
generateRecord,
|
|
309
|
-
defaultFieldGenerators,
|
|
310
|
-
autoSeed
|
|
311
|
-
};
|