@strapi/database 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,6 +1,5 @@
1
1
  'use strict';
2
2
 
3
- var umzug = require('umzug');
4
3
  var common = require('./common.js');
5
4
  var index = require('./internal-migrations/index.js');
6
5
  var storage = require('./storage.js');
@@ -13,48 +12,56 @@ const createInternalMigrationProvider = (db)=>{
13
12
  const migrations = [
14
13
  ...index.internalMigrations
15
14
  ];
16
- const umzugProvider = new umzug.Umzug({
17
- storage: storage.createStorage({
18
- db,
19
- tableName: 'strapi_migrations_internal'
20
- }),
21
- logger: {
22
- info (message) {
23
- // NOTE: only log internal migration in debug mode
24
- db.logger.debug(logger.transformLogMessage('info', message));
15
+ // Lazy: defer `umzug` (and its inquirer / @rushstack chain) until first call
16
+ let lazyProvider;
17
+ const provider = ()=>{
18
+ if (lazyProvider) return lazyProvider;
19
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
20
+ const { Umzug: UmzugCtor } = require('umzug');
21
+ lazyProvider = new UmzugCtor({
22
+ storage: storage.createStorage({
23
+ db,
24
+ tableName: 'strapi_migrations_internal'
25
+ }),
26
+ logger: {
27
+ info (message) {
28
+ // NOTE: only log internal migration in debug mode
29
+ db.logger.debug(logger.transformLogMessage('info', message));
30
+ },
31
+ warn (message) {
32
+ db.logger.warn(logger.transformLogMessage('warn', message));
33
+ },
34
+ error (message) {
35
+ db.logger.error(logger.transformLogMessage('error', message));
36
+ },
37
+ debug (message) {
38
+ db.logger.debug(logger.transformLogMessage('debug', message));
39
+ }
25
40
  },
26
- warn (message) {
27
- db.logger.warn(logger.transformLogMessage('warn', message));
28
- },
29
- error (message) {
30
- db.logger.error(logger.transformLogMessage('error', message));
31
- },
32
- debug (message) {
33
- db.logger.debug(logger.transformLogMessage('debug', message));
34
- }
35
- },
36
- context,
37
- migrations: ()=>migrations.map((migration)=>{
38
- return {
39
- name: migration.name,
40
- up: common.wrapTransaction(context.db)(migration.up),
41
- down: common.wrapTransaction(context.db)(migration.down)
42
- };
43
- })
44
- });
41
+ context,
42
+ migrations: ()=>migrations.map((migration)=>{
43
+ return {
44
+ name: migration.name,
45
+ up: common.wrapTransaction(context.db)(migration.up),
46
+ down: common.wrapTransaction(context.db)(migration.down)
47
+ };
48
+ })
49
+ });
50
+ return lazyProvider;
51
+ };
45
52
  return {
46
53
  async register (migration) {
47
54
  migrations.push(migration);
48
55
  },
49
56
  async shouldRun () {
50
- const pendingMigrations = await umzugProvider.pending();
57
+ const pendingMigrations = await provider().pending();
51
58
  return pendingMigrations.length > 0;
52
59
  },
53
60
  async up () {
54
- await umzugProvider.up();
61
+ await provider().up();
55
62
  },
56
63
  async down () {
57
- await umzugProvider.down();
64
+ await provider().down();
58
65
  }
59
66
  };
60
67
  };
@@ -1 +1 @@
1
- {"version":3,"file":"internal.js","sources":["../../src/migrations/internal.ts"],"sourcesContent":["import { Umzug } from 'umzug';\n\nimport { wrapTransaction } from './common';\nimport { internalMigrations } from './internal-migrations';\nimport { createStorage } from './storage';\nimport { transformLogMessage } from './logger';\n\nimport type { InternalMigrationProvider, Migration } from './common';\nimport type { Database } from '..';\n\nexport const createInternalMigrationProvider = (db: Database): InternalMigrationProvider => {\n const context = { db };\n const migrations: Migration[] = [...internalMigrations];\n\n const umzugProvider = new Umzug({\n storage: createStorage({ db, tableName: 'strapi_migrations_internal' }),\n logger: {\n info(message) {\n // NOTE: only log internal migration in debug mode\n db.logger.debug(transformLogMessage('info', message));\n },\n warn(message) {\n db.logger.warn(transformLogMessage('warn', message));\n },\n error(message) {\n db.logger.error(transformLogMessage('error', message));\n },\n debug(message) {\n db.logger.debug(transformLogMessage('debug', message));\n },\n },\n context,\n migrations: () =>\n migrations.map((migration) => {\n return {\n name: migration.name,\n up: wrapTransaction(context.db)(migration.up),\n down: wrapTransaction(context.db)(migration.down),\n };\n }),\n });\n\n return {\n async register(migration: Migration) {\n migrations.push(migration);\n },\n async shouldRun() {\n const pendingMigrations = await umzugProvider.pending();\n return pendingMigrations.length > 0;\n },\n async up() {\n await umzugProvider.up();\n },\n async down() {\n await umzugProvider.down();\n },\n };\n};\n"],"names":["createInternalMigrationProvider","db","context","migrations","internalMigrations","umzugProvider","Umzug","storage","createStorage","tableName","logger","info","message","debug","transformLogMessage","warn","error","map","migration","name","up","wrapTransaction","down","register","push","shouldRun","pendingMigrations","pending","length"],"mappings":";;;;;;;;AAUO,MAAMA,kCAAkC,CAACC,EAAAA,GAAAA;AAC9C,IAAA,MAAMC,OAAAA,GAAU;AAAED,QAAAA;AAAG,KAAA;AACrB,IAAA,MAAME,UAAAA,GAA0B;AAAIC,QAAAA,GAAAA;AAAmB,KAAA;IAEvD,MAAMC,aAAAA,GAAgB,IAAIC,WAAAA,CAAM;AAC9BC,QAAAA,OAAAA,EAASC,qBAAAA,CAAc;AAAEP,YAAAA,EAAAA;YAAIQ,SAAAA,EAAW;AAA6B,SAAA,CAAA;QACrEC,MAAAA,EAAQ;AACNC,YAAAA,IAAAA,CAAAA,CAAKC,OAAO,EAAA;;AAEVX,gBAAAA,EAAAA,CAAGS,MAAM,CAACG,KAAK,CAACC,2BAAoB,MAAA,EAAQF,OAAAA,CAAAA,CAAAA;AAC9C,YAAA,CAAA;AACAG,YAAAA,IAAAA,CAAAA,CAAKH,OAAO,EAAA;AACVX,gBAAAA,EAAAA,CAAGS,MAAM,CAACK,IAAI,CAACD,2BAAoB,MAAA,EAAQF,OAAAA,CAAAA,CAAAA;AAC7C,YAAA,CAAA;AACAI,YAAAA,KAAAA,CAAAA,CAAMJ,OAAO,EAAA;AACXX,gBAAAA,EAAAA,CAAGS,MAAM,CAACM,KAAK,CAACF,2BAAoB,OAAA,EAASF,OAAAA,CAAAA,CAAAA;AAC/C,YAAA,CAAA;AACAC,YAAAA,KAAAA,CAAAA,CAAMD,OAAO,EAAA;AACXX,gBAAAA,EAAAA,CAAGS,MAAM,CAACG,KAAK,CAACC,2BAAoB,OAAA,EAASF,OAAAA,CAAAA,CAAAA;AAC/C,YAAA;AACF,SAAA;AACAV,QAAAA,OAAAA;AACAC,QAAAA,UAAAA,EAAY,IACVA,UAAAA,CAAWc,GAAG,CAAC,CAACC,SAAAA,GAAAA;gBACd,OAAO;AACLC,oBAAAA,IAAAA,EAAMD,UAAUC,IAAI;AACpBC,oBAAAA,EAAAA,EAAIC,sBAAAA,CAAgBnB,OAAAA,CAAQD,EAAE,CAAA,CAAEiB,UAAUE,EAAE,CAAA;AAC5CE,oBAAAA,IAAAA,EAAMD,sBAAAA,CAAgBnB,OAAAA,CAAQD,EAAE,CAAA,CAAEiB,UAAUI,IAAI;AAClD,iBAAA;AACF,YAAA,CAAA;AACJ,KAAA,CAAA;IAEA,OAAO;AACL,QAAA,MAAMC,UAASL,SAAoB,EAAA;AACjCf,YAAAA,UAAAA,CAAWqB,IAAI,CAACN,SAAAA,CAAAA;AAClB,QAAA,CAAA;QACA,MAAMO,SAAAA,CAAAA,GAAAA;YACJ,MAAMC,iBAAAA,GAAoB,MAAMrB,aAAAA,CAAcsB,OAAO,EAAA;YACrD,OAAOD,iBAAAA,CAAkBE,MAAM,GAAG,CAAA;AACpC,QAAA,CAAA;QACA,MAAMR,EAAAA,CAAAA,GAAAA;AACJ,YAAA,MAAMf,cAAce,EAAE,EAAA;AACxB,QAAA,CAAA;QACA,MAAME,IAAAA,CAAAA,GAAAA;AACJ,YAAA,MAAMjB,cAAciB,IAAI,EAAA;AAC1B,QAAA;AACF,KAAA;AACF;;;;"}
1
+ {"version":3,"file":"internal.js","sources":["../../src/migrations/internal.ts"],"sourcesContent":["import type { Umzug } from 'umzug';\n\nimport { wrapTransaction } from './common';\nimport { internalMigrations } from './internal-migrations';\nimport { createStorage } from './storage';\nimport { transformLogMessage } from './logger';\n\nimport type { InternalMigrationProvider, Migration } from './common';\nimport type { Database } from '..';\n\nexport const createInternalMigrationProvider = (db: Database): InternalMigrationProvider => {\n const context = { db };\n const migrations: Migration[] = [...internalMigrations];\n\n // Lazy: defer `umzug` (and its inquirer / @rushstack chain) until first call\n let lazyProvider: Umzug<typeof context> | undefined;\n const provider = (): Umzug<typeof context> => {\n if (lazyProvider) return lazyProvider;\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const { Umzug: UmzugCtor } = require('umzug') as typeof import('umzug');\n lazyProvider = new UmzugCtor({\n storage: createStorage({ db, tableName: 'strapi_migrations_internal' }),\n logger: {\n info(message) {\n // NOTE: only log internal migration in debug mode\n db.logger.debug(transformLogMessage('info', message));\n },\n warn(message) {\n db.logger.warn(transformLogMessage('warn', message));\n },\n error(message) {\n db.logger.error(transformLogMessage('error', message));\n },\n debug(message) {\n db.logger.debug(transformLogMessage('debug', message));\n },\n },\n context,\n migrations: () =>\n migrations.map((migration) => {\n return {\n name: migration.name,\n up: wrapTransaction(context.db)(migration.up),\n down: wrapTransaction(context.db)(migration.down),\n };\n }),\n });\n return lazyProvider;\n };\n\n return {\n async register(migration: Migration) {\n migrations.push(migration);\n },\n async shouldRun() {\n const pendingMigrations = await provider().pending();\n return pendingMigrations.length > 0;\n },\n async up() {\n await provider().up();\n },\n async down() {\n await provider().down();\n },\n };\n};\n"],"names":["createInternalMigrationProvider","db","context","migrations","internalMigrations","lazyProvider","provider","Umzug","UmzugCtor","require","storage","createStorage","tableName","logger","info","message","debug","transformLogMessage","warn","error","map","migration","name","up","wrapTransaction","down","register","push","shouldRun","pendingMigrations","pending","length"],"mappings":";;;;;;;AAUO,MAAMA,kCAAkC,CAACC,EAAAA,GAAAA;AAC9C,IAAA,MAAMC,OAAAA,GAAU;AAAED,QAAAA;AAAG,KAAA;AACrB,IAAA,MAAME,UAAAA,GAA0B;AAAIC,QAAAA,GAAAA;AAAmB,KAAA;;IAGvD,IAAIC,YAAAA;AACJ,IAAA,MAAMC,QAAAA,GAAW,IAAA;AACf,QAAA,IAAID,cAAc,OAAOA,YAAAA;;AAEzB,QAAA,MAAM,EAAEE,KAAAA,EAAOC,SAAS,EAAE,GAAGC,OAAAA,CAAQ,OAAA,CAAA;AACrCJ,QAAAA,YAAAA,GAAe,IAAIG,SAAAA,CAAU;AAC3BE,YAAAA,OAAAA,EAASC,qBAAAA,CAAc;AAAEV,gBAAAA,EAAAA;gBAAIW,SAAAA,EAAW;AAA6B,aAAA,CAAA;YACrEC,MAAAA,EAAQ;AACNC,gBAAAA,IAAAA,CAAAA,CAAKC,OAAO,EAAA;;AAEVd,oBAAAA,EAAAA,CAAGY,MAAM,CAACG,KAAK,CAACC,2BAAoB,MAAA,EAAQF,OAAAA,CAAAA,CAAAA;AAC9C,gBAAA,CAAA;AACAG,gBAAAA,IAAAA,CAAAA,CAAKH,OAAO,EAAA;AACVd,oBAAAA,EAAAA,CAAGY,MAAM,CAACK,IAAI,CAACD,2BAAoB,MAAA,EAAQF,OAAAA,CAAAA,CAAAA;AAC7C,gBAAA,CAAA;AACAI,gBAAAA,KAAAA,CAAAA,CAAMJ,OAAO,EAAA;AACXd,oBAAAA,EAAAA,CAAGY,MAAM,CAACM,KAAK,CAACF,2BAAoB,OAAA,EAASF,OAAAA,CAAAA,CAAAA;AAC/C,gBAAA,CAAA;AACAC,gBAAAA,KAAAA,CAAAA,CAAMD,OAAO,EAAA;AACXd,oBAAAA,EAAAA,CAAGY,MAAM,CAACG,KAAK,CAACC,2BAAoB,OAAA,EAASF,OAAAA,CAAAA,CAAAA;AAC/C,gBAAA;AACF,aAAA;AACAb,YAAAA,OAAAA;AACAC,YAAAA,UAAAA,EAAY,IACVA,UAAAA,CAAWiB,GAAG,CAAC,CAACC,SAAAA,GAAAA;oBACd,OAAO;AACLC,wBAAAA,IAAAA,EAAMD,UAAUC,IAAI;AACpBC,wBAAAA,EAAAA,EAAIC,sBAAAA,CAAgBtB,OAAAA,CAAQD,EAAE,CAAA,CAAEoB,UAAUE,EAAE,CAAA;AAC5CE,wBAAAA,IAAAA,EAAMD,sBAAAA,CAAgBtB,OAAAA,CAAQD,EAAE,CAAA,CAAEoB,UAAUI,IAAI;AAClD,qBAAA;AACF,gBAAA,CAAA;AACJ,SAAA,CAAA;QACA,OAAOpB,YAAAA;AACT,IAAA,CAAA;IAEA,OAAO;AACL,QAAA,MAAMqB,UAASL,SAAoB,EAAA;AACjClB,YAAAA,UAAAA,CAAWwB,IAAI,CAACN,SAAAA,CAAAA;AAClB,QAAA,CAAA;QACA,MAAMO,SAAAA,CAAAA,GAAAA;YACJ,MAAMC,iBAAAA,GAAoB,MAAMvB,QAAAA,EAAAA,CAAWwB,OAAO,EAAA;YAClD,OAAOD,iBAAAA,CAAkBE,MAAM,GAAG,CAAA;AACpC,QAAA,CAAA;QACA,MAAMR,EAAAA,CAAAA,GAAAA;AACJ,YAAA,MAAMjB,WAAWiB,EAAE,EAAA;AACrB,QAAA,CAAA;QACA,MAAME,IAAAA,CAAAA,GAAAA;AACJ,YAAA,MAAMnB,WAAWmB,IAAI,EAAA;AACvB,QAAA;AACF,KAAA;AACF;;;;"}
@@ -1,4 +1,3 @@
1
- import { Umzug } from 'umzug';
2
1
  import { wrapTransaction } from './common.mjs';
3
2
  import { internalMigrations } from './internal-migrations/index.mjs';
4
3
  import { createStorage } from './storage.mjs';
@@ -11,48 +10,56 @@ const createInternalMigrationProvider = (db)=>{
11
10
  const migrations = [
12
11
  ...internalMigrations
13
12
  ];
14
- const umzugProvider = new Umzug({
15
- storage: createStorage({
16
- db,
17
- tableName: 'strapi_migrations_internal'
18
- }),
19
- logger: {
20
- info (message) {
21
- // NOTE: only log internal migration in debug mode
22
- db.logger.debug(transformLogMessage('info', message));
13
+ // Lazy: defer `umzug` (and its inquirer / @rushstack chain) until first call
14
+ let lazyProvider;
15
+ const provider = ()=>{
16
+ if (lazyProvider) return lazyProvider;
17
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
18
+ const { Umzug: UmzugCtor } = require('umzug');
19
+ lazyProvider = new UmzugCtor({
20
+ storage: createStorage({
21
+ db,
22
+ tableName: 'strapi_migrations_internal'
23
+ }),
24
+ logger: {
25
+ info (message) {
26
+ // NOTE: only log internal migration in debug mode
27
+ db.logger.debug(transformLogMessage('info', message));
28
+ },
29
+ warn (message) {
30
+ db.logger.warn(transformLogMessage('warn', message));
31
+ },
32
+ error (message) {
33
+ db.logger.error(transformLogMessage('error', message));
34
+ },
35
+ debug (message) {
36
+ db.logger.debug(transformLogMessage('debug', message));
37
+ }
23
38
  },
24
- warn (message) {
25
- db.logger.warn(transformLogMessage('warn', message));
26
- },
27
- error (message) {
28
- db.logger.error(transformLogMessage('error', message));
29
- },
30
- debug (message) {
31
- db.logger.debug(transformLogMessage('debug', message));
32
- }
33
- },
34
- context,
35
- migrations: ()=>migrations.map((migration)=>{
36
- return {
37
- name: migration.name,
38
- up: wrapTransaction(context.db)(migration.up),
39
- down: wrapTransaction(context.db)(migration.down)
40
- };
41
- })
42
- });
39
+ context,
40
+ migrations: ()=>migrations.map((migration)=>{
41
+ return {
42
+ name: migration.name,
43
+ up: wrapTransaction(context.db)(migration.up),
44
+ down: wrapTransaction(context.db)(migration.down)
45
+ };
46
+ })
47
+ });
48
+ return lazyProvider;
49
+ };
43
50
  return {
44
51
  async register (migration) {
45
52
  migrations.push(migration);
46
53
  },
47
54
  async shouldRun () {
48
- const pendingMigrations = await umzugProvider.pending();
55
+ const pendingMigrations = await provider().pending();
49
56
  return pendingMigrations.length > 0;
50
57
  },
51
58
  async up () {
52
- await umzugProvider.up();
59
+ await provider().up();
53
60
  },
54
61
  async down () {
55
- await umzugProvider.down();
62
+ await provider().down();
56
63
  }
57
64
  };
58
65
  };
@@ -1 +1 @@
1
- {"version":3,"file":"internal.mjs","sources":["../../src/migrations/internal.ts"],"sourcesContent":["import { Umzug } from 'umzug';\n\nimport { wrapTransaction } from './common';\nimport { internalMigrations } from './internal-migrations';\nimport { createStorage } from './storage';\nimport { transformLogMessage } from './logger';\n\nimport type { InternalMigrationProvider, Migration } from './common';\nimport type { Database } from '..';\n\nexport const createInternalMigrationProvider = (db: Database): InternalMigrationProvider => {\n const context = { db };\n const migrations: Migration[] = [...internalMigrations];\n\n const umzugProvider = new Umzug({\n storage: createStorage({ db, tableName: 'strapi_migrations_internal' }),\n logger: {\n info(message) {\n // NOTE: only log internal migration in debug mode\n db.logger.debug(transformLogMessage('info', message));\n },\n warn(message) {\n db.logger.warn(transformLogMessage('warn', message));\n },\n error(message) {\n db.logger.error(transformLogMessage('error', message));\n },\n debug(message) {\n db.logger.debug(transformLogMessage('debug', message));\n },\n },\n context,\n migrations: () =>\n migrations.map((migration) => {\n return {\n name: migration.name,\n up: wrapTransaction(context.db)(migration.up),\n down: wrapTransaction(context.db)(migration.down),\n };\n }),\n });\n\n return {\n async register(migration: Migration) {\n migrations.push(migration);\n },\n async shouldRun() {\n const pendingMigrations = await umzugProvider.pending();\n return pendingMigrations.length > 0;\n },\n async up() {\n await umzugProvider.up();\n },\n async down() {\n await umzugProvider.down();\n },\n };\n};\n"],"names":["createInternalMigrationProvider","db","context","migrations","internalMigrations","umzugProvider","Umzug","storage","createStorage","tableName","logger","info","message","debug","transformLogMessage","warn","error","map","migration","name","up","wrapTransaction","down","register","push","shouldRun","pendingMigrations","pending","length"],"mappings":";;;;;;AAUO,MAAMA,kCAAkC,CAACC,EAAAA,GAAAA;AAC9C,IAAA,MAAMC,OAAAA,GAAU;AAAED,QAAAA;AAAG,KAAA;AACrB,IAAA,MAAME,UAAAA,GAA0B;AAAIC,QAAAA,GAAAA;AAAmB,KAAA;IAEvD,MAAMC,aAAAA,GAAgB,IAAIC,KAAAA,CAAM;AAC9BC,QAAAA,OAAAA,EAASC,aAAAA,CAAc;AAAEP,YAAAA,EAAAA;YAAIQ,SAAAA,EAAW;AAA6B,SAAA,CAAA;QACrEC,MAAAA,EAAQ;AACNC,YAAAA,IAAAA,CAAAA,CAAKC,OAAO,EAAA;;AAEVX,gBAAAA,EAAAA,CAAGS,MAAM,CAACG,KAAK,CAACC,oBAAoB,MAAA,EAAQF,OAAAA,CAAAA,CAAAA;AAC9C,YAAA,CAAA;AACAG,YAAAA,IAAAA,CAAAA,CAAKH,OAAO,EAAA;AACVX,gBAAAA,EAAAA,CAAGS,MAAM,CAACK,IAAI,CAACD,oBAAoB,MAAA,EAAQF,OAAAA,CAAAA,CAAAA;AAC7C,YAAA,CAAA;AACAI,YAAAA,KAAAA,CAAAA,CAAMJ,OAAO,EAAA;AACXX,gBAAAA,EAAAA,CAAGS,MAAM,CAACM,KAAK,CAACF,oBAAoB,OAAA,EAASF,OAAAA,CAAAA,CAAAA;AAC/C,YAAA,CAAA;AACAC,YAAAA,KAAAA,CAAAA,CAAMD,OAAO,EAAA;AACXX,gBAAAA,EAAAA,CAAGS,MAAM,CAACG,KAAK,CAACC,oBAAoB,OAAA,EAASF,OAAAA,CAAAA,CAAAA;AAC/C,YAAA;AACF,SAAA;AACAV,QAAAA,OAAAA;AACAC,QAAAA,UAAAA,EAAY,IACVA,UAAAA,CAAWc,GAAG,CAAC,CAACC,SAAAA,GAAAA;gBACd,OAAO;AACLC,oBAAAA,IAAAA,EAAMD,UAAUC,IAAI;AACpBC,oBAAAA,EAAAA,EAAIC,eAAAA,CAAgBnB,OAAAA,CAAQD,EAAE,CAAA,CAAEiB,UAAUE,EAAE,CAAA;AAC5CE,oBAAAA,IAAAA,EAAMD,eAAAA,CAAgBnB,OAAAA,CAAQD,EAAE,CAAA,CAAEiB,UAAUI,IAAI;AAClD,iBAAA;AACF,YAAA,CAAA;AACJ,KAAA,CAAA;IAEA,OAAO;AACL,QAAA,MAAMC,UAASL,SAAoB,EAAA;AACjCf,YAAAA,UAAAA,CAAWqB,IAAI,CAACN,SAAAA,CAAAA;AAClB,QAAA,CAAA;QACA,MAAMO,SAAAA,CAAAA,GAAAA;YACJ,MAAMC,iBAAAA,GAAoB,MAAMrB,aAAAA,CAAcsB,OAAO,EAAA;YACrD,OAAOD,iBAAAA,CAAkBE,MAAM,GAAG,CAAA;AACpC,QAAA,CAAA;QACA,MAAMR,EAAAA,CAAAA,GAAAA;AACJ,YAAA,MAAMf,cAAce,EAAE,EAAA;AACxB,QAAA,CAAA;QACA,MAAME,IAAAA,CAAAA,GAAAA;AACJ,YAAA,MAAMjB,cAAciB,IAAI,EAAA;AAC1B,QAAA;AACF,KAAA;AACF;;;;"}
1
+ {"version":3,"file":"internal.mjs","sources":["../../src/migrations/internal.ts"],"sourcesContent":["import type { Umzug } from 'umzug';\n\nimport { wrapTransaction } from './common';\nimport { internalMigrations } from './internal-migrations';\nimport { createStorage } from './storage';\nimport { transformLogMessage } from './logger';\n\nimport type { InternalMigrationProvider, Migration } from './common';\nimport type { Database } from '..';\n\nexport const createInternalMigrationProvider = (db: Database): InternalMigrationProvider => {\n const context = { db };\n const migrations: Migration[] = [...internalMigrations];\n\n // Lazy: defer `umzug` (and its inquirer / @rushstack chain) until first call\n let lazyProvider: Umzug<typeof context> | undefined;\n const provider = (): Umzug<typeof context> => {\n if (lazyProvider) return lazyProvider;\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const { Umzug: UmzugCtor } = require('umzug') as typeof import('umzug');\n lazyProvider = new UmzugCtor({\n storage: createStorage({ db, tableName: 'strapi_migrations_internal' }),\n logger: {\n info(message) {\n // NOTE: only log internal migration in debug mode\n db.logger.debug(transformLogMessage('info', message));\n },\n warn(message) {\n db.logger.warn(transformLogMessage('warn', message));\n },\n error(message) {\n db.logger.error(transformLogMessage('error', message));\n },\n debug(message) {\n db.logger.debug(transformLogMessage('debug', message));\n },\n },\n context,\n migrations: () =>\n migrations.map((migration) => {\n return {\n name: migration.name,\n up: wrapTransaction(context.db)(migration.up),\n down: wrapTransaction(context.db)(migration.down),\n };\n }),\n });\n return lazyProvider;\n };\n\n return {\n async register(migration: Migration) {\n migrations.push(migration);\n },\n async shouldRun() {\n const pendingMigrations = await provider().pending();\n return pendingMigrations.length > 0;\n },\n async up() {\n await provider().up();\n },\n async down() {\n await provider().down();\n },\n };\n};\n"],"names":["createInternalMigrationProvider","db","context","migrations","internalMigrations","lazyProvider","provider","Umzug","UmzugCtor","require","storage","createStorage","tableName","logger","info","message","debug","transformLogMessage","warn","error","map","migration","name","up","wrapTransaction","down","register","push","shouldRun","pendingMigrations","pending","length"],"mappings":";;;;;AAUO,MAAMA,kCAAkC,CAACC,EAAAA,GAAAA;AAC9C,IAAA,MAAMC,OAAAA,GAAU;AAAED,QAAAA;AAAG,KAAA;AACrB,IAAA,MAAME,UAAAA,GAA0B;AAAIC,QAAAA,GAAAA;AAAmB,KAAA;;IAGvD,IAAIC,YAAAA;AACJ,IAAA,MAAMC,QAAAA,GAAW,IAAA;AACf,QAAA,IAAID,cAAc,OAAOA,YAAAA;;AAEzB,QAAA,MAAM,EAAEE,KAAAA,EAAOC,SAAS,EAAE,GAAGC,OAAAA,CAAQ,OAAA,CAAA;AACrCJ,QAAAA,YAAAA,GAAe,IAAIG,SAAAA,CAAU;AAC3BE,YAAAA,OAAAA,EAASC,aAAAA,CAAc;AAAEV,gBAAAA,EAAAA;gBAAIW,SAAAA,EAAW;AAA6B,aAAA,CAAA;YACrEC,MAAAA,EAAQ;AACNC,gBAAAA,IAAAA,CAAAA,CAAKC,OAAO,EAAA;;AAEVd,oBAAAA,EAAAA,CAAGY,MAAM,CAACG,KAAK,CAACC,oBAAoB,MAAA,EAAQF,OAAAA,CAAAA,CAAAA;AAC9C,gBAAA,CAAA;AACAG,gBAAAA,IAAAA,CAAAA,CAAKH,OAAO,EAAA;AACVd,oBAAAA,EAAAA,CAAGY,MAAM,CAACK,IAAI,CAACD,oBAAoB,MAAA,EAAQF,OAAAA,CAAAA,CAAAA;AAC7C,gBAAA,CAAA;AACAI,gBAAAA,KAAAA,CAAAA,CAAMJ,OAAO,EAAA;AACXd,oBAAAA,EAAAA,CAAGY,MAAM,CAACM,KAAK,CAACF,oBAAoB,OAAA,EAASF,OAAAA,CAAAA,CAAAA;AAC/C,gBAAA,CAAA;AACAC,gBAAAA,KAAAA,CAAAA,CAAMD,OAAO,EAAA;AACXd,oBAAAA,EAAAA,CAAGY,MAAM,CAACG,KAAK,CAACC,oBAAoB,OAAA,EAASF,OAAAA,CAAAA,CAAAA;AAC/C,gBAAA;AACF,aAAA;AACAb,YAAAA,OAAAA;AACAC,YAAAA,UAAAA,EAAY,IACVA,UAAAA,CAAWiB,GAAG,CAAC,CAACC,SAAAA,GAAAA;oBACd,OAAO;AACLC,wBAAAA,IAAAA,EAAMD,UAAUC,IAAI;AACpBC,wBAAAA,EAAAA,EAAIC,eAAAA,CAAgBtB,OAAAA,CAAQD,EAAE,CAAA,CAAEoB,UAAUE,EAAE,CAAA;AAC5CE,wBAAAA,IAAAA,EAAMD,eAAAA,CAAgBtB,OAAAA,CAAQD,EAAE,CAAA,CAAEoB,UAAUI,IAAI;AAClD,qBAAA;AACF,gBAAA,CAAA;AACJ,SAAA,CAAA;QACA,OAAOpB,YAAAA;AACT,IAAA,CAAA;IAEA,OAAO;AACL,QAAA,MAAMqB,UAASL,SAAoB,EAAA;AACjClB,YAAAA,UAAAA,CAAWwB,IAAI,CAACN,SAAAA,CAAAA;AAClB,QAAA,CAAA;QACA,MAAMO,SAAAA,CAAAA,GAAAA;YACJ,MAAMC,iBAAAA,GAAoB,MAAMvB,QAAAA,EAAAA,CAAWwB,OAAO,EAAA;YAClD,OAAOD,iBAAAA,CAAkBE,MAAM,GAAG,CAAA;AACpC,QAAA,CAAA;QACA,MAAMR,EAAAA,CAAAA,GAAAA;AACJ,YAAA,MAAMjB,WAAWiB,EAAE,EAAA;AACrB,QAAA,CAAA;QACA,MAAME,IAAAA,CAAAA,GAAAA;AACJ,YAAA,MAAMnB,WAAWmB,IAAI,EAAA;AACvB,QAAA;AACF,KAAA;AACF;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"users.d.ts","sourceRoot":"","sources":["../../src/migrations/users.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAqB,qBAAqB,EAAE,MAAM,UAAU,CAAC;AACzE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,IAAI,CAAC;AAiCnC,eAAO,MAAM,2BAA2B,OAAQ,QAAQ,KAAG,qBA2C1D,CAAC"}
1
+ {"version":3,"file":"users.d.ts","sourceRoot":"","sources":["../../src/migrations/users.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAqB,qBAAqB,EAAE,MAAM,UAAU,CAAC;AACzE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,IAAI,CAAC;AAiCnC,eAAO,MAAM,2BAA2B,OAAQ,QAAQ,KAAG,qBAmD1D,CAAC"}
@@ -1,7 +1,6 @@
1
1
  'use strict';
2
2
 
3
3
  var fse = require('fs-extra');
4
- var umzug = require('umzug');
5
4
  var storage = require('./storage.js');
6
5
  var common = require('./common.js');
7
6
  var logger = require('./logger.js');
@@ -38,47 +37,55 @@ const createUserMigrationProvider = (db)=>{
38
37
  const context = {
39
38
  db
40
39
  };
41
- const umzugProvider = new umzug.Umzug({
42
- storage: storage.createStorage({
43
- db,
44
- tableName: 'strapi_migrations'
45
- }),
46
- logger: {
47
- info (message) {
48
- // NOTE: only log internal migration in debug mode
49
- db.logger.info(logger.transformLogMessage('info', message));
50
- },
51
- warn (message) {
52
- db.logger.warn(logger.transformLogMessage('warn', message));
53
- },
54
- error (message) {
55
- db.logger.error(logger.transformLogMessage('error', message));
40
+ // Lazy: defer `umzug` (and its inquirer / @rushstack chain) until first call
41
+ let lazyProvider;
42
+ const provider = ()=>{
43
+ if (lazyProvider) return lazyProvider;
44
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
45
+ const { Umzug: UmzugCtor } = require('umzug');
46
+ lazyProvider = new UmzugCtor({
47
+ storage: storage.createStorage({
48
+ db,
49
+ tableName: 'strapi_migrations'
50
+ }),
51
+ logger: {
52
+ info (message) {
53
+ // NOTE: only log internal migration in debug mode
54
+ db.logger.info(logger.transformLogMessage('info', message));
55
+ },
56
+ warn (message) {
57
+ db.logger.warn(logger.transformLogMessage('warn', message));
58
+ },
59
+ error (message) {
60
+ db.logger.error(logger.transformLogMessage('error', message));
61
+ },
62
+ debug (message) {
63
+ db.logger.debug(logger.transformLogMessage('debug', message));
64
+ }
56
65
  },
57
- debug (message) {
58
- db.logger.debug(logger.transformLogMessage('debug', message));
66
+ context,
67
+ migrations: {
68
+ glob: [
69
+ '*.{js,sql}',
70
+ {
71
+ cwd: dir
72
+ }
73
+ ],
74
+ resolve: migrationResolver
59
75
  }
60
- },
61
- context,
62
- migrations: {
63
- glob: [
64
- '*.{js,sql}',
65
- {
66
- cwd: dir
67
- }
68
- ],
69
- resolve: migrationResolver
70
- }
71
- });
76
+ });
77
+ return lazyProvider;
78
+ };
72
79
  return {
73
80
  async shouldRun () {
74
- const pendingMigrations = await umzugProvider.pending();
81
+ const pendingMigrations = await provider().pending();
75
82
  return pendingMigrations.length > 0 && db.config?.settings?.runMigrations === true;
76
83
  },
77
84
  async up () {
78
- await umzugProvider.up();
85
+ await provider().up();
79
86
  },
80
87
  async down () {
81
- await umzugProvider.down();
88
+ await provider().down();
82
89
  }
83
90
  };
84
91
  };
@@ -1 +1 @@
1
- {"version":3,"file":"users.js","sources":["../../src/migrations/users.ts"],"sourcesContent":["import fse from 'fs-extra';\nimport { Umzug } from 'umzug';\n\nimport { createStorage } from './storage';\nimport { wrapTransaction } from './common';\nimport { transformLogMessage } from './logger';\n\nimport type { MigrationResolver, UserMigrationProvider } from './common';\nimport type { Database } from '..';\n\n// TODO: check multiple commands in one sql statement\nconst migrationResolver: MigrationResolver = ({ name, path, context }) => {\n const { db } = context;\n\n if (!path) {\n throw new Error(`Migration ${name} has no path`);\n }\n\n // if sql file run with knex raw\n if (path.match(/\\.sql$/)) {\n const sql = fse.readFileSync(path, 'utf8');\n\n return {\n name,\n up: wrapTransaction(db)((knex) => knex.raw(sql)),\n async down() {\n throw new Error('Down migration is not supported for sql files');\n },\n };\n }\n\n // NOTE: we can add some ts register if we want to handle ts migration files at some point\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const migration = require(path);\n return {\n name,\n up: wrapTransaction(db)(migration.up),\n down: wrapTransaction(db)(migration.down),\n };\n};\n\nexport const createUserMigrationProvider = (db: Database): UserMigrationProvider => {\n const dir = db.config.settings.migrations.dir;\n\n fse.ensureDirSync(dir);\n\n const context = { db };\n\n const umzugProvider = new Umzug({\n storage: createStorage({ db, tableName: 'strapi_migrations' }),\n logger: {\n info(message) {\n // NOTE: only log internal migration in debug mode\n db.logger.info(transformLogMessage('info', message));\n },\n warn(message) {\n db.logger.warn(transformLogMessage('warn', message));\n },\n error(message) {\n db.logger.error(transformLogMessage('error', message));\n },\n debug(message) {\n db.logger.debug(transformLogMessage('debug', message));\n },\n },\n context,\n migrations: {\n glob: ['*.{js,sql}', { cwd: dir }],\n resolve: migrationResolver,\n },\n });\n\n return {\n async shouldRun() {\n const pendingMigrations = await umzugProvider.pending();\n return pendingMigrations.length > 0 && db.config?.settings?.runMigrations === true;\n },\n async up() {\n await umzugProvider.up();\n },\n async down() {\n await umzugProvider.down();\n },\n };\n};\n"],"names":["migrationResolver","name","path","context","db","Error","match","sql","fse","readFileSync","up","wrapTransaction","knex","raw","down","migration","require","createUserMigrationProvider","dir","config","settings","migrations","ensureDirSync","umzugProvider","Umzug","storage","createStorage","tableName","logger","info","message","transformLogMessage","warn","error","debug","glob","cwd","resolve","shouldRun","pendingMigrations","pending","length","runMigrations"],"mappings":"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"}
1
+ {"version":3,"file":"users.js","sources":["../../src/migrations/users.ts"],"sourcesContent":["import fse from 'fs-extra';\nimport type { Umzug } from 'umzug';\n\nimport { createStorage } from './storage';\nimport { wrapTransaction } from './common';\nimport { transformLogMessage } from './logger';\n\nimport type { MigrationResolver, UserMigrationProvider } from './common';\nimport type { Database } from '..';\n\n// TODO: check multiple commands in one sql statement\nconst migrationResolver: MigrationResolver = ({ name, path, context }) => {\n const { db } = context;\n\n if (!path) {\n throw new Error(`Migration ${name} has no path`);\n }\n\n // if sql file run with knex raw\n if (path.match(/\\.sql$/)) {\n const sql = fse.readFileSync(path, 'utf8');\n\n return {\n name,\n up: wrapTransaction(db)((knex) => knex.raw(sql)),\n async down() {\n throw new Error('Down migration is not supported for sql files');\n },\n };\n }\n\n // NOTE: we can add some ts register if we want to handle ts migration files at some point\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const migration = require(path);\n return {\n name,\n up: wrapTransaction(db)(migration.up),\n down: wrapTransaction(db)(migration.down),\n };\n};\n\nexport const createUserMigrationProvider = (db: Database): UserMigrationProvider => {\n const dir = db.config.settings.migrations.dir;\n\n fse.ensureDirSync(dir);\n\n const context = { db };\n\n // Lazy: defer `umzug` (and its inquirer / @rushstack chain) until first call\n let lazyProvider: Umzug<typeof context> | undefined;\n const provider = (): Umzug<typeof context> => {\n if (lazyProvider) return lazyProvider;\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const { Umzug: UmzugCtor } = require('umzug') as typeof import('umzug');\n lazyProvider = new UmzugCtor({\n storage: createStorage({ db, tableName: 'strapi_migrations' }),\n logger: {\n info(message) {\n // NOTE: only log internal migration in debug mode\n db.logger.info(transformLogMessage('info', message));\n },\n warn(message) {\n db.logger.warn(transformLogMessage('warn', message));\n },\n error(message) {\n db.logger.error(transformLogMessage('error', message));\n },\n debug(message) {\n db.logger.debug(transformLogMessage('debug', message));\n },\n },\n context,\n migrations: {\n glob: ['*.{js,sql}', { cwd: dir }],\n resolve: migrationResolver,\n },\n });\n return lazyProvider;\n };\n\n return {\n async shouldRun() {\n const pendingMigrations = await provider().pending();\n return pendingMigrations.length > 0 && db.config?.settings?.runMigrations === true;\n },\n async up() {\n await provider().up();\n },\n async down() {\n await provider().down();\n },\n };\n};\n"],"names":["migrationResolver","name","path","context","db","Error","match","sql","fse","readFileSync","up","wrapTransaction","knex","raw","down","migration","require","createUserMigrationProvider","dir","config","settings","migrations","ensureDirSync","lazyProvider","provider","Umzug","UmzugCtor","storage","createStorage","tableName","logger","info","message","transformLogMessage","warn","error","debug","glob","cwd","resolve","shouldRun","pendingMigrations","pending","length","runMigrations"],"mappings":"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"}
@@ -1,5 +1,4 @@
1
1
  import fse from 'fs-extra';
2
- import { Umzug } from 'umzug';
3
2
  import { createStorage } from './storage.mjs';
4
3
  import { wrapTransaction } from './common.mjs';
5
4
  import { transformLogMessage } from './logger.mjs';
@@ -36,47 +35,55 @@ const createUserMigrationProvider = (db)=>{
36
35
  const context = {
37
36
  db
38
37
  };
39
- const umzugProvider = new Umzug({
40
- storage: createStorage({
41
- db,
42
- tableName: 'strapi_migrations'
43
- }),
44
- logger: {
45
- info (message) {
46
- // NOTE: only log internal migration in debug mode
47
- db.logger.info(transformLogMessage('info', message));
48
- },
49
- warn (message) {
50
- db.logger.warn(transformLogMessage('warn', message));
51
- },
52
- error (message) {
53
- db.logger.error(transformLogMessage('error', message));
38
+ // Lazy: defer `umzug` (and its inquirer / @rushstack chain) until first call
39
+ let lazyProvider;
40
+ const provider = ()=>{
41
+ if (lazyProvider) return lazyProvider;
42
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
43
+ const { Umzug: UmzugCtor } = require('umzug');
44
+ lazyProvider = new UmzugCtor({
45
+ storage: createStorage({
46
+ db,
47
+ tableName: 'strapi_migrations'
48
+ }),
49
+ logger: {
50
+ info (message) {
51
+ // NOTE: only log internal migration in debug mode
52
+ db.logger.info(transformLogMessage('info', message));
53
+ },
54
+ warn (message) {
55
+ db.logger.warn(transformLogMessage('warn', message));
56
+ },
57
+ error (message) {
58
+ db.logger.error(transformLogMessage('error', message));
59
+ },
60
+ debug (message) {
61
+ db.logger.debug(transformLogMessage('debug', message));
62
+ }
54
63
  },
55
- debug (message) {
56
- db.logger.debug(transformLogMessage('debug', message));
64
+ context,
65
+ migrations: {
66
+ glob: [
67
+ '*.{js,sql}',
68
+ {
69
+ cwd: dir
70
+ }
71
+ ],
72
+ resolve: migrationResolver
57
73
  }
58
- },
59
- context,
60
- migrations: {
61
- glob: [
62
- '*.{js,sql}',
63
- {
64
- cwd: dir
65
- }
66
- ],
67
- resolve: migrationResolver
68
- }
69
- });
74
+ });
75
+ return lazyProvider;
76
+ };
70
77
  return {
71
78
  async shouldRun () {
72
- const pendingMigrations = await umzugProvider.pending();
79
+ const pendingMigrations = await provider().pending();
73
80
  return pendingMigrations.length > 0 && db.config?.settings?.runMigrations === true;
74
81
  },
75
82
  async up () {
76
- await umzugProvider.up();
83
+ await provider().up();
77
84
  },
78
85
  async down () {
79
- await umzugProvider.down();
86
+ await provider().down();
80
87
  }
81
88
  };
82
89
  };
@@ -1 +1 @@
1
- {"version":3,"file":"users.mjs","sources":["../../src/migrations/users.ts"],"sourcesContent":["import fse from 'fs-extra';\nimport { Umzug } from 'umzug';\n\nimport { createStorage } from './storage';\nimport { wrapTransaction } from './common';\nimport { transformLogMessage } from './logger';\n\nimport type { MigrationResolver, UserMigrationProvider } from './common';\nimport type { Database } from '..';\n\n// TODO: check multiple commands in one sql statement\nconst migrationResolver: MigrationResolver = ({ name, path, context }) => {\n const { db } = context;\n\n if (!path) {\n throw new Error(`Migration ${name} has no path`);\n }\n\n // if sql file run with knex raw\n if (path.match(/\\.sql$/)) {\n const sql = fse.readFileSync(path, 'utf8');\n\n return {\n name,\n up: wrapTransaction(db)((knex) => knex.raw(sql)),\n async down() {\n throw new Error('Down migration is not supported for sql files');\n },\n };\n }\n\n // NOTE: we can add some ts register if we want to handle ts migration files at some point\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const migration = require(path);\n return {\n name,\n up: wrapTransaction(db)(migration.up),\n down: wrapTransaction(db)(migration.down),\n };\n};\n\nexport const createUserMigrationProvider = (db: Database): UserMigrationProvider => {\n const dir = db.config.settings.migrations.dir;\n\n fse.ensureDirSync(dir);\n\n const context = { db };\n\n const umzugProvider = new Umzug({\n storage: createStorage({ db, tableName: 'strapi_migrations' }),\n logger: {\n info(message) {\n // NOTE: only log internal migration in debug mode\n db.logger.info(transformLogMessage('info', message));\n },\n warn(message) {\n db.logger.warn(transformLogMessage('warn', message));\n },\n error(message) {\n db.logger.error(transformLogMessage('error', message));\n },\n debug(message) {\n db.logger.debug(transformLogMessage('debug', message));\n },\n },\n context,\n migrations: {\n glob: ['*.{js,sql}', { cwd: dir }],\n resolve: migrationResolver,\n },\n });\n\n return {\n async shouldRun() {\n const pendingMigrations = await umzugProvider.pending();\n return pendingMigrations.length > 0 && db.config?.settings?.runMigrations === true;\n },\n async up() {\n await umzugProvider.up();\n },\n async down() {\n await umzugProvider.down();\n },\n };\n};\n"],"names":["migrationResolver","name","path","context","db","Error","match","sql","fse","readFileSync","up","wrapTransaction","knex","raw","down","migration","require","createUserMigrationProvider","dir","config","settings","migrations","ensureDirSync","umzugProvider","Umzug","storage","createStorage","tableName","logger","info","message","transformLogMessage","warn","error","debug","glob","cwd","resolve","shouldRun","pendingMigrations","pending","length","runMigrations"],"mappings":"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"}
1
+ {"version":3,"file":"users.mjs","sources":["../../src/migrations/users.ts"],"sourcesContent":["import fse from 'fs-extra';\nimport type { Umzug } from 'umzug';\n\nimport { createStorage } from './storage';\nimport { wrapTransaction } from './common';\nimport { transformLogMessage } from './logger';\n\nimport type { MigrationResolver, UserMigrationProvider } from './common';\nimport type { Database } from '..';\n\n// TODO: check multiple commands in one sql statement\nconst migrationResolver: MigrationResolver = ({ name, path, context }) => {\n const { db } = context;\n\n if (!path) {\n throw new Error(`Migration ${name} has no path`);\n }\n\n // if sql file run with knex raw\n if (path.match(/\\.sql$/)) {\n const sql = fse.readFileSync(path, 'utf8');\n\n return {\n name,\n up: wrapTransaction(db)((knex) => knex.raw(sql)),\n async down() {\n throw new Error('Down migration is not supported for sql files');\n },\n };\n }\n\n // NOTE: we can add some ts register if we want to handle ts migration files at some point\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const migration = require(path);\n return {\n name,\n up: wrapTransaction(db)(migration.up),\n down: wrapTransaction(db)(migration.down),\n };\n};\n\nexport const createUserMigrationProvider = (db: Database): UserMigrationProvider => {\n const dir = db.config.settings.migrations.dir;\n\n fse.ensureDirSync(dir);\n\n const context = { db };\n\n // Lazy: defer `umzug` (and its inquirer / @rushstack chain) until first call\n let lazyProvider: Umzug<typeof context> | undefined;\n const provider = (): Umzug<typeof context> => {\n if (lazyProvider) return lazyProvider;\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const { Umzug: UmzugCtor } = require('umzug') as typeof import('umzug');\n lazyProvider = new UmzugCtor({\n storage: createStorage({ db, tableName: 'strapi_migrations' }),\n logger: {\n info(message) {\n // NOTE: only log internal migration in debug mode\n db.logger.info(transformLogMessage('info', message));\n },\n warn(message) {\n db.logger.warn(transformLogMessage('warn', message));\n },\n error(message) {\n db.logger.error(transformLogMessage('error', message));\n },\n debug(message) {\n db.logger.debug(transformLogMessage('debug', message));\n },\n },\n context,\n migrations: {\n glob: ['*.{js,sql}', { cwd: dir }],\n resolve: migrationResolver,\n },\n });\n return lazyProvider;\n };\n\n return {\n async shouldRun() {\n const pendingMigrations = await provider().pending();\n return pendingMigrations.length > 0 && db.config?.settings?.runMigrations === true;\n },\n async up() {\n await provider().up();\n },\n async down() {\n await provider().down();\n },\n };\n};\n"],"names":["migrationResolver","name","path","context","db","Error","match","sql","fse","readFileSync","up","wrapTransaction","knex","raw","down","migration","require","createUserMigrationProvider","dir","config","settings","migrations","ensureDirSync","lazyProvider","provider","Umzug","UmzugCtor","storage","createStorage","tableName","logger","info","message","transformLogMessage","warn","error","debug","glob","cwd","resolve","shouldRun","pendingMigrations","pending","length","runMigrations"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@strapi/database",
3
- "version": "5.47.0",
3
+ "version": "5.47.1",
4
4
  "description": "Strapi's database layer",
5
5
  "homepage": "https://strapi.io",
6
6
  "bugs": {
@@ -43,8 +43,8 @@
43
43
  },
44
44
  "dependencies": {
45
45
  "@paralleldrive/cuid2": "2.2.2",
46
- "@strapi/utils": "5.47.0",
47
- "ajv": "8.18.0",
46
+ "@strapi/utils": "5.47.1",
47
+ "ajv": "8.20.0",
48
48
  "date-fns": "2.30.0",
49
49
  "debug": "4.3.4",
50
50
  "fs-extra": "11.3.4",
@@ -55,8 +55,8 @@
55
55
  },
56
56
  "devDependencies": {
57
57
  "@types/fs-extra": "11.0.4",
58
- "eslint-config-custom": "5.47.0",
59
- "tsconfig": "5.47.0"
58
+ "eslint-config-custom": "5.47.1",
59
+ "tsconfig": "5.47.1"
60
60
  },
61
61
  "engines": {
62
62
  "node": ">=20.0.0 <=24.x.x",