@strapi/strapi 5.47.0 → 5.47.1

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.
@@ -1,15 +1,26 @@
1
- import * as tsUtils from '@strapi/typescript-utils';
2
- import { strings } from '@strapi/utils';
3
- import chokidar from 'chokidar';
4
1
  import fs from 'node:fs/promises';
5
2
  import path from 'node:path';
6
3
  import cluster from 'node:cluster';
7
- import { createStrapi } from '@strapi/core';
8
4
  import { checkRequiredDependencies } from './core/dependencies.mjs';
9
5
  import { prettyTime, getTimer } from './core/timer.mjs';
10
- import { createBuildContext } from './create-build-context.mjs';
11
- import { writeStaticClientFiles } from './staticFiles.mjs';
12
6
 
7
+ // Lazy: worker-only deps; primary cluster process should not pay for them
8
+ const lazy = (spec)=>{
9
+ let cached;
10
+ return ()=>{
11
+ if (cached === undefined) {
12
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
13
+ cached = require(spec);
14
+ }
15
+ return cached;
16
+ };
17
+ };
18
+ const tsUtils = lazy('@strapi/typescript-utils');
19
+ const utils = lazy('@strapi/utils');
20
+ const chokidar = lazy('chokidar');
21
+ const core = lazy('@strapi/core');
22
+ const buildCtx = lazy('./create-build-context');
23
+ const staticFs = lazy('./staticFiles');
13
24
  // This method removes all non-admin build files from the dist directory
14
25
  const cleanupDistDirectory = async ({ tsconfig, logger, timer })=>{
15
26
  const distDir = tsconfig?.config?.options?.outDir;
@@ -23,8 +34,8 @@ const cleanupDistDirectory = async ({ tsconfig, logger, timer })=>{
23
34
  const cleaningSpinner = logger.spinner(`Cleaning dist dir ${distDir}`).start();
24
35
  try {
25
36
  const dirContent = await fs.readdir(distDir);
26
- const validFilenames = dirContent// Ignore the admin build folder
27
- .filter((filename)=>filename !== 'build');
37
+ const validFilenames = dirContent// Ignore the admin build folder and the TypeScript incremental cache
38
+ .filter((filename)=>filename !== 'build' && !filename.endsWith('.tsbuildinfo'));
28
39
  for (const filename of validFilenames){
29
40
  await fs.rm(path.resolve(distDir, filename), {
30
41
  recursive: true
@@ -61,7 +72,7 @@ const develop = async ({ cwd, polling, logger, tsconfig, watchAdmin, buildAdmin,
61
72
  timer
62
73
  });
63
74
  try {
64
- await tsUtils.compile(cwd, {
75
+ await tsUtils().compile(cwd, {
65
76
  configOptions: {
66
77
  ignoreDiagnostics: true
67
78
  }
@@ -79,7 +90,7 @@ const develop = async ({ cwd, polling, logger, tsconfig, watchAdmin, buildAdmin,
79
90
  timer.start('createBuildContext');
80
91
  const contextSpinner = logger.spinner(`Building build context`).start();
81
92
  console.log('');
82
- const ctx = await createBuildContext({
93
+ const ctx = await buildCtx().createBuildContext({
83
94
  cwd,
84
95
  logger,
85
96
  tsconfig,
@@ -90,7 +101,7 @@ const develop = async ({ cwd, polling, logger, tsconfig, watchAdmin, buildAdmin,
90
101
  contextSpinner.succeed();
91
102
  timer.start('creatingAdmin');
92
103
  const adminSpinner = logger.spinner(`Creating admin`).start();
93
- await writeStaticClientFiles(ctx);
104
+ await staticFs().writeStaticClientFiles(ctx);
94
105
  if (ctx.bundler === 'webpack') {
95
106
  const { build: buildWebpack } = await import('./webpack/build.mjs');
96
107
  await buildWebpack(ctx);
@@ -114,7 +125,7 @@ const develop = async ({ cwd, polling, logger, tsconfig, watchAdmin, buildAdmin,
114
125
  logger,
115
126
  timer
116
127
  });
117
- await tsUtils.compile(cwd, {
128
+ await tsUtils().compile(cwd, {
118
129
  configOptions: {
119
130
  ignoreDiagnostics: true
120
131
  }
@@ -147,7 +158,7 @@ const develop = async ({ cwd, polling, logger, tsconfig, watchAdmin, buildAdmin,
147
158
  if (cluster.isWorker) {
148
159
  timer.start('loadStrapi');
149
160
  const loadStrapiSpinner = logger.spinner(`Loading Strapi`).start();
150
- const strapi = createStrapi({
161
+ const strapi = core().createStrapi({
151
162
  appDir: cwd,
152
163
  distDir: tsconfig?.config.options.outDir ?? '',
153
164
  autoReload: true,
@@ -173,7 +184,7 @@ const develop = async ({ cwd, polling, logger, tsconfig, watchAdmin, buildAdmin,
173
184
  if (watchAdmin) {
174
185
  timer.start('createBuildContext');
175
186
  contextSpinner.start();
176
- const ctx = await createBuildContext({
187
+ const ctx = await buildCtx().createBuildContext({
177
188
  cwd,
178
189
  logger,
179
190
  strapi,
@@ -185,7 +196,7 @@ const develop = async ({ cwd, polling, logger, tsconfig, watchAdmin, buildAdmin,
185
196
  contextSpinner.succeed();
186
197
  timer.start('creatingAdmin');
187
198
  adminSpinner.start();
188
- await writeStaticClientFiles(ctx);
199
+ await staticFs().writeStaticClientFiles(ctx);
189
200
  if (ctx.bundler === 'webpack') {
190
201
  const { watch: watchWebpack } = await import('./webpack/watch.mjs');
191
202
  bundleWatcher = await watchWebpack(ctx);
@@ -205,7 +216,7 @@ const develop = async ({ cwd, polling, logger, tsconfig, watchAdmin, buildAdmin,
205
216
  if (tsconfig?.config || strapi.config.get('typescript.autogenerate') !== false) {
206
217
  timer.start('generatingTS');
207
218
  generatingTsSpinner.start();
208
- await tsUtils.generators.generate({
219
+ await tsUtils().generators.generate({
209
220
  strapi: strapiInstance,
210
221
  pwd: cwd,
211
222
  rootDir: undefined,
@@ -230,7 +241,7 @@ const develop = async ({ cwd, polling, logger, tsconfig, watchAdmin, buildAdmin,
230
241
  logger,
231
242
  timer
232
243
  });
233
- await tsUtils.compile(cwd, {
244
+ await tsUtils().compile(cwd, {
234
245
  configOptions: {
235
246
  ignoreDiagnostics: false
236
247
  }
@@ -271,7 +282,7 @@ function startWatcher(strapiInstance, cwd, polling, logger, bundleWatcher) {
271
282
  strapiInstance.reload();
272
283
  }
273
284
  };
274
- const watcher = chokidar.watch(cwd, {
285
+ const watcher = chokidar().watch(cwd, {
275
286
  ignoreInitial: true,
276
287
  usePolling: polling,
277
288
  ignored: [
@@ -296,7 +307,7 @@ function startWatcher(strapiInstance, cwd, polling, logger, bundleWatcher) {
296
307
  '**/public',
297
308
  '**/public/**',
298
309
  strapiInstance.dirs.static.public,
299
- strings.joinBy('/', strapiInstance.dirs.static.public, '**'),
310
+ utils().strings.joinBy('/', strapiInstance.dirs.static.public, '**'),
300
311
  '**/*.db*',
301
312
  '**/exports/**',
302
313
  '**/dist/**',
@@ -1 +1 @@
1
- {"version":3,"file":"develop.mjs","sources":["../../../src/node/develop.ts"],"sourcesContent":["import * as tsUtils from '@strapi/typescript-utils';\nimport { strings } from '@strapi/utils';\nimport chokidar from 'chokidar';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport cluster from 'node:cluster';\nimport { createStrapi } from '@strapi/core';\n\nimport type { CLIContext } from '../cli/types';\nimport { checkRequiredDependencies } from './core/dependencies';\nimport { getTimer, prettyTime, type TimeMeasurer } from './core/timer';\nimport { createBuildContext } from './create-build-context';\nimport type { WebpackWatcher } from './webpack/watch';\nimport type { ViteWatcher } from './vite/watch';\n\nimport { writeStaticClientFiles } from './staticFiles';\nimport { Logger } from '../cli/utils/logger';\n\ninterface DevelopOptions extends CLIContext {\n /**\n * Which bundler to use for building.\n *\n * @default webpack\n */\n bundler?: 'webpack' | 'vite';\n polling?: boolean;\n open?: boolean;\n watchAdmin?: boolean;\n buildAdmin?: boolean;\n}\n\n// This method removes all non-admin build files from the dist directory\nconst cleanupDistDirectory = async ({\n tsconfig,\n logger,\n timer,\n}: Pick<DevelopOptions, 'tsconfig' | 'logger'> & { timer: TimeMeasurer }) => {\n const distDir = tsconfig?.config?.options?.outDir;\n\n if (\n !distDir || // we don't have a dist dir\n (await fs\n .access(distDir)\n .then(() => false)\n .catch(() => true)) // it doesn't exist -- if it does but no access, that will be caught later\n ) {\n return;\n }\n\n const timerName = `cleaningDist${Date.now()}`;\n timer.start(timerName);\n const cleaningSpinner = logger.spinner(`Cleaning dist dir ${distDir}`).start();\n\n try {\n const dirContent = await fs.readdir(distDir);\n const validFilenames = dirContent\n // Ignore the admin build folder\n .filter((filename) => filename !== 'build');\n for (const filename of validFilenames) {\n await fs.rm(path.resolve(distDir, filename), { recursive: true });\n }\n } catch (err: unknown) {\n const generatingDuration = timer.end(timerName);\n cleaningSpinner.text = `Error cleaning dist dir: ${err} (${prettyTime(generatingDuration)})`;\n cleaningSpinner?.fail();\n return;\n }\n\n const generatingDuration = timer.end(timerName);\n cleaningSpinner.text = `Cleaning dist dir (${prettyTime(generatingDuration)})`;\n cleaningSpinner?.succeed();\n};\n\nconst develop = async ({\n cwd,\n polling,\n logger,\n tsconfig,\n watchAdmin,\n buildAdmin,\n ...options\n}: DevelopOptions) => {\n const timer = getTimer();\n\n if (cluster.isPrimary) {\n const { didInstall } = await checkRequiredDependencies({ cwd, logger }).catch((err) => {\n logger.error(err.message);\n process.exit(1);\n });\n\n if (didInstall) {\n return;\n }\n\n if (tsconfig?.config) {\n // Build without diagnostics in case schemas have changed\n await cleanupDistDirectory({ tsconfig, logger, timer });\n try {\n await tsUtils.compile(cwd, { configOptions: { ignoreDiagnostics: true } });\n } catch (err: unknown) {\n logger.error(`Error during initial TypeScript compilation: ${(err as Error).message}`);\n // We don't return here because we want to attempt to start the server even if the initial compilation fails, as it can be fixed while the server is running\n }\n }\n\n /**\n * IF we're not watching the admin we're going to build it, this makes\n * sure that at least the admin is built for users & they can interact\n * with the application.\n */\n if (!watchAdmin && buildAdmin) {\n timer.start('createBuildContext');\n const contextSpinner = logger.spinner(`Building build context`).start();\n console.log('');\n\n const ctx = await createBuildContext({\n cwd,\n logger,\n tsconfig,\n options,\n });\n const contextDuration = timer.end('createBuildContext');\n contextSpinner.text = `Building build context (${prettyTime(contextDuration)})`;\n contextSpinner.succeed();\n\n timer.start('creatingAdmin');\n const adminSpinner = logger.spinner(`Creating admin`).start();\n\n await writeStaticClientFiles(ctx);\n\n if (ctx.bundler === 'webpack') {\n const { build: buildWebpack } = await import('./webpack/build');\n await buildWebpack(ctx);\n } else if (ctx.bundler === 'vite') {\n const { build: buildVite } = await import('./vite/build');\n await buildVite(ctx);\n }\n\n const adminDuration = timer.end('creatingAdmin');\n adminSpinner.text = `Creating admin (${prettyTime(adminDuration)})`;\n adminSpinner.succeed();\n }\n\n cluster.on('message', async (worker, message) => {\n switch (message) {\n case 'reload': {\n if (tsconfig?.config) {\n try {\n // Build without diagnostics in case schemas have changed\n await cleanupDistDirectory({ tsconfig, logger, timer });\n await tsUtils.compile(cwd, { configOptions: { ignoreDiagnostics: true } });\n } catch (err: unknown) {\n const message = err instanceof Error ? err.message : String(err);\n logger.error(`Error during TypeScript compilation on reload: ${message}`);\n process.exit(1);\n }\n }\n logger.debug('cluster has the reload message, sending the worker kill message');\n worker.send('kill');\n break;\n }\n case 'killed': {\n logger.debug('cluster has the killed message, forking the cluster');\n cluster.fork();\n break;\n }\n case 'stop': {\n process.exit(1);\n break;\n }\n default:\n break;\n }\n });\n\n cluster.fork();\n }\n\n if (cluster.isWorker) {\n timer.start('loadStrapi');\n const loadStrapiSpinner = logger.spinner(`Loading Strapi`).start();\n\n const strapi = createStrapi({\n appDir: cwd,\n distDir: tsconfig?.config.options.outDir ?? '',\n autoReload: true,\n serveAdminPanel: !watchAdmin,\n });\n\n /**\n * If we're watching the admin panel then we're going to attach the watcher\n * as a strapi middleware.\n */\n let bundleWatcher: WebpackWatcher | ViteWatcher | undefined;\n\n const strapiInstance = await strapi.load();\n\n const contextSpinner = logger.spinner(`Building build context`);\n const adminSpinner = logger.spinner(`Creating admin`);\n const generatingTsSpinner = logger.spinner(`Generating types`);\n const compilingTsSpinner = logger.spinner(`Compiling TS`);\n\n let watcherStarted = false;\n const ensureWatcher = () => {\n if (!watcherStarted) {\n watcherStarted = true;\n startWatcher(strapiInstance, cwd, polling ?? false, logger, bundleWatcher);\n }\n };\n\n try {\n if (watchAdmin) {\n timer.start('createBuildContext');\n contextSpinner.start();\n\n const ctx = await createBuildContext({\n cwd,\n logger,\n strapi,\n tsconfig,\n options,\n });\n const contextDuration = timer.end('createBuildContext');\n contextSpinner.text = `Building build context (${prettyTime(contextDuration)})`;\n contextSpinner.succeed();\n\n timer.start('creatingAdmin');\n adminSpinner.start();\n\n await writeStaticClientFiles(ctx);\n\n if (ctx.bundler === 'webpack') {\n const { watch: watchWebpack } = await import('./webpack/watch');\n bundleWatcher = await watchWebpack(ctx);\n } else if (ctx.bundler === 'vite') {\n const { watch: watchVite } = await import('./vite/watch');\n bundleWatcher = await watchVite(ctx);\n }\n\n const adminDuration = timer.end('creatingAdmin');\n adminSpinner.text = `Creating admin (${prettyTime(adminDuration)})`;\n adminSpinner.succeed();\n }\n\n const loadStrapiDuration = timer.end('loadStrapi');\n loadStrapiSpinner.text = `Loading Strapi (${prettyTime(loadStrapiDuration)})`;\n loadStrapiSpinner.succeed();\n\n // For TS projects, type generation is a requirement for the develop command so that the server can restart\n // For JS projects, we respect the experimental autogenerate setting\n if (tsconfig?.config || strapi.config.get('typescript.autogenerate') !== false) {\n timer.start('generatingTS');\n generatingTsSpinner.start();\n\n await tsUtils.generators.generate({\n strapi: strapiInstance,\n pwd: cwd,\n rootDir: undefined,\n logger: { silent: true, debug: false },\n artifacts: { contentTypes: true, components: true },\n });\n\n const generatingDuration = timer.end('generatingTS');\n generatingTsSpinner.text = `Generating types (${prettyTime(generatingDuration)})`;\n generatingTsSpinner.succeed();\n }\n\n if (tsconfig?.config) {\n timer.start('compilingTS');\n compilingTsSpinner.start();\n\n await cleanupDistDirectory({ tsconfig, logger, timer });\n await tsUtils.compile(cwd, { configOptions: { ignoreDiagnostics: false } });\n\n const compilingDuration = timer.end('compilingTS');\n compilingTsSpinner.text = `Compiling TS (${prettyTime(compilingDuration)})`;\n compilingTsSpinner.succeed();\n }\n\n ensureWatcher();\n\n strapiInstance.start();\n } catch (err: unknown) {\n const message = err instanceof Error ? err.message : String(err);\n logger.error(`Error during development: ${message}`);\n\n if (loadStrapiSpinner.isSpinning) {\n loadStrapiSpinner.fail();\n }\n // Fail any spinners that were left running.\n if (contextSpinner.isSpinning) {\n contextSpinner.fail();\n }\n if (compilingTsSpinner.isSpinning) {\n compilingTsSpinner.fail();\n }\n if (adminSpinner.isSpinning) {\n adminSpinner.fail();\n }\n if (generatingTsSpinner.isSpinning) {\n generatingTsSpinner.fail();\n }\n\n ensureWatcher();\n }\n }\n};\n\nfunction startWatcher(\n strapiInstance: Awaited<ReturnType<typeof createStrapi>>,\n cwd: string,\n polling: boolean,\n logger: Logger,\n bundleWatcher?: WebpackWatcher | ViteWatcher\n) {\n const restart = async () => {\n if (strapiInstance.reload.isWatching && !strapiInstance.reload.isReloading) {\n strapiInstance.reload.isReloading = true;\n strapiInstance.reload();\n }\n };\n\n const watcher = chokidar\n .watch(cwd, {\n ignoreInitial: true,\n usePolling: polling,\n ignored: [\n /(^|[/\\\\])\\../, // dot files\n /tmp/,\n '**/src/admin/**',\n '**/src/plugins/**/admin/**',\n '**/dist/src/plugins/test/admin/**',\n '**/documentation',\n '**/documentation/**',\n '**/node_modules',\n '**/node_modules/**',\n '**/plugins.json',\n '**/build',\n '**/build/**',\n '**/log',\n '**/log/**',\n '**/logs',\n '**/logs/**',\n '**/*.log',\n '**/index.html',\n '**/public',\n '**/public/**',\n strapiInstance.dirs.static.public,\n strings.joinBy('/', strapiInstance.dirs.static.public, '**'),\n '**/*.db*',\n '**/exports/**',\n '**/dist/**',\n '**/*.d.ts',\n '**/.yalc/**',\n '**/yalc.lock',\n // TODO v6: watch only src folder by default, and flip this to watchIncludeFiles\n ...strapiInstance.config.get('admin.watchIgnoreFiles', []),\n ],\n })\n .on('add', (path) => {\n strapiInstance.log.info(`File created: ${path}`);\n restart();\n })\n .on('change', (path) => {\n strapiInstance.log.info(`File changed: ${path}`);\n restart();\n })\n .on('unlink', (path) => {\n strapiInstance.log.info(`File deleted: ${path}`);\n restart();\n });\n\n process.on('message', async (message) => {\n switch (message) {\n case 'kill': {\n logger.debug(\n 'child process has the kill message, destroying the strapi instance and sending the killed process message'\n );\n await watcher.close();\n\n await strapiInstance.destroy();\n\n if (bundleWatcher) {\n bundleWatcher.close();\n }\n process.send?.('killed');\n break;\n }\n default:\n break;\n }\n });\n}\n\nexport { develop };\nexport type { DevelopOptions };\n"],"names":["cleanupDistDirectory","tsconfig","logger","timer","distDir","config","options","outDir","fs","access","then","catch","timerName","Date","now","start","cleaningSpinner","spinner","dirContent","readdir","validFilenames","filter","filename","rm","path","resolve","recursive","err","generatingDuration","end","text","prettyTime","fail","succeed","develop","cwd","polling","watchAdmin","buildAdmin","getTimer","cluster","isPrimary","didInstall","checkRequiredDependencies","error","message","process","exit","tsUtils","compile","configOptions","ignoreDiagnostics","contextSpinner","console","log","ctx","createBuildContext","contextDuration","adminSpinner","writeStaticClientFiles","bundler","build","buildWebpack","buildVite","adminDuration","on","worker","Error","String","debug","send","fork","isWorker","loadStrapiSpinner","strapi","createStrapi","appDir","autoReload","serveAdminPanel","bundleWatcher","strapiInstance","load","generatingTsSpinner","compilingTsSpinner","watcherStarted","ensureWatcher","startWatcher","watch","watchWebpack","watchVite","loadStrapiDuration","get","generators","generate","pwd","rootDir","undefined","silent","artifacts","contentTypes","components","compilingDuration","isSpinning","restart","reload","isWatching","isReloading","watcher","chokidar","ignoreInitial","usePolling","ignored","dirs","static","public","strings","joinBy","info","close","destroy"],"mappings":"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"}
1
+ {"version":3,"file":"develop.mjs","sources":["../../../src/node/develop.ts"],"sourcesContent":["import fs from 'node:fs/promises';\nimport path from 'node:path';\nimport cluster from 'node:cluster';\n\nimport type chokidarType from 'chokidar';\nimport type { createStrapi as CreateStrapi } from '@strapi/core';\nimport type { CLIContext } from '../cli/types';\nimport { checkRequiredDependencies } from './core/dependencies';\nimport { getTimer, prettyTime, type TimeMeasurer } from './core/timer';\nimport type { WebpackWatcher } from './webpack/watch';\nimport type { ViteWatcher } from './vite/watch';\nimport type { Logger } from '../cli/utils/logger';\n\n// Lazy: worker-only deps; primary cluster process should not pay for them\nconst lazy = <T>(spec: string): (() => T) => {\n let cached: T | undefined;\n return (): T => {\n if (cached === undefined) {\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n cached = require(spec);\n }\n return cached as T;\n };\n};\nconst tsUtils = lazy<typeof import('@strapi/typescript-utils')>('@strapi/typescript-utils');\nconst utils = lazy<typeof import('@strapi/utils')>('@strapi/utils');\nconst chokidar = lazy<typeof chokidarType>('chokidar');\nconst core = lazy<typeof import('@strapi/core')>('@strapi/core');\nconst buildCtx = lazy<typeof import('./create-build-context')>('./create-build-context');\nconst staticFs = lazy<typeof import('./staticFiles')>('./staticFiles');\n\ninterface DevelopOptions extends CLIContext {\n /**\n * Which bundler to use for building.\n *\n * @default webpack\n */\n bundler?: 'webpack' | 'vite';\n polling?: boolean;\n open?: boolean;\n watchAdmin?: boolean;\n buildAdmin?: boolean;\n}\n\n// This method removes all non-admin build files from the dist directory\nconst cleanupDistDirectory = async ({\n tsconfig,\n logger,\n timer,\n}: Pick<DevelopOptions, 'tsconfig' | 'logger'> & { timer: TimeMeasurer }) => {\n const distDir = tsconfig?.config?.options?.outDir;\n\n if (\n !distDir || // we don't have a dist dir\n (await fs\n .access(distDir)\n .then(() => false)\n .catch(() => true)) // it doesn't exist -- if it does but no access, that will be caught later\n ) {\n return;\n }\n\n const timerName = `cleaningDist${Date.now()}`;\n timer.start(timerName);\n const cleaningSpinner = logger.spinner(`Cleaning dist dir ${distDir}`).start();\n\n try {\n const dirContent = await fs.readdir(distDir);\n const validFilenames = dirContent\n // Ignore the admin build folder and the TypeScript incremental cache\n .filter((filename) => filename !== 'build' && !filename.endsWith('.tsbuildinfo'));\n for (const filename of validFilenames) {\n await fs.rm(path.resolve(distDir, filename), { recursive: true });\n }\n } catch (err: unknown) {\n const generatingDuration = timer.end(timerName);\n cleaningSpinner.text = `Error cleaning dist dir: ${err} (${prettyTime(generatingDuration)})`;\n cleaningSpinner?.fail();\n return;\n }\n\n const generatingDuration = timer.end(timerName);\n cleaningSpinner.text = `Cleaning dist dir (${prettyTime(generatingDuration)})`;\n cleaningSpinner?.succeed();\n};\n\nconst develop = async ({\n cwd,\n polling,\n logger,\n tsconfig,\n watchAdmin,\n buildAdmin,\n ...options\n}: DevelopOptions) => {\n const timer = getTimer();\n\n if (cluster.isPrimary) {\n const { didInstall } = await checkRequiredDependencies({ cwd, logger }).catch((err) => {\n logger.error(err.message);\n process.exit(1);\n });\n\n if (didInstall) {\n return;\n }\n\n if (tsconfig?.config) {\n // Build without diagnostics in case schemas have changed\n await cleanupDistDirectory({ tsconfig, logger, timer });\n try {\n await tsUtils().compile(cwd, { configOptions: { ignoreDiagnostics: true } });\n } catch (err: unknown) {\n logger.error(`Error during initial TypeScript compilation: ${(err as Error).message}`);\n // We don't return here because we want to attempt to start the server even if the initial compilation fails, as it can be fixed while the server is running\n }\n }\n\n /**\n * IF we're not watching the admin we're going to build it, this makes\n * sure that at least the admin is built for users & they can interact\n * with the application.\n */\n if (!watchAdmin && buildAdmin) {\n timer.start('createBuildContext');\n const contextSpinner = logger.spinner(`Building build context`).start();\n console.log('');\n\n const ctx = await buildCtx().createBuildContext({\n cwd,\n logger,\n tsconfig,\n options,\n });\n const contextDuration = timer.end('createBuildContext');\n contextSpinner.text = `Building build context (${prettyTime(contextDuration)})`;\n contextSpinner.succeed();\n\n timer.start('creatingAdmin');\n const adminSpinner = logger.spinner(`Creating admin`).start();\n\n await staticFs().writeStaticClientFiles(ctx);\n\n if (ctx.bundler === 'webpack') {\n const { build: buildWebpack } = await import('./webpack/build');\n await buildWebpack(ctx);\n } else if (ctx.bundler === 'vite') {\n const { build: buildVite } = await import('./vite/build');\n await buildVite(ctx);\n }\n\n const adminDuration = timer.end('creatingAdmin');\n adminSpinner.text = `Creating admin (${prettyTime(adminDuration)})`;\n adminSpinner.succeed();\n }\n\n cluster.on('message', async (worker, message) => {\n switch (message) {\n case 'reload': {\n if (tsconfig?.config) {\n try {\n // Build without diagnostics in case schemas have changed\n await cleanupDistDirectory({ tsconfig, logger, timer });\n await tsUtils().compile(cwd, { configOptions: { ignoreDiagnostics: true } });\n } catch (err: unknown) {\n const message = err instanceof Error ? err.message : String(err);\n logger.error(`Error during TypeScript compilation on reload: ${message}`);\n process.exit(1);\n }\n }\n logger.debug('cluster has the reload message, sending the worker kill message');\n worker.send('kill');\n break;\n }\n case 'killed': {\n logger.debug('cluster has the killed message, forking the cluster');\n cluster.fork();\n break;\n }\n case 'stop': {\n process.exit(1);\n break;\n }\n default:\n break;\n }\n });\n\n cluster.fork();\n }\n\n if (cluster.isWorker) {\n timer.start('loadStrapi');\n const loadStrapiSpinner = logger.spinner(`Loading Strapi`).start();\n\n const strapi = core().createStrapi({\n appDir: cwd,\n distDir: tsconfig?.config.options.outDir ?? '',\n autoReload: true,\n serveAdminPanel: !watchAdmin,\n });\n\n /**\n * If we're watching the admin panel then we're going to attach the watcher\n * as a strapi middleware.\n */\n let bundleWatcher: WebpackWatcher | ViteWatcher | undefined;\n\n const strapiInstance = await strapi.load();\n\n const contextSpinner = logger.spinner(`Building build context`);\n const adminSpinner = logger.spinner(`Creating admin`);\n const generatingTsSpinner = logger.spinner(`Generating types`);\n const compilingTsSpinner = logger.spinner(`Compiling TS`);\n\n let watcherStarted = false;\n const ensureWatcher = () => {\n if (!watcherStarted) {\n watcherStarted = true;\n startWatcher(strapiInstance, cwd, polling ?? false, logger, bundleWatcher);\n }\n };\n\n try {\n if (watchAdmin) {\n timer.start('createBuildContext');\n contextSpinner.start();\n\n const ctx = await buildCtx().createBuildContext({\n cwd,\n logger,\n strapi,\n tsconfig,\n options,\n });\n const contextDuration = timer.end('createBuildContext');\n contextSpinner.text = `Building build context (${prettyTime(contextDuration)})`;\n contextSpinner.succeed();\n\n timer.start('creatingAdmin');\n adminSpinner.start();\n\n await staticFs().writeStaticClientFiles(ctx);\n\n if (ctx.bundler === 'webpack') {\n const { watch: watchWebpack } = await import('./webpack/watch');\n bundleWatcher = await watchWebpack(ctx);\n } else if (ctx.bundler === 'vite') {\n const { watch: watchVite } = await import('./vite/watch');\n bundleWatcher = await watchVite(ctx);\n }\n\n const adminDuration = timer.end('creatingAdmin');\n adminSpinner.text = `Creating admin (${prettyTime(adminDuration)})`;\n adminSpinner.succeed();\n }\n\n const loadStrapiDuration = timer.end('loadStrapi');\n loadStrapiSpinner.text = `Loading Strapi (${prettyTime(loadStrapiDuration)})`;\n loadStrapiSpinner.succeed();\n\n // For TS projects, type generation is a requirement for the develop command so that the server can restart\n // For JS projects, we respect the experimental autogenerate setting\n if (tsconfig?.config || strapi.config.get('typescript.autogenerate') !== false) {\n timer.start('generatingTS');\n generatingTsSpinner.start();\n\n await tsUtils().generators.generate({\n strapi: strapiInstance,\n pwd: cwd,\n rootDir: undefined,\n logger: { silent: true, debug: false },\n artifacts: { contentTypes: true, components: true },\n });\n\n const generatingDuration = timer.end('generatingTS');\n generatingTsSpinner.text = `Generating types (${prettyTime(generatingDuration)})`;\n generatingTsSpinner.succeed();\n }\n\n if (tsconfig?.config) {\n timer.start('compilingTS');\n compilingTsSpinner.start();\n\n await cleanupDistDirectory({ tsconfig, logger, timer });\n await tsUtils().compile(cwd, { configOptions: { ignoreDiagnostics: false } });\n\n const compilingDuration = timer.end('compilingTS');\n compilingTsSpinner.text = `Compiling TS (${prettyTime(compilingDuration)})`;\n compilingTsSpinner.succeed();\n }\n\n ensureWatcher();\n\n strapiInstance.start();\n } catch (err: unknown) {\n const message = err instanceof Error ? err.message : String(err);\n logger.error(`Error during development: ${message}`);\n\n if (loadStrapiSpinner.isSpinning) {\n loadStrapiSpinner.fail();\n }\n // Fail any spinners that were left running.\n if (contextSpinner.isSpinning) {\n contextSpinner.fail();\n }\n if (compilingTsSpinner.isSpinning) {\n compilingTsSpinner.fail();\n }\n if (adminSpinner.isSpinning) {\n adminSpinner.fail();\n }\n if (generatingTsSpinner.isSpinning) {\n generatingTsSpinner.fail();\n }\n\n ensureWatcher();\n }\n }\n};\n\nfunction startWatcher(\n strapiInstance: Awaited<ReturnType<typeof CreateStrapi>>,\n cwd: string,\n polling: boolean,\n logger: Logger,\n bundleWatcher?: WebpackWatcher | ViteWatcher\n) {\n const restart = async () => {\n if (strapiInstance.reload.isWatching && !strapiInstance.reload.isReloading) {\n strapiInstance.reload.isReloading = true;\n strapiInstance.reload();\n }\n };\n\n const watcher = chokidar()\n .watch(cwd, {\n ignoreInitial: true,\n usePolling: polling,\n ignored: [\n /(^|[/\\\\])\\../, // dot files\n /tmp/,\n '**/src/admin/**',\n '**/src/plugins/**/admin/**',\n '**/dist/src/plugins/test/admin/**',\n '**/documentation',\n '**/documentation/**',\n '**/node_modules',\n '**/node_modules/**',\n '**/plugins.json',\n '**/build',\n '**/build/**',\n '**/log',\n '**/log/**',\n '**/logs',\n '**/logs/**',\n '**/*.log',\n '**/index.html',\n '**/public',\n '**/public/**',\n strapiInstance.dirs.static.public,\n utils().strings.joinBy('/', strapiInstance.dirs.static.public, '**'),\n '**/*.db*',\n '**/exports/**',\n '**/dist/**',\n '**/*.d.ts',\n '**/.yalc/**',\n '**/yalc.lock',\n // TODO v6: watch only src folder by default, and flip this to watchIncludeFiles\n ...strapiInstance.config.get('admin.watchIgnoreFiles', []),\n ],\n })\n .on('add', (path) => {\n strapiInstance.log.info(`File created: ${path}`);\n restart();\n })\n .on('change', (path) => {\n strapiInstance.log.info(`File changed: ${path}`);\n restart();\n })\n .on('unlink', (path) => {\n strapiInstance.log.info(`File deleted: ${path}`);\n restart();\n });\n\n process.on('message', async (message) => {\n switch (message) {\n case 'kill': {\n logger.debug(\n 'child process has the kill message, destroying the strapi instance and sending the killed process message'\n );\n await watcher.close();\n\n await strapiInstance.destroy();\n\n if (bundleWatcher) {\n bundleWatcher.close();\n }\n process.send?.('killed');\n break;\n }\n default:\n break;\n }\n });\n}\n\nexport { develop };\nexport type { DevelopOptions };\n"],"names":["lazy","spec","cached","undefined","require","tsUtils","utils","chokidar","core","buildCtx","staticFs","cleanupDistDirectory","tsconfig","logger","timer","distDir","config","options","outDir","fs","access","then","catch","timerName","Date","now","start","cleaningSpinner","spinner","dirContent","readdir","validFilenames","filter","filename","endsWith","rm","path","resolve","recursive","err","generatingDuration","end","text","prettyTime","fail","succeed","develop","cwd","polling","watchAdmin","buildAdmin","getTimer","cluster","isPrimary","didInstall","checkRequiredDependencies","error","message","process","exit","compile","configOptions","ignoreDiagnostics","contextSpinner","console","log","ctx","createBuildContext","contextDuration","adminSpinner","writeStaticClientFiles","bundler","build","buildWebpack","buildVite","adminDuration","on","worker","Error","String","debug","send","fork","isWorker","loadStrapiSpinner","strapi","createStrapi","appDir","autoReload","serveAdminPanel","bundleWatcher","strapiInstance","load","generatingTsSpinner","compilingTsSpinner","watcherStarted","ensureWatcher","startWatcher","watch","watchWebpack","watchVite","loadStrapiDuration","get","generators","generate","pwd","rootDir","silent","artifacts","contentTypes","components","compilingDuration","isSpinning","restart","reload","isWatching","isReloading","watcher","ignoreInitial","usePolling","ignored","dirs","static","public","strings","joinBy","info","close","destroy"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@strapi/strapi",
3
- "version": "5.47.0",
3
+ "version": "5.47.1",
4
4
  "description": "An open source headless CMS solution to create and manage your own API. It provides a powerful dashboard and features to make your life easier. Databases supported: MySQL, MariaDB, PostgreSQL, SQLite",
5
5
  "keywords": [
6
6
  "strapi",
@@ -109,25 +109,25 @@
109
109
  },
110
110
  "dependencies": {
111
111
  "@pmmmwh/react-refresh-webpack-plugin": "0.5.17",
112
- "@strapi/admin": "5.47.0",
113
- "@strapi/cloud-cli": "5.47.0",
114
- "@strapi/content-manager": "5.47.0",
115
- "@strapi/content-releases": "5.47.0",
116
- "@strapi/content-type-builder": "5.47.0",
117
- "@strapi/core": "5.47.0",
118
- "@strapi/data-transfer": "5.47.0",
119
- "@strapi/database": "5.47.0",
120
- "@strapi/email": "5.47.0",
121
- "@strapi/generators": "5.47.0",
122
- "@strapi/i18n": "5.47.0",
123
- "@strapi/logger": "5.47.0",
124
- "@strapi/openapi": "5.47.0",
125
- "@strapi/permissions": "5.47.0",
126
- "@strapi/review-workflows": "5.47.0",
127
- "@strapi/types": "5.47.0",
128
- "@strapi/typescript-utils": "5.47.0",
129
- "@strapi/upload": "5.47.0",
130
- "@strapi/utils": "5.47.0",
112
+ "@strapi/admin": "5.47.1",
113
+ "@strapi/cloud-cli": "5.47.1",
114
+ "@strapi/content-manager": "5.47.1",
115
+ "@strapi/content-releases": "5.47.1",
116
+ "@strapi/content-type-builder": "5.47.1",
117
+ "@strapi/core": "5.47.1",
118
+ "@strapi/data-transfer": "5.47.1",
119
+ "@strapi/database": "5.47.1",
120
+ "@strapi/email": "5.47.1",
121
+ "@strapi/generators": "5.47.1",
122
+ "@strapi/i18n": "5.47.1",
123
+ "@strapi/logger": "5.47.1",
124
+ "@strapi/openapi": "5.47.1",
125
+ "@strapi/permissions": "5.47.1",
126
+ "@strapi/review-workflows": "5.47.1",
127
+ "@strapi/types": "5.47.1",
128
+ "@strapi/typescript-utils": "5.47.1",
129
+ "@strapi/upload": "5.47.1",
130
+ "@strapi/utils": "5.47.1",
131
131
  "@types/nodemon": "1.19.6",
132
132
  "@vitejs/plugin-react-swc": "3.6.0",
133
133
  "boxen": "5.1.2",
@@ -180,11 +180,11 @@
180
180
  "@types/node": "24.10.0",
181
181
  "@types/webpack-bundle-analyzer": "4.7.0",
182
182
  "@types/webpack-hot-middleware": "2.25.9",
183
- "eslint-config-custom": "5.47.0",
183
+ "eslint-config-custom": "5.47.1",
184
184
  "jest": "29.6.0",
185
185
  "react": "18.3.1",
186
186
  "react-dom": "18.3.1",
187
- "tsconfig": "5.47.0",
187
+ "tsconfig": "5.47.1",
188
188
  "yalc": "1.0.0-pre.53"
189
189
  },
190
190
  "peerDependencies": {