@strapi/core 0.0.0-experimental.fc1ac2acd58c8a5a858679956b6d102ac5ee4011 → 0.0.0-experimental.fd379e4937e431407d784eaa5fe7f93cf2a53386

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.
Files changed (810) hide show
  1. package/LICENSE +18 -3
  2. package/dist/Strapi.d.ts +52 -59
  3. package/dist/Strapi.d.ts.map +1 -1
  4. package/dist/Strapi.js +195 -214
  5. package/dist/Strapi.js.map +1 -1
  6. package/dist/Strapi.mjs +165 -204
  7. package/dist/Strapi.mjs.map +1 -1
  8. package/dist/configuration/config-loader.d.ts.map +1 -1
  9. package/dist/configuration/config-loader.js +9 -5
  10. package/dist/configuration/config-loader.js.map +1 -1
  11. package/dist/configuration/config-loader.mjs +9 -5
  12. package/dist/configuration/config-loader.mjs.map +1 -1
  13. package/dist/configuration/get-dirs.d.ts +10 -0
  14. package/dist/configuration/get-dirs.d.ts.map +1 -0
  15. package/dist/{utils → configuration}/get-dirs.js +3 -2
  16. package/dist/configuration/get-dirs.js.map +1 -0
  17. package/dist/{utils → configuration}/get-dirs.mjs +3 -2
  18. package/dist/configuration/get-dirs.mjs.map +1 -0
  19. package/dist/configuration/index.d.ts +4 -7
  20. package/dist/configuration/index.d.ts.map +1 -1
  21. package/dist/configuration/index.js +8 -6
  22. package/dist/configuration/index.js.map +1 -1
  23. package/dist/configuration/index.mjs +5 -4
  24. package/dist/configuration/index.mjs.map +1 -1
  25. package/dist/container.d.ts +2 -2
  26. package/dist/container.d.ts.map +1 -1
  27. package/dist/container.js.map +1 -1
  28. package/dist/container.mjs.map +1 -1
  29. package/dist/core-api/controller/collection-type.d.ts +3 -3
  30. package/dist/core-api/controller/collection-type.d.ts.map +1 -1
  31. package/dist/core-api/controller/collection-type.js +6 -3
  32. package/dist/core-api/controller/collection-type.js.map +1 -1
  33. package/dist/core-api/controller/collection-type.mjs +3 -0
  34. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  35. package/dist/core-api/controller/index.d.ts +3 -3
  36. package/dist/core-api/controller/index.d.ts.map +1 -1
  37. package/dist/core-api/controller/index.js +7 -7
  38. package/dist/core-api/controller/index.js.map +1 -1
  39. package/dist/core-api/controller/index.mjs +6 -6
  40. package/dist/core-api/controller/index.mjs.map +1 -1
  41. package/dist/core-api/controller/single-type.d.ts +3 -3
  42. package/dist/core-api/controller/single-type.d.ts.map +1 -1
  43. package/dist/core-api/controller/single-type.js +3 -2
  44. package/dist/core-api/controller/single-type.js.map +1 -1
  45. package/dist/core-api/controller/single-type.mjs +1 -0
  46. package/dist/core-api/controller/single-type.mjs.map +1 -1
  47. package/dist/core-api/controller/transform.d.ts +2 -2
  48. package/dist/core-api/controller/transform.d.ts.map +1 -1
  49. package/dist/core-api/controller/transform.js +10 -13
  50. package/dist/core-api/controller/transform.js.map +1 -1
  51. package/dist/core-api/controller/transform.mjs +2 -5
  52. package/dist/core-api/controller/transform.mjs.map +1 -1
  53. package/dist/core-api/routes/index.d.ts.map +1 -1
  54. package/dist/core-api/service/collection-type.d.ts +11 -17
  55. package/dist/core-api/service/collection-type.d.ts.map +1 -1
  56. package/dist/core-api/service/collection-type.js +18 -7
  57. package/dist/core-api/service/collection-type.js.map +1 -1
  58. package/dist/core-api/service/collection-type.mjs +19 -8
  59. package/dist/core-api/service/collection-type.mjs.map +1 -1
  60. package/dist/core-api/service/index.d.ts +3 -3
  61. package/dist/core-api/service/index.d.ts.map +1 -1
  62. package/dist/core-api/service/index.js.map +1 -1
  63. package/dist/core-api/service/index.mjs.map +1 -1
  64. package/dist/core-api/service/pagination.d.ts +4 -11
  65. package/dist/core-api/service/pagination.d.ts.map +1 -1
  66. package/dist/core-api/service/pagination.js +18 -44
  67. package/dist/core-api/service/pagination.js.map +1 -1
  68. package/dist/core-api/service/pagination.mjs +16 -42
  69. package/dist/core-api/service/pagination.mjs.map +1 -1
  70. package/dist/core-api/service/single-type.d.ts +4 -4
  71. package/dist/core-api/service/single-type.d.ts.map +1 -1
  72. package/dist/core-api/service/single-type.js +9 -2
  73. package/dist/core-api/service/single-type.js.map +1 -1
  74. package/dist/core-api/service/single-type.mjs +9 -2
  75. package/dist/core-api/service/single-type.mjs.map +1 -1
  76. package/dist/domain/content-type/index.d.ts +1 -1
  77. package/dist/domain/content-type/index.d.ts.map +1 -1
  78. package/dist/domain/content-type/index.js +4 -4
  79. package/dist/domain/content-type/index.js.map +1 -1
  80. package/dist/domain/module/index.d.ts +24 -23
  81. package/dist/domain/module/index.d.ts.map +1 -1
  82. package/dist/domain/module/index.js +2 -1
  83. package/dist/domain/module/index.js.map +1 -1
  84. package/dist/domain/module/index.mjs +3 -2
  85. package/dist/domain/module/index.mjs.map +1 -1
  86. package/dist/ee/index.d.ts +4 -2
  87. package/dist/ee/index.d.ts.map +1 -1
  88. package/dist/ee/index.js +9 -4
  89. package/dist/ee/index.js.map +1 -1
  90. package/dist/ee/index.mjs +6 -1
  91. package/dist/ee/index.mjs.map +1 -1
  92. package/dist/ee/license.d.ts +2 -2
  93. package/dist/ee/license.d.ts.map +1 -1
  94. package/dist/ee/license.js +2 -1
  95. package/dist/ee/license.js.map +1 -1
  96. package/dist/ee/license.mjs +2 -1
  97. package/dist/ee/license.mjs.map +1 -1
  98. package/dist/factories.d.ts +10 -10
  99. package/dist/factories.d.ts.map +1 -1
  100. package/dist/factories.js +10 -6
  101. package/dist/factories.js.map +1 -1
  102. package/dist/factories.mjs +6 -2
  103. package/dist/factories.mjs.map +1 -1
  104. package/dist/index.d.ts +18 -2
  105. package/dist/index.d.ts.map +1 -1
  106. package/dist/index.js +25 -1
  107. package/dist/index.js.map +1 -1
  108. package/dist/index.mjs +27 -3
  109. package/dist/index.mjs.map +1 -1
  110. package/dist/loaders/admin.d.ts +2 -2
  111. package/dist/loaders/admin.d.ts.map +1 -1
  112. package/dist/loaders/admin.js +0 -1
  113. package/dist/loaders/admin.js.map +1 -1
  114. package/dist/loaders/admin.mjs +0 -1
  115. package/dist/loaders/admin.mjs.map +1 -1
  116. package/dist/loaders/apis.d.ts +2 -2
  117. package/dist/loaders/apis.d.ts.map +1 -1
  118. package/dist/loaders/apis.js +12 -12
  119. package/dist/loaders/apis.js.map +1 -1
  120. package/dist/loaders/apis.mjs +10 -10
  121. package/dist/loaders/apis.mjs.map +1 -1
  122. package/dist/loaders/components.d.ts +2 -2
  123. package/dist/loaders/components.d.ts.map +1 -1
  124. package/dist/loaders/components.js.map +1 -1
  125. package/dist/loaders/components.mjs.map +1 -1
  126. package/dist/loaders/index.d.ts +2 -2
  127. package/dist/loaders/index.d.ts.map +1 -1
  128. package/dist/loaders/index.js +0 -2
  129. package/dist/loaders/index.js.map +1 -1
  130. package/dist/loaders/index.mjs +0 -2
  131. package/dist/loaders/index.mjs.map +1 -1
  132. package/dist/loaders/middlewares.d.ts +2 -2
  133. package/dist/loaders/middlewares.d.ts.map +1 -1
  134. package/dist/loaders/middlewares.js.map +1 -1
  135. package/dist/loaders/middlewares.mjs.map +1 -1
  136. package/dist/loaders/plugins/get-enabled-plugins.d.ts +2 -2
  137. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  138. package/dist/loaders/plugins/get-enabled-plugins.js +46 -16
  139. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
  140. package/dist/loaders/plugins/get-enabled-plugins.mjs +16 -8
  141. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
  142. package/dist/loaders/plugins/get-user-plugins-config.js +2 -2
  143. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -1
  144. package/dist/loaders/plugins/index.d.ts +2 -2
  145. package/dist/loaders/plugins/index.d.ts.map +1 -1
  146. package/dist/loaders/plugins/index.js +34 -7
  147. package/dist/loaders/plugins/index.js.map +1 -1
  148. package/dist/loaders/plugins/index.mjs +9 -1
  149. package/dist/loaders/plugins/index.mjs.map +1 -1
  150. package/dist/loaders/policies.d.ts +2 -2
  151. package/dist/loaders/policies.d.ts.map +1 -1
  152. package/dist/loaders/policies.js.map +1 -1
  153. package/dist/loaders/policies.mjs.map +1 -1
  154. package/dist/loaders/sanitizers.d.ts +2 -2
  155. package/dist/loaders/sanitizers.d.ts.map +1 -1
  156. package/dist/loaders/sanitizers.js.map +1 -1
  157. package/dist/loaders/sanitizers.mjs.map +1 -1
  158. package/dist/loaders/src-index.d.ts +2 -2
  159. package/dist/loaders/src-index.d.ts.map +1 -1
  160. package/dist/loaders/src-index.js.map +1 -1
  161. package/dist/loaders/src-index.mjs.map +1 -1
  162. package/dist/loaders/validators.d.ts +2 -2
  163. package/dist/loaders/validators.d.ts.map +1 -1
  164. package/dist/loaders/validators.js.map +1 -1
  165. package/dist/loaders/validators.mjs.map +1 -1
  166. package/dist/middlewares/body.d.ts +4 -4
  167. package/dist/middlewares/body.d.ts.map +1 -1
  168. package/dist/middlewares/body.js +6 -6
  169. package/dist/middlewares/body.js.map +1 -1
  170. package/dist/middlewares/body.mjs +4 -4
  171. package/dist/middlewares/body.mjs.map +1 -1
  172. package/dist/middlewares/compression.d.ts +2 -2
  173. package/dist/middlewares/compression.d.ts.map +1 -1
  174. package/dist/middlewares/compression.js.map +1 -1
  175. package/dist/middlewares/compression.mjs.map +1 -1
  176. package/dist/middlewares/cors.d.ts +2 -2
  177. package/dist/middlewares/cors.d.ts.map +1 -1
  178. package/dist/middlewares/cors.js +9 -7
  179. package/dist/middlewares/cors.js.map +1 -1
  180. package/dist/middlewares/cors.mjs +9 -7
  181. package/dist/middlewares/cors.mjs.map +1 -1
  182. package/dist/middlewares/errors.d.ts +2 -2
  183. package/dist/middlewares/errors.d.ts.map +1 -1
  184. package/dist/middlewares/errors.js.map +1 -1
  185. package/dist/middlewares/errors.mjs.map +1 -1
  186. package/dist/middlewares/favicon.d.ts +2 -2
  187. package/dist/middlewares/favicon.d.ts.map +1 -1
  188. package/dist/middlewares/favicon.js.map +1 -1
  189. package/dist/middlewares/favicon.mjs.map +1 -1
  190. package/dist/middlewares/index.d.ts +2 -2
  191. package/dist/middlewares/index.d.ts.map +1 -1
  192. package/dist/middlewares/index.js.map +1 -1
  193. package/dist/middlewares/index.mjs.map +1 -1
  194. package/dist/middlewares/ip.d.ts +2 -2
  195. package/dist/middlewares/ip.d.ts.map +1 -1
  196. package/dist/middlewares/ip.js.map +1 -1
  197. package/dist/middlewares/ip.mjs.map +1 -1
  198. package/dist/middlewares/logger.d.ts +2 -2
  199. package/dist/middlewares/logger.d.ts.map +1 -1
  200. package/dist/middlewares/logger.js.map +1 -1
  201. package/dist/middlewares/logger.mjs.map +1 -1
  202. package/dist/middlewares/powered-by.d.ts +2 -2
  203. package/dist/middlewares/powered-by.d.ts.map +1 -1
  204. package/dist/middlewares/powered-by.js.map +1 -1
  205. package/dist/middlewares/powered-by.mjs.map +1 -1
  206. package/dist/middlewares/public.d.ts +2 -2
  207. package/dist/middlewares/public.d.ts.map +1 -1
  208. package/dist/middlewares/public.js +3 -3
  209. package/dist/middlewares/public.js.map +1 -1
  210. package/dist/middlewares/public.mjs +1 -1
  211. package/dist/middlewares/public.mjs.map +1 -1
  212. package/dist/middlewares/query.d.ts +2 -2
  213. package/dist/middlewares/query.d.ts.map +1 -1
  214. package/dist/middlewares/query.js.map +1 -1
  215. package/dist/middlewares/query.mjs.map +1 -1
  216. package/dist/middlewares/response-time.d.ts +2 -2
  217. package/dist/middlewares/response-time.d.ts.map +1 -1
  218. package/dist/middlewares/response-time.js.map +1 -1
  219. package/dist/middlewares/response-time.mjs.map +1 -1
  220. package/dist/middlewares/responses.d.ts +3 -3
  221. package/dist/middlewares/responses.d.ts.map +1 -1
  222. package/dist/middlewares/responses.js +2 -2
  223. package/dist/middlewares/responses.js.map +1 -1
  224. package/dist/middlewares/responses.mjs.map +1 -1
  225. package/dist/middlewares/security.d.ts +2 -2
  226. package/dist/middlewares/security.d.ts.map +1 -1
  227. package/dist/middlewares/security.js +13 -6
  228. package/dist/middlewares/security.js.map +1 -1
  229. package/dist/middlewares/security.mjs +12 -5
  230. package/dist/middlewares/security.mjs.map +1 -1
  231. package/dist/middlewares/session.d.ts +2 -2
  232. package/dist/middlewares/session.d.ts.map +1 -1
  233. package/dist/middlewares/session.js +2 -2
  234. package/dist/middlewares/session.js.map +1 -1
  235. package/dist/middlewares/session.mjs.map +1 -1
  236. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +33 -0
  237. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -0
  238. package/dist/migrations/database/5.0.0-discard-drafts.js +94 -0
  239. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -0
  240. package/dist/migrations/database/5.0.0-discard-drafts.mjs +94 -0
  241. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -0
  242. package/dist/migrations/draft-publish.d.ts +1 -1
  243. package/dist/migrations/draft-publish.d.ts.map +1 -1
  244. package/dist/migrations/draft-publish.js +14 -31
  245. package/dist/migrations/draft-publish.js.map +1 -1
  246. package/dist/migrations/draft-publish.mjs +15 -32
  247. package/dist/migrations/draft-publish.mjs.map +1 -1
  248. package/dist/migrations/i18n.d.ts +5 -0
  249. package/dist/migrations/i18n.d.ts.map +1 -0
  250. package/dist/migrations/i18n.js +54 -0
  251. package/dist/migrations/i18n.js.map +1 -0
  252. package/dist/migrations/i18n.mjs +54 -0
  253. package/dist/migrations/i18n.mjs.map +1 -0
  254. package/dist/migrations/index.d.ts +5 -0
  255. package/dist/migrations/index.d.ts.map +1 -0
  256. package/dist/migrations/index.js +15 -0
  257. package/dist/migrations/index.js.map +1 -0
  258. package/dist/migrations/index.mjs +15 -0
  259. package/dist/migrations/index.mjs.map +1 -0
  260. package/dist/providers/admin.d.ts +3 -0
  261. package/dist/providers/admin.d.ts.map +1 -0
  262. package/dist/providers/admin.js +20 -0
  263. package/dist/providers/admin.js.map +1 -0
  264. package/dist/providers/admin.mjs +21 -0
  265. package/dist/providers/admin.mjs.map +1 -0
  266. package/dist/providers/coreStore.d.ts +3 -0
  267. package/dist/providers/coreStore.d.ts.map +1 -0
  268. package/dist/providers/coreStore.js +11 -0
  269. package/dist/providers/coreStore.js.map +1 -0
  270. package/dist/providers/coreStore.mjs +12 -0
  271. package/dist/providers/coreStore.mjs.map +1 -0
  272. package/dist/providers/cron.d.ts +3 -0
  273. package/dist/providers/cron.d.ts.map +1 -0
  274. package/dist/providers/cron.js +20 -0
  275. package/dist/providers/cron.js.map +1 -0
  276. package/dist/providers/cron.mjs +21 -0
  277. package/dist/providers/cron.mjs.map +1 -0
  278. package/dist/providers/index.d.ts +3 -0
  279. package/dist/providers/index.d.ts.map +1 -0
  280. package/dist/providers/index.js +11 -0
  281. package/dist/providers/index.js.map +1 -0
  282. package/dist/providers/index.mjs +11 -0
  283. package/dist/providers/index.mjs.map +1 -0
  284. package/dist/providers/provider.d.ts +9 -0
  285. package/dist/providers/provider.d.ts.map +1 -0
  286. package/dist/providers/provider.js +5 -0
  287. package/dist/providers/provider.js.map +1 -0
  288. package/dist/providers/provider.mjs +5 -0
  289. package/dist/providers/provider.mjs.map +1 -0
  290. package/dist/providers/registries.d.ts +3 -0
  291. package/dist/providers/registries.d.ts.map +1 -0
  292. package/dist/providers/registries.js +35 -0
  293. package/dist/providers/registries.js.map +1 -0
  294. package/dist/providers/registries.mjs +36 -0
  295. package/dist/providers/registries.mjs.map +1 -0
  296. package/dist/providers/telemetry.d.ts +3 -0
  297. package/dist/providers/telemetry.d.ts.map +1 -0
  298. package/dist/providers/telemetry.js +19 -0
  299. package/dist/providers/telemetry.js.map +1 -0
  300. package/dist/providers/telemetry.mjs +20 -0
  301. package/dist/providers/telemetry.mjs.map +1 -0
  302. package/dist/providers/webhooks.d.ts +3 -0
  303. package/dist/providers/webhooks.d.ts.map +1 -0
  304. package/dist/providers/webhooks.js +30 -0
  305. package/dist/providers/webhooks.js.map +1 -0
  306. package/dist/providers/webhooks.mjs +31 -0
  307. package/dist/providers/webhooks.mjs.map +1 -0
  308. package/dist/registries/apis.d.ts +2 -2
  309. package/dist/registries/apis.d.ts.map +1 -1
  310. package/dist/registries/apis.js +2 -2
  311. package/dist/registries/apis.js.map +1 -1
  312. package/dist/registries/apis.mjs.map +1 -1
  313. package/dist/registries/components.d.ts +6 -6
  314. package/dist/registries/components.d.ts.map +1 -1
  315. package/dist/registries/components.js +2 -2
  316. package/dist/registries/components.js.map +1 -1
  317. package/dist/registries/components.mjs.map +1 -1
  318. package/dist/registries/content-types.d.ts +5 -5
  319. package/dist/registries/content-types.d.ts.map +1 -1
  320. package/dist/registries/content-types.js +3 -3
  321. package/dist/registries/content-types.js.map +1 -1
  322. package/dist/registries/content-types.mjs.map +1 -1
  323. package/dist/registries/controllers.d.ts +10 -10
  324. package/dist/registries/controllers.d.ts.map +1 -1
  325. package/dist/registries/controllers.js +3 -3
  326. package/dist/registries/controllers.js.map +1 -1
  327. package/dist/registries/controllers.mjs.map +1 -1
  328. package/dist/registries/custom-fields.d.ts +3 -3
  329. package/dist/registries/custom-fields.d.ts.map +1 -1
  330. package/dist/registries/custom-fields.js +4 -4
  331. package/dist/registries/custom-fields.js.map +1 -1
  332. package/dist/registries/custom-fields.mjs.map +1 -1
  333. package/dist/registries/hooks.js +2 -2
  334. package/dist/registries/hooks.js.map +1 -1
  335. package/dist/registries/index.d.ts +0 -1
  336. package/dist/registries/index.d.ts.map +1 -1
  337. package/dist/registries/middlewares.d.ts +6 -6
  338. package/dist/registries/middlewares.d.ts.map +1 -1
  339. package/dist/registries/middlewares.js +3 -3
  340. package/dist/registries/middlewares.js.map +1 -1
  341. package/dist/registries/middlewares.mjs.map +1 -1
  342. package/dist/registries/modules.d.ts +2 -2
  343. package/dist/registries/modules.d.ts.map +1 -1
  344. package/dist/registries/modules.js +3 -3
  345. package/dist/registries/modules.js.map +1 -1
  346. package/dist/registries/modules.mjs.map +1 -1
  347. package/dist/registries/plugins.d.ts +5 -5
  348. package/dist/registries/plugins.d.ts.map +1 -1
  349. package/dist/registries/plugins.js +2 -2
  350. package/dist/registries/plugins.js.map +1 -1
  351. package/dist/registries/plugins.mjs.map +1 -1
  352. package/dist/registries/policies.d.ts +22 -10
  353. package/dist/registries/policies.d.ts.map +1 -1
  354. package/dist/registries/policies.js +66 -20
  355. package/dist/registries/policies.js.map +1 -1
  356. package/dist/registries/policies.mjs +65 -19
  357. package/dist/registries/policies.mjs.map +1 -1
  358. package/dist/registries/services.d.ts +8 -8
  359. package/dist/registries/services.d.ts.map +1 -1
  360. package/dist/registries/services.js +3 -3
  361. package/dist/registries/services.js.map +1 -1
  362. package/dist/registries/services.mjs.map +1 -1
  363. package/dist/services/auth/index.d.ts +4 -4
  364. package/dist/services/auth/index.d.ts.map +1 -1
  365. package/dist/services/auth/index.js +3 -3
  366. package/dist/services/auth/index.js.map +1 -1
  367. package/dist/services/auth/index.mjs.map +1 -1
  368. package/dist/services/config.d.ts +3 -0
  369. package/dist/services/config.d.ts.map +1 -0
  370. package/dist/services/config.js +47 -0
  371. package/dist/services/config.js.map +1 -0
  372. package/dist/services/config.mjs +47 -0
  373. package/dist/services/config.mjs.map +1 -0
  374. package/dist/services/content-api/index.d.ts +31 -15
  375. package/dist/services/content-api/index.d.ts.map +1 -1
  376. package/dist/services/content-api/index.js +28 -2
  377. package/dist/services/content-api/index.js.map +1 -1
  378. package/dist/services/content-api/index.mjs +28 -2
  379. package/dist/services/content-api/index.mjs.map +1 -1
  380. package/dist/services/content-api/permissions/index.d.ts +13 -15
  381. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  382. package/dist/services/content-api/permissions/index.js +1 -1
  383. package/dist/services/content-api/permissions/index.js.map +1 -1
  384. package/dist/services/content-api/permissions/index.mjs +1 -1
  385. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  386. package/dist/services/content-api/permissions/providers/action.d.ts +5 -6
  387. package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -1
  388. package/dist/services/content-api/permissions/providers/condition.d.ts +5 -6
  389. package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -1
  390. package/dist/services/core-store.d.ts.map +1 -1
  391. package/dist/services/core-store.js +3 -3
  392. package/dist/services/core-store.js.map +1 -1
  393. package/dist/services/cron.d.ts +5 -5
  394. package/dist/services/cron.d.ts.map +1 -1
  395. package/dist/services/cron.js +3 -3
  396. package/dist/services/cron.js.map +1 -1
  397. package/dist/services/cron.mjs.map +1 -1
  398. package/dist/services/custom-fields.d.ts +2 -2
  399. package/dist/services/custom-fields.d.ts.map +1 -1
  400. package/dist/services/custom-fields.js.map +1 -1
  401. package/dist/services/custom-fields.mjs.map +1 -1
  402. package/dist/services/document-service/attributes/index.d.ts +6 -0
  403. package/dist/services/document-service/attributes/index.d.ts.map +1 -0
  404. package/dist/services/{entity-service → document-service}/attributes/index.js +5 -5
  405. package/dist/services/document-service/attributes/index.js.map +1 -0
  406. package/dist/services/{entity-service → document-service}/attributes/index.mjs +5 -5
  407. package/dist/services/document-service/attributes/index.mjs.map +1 -0
  408. package/dist/services/document-service/attributes/transforms.d.ts +10 -0
  409. package/dist/services/document-service/attributes/transforms.d.ts.map +1 -0
  410. package/dist/services/{entity-service → document-service}/attributes/transforms.js +3 -3
  411. package/dist/services/document-service/attributes/transforms.js.map +1 -0
  412. package/dist/services/document-service/attributes/transforms.mjs.map +1 -0
  413. package/dist/services/document-service/common.d.ts +2 -2
  414. package/dist/services/document-service/common.d.ts.map +1 -1
  415. package/dist/services/document-service/common.js.map +1 -1
  416. package/dist/services/document-service/common.mjs.map +1 -1
  417. package/dist/services/document-service/components.d.ts +25 -1
  418. package/dist/services/document-service/components.d.ts.map +1 -1
  419. package/dist/services/{entity-service → document-service}/components.js +52 -148
  420. package/dist/services/document-service/components.js.map +1 -0
  421. package/dist/services/{entity-service → document-service}/components.mjs +42 -138
  422. package/dist/services/document-service/components.mjs.map +1 -0
  423. package/dist/services/document-service/draft-and-publish.d.ts +7 -7
  424. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  425. package/dist/services/document-service/draft-and-publish.js +16 -16
  426. package/dist/services/document-service/draft-and-publish.js.map +1 -1
  427. package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
  428. package/dist/services/document-service/entries.d.ts +10 -0
  429. package/dist/services/document-service/entries.d.ts.map +1 -0
  430. package/dist/services/document-service/entries.js +96 -0
  431. package/dist/services/document-service/entries.js.map +1 -0
  432. package/dist/services/document-service/entries.mjs +96 -0
  433. package/dist/services/document-service/entries.mjs.map +1 -0
  434. package/dist/services/document-service/events.d.ts +25 -0
  435. package/dist/services/document-service/events.d.ts.map +1 -0
  436. package/dist/services/document-service/events.js +47 -0
  437. package/dist/services/document-service/events.js.map +1 -0
  438. package/dist/services/document-service/events.mjs +47 -0
  439. package/dist/services/document-service/events.mjs.map +1 -0
  440. package/dist/services/document-service/index.d.ts +2 -4
  441. package/dist/services/document-service/index.d.ts.map +1 -1
  442. package/dist/services/document-service/index.js +18 -5
  443. package/dist/services/document-service/index.js.map +1 -1
  444. package/dist/services/document-service/index.mjs +16 -3
  445. package/dist/services/document-service/index.mjs.map +1 -1
  446. package/dist/services/document-service/internationalization.d.ts +5 -5
  447. package/dist/services/document-service/internationalization.d.ts.map +1 -1
  448. package/dist/services/document-service/internationalization.js +21 -12
  449. package/dist/services/document-service/internationalization.js.map +1 -1
  450. package/dist/services/document-service/internationalization.mjs +14 -5
  451. package/dist/services/document-service/internationalization.mjs.map +1 -1
  452. package/dist/services/document-service/middlewares/errors.d.ts +6 -0
  453. package/dist/services/document-service/middlewares/errors.d.ts.map +1 -0
  454. package/dist/services/document-service/middlewares/errors.js +25 -0
  455. package/dist/services/document-service/middlewares/errors.js.map +1 -0
  456. package/dist/services/document-service/middlewares/errors.mjs +25 -0
  457. package/dist/services/document-service/middlewares/errors.mjs.map +1 -0
  458. package/dist/services/document-service/middlewares/index.d.ts +3 -0
  459. package/dist/services/document-service/middlewares/index.d.ts.map +1 -0
  460. package/dist/services/document-service/middlewares/middleware-manager.d.ts +10 -0
  461. package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -0
  462. package/dist/services/document-service/{middlewares.js → middlewares/middleware-manager.js} +9 -6
  463. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -0
  464. package/dist/services/document-service/{middlewares.mjs → middlewares/middleware-manager.mjs} +9 -6
  465. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -0
  466. package/dist/services/document-service/params.d.ts +3 -1
  467. package/dist/services/document-service/params.d.ts.map +1 -1
  468. package/dist/services/{entity-service → document-service}/params.js +2 -2
  469. package/dist/services/document-service/params.js.map +1 -0
  470. package/dist/services/document-service/params.mjs.map +1 -0
  471. package/dist/services/document-service/repository.d.ts.map +1 -1
  472. package/dist/services/document-service/repository.js +207 -183
  473. package/dist/services/document-service/repository.js.map +1 -1
  474. package/dist/services/document-service/repository.mjs +187 -163
  475. package/dist/services/document-service/repository.mjs.map +1 -1
  476. package/dist/services/document-service/transform/data.d.ts.map +1 -1
  477. package/dist/services/document-service/transform/data.js +4 -2
  478. package/dist/services/document-service/transform/data.js.map +1 -1
  479. package/dist/services/document-service/transform/data.mjs +4 -2
  480. package/dist/services/document-service/transform/data.mjs.map +1 -1
  481. package/dist/services/document-service/transform/fields.d.ts +2 -2
  482. package/dist/services/document-service/transform/fields.d.ts.map +1 -1
  483. package/dist/services/document-service/transform/fields.js.map +1 -1
  484. package/dist/services/document-service/transform/fields.mjs.map +1 -1
  485. package/dist/services/document-service/transform/id-map.d.ts +3 -3
  486. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  487. package/dist/services/document-service/transform/id-map.js.map +1 -1
  488. package/dist/services/document-service/transform/id-map.mjs.map +1 -1
  489. package/dist/services/document-service/transform/id-transform.d.ts +2 -2
  490. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  491. package/dist/services/document-service/transform/id-transform.js +2 -2
  492. package/dist/services/document-service/transform/id-transform.js.map +1 -1
  493. package/dist/services/document-service/transform/id-transform.mjs.map +1 -1
  494. package/dist/services/document-service/transform/populate.d.ts +2 -2
  495. package/dist/services/document-service/transform/populate.d.ts.map +1 -1
  496. package/dist/services/document-service/transform/populate.js +1 -1
  497. package/dist/services/document-service/transform/populate.js.map +1 -1
  498. package/dist/services/document-service/transform/populate.mjs +1 -1
  499. package/dist/services/document-service/transform/populate.mjs.map +1 -1
  500. package/dist/services/document-service/transform/query.d.ts +5 -0
  501. package/dist/services/document-service/transform/query.d.ts.map +1 -0
  502. package/dist/services/document-service/transform/query.js +9 -0
  503. package/dist/services/document-service/transform/query.js.map +1 -0
  504. package/dist/services/document-service/transform/query.mjs +9 -0
  505. package/dist/services/document-service/transform/query.mjs.map +1 -0
  506. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +8 -7
  507. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  508. package/dist/services/document-service/transform/relations/extract/data-ids.js +45 -78
  509. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
  510. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +44 -77
  511. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
  512. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +8 -4
  513. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  514. package/dist/services/document-service/transform/relations/transform/data-ids.js +61 -126
  515. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
  516. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +61 -126
  517. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
  518. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts +9 -0
  519. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts.map +1 -0
  520. package/dist/services/document-service/transform/relations/transform/default-locale.js +32 -0
  521. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -0
  522. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +32 -0
  523. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -0
  524. package/dist/services/document-service/transform/relations/utils/dp.d.ts +3 -3
  525. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  526. package/dist/services/document-service/transform/relations/utils/dp.js +10 -5
  527. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -1
  528. package/dist/services/document-service/transform/relations/utils/dp.mjs +9 -4
  529. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -1
  530. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +6 -6
  531. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  532. package/dist/services/document-service/transform/relations/utils/i18n.js +3 -9
  533. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
  534. package/dist/services/document-service/transform/relations/utils/i18n.mjs +3 -9
  535. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
  536. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts +6 -0
  537. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -0
  538. package/dist/services/document-service/transform/relations/utils/map-relation.js +91 -0
  539. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -0
  540. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +91 -0
  541. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -0
  542. package/dist/services/document-service/transform/relations/utils/types.d.ts +6 -0
  543. package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -1
  544. package/dist/services/document-service/transform/types.d.ts +3 -3
  545. package/dist/services/document-service/transform/types.d.ts.map +1 -1
  546. package/dist/services/document-service/utils/populate.d.ts +9 -2
  547. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  548. package/dist/services/document-service/utils/populate.js +11 -5
  549. package/dist/services/document-service/utils/populate.js.map +1 -1
  550. package/dist/services/document-service/utils/populate.mjs +11 -5
  551. package/dist/services/document-service/utils/populate.mjs.map +1 -1
  552. package/dist/services/document-service/utils/unidirectional-relations.d.ts +36 -0
  553. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -0
  554. package/dist/services/document-service/utils/unidirectional-relations.js +69 -0
  555. package/dist/services/document-service/utils/unidirectional-relations.js.map +1 -0
  556. package/dist/services/document-service/utils/unidirectional-relations.mjs +69 -0
  557. package/dist/services/document-service/utils/unidirectional-relations.mjs.map +1 -0
  558. package/dist/services/entity-service/index.d.ts +4 -6
  559. package/dist/services/entity-service/index.d.ts.map +1 -1
  560. package/dist/services/entity-service/index.js +44 -203
  561. package/dist/services/entity-service/index.js.map +1 -1
  562. package/dist/services/entity-service/index.mjs +38 -197
  563. package/dist/services/entity-service/index.mjs.map +1 -1
  564. package/dist/services/entity-validator/blocks-validator.d.ts +1 -2
  565. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
  566. package/dist/services/entity-validator/blocks-validator.js +4 -3
  567. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  568. package/dist/services/entity-validator/blocks-validator.mjs +3 -3
  569. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  570. package/dist/services/entity-validator/index.d.ts +16 -2
  571. package/dist/services/entity-validator/index.d.ts.map +1 -1
  572. package/dist/services/entity-validator/index.js +197 -130
  573. package/dist/services/entity-validator/index.js.map +1 -1
  574. package/dist/services/entity-validator/index.mjs +192 -125
  575. package/dist/services/entity-validator/index.mjs.map +1 -1
  576. package/dist/services/entity-validator/validators.d.ts +36 -25
  577. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  578. package/dist/services/entity-validator/validators.js +153 -33
  579. package/dist/services/entity-validator/validators.js.map +1 -1
  580. package/dist/services/entity-validator/validators.mjs +145 -25
  581. package/dist/services/entity-validator/validators.mjs.map +1 -1
  582. package/dist/services/event-hub.d.ts +1 -0
  583. package/dist/services/event-hub.d.ts.map +1 -1
  584. package/dist/services/event-hub.js +9 -4
  585. package/dist/services/event-hub.js.map +1 -1
  586. package/dist/services/event-hub.mjs +9 -4
  587. package/dist/services/event-hub.mjs.map +1 -1
  588. package/dist/services/features.d.ts +3 -3
  589. package/dist/services/features.d.ts.map +1 -1
  590. package/dist/services/features.js.map +1 -1
  591. package/dist/services/features.mjs.map +1 -1
  592. package/dist/services/fs.d.ts +2 -2
  593. package/dist/services/fs.d.ts.map +1 -1
  594. package/dist/services/fs.js.map +1 -1
  595. package/dist/services/fs.mjs.map +1 -1
  596. package/dist/services/metrics/admin-user-hash.d.ts +2 -2
  597. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  598. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  599. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  600. package/dist/services/metrics/index.d.ts +2 -2
  601. package/dist/services/metrics/index.d.ts.map +1 -1
  602. package/dist/services/metrics/index.js.map +1 -1
  603. package/dist/services/metrics/index.mjs.map +1 -1
  604. package/dist/services/metrics/middleware.d.ts +2 -2
  605. package/dist/services/metrics/middleware.d.ts.map +1 -1
  606. package/dist/services/metrics/middleware.js.map +1 -1
  607. package/dist/services/metrics/middleware.mjs.map +1 -1
  608. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  609. package/dist/services/metrics/rate-limiter.js.map +1 -1
  610. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  611. package/dist/services/metrics/sender.d.ts +3 -3
  612. package/dist/services/metrics/sender.d.ts.map +1 -1
  613. package/dist/services/metrics/sender.js.map +1 -1
  614. package/dist/services/metrics/sender.mjs.map +1 -1
  615. package/dist/services/query-params.d.ts +7 -0
  616. package/dist/services/query-params.d.ts.map +1 -0
  617. package/dist/services/query-params.js +12 -0
  618. package/dist/services/query-params.js.map +1 -0
  619. package/dist/services/query-params.mjs +13 -0
  620. package/dist/services/query-params.mjs.map +1 -0
  621. package/dist/services/reloader.d.ts +7 -0
  622. package/dist/services/reloader.d.ts.map +1 -0
  623. package/dist/services/reloader.js +36 -0
  624. package/dist/services/reloader.js.map +1 -0
  625. package/dist/services/reloader.mjs +36 -0
  626. package/dist/services/reloader.mjs.map +1 -0
  627. package/dist/services/server/admin-api.d.ts +3 -3
  628. package/dist/services/server/admin-api.d.ts.map +1 -1
  629. package/dist/services/server/admin-api.js.map +1 -1
  630. package/dist/services/server/admin-api.mjs.map +1 -1
  631. package/dist/services/server/api.d.ts +3 -3
  632. package/dist/services/server/api.d.ts.map +1 -1
  633. package/dist/services/server/api.js.map +1 -1
  634. package/dist/services/server/api.mjs.map +1 -1
  635. package/dist/services/server/compose-endpoint.d.ts +2 -2
  636. package/dist/services/server/compose-endpoint.d.ts.map +1 -1
  637. package/dist/services/server/compose-endpoint.js +8 -9
  638. package/dist/services/server/compose-endpoint.js.map +1 -1
  639. package/dist/services/server/compose-endpoint.mjs +2 -3
  640. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  641. package/dist/services/server/content-api.d.ts +3 -3
  642. package/dist/services/server/content-api.d.ts.map +1 -1
  643. package/dist/services/server/content-api.js.map +1 -1
  644. package/dist/services/server/content-api.mjs.map +1 -1
  645. package/dist/services/server/http-server.d.ts +2 -2
  646. package/dist/services/server/http-server.d.ts.map +1 -1
  647. package/dist/services/server/http-server.js.map +1 -1
  648. package/dist/services/server/http-server.mjs.map +1 -1
  649. package/dist/services/server/index.d.ts +2 -2
  650. package/dist/services/server/index.d.ts.map +1 -1
  651. package/dist/services/server/index.js +2 -3
  652. package/dist/services/server/index.js.map +1 -1
  653. package/dist/services/server/index.mjs +2 -3
  654. package/dist/services/server/index.mjs.map +1 -1
  655. package/dist/services/server/koa.d.ts.map +1 -1
  656. package/dist/services/server/koa.js +4 -4
  657. package/dist/services/server/koa.js.map +1 -1
  658. package/dist/services/server/koa.mjs +1 -1
  659. package/dist/services/server/koa.mjs.map +1 -1
  660. package/dist/services/server/middleware.d.ts +4 -4
  661. package/dist/services/server/middleware.d.ts.map +1 -1
  662. package/dist/services/server/middleware.js +3 -3
  663. package/dist/services/server/middleware.js.map +1 -1
  664. package/dist/services/server/middleware.mjs.map +1 -1
  665. package/dist/services/server/policy.d.ts +3 -3
  666. package/dist/services/server/policy.d.ts.map +1 -1
  667. package/dist/services/server/policy.js +4 -4
  668. package/dist/services/server/policy.js.map +1 -1
  669. package/dist/services/server/policy.mjs +4 -4
  670. package/dist/services/server/policy.mjs.map +1 -1
  671. package/dist/services/server/register-middlewares.d.ts +2 -2
  672. package/dist/services/server/register-middlewares.d.ts.map +1 -1
  673. package/dist/services/server/register-middlewares.js.map +1 -1
  674. package/dist/services/server/register-middlewares.mjs.map +1 -1
  675. package/dist/services/server/register-routes.d.ts +2 -2
  676. package/dist/services/server/register-routes.d.ts.map +1 -1
  677. package/dist/services/server/register-routes.js +3 -3
  678. package/dist/services/server/register-routes.js.map +1 -1
  679. package/dist/services/server/register-routes.mjs +3 -3
  680. package/dist/services/server/register-routes.mjs.map +1 -1
  681. package/dist/services/server/routing.d.ts +5 -5
  682. package/dist/services/server/routing.d.ts.map +1 -1
  683. package/dist/services/server/routing.js +2 -2
  684. package/dist/services/server/routing.js.map +1 -1
  685. package/dist/services/server/routing.mjs.map +1 -1
  686. package/dist/services/utils/dynamic-zones.d.ts.map +1 -1
  687. package/dist/services/utils/dynamic-zones.js +7 -6
  688. package/dist/services/utils/dynamic-zones.js.map +1 -1
  689. package/dist/services/utils/dynamic-zones.mjs +2 -1
  690. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  691. package/dist/services/webhook-runner.d.ts +2 -1
  692. package/dist/services/webhook-runner.d.ts.map +1 -1
  693. package/dist/services/webhook-runner.js.map +1 -1
  694. package/dist/services/webhook-runner.mjs.map +1 -1
  695. package/dist/services/webhook-store.d.ts +2 -8
  696. package/dist/services/webhook-store.d.ts.map +1 -1
  697. package/dist/services/webhook-store.js +14 -8
  698. package/dist/services/webhook-store.js.map +1 -1
  699. package/dist/services/webhook-store.mjs +14 -8
  700. package/dist/services/webhook-store.mjs.map +1 -1
  701. package/dist/utils/convert-custom-field-type.d.ts +2 -2
  702. package/dist/utils/convert-custom-field-type.d.ts.map +1 -1
  703. package/dist/utils/convert-custom-field-type.js.map +1 -1
  704. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  705. package/dist/utils/cron.js +3 -3
  706. package/dist/utils/cron.js.map +1 -1
  707. package/dist/utils/fetch.d.ts +3 -3
  708. package/dist/utils/fetch.d.ts.map +1 -1
  709. package/dist/utils/fetch.js +4 -3
  710. package/dist/utils/fetch.js.map +1 -1
  711. package/dist/utils/fetch.mjs +4 -3
  712. package/dist/utils/fetch.mjs.map +1 -1
  713. package/dist/utils/filepath-to-prop-path.d.ts +1 -1
  714. package/dist/utils/filepath-to-prop-path.d.ts.map +1 -1
  715. package/dist/utils/filepath-to-prop-path.js +27 -6
  716. package/dist/utils/filepath-to-prop-path.js.map +1 -1
  717. package/dist/utils/filepath-to-prop-path.mjs +25 -5
  718. package/dist/utils/filepath-to-prop-path.mjs.map +1 -1
  719. package/dist/utils/index.d.ts +2 -1
  720. package/dist/utils/index.d.ts.map +1 -1
  721. package/dist/utils/is-initialized.d.ts +2 -2
  722. package/dist/utils/is-initialized.d.ts.map +1 -1
  723. package/dist/utils/is-initialized.js +4 -4
  724. package/dist/utils/is-initialized.js.map +1 -1
  725. package/dist/utils/is-initialized.mjs +1 -1
  726. package/dist/utils/is-initialized.mjs.map +1 -1
  727. package/dist/utils/load-files.d.ts.map +1 -1
  728. package/dist/utils/open-browser.d.ts +2 -2
  729. package/dist/utils/open-browser.d.ts.map +1 -1
  730. package/dist/utils/open-browser.js.map +1 -1
  731. package/dist/utils/open-browser.mjs.map +1 -1
  732. package/dist/utils/resolve-working-dirs.d.ts +19 -0
  733. package/dist/utils/resolve-working-dirs.d.ts.map +1 -0
  734. package/dist/utils/resolve-working-dirs.js +13 -0
  735. package/dist/utils/resolve-working-dirs.js.map +1 -0
  736. package/dist/utils/resolve-working-dirs.mjs +11 -0
  737. package/dist/utils/resolve-working-dirs.mjs.map +1 -0
  738. package/dist/utils/signals.d.ts +2 -2
  739. package/dist/utils/signals.d.ts.map +1 -1
  740. package/dist/utils/signals.js.map +1 -1
  741. package/dist/utils/signals.mjs.map +1 -1
  742. package/dist/utils/startup-logger.d.ts +2 -2
  743. package/dist/utils/startup-logger.d.ts.map +1 -1
  744. package/dist/utils/startup-logger.js +4 -4
  745. package/dist/utils/startup-logger.js.map +1 -1
  746. package/dist/utils/startup-logger.mjs +3 -3
  747. package/dist/utils/startup-logger.mjs.map +1 -1
  748. package/dist/utils/transform-content-types-to-models.d.ts +54 -99
  749. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  750. package/dist/utils/transform-content-types-to-models.js +112 -61
  751. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  752. package/dist/utils/transform-content-types-to-models.mjs +111 -60
  753. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  754. package/dist/utils/update-notifier/index.d.ts +2 -7
  755. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  756. package/dist/utils/update-notifier/index.js +11 -14
  757. package/dist/utils/update-notifier/index.js.map +1 -1
  758. package/dist/utils/update-notifier/index.mjs +11 -14
  759. package/dist/utils/update-notifier/index.mjs.map +1 -1
  760. package/package.json +35 -31
  761. package/dist/registries/config.d.ts +0 -4
  762. package/dist/registries/config.d.ts.map +0 -1
  763. package/dist/registries/config.js +0 -31
  764. package/dist/registries/config.js.map +0 -1
  765. package/dist/registries/config.mjs +0 -32
  766. package/dist/registries/config.mjs.map +0 -1
  767. package/dist/services/document-service/middlewares.d.ts +0 -8
  768. package/dist/services/document-service/middlewares.d.ts.map +0 -1
  769. package/dist/services/document-service/middlewares.js.map +0 -1
  770. package/dist/services/document-service/middlewares.mjs.map +0 -1
  771. package/dist/services/document-service/transform/filters.d.ts +0 -3
  772. package/dist/services/document-service/transform/filters.d.ts.map +0 -1
  773. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts +0 -4
  774. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts.map +0 -1
  775. package/dist/services/document-service/transform/relations/utils/data.js +0 -12
  776. package/dist/services/document-service/transform/relations/utils/data.js.map +0 -1
  777. package/dist/services/document-service/transform/relations/utils/data.mjs +0 -12
  778. package/dist/services/document-service/transform/relations/utils/data.mjs.map +0 -1
  779. package/dist/services/document-service/transform/sort.d.ts +0 -5
  780. package/dist/services/document-service/transform/sort.d.ts.map +0 -1
  781. package/dist/services/document-service/transform/utils.d.ts +0 -9
  782. package/dist/services/document-service/transform/utils.d.ts.map +0 -1
  783. package/dist/services/entity-service/attributes/index.d.ts +0 -6
  784. package/dist/services/entity-service/attributes/index.d.ts.map +0 -1
  785. package/dist/services/entity-service/attributes/index.js.map +0 -1
  786. package/dist/services/entity-service/attributes/index.mjs.map +0 -1
  787. package/dist/services/entity-service/attributes/transforms.d.ts +0 -10
  788. package/dist/services/entity-service/attributes/transforms.d.ts.map +0 -1
  789. package/dist/services/entity-service/attributes/transforms.js.map +0 -1
  790. package/dist/services/entity-service/attributes/transforms.mjs.map +0 -1
  791. package/dist/services/entity-service/components.d.ts +0 -23
  792. package/dist/services/entity-service/components.d.ts.map +0 -1
  793. package/dist/services/entity-service/components.js.map +0 -1
  794. package/dist/services/entity-service/components.mjs.map +0 -1
  795. package/dist/services/entity-service/params.d.ts +0 -8
  796. package/dist/services/entity-service/params.d.ts.map +0 -1
  797. package/dist/services/entity-service/params.js.map +0 -1
  798. package/dist/services/entity-service/params.mjs.map +0 -1
  799. package/dist/services/utils/upload-files.d.ts +0 -8
  800. package/dist/services/utils/upload-files.d.ts.map +0 -1
  801. package/dist/services/utils/upload-files.js +0 -64
  802. package/dist/services/utils/upload-files.js.map +0 -1
  803. package/dist/services/utils/upload-files.mjs +0 -63
  804. package/dist/services/utils/upload-files.mjs.map +0 -1
  805. package/dist/utils/get-dirs.d.ts +0 -9
  806. package/dist/utils/get-dirs.d.ts.map +0 -1
  807. package/dist/utils/get-dirs.js.map +0 -1
  808. package/dist/utils/get-dirs.mjs.map +0 -1
  809. /package/dist/services/{entity-service → document-service}/attributes/transforms.mjs +0 -0
  810. /package/dist/services/{entity-service → document-service}/params.mjs +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"query.mjs","sources":["../../src/middlewares/query.ts"],"sourcesContent":["import qs, { IParseOptions } from 'qs';\nimport type Koa from 'koa';\nimport type { Strapi, Common } from '@strapi/types';\n\ntype Config = IParseOptions;\n\nconst defaults: Config = {\n strictNullHandling: true,\n arrayLimit: 100,\n depth: 20,\n};\n\n/**\n * Body parser hook\n */\nconst addQsParser = (app: Koa, settings: Config) => {\n Object.defineProperty(app.request, 'query', {\n configurable: false,\n enumerable: true,\n /*\n * Get parsed query-string.\n */\n get() {\n const qstr = this.querystring;\n this._querycache = this._querycache || {};\n const cache = this._querycache;\n\n if (!cache[qstr]) {\n cache[qstr] = qs.parse(qstr, settings);\n }\n\n return cache[qstr];\n },\n\n /*\n * Set query-string as an object.\n */\n set(obj) {\n this.querystring = qs.stringify(obj);\n },\n });\n\n return app;\n};\n\nexport const query: Common.MiddlewareFactory = (\n config: Partial<Config>,\n { strapi }: { strapi: Strapi }\n) => {\n addQsParser(strapi.server.app, { ...defaults, ...config });\n};\n"],"names":[],"mappings":";AAMA,MAAM,WAAmB;AAAA,EACvB,oBAAoB;AAAA,EACpB,YAAY;AAAA,EACZ,OAAO;AACT;AAKA,MAAM,cAAc,CAAC,KAAU,aAAqB;AAC3C,SAAA,eAAe,IAAI,SAAS,SAAS;AAAA,IAC1C,cAAc;AAAA,IACd,YAAY;AAAA;AAAA;AAAA;AAAA,IAIZ,MAAM;AACJ,YAAM,OAAO,KAAK;AACb,WAAA,cAAc,KAAK,eAAe,CAAA;AACvC,YAAM,QAAQ,KAAK;AAEf,UAAA,CAAC,MAAM,IAAI,GAAG;AAChB,cAAM,IAAI,IAAI,GAAG,MAAM,MAAM,QAAQ;AAAA,MACvC;AAEA,aAAO,MAAM,IAAI;AAAA,IACnB;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAK;AACF,WAAA,cAAc,GAAG,UAAU,GAAG;AAAA,IACrC;AAAA,EAAA,CACD;AAEM,SAAA;AACT;AAEO,MAAM,QAAkC,CAC7C,QACA,EAAE,aACC;AACS,cAAA,OAAO,OAAO,KAAK,EAAE,GAAG,UAAU,GAAG,QAAQ;AAC3D;"}
1
+ {"version":3,"file":"query.mjs","sources":["../../src/middlewares/query.ts"],"sourcesContent":["import qs from 'qs';\nimport type Koa from 'koa';\nimport type { Core } from '@strapi/types';\n\ntype Config = Parameters<typeof qs.parse>[1];\n\nconst defaults: Config = {\n strictNullHandling: true,\n arrayLimit: 100,\n depth: 20,\n};\n\n/**\n * Body parser hook\n */\nconst addQsParser = (app: Koa, settings: Config) => {\n Object.defineProperty(app.request, 'query', {\n configurable: false,\n enumerable: true,\n /*\n * Get parsed query-string.\n */\n get() {\n const qstr = this.querystring;\n\n this._querycache = this._querycache || {};\n const cache = this._querycache;\n\n if (!cache[qstr]) {\n cache[qstr] = qs.parse(qstr, settings);\n }\n\n return cache[qstr];\n },\n\n /*\n * Set query-string as an object.\n */\n set(obj) {\n this.querystring = qs.stringify(obj);\n },\n } satisfies PropertyDescriptor & ThisType<Koa.BaseRequest>);\n\n return app;\n};\n\nexport const query: Core.MiddlewareFactory = (\n config: Partial<Config>,\n { strapi }: { strapi: Core.Strapi }\n) => {\n addQsParser(strapi.server.app, { ...defaults, ...config } as Config);\n};\n"],"names":[],"mappings":";AAMA,MAAM,WAAmB;AAAA,EACvB,oBAAoB;AAAA,EACpB,YAAY;AAAA,EACZ,OAAO;AACT;AAKA,MAAM,cAAc,CAAC,KAAU,aAAqB;AAC3C,SAAA,eAAe,IAAI,SAAS,SAAS;AAAA,IAC1C,cAAc;AAAA,IACd,YAAY;AAAA;AAAA;AAAA;AAAA,IAIZ,MAAM;AACJ,YAAM,OAAO,KAAK;AAEb,WAAA,cAAc,KAAK,eAAe,CAAA;AACvC,YAAM,QAAQ,KAAK;AAEf,UAAA,CAAC,MAAM,IAAI,GAAG;AAChB,cAAM,IAAI,IAAI,GAAG,MAAM,MAAM,QAAQ;AAAA,MACvC;AAEA,aAAO,MAAM,IAAI;AAAA,IACnB;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAK;AACF,WAAA,cAAc,GAAG,UAAU,GAAG;AAAA,IACrC;AAAA,EAAA,CACwD;AAEnD,SAAA;AACT;AAEO,MAAM,QAAgC,CAC3C,QACA,EAAE,aACC;AACS,cAAA,OAAO,OAAO,KAAK,EAAE,GAAG,UAAU,GAAG,QAAkB;AACrE;"}
@@ -1,3 +1,3 @@
1
- import type { Common } from '@strapi/types';
2
- export declare const responseTime: Common.MiddlewareFactory;
1
+ import type { Core } from '@strapi/types';
2
+ export declare const responseTime: Core.MiddlewareFactory;
3
3
  //# sourceMappingURL=response-time.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"response-time.d.ts","sourceRoot":"","sources":["../../src/middlewares/response-time.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAE5C,eAAO,MAAM,YAAY,EAAE,MAAM,CAAC,iBASjC,CAAC"}
1
+ {"version":3,"file":"response-time.d.ts","sourceRoot":"","sources":["../../src/middlewares/response-time.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAE1C,eAAO,MAAM,YAAY,EAAE,IAAI,CAAC,iBAS/B,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"response-time.js","sources":["../../src/middlewares/response-time.ts"],"sourcesContent":["import type { Common } from '@strapi/types';\n\nexport const responseTime: Common.MiddlewareFactory = () => {\n return async (ctx, next) => {\n const start = Date.now();\n\n await next();\n\n const delta = Math.ceil(Date.now() - start);\n ctx.set('X-Response-Time', `${delta}ms`);\n };\n};\n"],"names":[],"mappings":";;AAEO,MAAM,eAAyC,MAAM;AACnD,SAAA,OAAO,KAAK,SAAS;AACpB,UAAA,QAAQ,KAAK;AAEnB,UAAM,KAAK;AAEX,UAAM,QAAQ,KAAK,KAAK,KAAK,IAAA,IAAQ,KAAK;AAC1C,QAAI,IAAI,mBAAmB,GAAG,KAAK,IAAI;AAAA,EAAA;AAE3C;;"}
1
+ {"version":3,"file":"response-time.js","sources":["../../src/middlewares/response-time.ts"],"sourcesContent":["import type { Core } from '@strapi/types';\n\nexport const responseTime: Core.MiddlewareFactory = () => {\n return async (ctx, next) => {\n const start = Date.now();\n\n await next();\n\n const delta = Math.ceil(Date.now() - start);\n ctx.set('X-Response-Time', `${delta}ms`);\n };\n};\n"],"names":[],"mappings":";;AAEO,MAAM,eAAuC,MAAM;AACjD,SAAA,OAAO,KAAK,SAAS;AACpB,UAAA,QAAQ,KAAK;AAEnB,UAAM,KAAK;AAEX,UAAM,QAAQ,KAAK,KAAK,KAAK,IAAA,IAAQ,KAAK;AAC1C,QAAI,IAAI,mBAAmB,GAAG,KAAK,IAAI;AAAA,EAAA;AAE3C;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"response-time.mjs","sources":["../../src/middlewares/response-time.ts"],"sourcesContent":["import type { Common } from '@strapi/types';\n\nexport const responseTime: Common.MiddlewareFactory = () => {\n return async (ctx, next) => {\n const start = Date.now();\n\n await next();\n\n const delta = Math.ceil(Date.now() - start);\n ctx.set('X-Response-Time', `${delta}ms`);\n };\n};\n"],"names":[],"mappings":"AAEO,MAAM,eAAyC,MAAM;AACnD,SAAA,OAAO,KAAK,SAAS;AACpB,UAAA,QAAQ,KAAK;AAEnB,UAAM,KAAK;AAEX,UAAM,QAAQ,KAAK,KAAK,KAAK,IAAA,IAAQ,KAAK;AAC1C,QAAI,IAAI,mBAAmB,GAAG,KAAK,IAAI;AAAA,EAAA;AAE3C;"}
1
+ {"version":3,"file":"response-time.mjs","sources":["../../src/middlewares/response-time.ts"],"sourcesContent":["import type { Core } from '@strapi/types';\n\nexport const responseTime: Core.MiddlewareFactory = () => {\n return async (ctx, next) => {\n const start = Date.now();\n\n await next();\n\n const delta = Math.ceil(Date.now() - start);\n ctx.set('X-Response-Time', `${delta}ms`);\n };\n};\n"],"names":[],"mappings":"AAEO,MAAM,eAAuC,MAAM;AACjD,SAAA,OAAO,KAAK,SAAS;AACpB,UAAA,QAAQ,KAAK;AAEnB,UAAM,KAAK;AAEX,UAAM,QAAQ,KAAK,KAAK,KAAK,IAAA,IAAQ,KAAK;AAC1C,QAAI,IAAI,mBAAmB,GAAG,KAAK,IAAI;AAAA,EAAA;AAE3C;"}
@@ -1,6 +1,6 @@
1
- import type { Common } from '@strapi/types';
1
+ import type { Core } from '@strapi/types';
2
2
  export interface Config {
3
- handlers?: Record<number, Common.MiddlewareHandler>;
3
+ handlers?: Record<number, Core.MiddlewareHandler>;
4
4
  }
5
- export declare const responses: Common.MiddlewareFactory<Config>;
5
+ export declare const responses: Core.MiddlewareFactory<Config>;
6
6
  //# sourceMappingURL=responses.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"responses.d.ts","sourceRoot":"","sources":["../../src/middlewares/responses.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAE5C,MAAM,WAAW,MAAM;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,iBAAiB,CAAC,CAAC;CACrD;AAED,eAAO,MAAM,SAAS,EAAE,MAAM,CAAC,iBAAiB,CAAC,MAAM,CAWtD,CAAC"}
1
+ {"version":3,"file":"responses.d.ts","sourceRoot":"","sources":["../../src/middlewares/responses.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAE1C,MAAM,WAAW,MAAM;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;CACnD;AAED,eAAO,MAAM,SAAS,EAAE,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAWpD,CAAC"}
@@ -1,12 +1,12 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const _ = require("lodash/fp");
3
+ const fp = require("lodash/fp");
4
4
  const responses = (config = {}) => {
5
5
  return async (ctx, next) => {
6
6
  await next();
7
7
  const { status } = ctx;
8
8
  const handler = config?.handlers?.[status];
9
- if (_.isFunction(handler)) {
9
+ if (fp.isFunction(handler)) {
10
10
  await handler(ctx, next);
11
11
  }
12
12
  };
@@ -1 +1 @@
1
- {"version":3,"file":"responses.js","sources":["../../src/middlewares/responses.ts"],"sourcesContent":["import { isFunction } from 'lodash/fp';\nimport type { Common } from '@strapi/types';\n\nexport interface Config {\n handlers?: Record<number, Common.MiddlewareHandler>;\n}\n\nexport const responses: Common.MiddlewareFactory<Config> = (config = {}) => {\n return async (ctx, next) => {\n await next();\n\n const { status } = ctx;\n const handler = config?.handlers?.[status];\n\n if (isFunction(handler)) {\n await handler(ctx, next);\n }\n };\n};\n"],"names":["isFunction"],"mappings":";;;AAOO,MAAM,YAA8C,CAAC,SAAS,OAAO;AACnE,SAAA,OAAO,KAAK,SAAS;AAC1B,UAAM,KAAK;AAEL,UAAA,EAAE,OAAW,IAAA;AACb,UAAA,UAAU,QAAQ,WAAW,MAAM;AAErC,QAAAA,EAAAA,WAAW,OAAO,GAAG;AACjB,YAAA,QAAQ,KAAK,IAAI;AAAA,IACzB;AAAA,EAAA;AAEJ;;"}
1
+ {"version":3,"file":"responses.js","sources":["../../src/middlewares/responses.ts"],"sourcesContent":["import { isFunction } from 'lodash/fp';\nimport type { Core } from '@strapi/types';\n\nexport interface Config {\n handlers?: Record<number, Core.MiddlewareHandler>;\n}\n\nexport const responses: Core.MiddlewareFactory<Config> = (config = {}) => {\n return async (ctx, next) => {\n await next();\n\n const { status } = ctx;\n const handler = config?.handlers?.[status];\n\n if (isFunction(handler)) {\n await handler(ctx, next);\n }\n };\n};\n"],"names":["isFunction"],"mappings":";;;AAOO,MAAM,YAA4C,CAAC,SAAS,OAAO;AACjE,SAAA,OAAO,KAAK,SAAS;AAC1B,UAAM,KAAK;AAEL,UAAA,EAAE,OAAW,IAAA;AACb,UAAA,UAAU,QAAQ,WAAW,MAAM;AAErC,QAAAA,GAAAA,WAAW,OAAO,GAAG;AACjB,YAAA,QAAQ,KAAK,IAAI;AAAA,IACzB;AAAA,EAAA;AAEJ;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"responses.mjs","sources":["../../src/middlewares/responses.ts"],"sourcesContent":["import { isFunction } from 'lodash/fp';\nimport type { Common } from '@strapi/types';\n\nexport interface Config {\n handlers?: Record<number, Common.MiddlewareHandler>;\n}\n\nexport const responses: Common.MiddlewareFactory<Config> = (config = {}) => {\n return async (ctx, next) => {\n await next();\n\n const { status } = ctx;\n const handler = config?.handlers?.[status];\n\n if (isFunction(handler)) {\n await handler(ctx, next);\n }\n };\n};\n"],"names":[],"mappings":";AAOO,MAAM,YAA8C,CAAC,SAAS,OAAO;AACnE,SAAA,OAAO,KAAK,SAAS;AAC1B,UAAM,KAAK;AAEL,UAAA,EAAE,OAAW,IAAA;AACb,UAAA,UAAU,QAAQ,WAAW,MAAM;AAErC,QAAA,WAAW,OAAO,GAAG;AACjB,YAAA,QAAQ,KAAK,IAAI;AAAA,IACzB;AAAA,EAAA;AAEJ;"}
1
+ {"version":3,"file":"responses.mjs","sources":["../../src/middlewares/responses.ts"],"sourcesContent":["import { isFunction } from 'lodash/fp';\nimport type { Core } from '@strapi/types';\n\nexport interface Config {\n handlers?: Record<number, Core.MiddlewareHandler>;\n}\n\nexport const responses: Core.MiddlewareFactory<Config> = (config = {}) => {\n return async (ctx, next) => {\n await next();\n\n const { status } = ctx;\n const handler = config?.handlers?.[status];\n\n if (isFunction(handler)) {\n await handler(ctx, next);\n }\n };\n};\n"],"names":[],"mappings":";AAOO,MAAM,YAA4C,CAAC,SAAS,OAAO;AACjE,SAAA,OAAO,KAAK,SAAS;AAC1B,UAAM,KAAK;AAEL,UAAA,EAAE,OAAW,IAAA;AACb,UAAA,UAAU,QAAQ,WAAW,MAAM;AAErC,QAAA,WAAW,OAAO,GAAG;AACjB,YAAA,QAAQ,KAAK,IAAI;AAAA,IACzB;AAAA,EAAA;AAEJ;"}
@@ -1,5 +1,5 @@
1
1
  import { KoaHelmet } from 'koa-helmet';
2
- import type { Common } from '@strapi/types';
2
+ import type { Core } from '@strapi/types';
3
3
  export type Config = NonNullable<Parameters<KoaHelmet>[0]>;
4
- export declare const security: Common.MiddlewareFactory<Config>;
4
+ export declare const security: Core.MiddlewareFactory<Config>;
5
5
  //# sourceMappingURL=security.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"security.d.ts","sourceRoot":"","sources":["../../src/middlewares/security.ts"],"names":[],"mappings":"AACA,OAAe,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAE/C,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAE5C,MAAM,MAAM,MAAM,GAAG,WAAW,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AA0B3D,eAAO,MAAM,QAAQ,EAAE,MAAM,CAAC,iBAAiB,CAAC,MAAM,CAsDnD,CAAC"}
1
+ {"version":3,"file":"security.d.ts","sourceRoot":"","sources":["../../src/middlewares/security.ts"],"names":[],"mappings":"AACA,OAAe,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAE/C,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAE1C,MAAM,MAAM,MAAM,GAAG,WAAW,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAkC3D,eAAO,MAAM,QAAQ,EAAE,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAmEjD,CAAC"}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const _ = require("lodash/fp");
3
+ const fp = require("lodash/fp");
4
4
  const helmet = require("koa-helmet");
5
5
  const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
6
6
  const helmet__default = /* @__PURE__ */ _interopDefault(helmet);
@@ -27,8 +27,15 @@ const defaults = {
27
27
  action: "sameorigin"
28
28
  }
29
29
  };
30
+ const mergeConfig = (existingConfig, newConfig) => {
31
+ return fp.mergeWith(
32
+ (obj, src) => Array.isArray(obj) && Array.isArray(src) ? obj.concat(src) : void 0,
33
+ existingConfig,
34
+ newConfig
35
+ );
36
+ };
30
37
  const security = (config, { strapi }) => (ctx, next) => {
31
- let helmetConfig = _.defaultsDeep(defaults, config);
38
+ let helmetConfig = fp.defaultsDeep(defaults, config);
32
39
  const specialPaths = ["/documentation"];
33
40
  const directives = {
34
41
  "script-src": ["'self'", "'unsafe-inline'", "cdn.jsdelivr.net"],
@@ -47,7 +54,7 @@ const security = (config, { strapi }) => (ctx, next) => {
47
54
  directives["frame-src"].push("sandbox.embed.apollographql.com");
48
55
  }
49
56
  if (ctx.method === "GET" && specialPaths.some((str) => ctx.path.startsWith(str))) {
50
- helmetConfig = _.merge(helmetConfig, {
57
+ helmetConfig = mergeConfig(helmetConfig, {
51
58
  crossOriginEmbedderPolicy: false,
52
59
  // TODO: only use this for graphql playground
53
60
  contentSecurityPolicy: {
@@ -55,12 +62,12 @@ const security = (config, { strapi }) => (ctx, next) => {
55
62
  }
56
63
  });
57
64
  }
58
- if (ctx.method === "GET" && ["/admin"].some((str) => ctx.path.startsWith(str))) {
59
- helmetConfig = _.merge(helmetConfig, {
65
+ if (["development", "test"].includes(process.env.NODE_ENV ?? "") && ctx.method === "GET" && ctx.path.startsWith(strapi.config.get("admin.path"))) {
66
+ helmetConfig = mergeConfig(helmetConfig, {
60
67
  contentSecurityPolicy: {
61
68
  directives: {
62
69
  "script-src": ["'self'", "'unsafe-inline'"],
63
- "connect-src": ["'self'", "https:", "ws:"]
70
+ "connect-src": ["'self'", "http:", "https:", "ws:"]
64
71
  }
65
72
  }
66
73
  });
@@ -1 +1 @@
1
- {"version":3,"file":"security.js","sources":["../../src/middlewares/security.ts"],"sourcesContent":["import { defaultsDeep, merge } from 'lodash/fp';\nimport helmet, { KoaHelmet } from 'koa-helmet';\n\nimport type { Common } from '@strapi/types';\n\nexport type Config = NonNullable<Parameters<KoaHelmet>[0]>;\n\nconst defaults: Config = {\n crossOriginEmbedderPolicy: false,\n crossOriginOpenerPolicy: false,\n crossOriginResourcePolicy: false,\n originAgentCluster: false,\n contentSecurityPolicy: {\n useDefaults: true,\n directives: {\n 'connect-src': [\"'self'\", 'https:'],\n 'img-src': [\"'self'\", 'data:', 'blob:', 'https://market-assets.strapi.io'],\n 'media-src': [\"'self'\", 'data:', 'blob:'],\n upgradeInsecureRequests: null,\n },\n },\n xssFilter: false,\n hsts: {\n maxAge: 31536000,\n includeSubDomains: true,\n },\n frameguard: {\n action: 'sameorigin',\n },\n};\n\nexport const security: Common.MiddlewareFactory<Config> =\n (config, { strapi }) =>\n (ctx, next) => {\n let helmetConfig: Config = defaultsDeep(defaults, config);\n\n const specialPaths = ['/documentation'];\n\n const directives: {\n 'script-src': string[];\n 'img-src': string[];\n 'manifest-src': string[];\n 'frame-src': string[];\n } = {\n 'script-src': [\"'self'\", \"'unsafe-inline'\", 'cdn.jsdelivr.net'],\n 'img-src': [\"'self'\", 'data:', 'cdn.jsdelivr.net', 'strapi.io'],\n 'manifest-src': [],\n 'frame-src': [],\n };\n\n // if apollo graphql playground is enabled, add exceptions for it\n if (strapi.plugin('graphql')?.service('utils').playground.isEnabled()) {\n const { config: gqlConfig } = strapi.plugin('graphql');\n specialPaths.push(gqlConfig('endpoint'));\n\n directives['script-src'].push(`https: 'unsafe-inline'`);\n directives['img-src'].push(`'apollo-server-landing-page.cdn.apollographql.com'`);\n directives['manifest-src'].push(`'self'`);\n directives['manifest-src'].push('apollo-server-landing-page.cdn.apollographql.com');\n directives['frame-src'].push(`'self'`);\n directives['frame-src'].push('sandbox.embed.apollographql.com');\n }\n\n // TODO: we shouldn't combine playground exceptions with documentation for all routes, we should first check the path and then return exceptions specific to that\n if (ctx.method === 'GET' && specialPaths.some((str) => ctx.path.startsWith(str))) {\n helmetConfig = merge(helmetConfig, {\n crossOriginEmbedderPolicy: false, // TODO: only use this for graphql playground\n contentSecurityPolicy: {\n directives,\n },\n });\n }\n\n if (ctx.method === 'GET' && ['/admin'].some((str) => ctx.path.startsWith(str))) {\n helmetConfig = merge(helmetConfig, {\n contentSecurityPolicy: {\n directives: {\n 'script-src': [\"'self'\", \"'unsafe-inline'\"],\n 'connect-src': [\"'self'\", 'https:', 'ws:'],\n },\n },\n });\n }\n\n return helmet(helmetConfig)(ctx, next);\n };\n"],"names":["defaultsDeep","merge","helmet"],"mappings":";;;;;;AAOA,MAAM,WAAmB;AAAA,EACvB,2BAA2B;AAAA,EAC3B,yBAAyB;AAAA,EACzB,2BAA2B;AAAA,EAC3B,oBAAoB;AAAA,EACpB,uBAAuB;AAAA,IACrB,aAAa;AAAA,IACb,YAAY;AAAA,MACV,eAAe,CAAC,UAAU,QAAQ;AAAA,MAClC,WAAW,CAAC,UAAU,SAAS,SAAS,iCAAiC;AAAA,MACzE,aAAa,CAAC,UAAU,SAAS,OAAO;AAAA,MACxC,yBAAyB;AAAA,IAC3B;AAAA,EACF;AAAA,EACA,WAAW;AAAA,EACX,MAAM;AAAA,IACJ,QAAQ;AAAA,IACR,mBAAmB;AAAA,EACrB;AAAA,EACA,YAAY;AAAA,IACV,QAAQ;AAAA,EACV;AACF;AAEa,MAAA,WACX,CAAC,QAAQ,EAAE,aACX,CAAC,KAAK,SAAS;AACT,MAAA,eAAuBA,EAAAA,aAAa,UAAU,MAAM;AAElD,QAAA,eAAe,CAAC,gBAAgB;AAEtC,QAAM,aAKF;AAAA,IACF,cAAc,CAAC,UAAU,mBAAmB,kBAAkB;AAAA,IAC9D,WAAW,CAAC,UAAU,SAAS,oBAAoB,WAAW;AAAA,IAC9D,gBAAgB,CAAC;AAAA,IACjB,aAAa,CAAC;AAAA,EAAA;AAIZ,MAAA,OAAO,OAAO,SAAS,GAAG,QAAQ,OAAO,EAAE,WAAW,aAAa;AACrE,UAAM,EAAE,QAAQ,UAAA,IAAc,OAAO,OAAO,SAAS;AACxC,iBAAA,KAAK,UAAU,UAAU,CAAC;AAE5B,eAAA,YAAY,EAAE,KAAK,wBAAwB;AAC3C,eAAA,SAAS,EAAE,KAAK,oDAAoD;AACpE,eAAA,cAAc,EAAE,KAAK,QAAQ;AAC7B,eAAA,cAAc,EAAE,KAAK,kDAAkD;AACvE,eAAA,WAAW,EAAE,KAAK,QAAQ;AAC1B,eAAA,WAAW,EAAE,KAAK,iCAAiC;AAAA,EAChE;AAGA,MAAI,IAAI,WAAW,SAAS,aAAa,KAAK,CAAC,QAAQ,IAAI,KAAK,WAAW,GAAG,CAAC,GAAG;AAChF,mBAAeC,QAAM,cAAc;AAAA,MACjC,2BAA2B;AAAA;AAAA,MAC3B,uBAAuB;AAAA,QACrB;AAAA,MACF;AAAA,IAAA,CACD;AAAA,EACH;AAEA,MAAI,IAAI,WAAW,SAAS,CAAC,QAAQ,EAAE,KAAK,CAAC,QAAQ,IAAI,KAAK,WAAW,GAAG,CAAC,GAAG;AAC9E,mBAAeA,QAAM,cAAc;AAAA,MACjC,uBAAuB;AAAA,QACrB,YAAY;AAAA,UACV,cAAc,CAAC,UAAU,iBAAiB;AAAA,UAC1C,eAAe,CAAC,UAAU,UAAU,KAAK;AAAA,QAC3C;AAAA,MACF;AAAA,IAAA,CACD;AAAA,EACH;AAEA,SAAOC,gBAAO,QAAA,YAAY,EAAE,KAAK,IAAI;AACvC;;"}
1
+ {"version":3,"file":"security.js","sources":["../../src/middlewares/security.ts"],"sourcesContent":["import { defaultsDeep, mergeWith } from 'lodash/fp';\nimport helmet, { KoaHelmet } from 'koa-helmet';\n\nimport type { Core } from '@strapi/types';\n\nexport type Config = NonNullable<Parameters<KoaHelmet>[0]>;\n\nconst defaults: Config = {\n crossOriginEmbedderPolicy: false,\n crossOriginOpenerPolicy: false,\n crossOriginResourcePolicy: false,\n originAgentCluster: false,\n contentSecurityPolicy: {\n useDefaults: true,\n directives: {\n 'connect-src': [\"'self'\", 'https:'],\n 'img-src': [\"'self'\", 'data:', 'blob:', 'https://market-assets.strapi.io'],\n 'media-src': [\"'self'\", 'data:', 'blob:'],\n upgradeInsecureRequests: null,\n },\n },\n xssFilter: false,\n hsts: {\n maxAge: 31536000,\n includeSubDomains: true,\n },\n frameguard: {\n action: 'sameorigin',\n },\n};\n\nconst mergeConfig = (existingConfig: Config, newConfig: Config) => {\n return mergeWith(\n (obj, src) => (Array.isArray(obj) && Array.isArray(src) ? obj.concat(src) : undefined),\n existingConfig,\n newConfig\n );\n};\n\nexport const security: Core.MiddlewareFactory<Config> =\n (config, { strapi }) =>\n (ctx, next) => {\n let helmetConfig: Config = defaultsDeep(defaults, config);\n\n const specialPaths = ['/documentation'];\n\n const directives: {\n 'script-src': string[];\n 'img-src': string[];\n 'manifest-src': string[];\n 'frame-src': string[];\n } = {\n 'script-src': [\"'self'\", \"'unsafe-inline'\", 'cdn.jsdelivr.net'],\n 'img-src': [\"'self'\", 'data:', 'cdn.jsdelivr.net', 'strapi.io'],\n 'manifest-src': [],\n 'frame-src': [],\n };\n\n // if apollo graphql playground is enabled, add exceptions for it\n if (strapi.plugin('graphql')?.service('utils').playground.isEnabled()) {\n const { config: gqlConfig } = strapi.plugin('graphql');\n specialPaths.push(gqlConfig('endpoint'));\n\n directives['script-src'].push(`https: 'unsafe-inline'`);\n directives['img-src'].push(`'apollo-server-landing-page.cdn.apollographql.com'`);\n directives['manifest-src'].push(`'self'`);\n directives['manifest-src'].push('apollo-server-landing-page.cdn.apollographql.com');\n directives['frame-src'].push(`'self'`);\n directives['frame-src'].push('sandbox.embed.apollographql.com');\n }\n\n // TODO: we shouldn't combine playground exceptions with documentation for all routes, we should first check the path and then return exceptions specific to that\n if (ctx.method === 'GET' && specialPaths.some((str) => ctx.path.startsWith(str))) {\n helmetConfig = mergeConfig(helmetConfig, {\n crossOriginEmbedderPolicy: false, // TODO: only use this for graphql playground\n contentSecurityPolicy: {\n directives,\n },\n });\n }\n\n /**\n * These are for vite's watch mode so it can accurately\n * connect to the HMR websocket & reconnect on failure\n * or when the server restarts.\n *\n * It only applies in development, and only on GET requests\n * that are part of the admin route.\n */\n\n if (\n ['development', 'test'].includes(process.env.NODE_ENV ?? '') &&\n ctx.method === 'GET' &&\n ctx.path.startsWith(strapi.config.get('admin.path'))\n ) {\n helmetConfig = mergeConfig(helmetConfig, {\n contentSecurityPolicy: {\n directives: {\n 'script-src': [\"'self'\", \"'unsafe-inline'\"],\n 'connect-src': [\"'self'\", 'http:', 'https:', 'ws:'],\n },\n },\n });\n }\n\n return helmet(helmetConfig)(ctx, next);\n };\n"],"names":["mergeWith","defaultsDeep","helmet"],"mappings":";;;;;;AAOA,MAAM,WAAmB;AAAA,EACvB,2BAA2B;AAAA,EAC3B,yBAAyB;AAAA,EACzB,2BAA2B;AAAA,EAC3B,oBAAoB;AAAA,EACpB,uBAAuB;AAAA,IACrB,aAAa;AAAA,IACb,YAAY;AAAA,MACV,eAAe,CAAC,UAAU,QAAQ;AAAA,MAClC,WAAW,CAAC,UAAU,SAAS,SAAS,iCAAiC;AAAA,MACzE,aAAa,CAAC,UAAU,SAAS,OAAO;AAAA,MACxC,yBAAyB;AAAA,IAC3B;AAAA,EACF;AAAA,EACA,WAAW;AAAA,EACX,MAAM;AAAA,IACJ,QAAQ;AAAA,IACR,mBAAmB;AAAA,EACrB;AAAA,EACA,YAAY;AAAA,IACV,QAAQ;AAAA,EACV;AACF;AAEA,MAAM,cAAc,CAAC,gBAAwB,cAAsB;AAC1D,SAAAA,GAAA;AAAA,IACL,CAAC,KAAK,QAAS,MAAM,QAAQ,GAAG,KAAK,MAAM,QAAQ,GAAG,IAAI,IAAI,OAAO,GAAG,IAAI;AAAA,IAC5E;AAAA,IACA;AAAA,EAAA;AAEJ;AAEa,MAAA,WACX,CAAC,QAAQ,EAAE,aACX,CAAC,KAAK,SAAS;AACT,MAAA,eAAuBC,GAAAA,aAAa,UAAU,MAAM;AAElD,QAAA,eAAe,CAAC,gBAAgB;AAEtC,QAAM,aAKF;AAAA,IACF,cAAc,CAAC,UAAU,mBAAmB,kBAAkB;AAAA,IAC9D,WAAW,CAAC,UAAU,SAAS,oBAAoB,WAAW;AAAA,IAC9D,gBAAgB,CAAC;AAAA,IACjB,aAAa,CAAC;AAAA,EAAA;AAIZ,MAAA,OAAO,OAAO,SAAS,GAAG,QAAQ,OAAO,EAAE,WAAW,aAAa;AACrE,UAAM,EAAE,QAAQ,UAAA,IAAc,OAAO,OAAO,SAAS;AACxC,iBAAA,KAAK,UAAU,UAAU,CAAC;AAE5B,eAAA,YAAY,EAAE,KAAK,wBAAwB;AAC3C,eAAA,SAAS,EAAE,KAAK,oDAAoD;AACpE,eAAA,cAAc,EAAE,KAAK,QAAQ;AAC7B,eAAA,cAAc,EAAE,KAAK,kDAAkD;AACvE,eAAA,WAAW,EAAE,KAAK,QAAQ;AAC1B,eAAA,WAAW,EAAE,KAAK,iCAAiC;AAAA,EAChE;AAGA,MAAI,IAAI,WAAW,SAAS,aAAa,KAAK,CAAC,QAAQ,IAAI,KAAK,WAAW,GAAG,CAAC,GAAG;AAChF,mBAAe,YAAY,cAAc;AAAA,MACvC,2BAA2B;AAAA;AAAA,MAC3B,uBAAuB;AAAA,QACrB;AAAA,MACF;AAAA,IAAA,CACD;AAAA,EACH;AAYE,MAAA,CAAC,eAAe,MAAM,EAAE,SAAS,QAAQ,IAAI,YAAY,EAAE,KAC3D,IAAI,WAAW,SACf,IAAI,KAAK,WAAW,OAAO,OAAO,IAAI,YAAY,CAAC,GACnD;AACA,mBAAe,YAAY,cAAc;AAAA,MACvC,uBAAuB;AAAA,QACrB,YAAY;AAAA,UACV,cAAc,CAAC,UAAU,iBAAiB;AAAA,UAC1C,eAAe,CAAC,UAAU,SAAS,UAAU,KAAK;AAAA,QACpD;AAAA,MACF;AAAA,IAAA,CACD;AAAA,EACH;AAEA,SAAOC,gBAAO,QAAA,YAAY,EAAE,KAAK,IAAI;AACvC;;"}
@@ -1,4 +1,4 @@
1
- import { defaultsDeep, merge } from "lodash/fp";
1
+ import { defaultsDeep, mergeWith } from "lodash/fp";
2
2
  import helmet from "koa-helmet";
3
3
  const defaults = {
4
4
  crossOriginEmbedderPolicy: false,
@@ -23,6 +23,13 @@ const defaults = {
23
23
  action: "sameorigin"
24
24
  }
25
25
  };
26
+ const mergeConfig = (existingConfig, newConfig) => {
27
+ return mergeWith(
28
+ (obj, src) => Array.isArray(obj) && Array.isArray(src) ? obj.concat(src) : void 0,
29
+ existingConfig,
30
+ newConfig
31
+ );
32
+ };
26
33
  const security = (config, { strapi }) => (ctx, next) => {
27
34
  let helmetConfig = defaultsDeep(defaults, config);
28
35
  const specialPaths = ["/documentation"];
@@ -43,7 +50,7 @@ const security = (config, { strapi }) => (ctx, next) => {
43
50
  directives["frame-src"].push("sandbox.embed.apollographql.com");
44
51
  }
45
52
  if (ctx.method === "GET" && specialPaths.some((str) => ctx.path.startsWith(str))) {
46
- helmetConfig = merge(helmetConfig, {
53
+ helmetConfig = mergeConfig(helmetConfig, {
47
54
  crossOriginEmbedderPolicy: false,
48
55
  // TODO: only use this for graphql playground
49
56
  contentSecurityPolicy: {
@@ -51,12 +58,12 @@ const security = (config, { strapi }) => (ctx, next) => {
51
58
  }
52
59
  });
53
60
  }
54
- if (ctx.method === "GET" && ["/admin"].some((str) => ctx.path.startsWith(str))) {
55
- helmetConfig = merge(helmetConfig, {
61
+ if (["development", "test"].includes(process.env.NODE_ENV ?? "") && ctx.method === "GET" && ctx.path.startsWith(strapi.config.get("admin.path"))) {
62
+ helmetConfig = mergeConfig(helmetConfig, {
56
63
  contentSecurityPolicy: {
57
64
  directives: {
58
65
  "script-src": ["'self'", "'unsafe-inline'"],
59
- "connect-src": ["'self'", "https:", "ws:"]
66
+ "connect-src": ["'self'", "http:", "https:", "ws:"]
60
67
  }
61
68
  }
62
69
  });
@@ -1 +1 @@
1
- {"version":3,"file":"security.mjs","sources":["../../src/middlewares/security.ts"],"sourcesContent":["import { defaultsDeep, merge } from 'lodash/fp';\nimport helmet, { KoaHelmet } from 'koa-helmet';\n\nimport type { Common } from '@strapi/types';\n\nexport type Config = NonNullable<Parameters<KoaHelmet>[0]>;\n\nconst defaults: Config = {\n crossOriginEmbedderPolicy: false,\n crossOriginOpenerPolicy: false,\n crossOriginResourcePolicy: false,\n originAgentCluster: false,\n contentSecurityPolicy: {\n useDefaults: true,\n directives: {\n 'connect-src': [\"'self'\", 'https:'],\n 'img-src': [\"'self'\", 'data:', 'blob:', 'https://market-assets.strapi.io'],\n 'media-src': [\"'self'\", 'data:', 'blob:'],\n upgradeInsecureRequests: null,\n },\n },\n xssFilter: false,\n hsts: {\n maxAge: 31536000,\n includeSubDomains: true,\n },\n frameguard: {\n action: 'sameorigin',\n },\n};\n\nexport const security: Common.MiddlewareFactory<Config> =\n (config, { strapi }) =>\n (ctx, next) => {\n let helmetConfig: Config = defaultsDeep(defaults, config);\n\n const specialPaths = ['/documentation'];\n\n const directives: {\n 'script-src': string[];\n 'img-src': string[];\n 'manifest-src': string[];\n 'frame-src': string[];\n } = {\n 'script-src': [\"'self'\", \"'unsafe-inline'\", 'cdn.jsdelivr.net'],\n 'img-src': [\"'self'\", 'data:', 'cdn.jsdelivr.net', 'strapi.io'],\n 'manifest-src': [],\n 'frame-src': [],\n };\n\n // if apollo graphql playground is enabled, add exceptions for it\n if (strapi.plugin('graphql')?.service('utils').playground.isEnabled()) {\n const { config: gqlConfig } = strapi.plugin('graphql');\n specialPaths.push(gqlConfig('endpoint'));\n\n directives['script-src'].push(`https: 'unsafe-inline'`);\n directives['img-src'].push(`'apollo-server-landing-page.cdn.apollographql.com'`);\n directives['manifest-src'].push(`'self'`);\n directives['manifest-src'].push('apollo-server-landing-page.cdn.apollographql.com');\n directives['frame-src'].push(`'self'`);\n directives['frame-src'].push('sandbox.embed.apollographql.com');\n }\n\n // TODO: we shouldn't combine playground exceptions with documentation for all routes, we should first check the path and then return exceptions specific to that\n if (ctx.method === 'GET' && specialPaths.some((str) => ctx.path.startsWith(str))) {\n helmetConfig = merge(helmetConfig, {\n crossOriginEmbedderPolicy: false, // TODO: only use this for graphql playground\n contentSecurityPolicy: {\n directives,\n },\n });\n }\n\n if (ctx.method === 'GET' && ['/admin'].some((str) => ctx.path.startsWith(str))) {\n helmetConfig = merge(helmetConfig, {\n contentSecurityPolicy: {\n directives: {\n 'script-src': [\"'self'\", \"'unsafe-inline'\"],\n 'connect-src': [\"'self'\", 'https:', 'ws:'],\n },\n },\n });\n }\n\n return helmet(helmetConfig)(ctx, next);\n };\n"],"names":[],"mappings":";;AAOA,MAAM,WAAmB;AAAA,EACvB,2BAA2B;AAAA,EAC3B,yBAAyB;AAAA,EACzB,2BAA2B;AAAA,EAC3B,oBAAoB;AAAA,EACpB,uBAAuB;AAAA,IACrB,aAAa;AAAA,IACb,YAAY;AAAA,MACV,eAAe,CAAC,UAAU,QAAQ;AAAA,MAClC,WAAW,CAAC,UAAU,SAAS,SAAS,iCAAiC;AAAA,MACzE,aAAa,CAAC,UAAU,SAAS,OAAO;AAAA,MACxC,yBAAyB;AAAA,IAC3B;AAAA,EACF;AAAA,EACA,WAAW;AAAA,EACX,MAAM;AAAA,IACJ,QAAQ;AAAA,IACR,mBAAmB;AAAA,EACrB;AAAA,EACA,YAAY;AAAA,IACV,QAAQ;AAAA,EACV;AACF;AAEa,MAAA,WACX,CAAC,QAAQ,EAAE,aACX,CAAC,KAAK,SAAS;AACT,MAAA,eAAuB,aAAa,UAAU,MAAM;AAElD,QAAA,eAAe,CAAC,gBAAgB;AAEtC,QAAM,aAKF;AAAA,IACF,cAAc,CAAC,UAAU,mBAAmB,kBAAkB;AAAA,IAC9D,WAAW,CAAC,UAAU,SAAS,oBAAoB,WAAW;AAAA,IAC9D,gBAAgB,CAAC;AAAA,IACjB,aAAa,CAAC;AAAA,EAAA;AAIZ,MAAA,OAAO,OAAO,SAAS,GAAG,QAAQ,OAAO,EAAE,WAAW,aAAa;AACrE,UAAM,EAAE,QAAQ,UAAA,IAAc,OAAO,OAAO,SAAS;AACxC,iBAAA,KAAK,UAAU,UAAU,CAAC;AAE5B,eAAA,YAAY,EAAE,KAAK,wBAAwB;AAC3C,eAAA,SAAS,EAAE,KAAK,oDAAoD;AACpE,eAAA,cAAc,EAAE,KAAK,QAAQ;AAC7B,eAAA,cAAc,EAAE,KAAK,kDAAkD;AACvE,eAAA,WAAW,EAAE,KAAK,QAAQ;AAC1B,eAAA,WAAW,EAAE,KAAK,iCAAiC;AAAA,EAChE;AAGA,MAAI,IAAI,WAAW,SAAS,aAAa,KAAK,CAAC,QAAQ,IAAI,KAAK,WAAW,GAAG,CAAC,GAAG;AAChF,mBAAe,MAAM,cAAc;AAAA,MACjC,2BAA2B;AAAA;AAAA,MAC3B,uBAAuB;AAAA,QACrB;AAAA,MACF;AAAA,IAAA,CACD;AAAA,EACH;AAEA,MAAI,IAAI,WAAW,SAAS,CAAC,QAAQ,EAAE,KAAK,CAAC,QAAQ,IAAI,KAAK,WAAW,GAAG,CAAC,GAAG;AAC9E,mBAAe,MAAM,cAAc;AAAA,MACjC,uBAAuB;AAAA,QACrB,YAAY;AAAA,UACV,cAAc,CAAC,UAAU,iBAAiB;AAAA,UAC1C,eAAe,CAAC,UAAU,UAAU,KAAK;AAAA,QAC3C;AAAA,MACF;AAAA,IAAA,CACD;AAAA,EACH;AAEA,SAAO,OAAO,YAAY,EAAE,KAAK,IAAI;AACvC;"}
1
+ {"version":3,"file":"security.mjs","sources":["../../src/middlewares/security.ts"],"sourcesContent":["import { defaultsDeep, mergeWith } from 'lodash/fp';\nimport helmet, { KoaHelmet } from 'koa-helmet';\n\nimport type { Core } from '@strapi/types';\n\nexport type Config = NonNullable<Parameters<KoaHelmet>[0]>;\n\nconst defaults: Config = {\n crossOriginEmbedderPolicy: false,\n crossOriginOpenerPolicy: false,\n crossOriginResourcePolicy: false,\n originAgentCluster: false,\n contentSecurityPolicy: {\n useDefaults: true,\n directives: {\n 'connect-src': [\"'self'\", 'https:'],\n 'img-src': [\"'self'\", 'data:', 'blob:', 'https://market-assets.strapi.io'],\n 'media-src': [\"'self'\", 'data:', 'blob:'],\n upgradeInsecureRequests: null,\n },\n },\n xssFilter: false,\n hsts: {\n maxAge: 31536000,\n includeSubDomains: true,\n },\n frameguard: {\n action: 'sameorigin',\n },\n};\n\nconst mergeConfig = (existingConfig: Config, newConfig: Config) => {\n return mergeWith(\n (obj, src) => (Array.isArray(obj) && Array.isArray(src) ? obj.concat(src) : undefined),\n existingConfig,\n newConfig\n );\n};\n\nexport const security: Core.MiddlewareFactory<Config> =\n (config, { strapi }) =>\n (ctx, next) => {\n let helmetConfig: Config = defaultsDeep(defaults, config);\n\n const specialPaths = ['/documentation'];\n\n const directives: {\n 'script-src': string[];\n 'img-src': string[];\n 'manifest-src': string[];\n 'frame-src': string[];\n } = {\n 'script-src': [\"'self'\", \"'unsafe-inline'\", 'cdn.jsdelivr.net'],\n 'img-src': [\"'self'\", 'data:', 'cdn.jsdelivr.net', 'strapi.io'],\n 'manifest-src': [],\n 'frame-src': [],\n };\n\n // if apollo graphql playground is enabled, add exceptions for it\n if (strapi.plugin('graphql')?.service('utils').playground.isEnabled()) {\n const { config: gqlConfig } = strapi.plugin('graphql');\n specialPaths.push(gqlConfig('endpoint'));\n\n directives['script-src'].push(`https: 'unsafe-inline'`);\n directives['img-src'].push(`'apollo-server-landing-page.cdn.apollographql.com'`);\n directives['manifest-src'].push(`'self'`);\n directives['manifest-src'].push('apollo-server-landing-page.cdn.apollographql.com');\n directives['frame-src'].push(`'self'`);\n directives['frame-src'].push('sandbox.embed.apollographql.com');\n }\n\n // TODO: we shouldn't combine playground exceptions with documentation for all routes, we should first check the path and then return exceptions specific to that\n if (ctx.method === 'GET' && specialPaths.some((str) => ctx.path.startsWith(str))) {\n helmetConfig = mergeConfig(helmetConfig, {\n crossOriginEmbedderPolicy: false, // TODO: only use this for graphql playground\n contentSecurityPolicy: {\n directives,\n },\n });\n }\n\n /**\n * These are for vite's watch mode so it can accurately\n * connect to the HMR websocket & reconnect on failure\n * or when the server restarts.\n *\n * It only applies in development, and only on GET requests\n * that are part of the admin route.\n */\n\n if (\n ['development', 'test'].includes(process.env.NODE_ENV ?? '') &&\n ctx.method === 'GET' &&\n ctx.path.startsWith(strapi.config.get('admin.path'))\n ) {\n helmetConfig = mergeConfig(helmetConfig, {\n contentSecurityPolicy: {\n directives: {\n 'script-src': [\"'self'\", \"'unsafe-inline'\"],\n 'connect-src': [\"'self'\", 'http:', 'https:', 'ws:'],\n },\n },\n });\n }\n\n return helmet(helmetConfig)(ctx, next);\n };\n"],"names":[],"mappings":";;AAOA,MAAM,WAAmB;AAAA,EACvB,2BAA2B;AAAA,EAC3B,yBAAyB;AAAA,EACzB,2BAA2B;AAAA,EAC3B,oBAAoB;AAAA,EACpB,uBAAuB;AAAA,IACrB,aAAa;AAAA,IACb,YAAY;AAAA,MACV,eAAe,CAAC,UAAU,QAAQ;AAAA,MAClC,WAAW,CAAC,UAAU,SAAS,SAAS,iCAAiC;AAAA,MACzE,aAAa,CAAC,UAAU,SAAS,OAAO;AAAA,MACxC,yBAAyB;AAAA,IAC3B;AAAA,EACF;AAAA,EACA,WAAW;AAAA,EACX,MAAM;AAAA,IACJ,QAAQ;AAAA,IACR,mBAAmB;AAAA,EACrB;AAAA,EACA,YAAY;AAAA,IACV,QAAQ;AAAA,EACV;AACF;AAEA,MAAM,cAAc,CAAC,gBAAwB,cAAsB;AAC1D,SAAA;AAAA,IACL,CAAC,KAAK,QAAS,MAAM,QAAQ,GAAG,KAAK,MAAM,QAAQ,GAAG,IAAI,IAAI,OAAO,GAAG,IAAI;AAAA,IAC5E;AAAA,IACA;AAAA,EAAA;AAEJ;AAEa,MAAA,WACX,CAAC,QAAQ,EAAE,aACX,CAAC,KAAK,SAAS;AACT,MAAA,eAAuB,aAAa,UAAU,MAAM;AAElD,QAAA,eAAe,CAAC,gBAAgB;AAEtC,QAAM,aAKF;AAAA,IACF,cAAc,CAAC,UAAU,mBAAmB,kBAAkB;AAAA,IAC9D,WAAW,CAAC,UAAU,SAAS,oBAAoB,WAAW;AAAA,IAC9D,gBAAgB,CAAC;AAAA,IACjB,aAAa,CAAC;AAAA,EAAA;AAIZ,MAAA,OAAO,OAAO,SAAS,GAAG,QAAQ,OAAO,EAAE,WAAW,aAAa;AACrE,UAAM,EAAE,QAAQ,UAAA,IAAc,OAAO,OAAO,SAAS;AACxC,iBAAA,KAAK,UAAU,UAAU,CAAC;AAE5B,eAAA,YAAY,EAAE,KAAK,wBAAwB;AAC3C,eAAA,SAAS,EAAE,KAAK,oDAAoD;AACpE,eAAA,cAAc,EAAE,KAAK,QAAQ;AAC7B,eAAA,cAAc,EAAE,KAAK,kDAAkD;AACvE,eAAA,WAAW,EAAE,KAAK,QAAQ;AAC1B,eAAA,WAAW,EAAE,KAAK,iCAAiC;AAAA,EAChE;AAGA,MAAI,IAAI,WAAW,SAAS,aAAa,KAAK,CAAC,QAAQ,IAAI,KAAK,WAAW,GAAG,CAAC,GAAG;AAChF,mBAAe,YAAY,cAAc;AAAA,MACvC,2BAA2B;AAAA;AAAA,MAC3B,uBAAuB;AAAA,QACrB;AAAA,MACF;AAAA,IAAA,CACD;AAAA,EACH;AAYE,MAAA,CAAC,eAAe,MAAM,EAAE,SAAS,QAAQ,IAAI,YAAY,EAAE,KAC3D,IAAI,WAAW,SACf,IAAI,KAAK,WAAW,OAAO,OAAO,IAAI,YAAY,CAAC,GACnD;AACA,mBAAe,YAAY,cAAc;AAAA,MACvC,uBAAuB;AAAA,QACrB,YAAY;AAAA,UACV,cAAc,CAAC,UAAU,iBAAiB;AAAA,UAC1C,eAAe,CAAC,UAAU,SAAS,UAAU,KAAK;AAAA,QACpD;AAAA,MACF;AAAA,IAAA,CACD;AAAA,EACH;AAEA,SAAO,OAAO,YAAY,EAAE,KAAK,IAAI;AACvC;"}
@@ -1,4 +1,4 @@
1
1
  import koaSession from 'koa-session';
2
- import type { Common } from '@strapi/types';
3
- export declare const session: Common.MiddlewareFactory<Partial<koaSession.opts>>;
2
+ import type { Core } from '@strapi/types';
3
+ export declare const session: Core.MiddlewareFactory<Partial<koaSession.opts>>;
4
4
  //# sourceMappingURL=session.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"session.d.ts","sourceRoot":"","sources":["../../src/middlewares/session.ts"],"names":[],"mappings":"AACA,OAAO,UAAU,MAAM,aAAa,CAAC;AACrC,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAe5C,eAAO,MAAM,OAAO,EAAE,MAAM,CAAC,iBAAiB,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CActE,CAAC"}
1
+ {"version":3,"file":"session.d.ts","sourceRoot":"","sources":["../../src/middlewares/session.ts"],"names":[],"mappings":"AACA,OAAO,UAAU,MAAM,aAAa,CAAC;AACrC,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAe1C,eAAO,MAAM,OAAO,EAAE,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAcpE,CAAC"}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const _ = require("lodash/fp");
3
+ const fp = require("lodash/fp");
4
4
  const koaSession = require("koa-session");
5
5
  const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
6
6
  const koaSession__default = /* @__PURE__ */ _interopDefault(koaSession);
@@ -18,7 +18,7 @@ const defaultConfig = {
18
18
  };
19
19
  const session = (userConfig, { strapi }) => {
20
20
  const { keys } = strapi.server.app;
21
- if (!_.isArray(keys) || _.isEmpty(keys) || keys.some(_.isEmpty)) {
21
+ if (!fp.isArray(keys) || fp.isEmpty(keys) || keys.some(fp.isEmpty)) {
22
22
  throw new Error(
23
23
  `App keys are required. Please set app.keys in config/server.js (ex: keys: ['myKeyA', 'myKeyB'])`
24
24
  );
@@ -1 +1 @@
1
- {"version":3,"file":"session.js","sources":["../../src/middlewares/session.ts"],"sourcesContent":["import { isEmpty, isArray } from 'lodash/fp';\nimport koaSession from 'koa-session';\nimport type { Common } from '@strapi/types';\n\nconst defaultConfig = {\n key: 'koa.sess',\n maxAge: 86400000,\n autoCommit: true,\n overwrite: true,\n httpOnly: true,\n signed: true,\n rolling: false,\n renew: false,\n secure: process.env.NODE_ENV === 'production',\n sameSite: undefined,\n};\n\nexport const session: Common.MiddlewareFactory<Partial<koaSession.opts>> = (\n userConfig,\n { strapi }\n) => {\n const { keys } = strapi.server.app;\n if (!isArray(keys) || isEmpty(keys) || keys.some(isEmpty)) {\n throw new Error(\n `App keys are required. Please set app.keys in config/server.js (ex: keys: ['myKeyA', 'myKeyB'])`\n );\n }\n\n const config: Partial<koaSession.opts> = { ...defaultConfig, ...userConfig };\n\n strapi.server.use(koaSession(config, strapi.server.app));\n};\n"],"names":["isArray","isEmpty","koaSession"],"mappings":";;;;;;AAIA,MAAM,gBAAgB;AAAA,EACpB,KAAK;AAAA,EACL,QAAQ;AAAA,EACR,YAAY;AAAA,EACZ,WAAW;AAAA,EACX,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,SAAS;AAAA,EACT,OAAO;AAAA,EACP,QAAQ,QAAQ,IAAI,aAAa;AAAA,EACjC,UAAU;AACZ;AAEO,MAAM,UAA8D,CACzE,YACA,EAAE,aACC;AACH,QAAM,EAAE,KAAS,IAAA,OAAO,OAAO;AAC3B,MAAA,CAACA,EAAAA,QAAQ,IAAI,KAAKC,EAAA,QAAQ,IAAI,KAAK,KAAK,KAAKA,EAAAA,OAAO,GAAG;AACzD,UAAM,IAAI;AAAA,MACR;AAAA,IAAA;AAAA,EAEJ;AAEA,QAAM,SAAmC,EAAE,GAAG,eAAe,GAAG,WAAW;AAE3E,SAAO,OAAO,IAAIC,oBAAA,QAAW,QAAQ,OAAO,OAAO,GAAG,CAAC;AACzD;;"}
1
+ {"version":3,"file":"session.js","sources":["../../src/middlewares/session.ts"],"sourcesContent":["import { isEmpty, isArray } from 'lodash/fp';\nimport koaSession from 'koa-session';\nimport type { Core } from '@strapi/types';\n\nconst defaultConfig = {\n key: 'koa.sess',\n maxAge: 86400000,\n autoCommit: true,\n overwrite: true,\n httpOnly: true,\n signed: true,\n rolling: false,\n renew: false,\n secure: process.env.NODE_ENV === 'production',\n sameSite: undefined,\n};\n\nexport const session: Core.MiddlewareFactory<Partial<koaSession.opts>> = (\n userConfig,\n { strapi }\n) => {\n const { keys } = strapi.server.app;\n if (!isArray(keys) || isEmpty(keys) || keys.some(isEmpty)) {\n throw new Error(\n `App keys are required. Please set app.keys in config/server.js (ex: keys: ['myKeyA', 'myKeyB'])`\n );\n }\n\n const config: Partial<koaSession.opts> = { ...defaultConfig, ...userConfig };\n\n strapi.server.use(koaSession(config, strapi.server.app));\n};\n"],"names":["isArray","isEmpty","koaSession"],"mappings":";;;;;;AAIA,MAAM,gBAAgB;AAAA,EACpB,KAAK;AAAA,EACL,QAAQ;AAAA,EACR,YAAY;AAAA,EACZ,WAAW;AAAA,EACX,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,SAAS;AAAA,EACT,OAAO;AAAA,EACP,QAAQ,QAAQ,IAAI,aAAa;AAAA,EACjC,UAAU;AACZ;AAEO,MAAM,UAA4D,CACvE,YACA,EAAE,aACC;AACH,QAAM,EAAE,KAAS,IAAA,OAAO,OAAO;AAC3B,MAAA,CAACA,GAAAA,QAAQ,IAAI,KAAKC,GAAA,QAAQ,IAAI,KAAK,KAAK,KAAKA,GAAAA,OAAO,GAAG;AACzD,UAAM,IAAI;AAAA,MACR;AAAA,IAAA;AAAA,EAEJ;AAEA,QAAM,SAAmC,EAAE,GAAG,eAAe,GAAG,WAAW;AAE3E,SAAO,OAAO,IAAIC,oBAAA,QAAW,QAAQ,OAAO,OAAO,GAAG,CAAC;AACzD;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"session.mjs","sources":["../../src/middlewares/session.ts"],"sourcesContent":["import { isEmpty, isArray } from 'lodash/fp';\nimport koaSession from 'koa-session';\nimport type { Common } from '@strapi/types';\n\nconst defaultConfig = {\n key: 'koa.sess',\n maxAge: 86400000,\n autoCommit: true,\n overwrite: true,\n httpOnly: true,\n signed: true,\n rolling: false,\n renew: false,\n secure: process.env.NODE_ENV === 'production',\n sameSite: undefined,\n};\n\nexport const session: Common.MiddlewareFactory<Partial<koaSession.opts>> = (\n userConfig,\n { strapi }\n) => {\n const { keys } = strapi.server.app;\n if (!isArray(keys) || isEmpty(keys) || keys.some(isEmpty)) {\n throw new Error(\n `App keys are required. Please set app.keys in config/server.js (ex: keys: ['myKeyA', 'myKeyB'])`\n );\n }\n\n const config: Partial<koaSession.opts> = { ...defaultConfig, ...userConfig };\n\n strapi.server.use(koaSession(config, strapi.server.app));\n};\n"],"names":[],"mappings":";;AAIA,MAAM,gBAAgB;AAAA,EACpB,KAAK;AAAA,EACL,QAAQ;AAAA,EACR,YAAY;AAAA,EACZ,WAAW;AAAA,EACX,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,SAAS;AAAA,EACT,OAAO;AAAA,EACP,QAAQ,QAAQ,IAAI,aAAa;AAAA,EACjC,UAAU;AACZ;AAEO,MAAM,UAA8D,CACzE,YACA,EAAE,aACC;AACH,QAAM,EAAE,KAAS,IAAA,OAAO,OAAO;AAC3B,MAAA,CAAC,QAAQ,IAAI,KAAK,QAAQ,IAAI,KAAK,KAAK,KAAK,OAAO,GAAG;AACzD,UAAM,IAAI;AAAA,MACR;AAAA,IAAA;AAAA,EAEJ;AAEA,QAAM,SAAmC,EAAE,GAAG,eAAe,GAAG,WAAW;AAE3E,SAAO,OAAO,IAAI,WAAW,QAAQ,OAAO,OAAO,GAAG,CAAC;AACzD;"}
1
+ {"version":3,"file":"session.mjs","sources":["../../src/middlewares/session.ts"],"sourcesContent":["import { isEmpty, isArray } from 'lodash/fp';\nimport koaSession from 'koa-session';\nimport type { Core } from '@strapi/types';\n\nconst defaultConfig = {\n key: 'koa.sess',\n maxAge: 86400000,\n autoCommit: true,\n overwrite: true,\n httpOnly: true,\n signed: true,\n rolling: false,\n renew: false,\n secure: process.env.NODE_ENV === 'production',\n sameSite: undefined,\n};\n\nexport const session: Core.MiddlewareFactory<Partial<koaSession.opts>> = (\n userConfig,\n { strapi }\n) => {\n const { keys } = strapi.server.app;\n if (!isArray(keys) || isEmpty(keys) || keys.some(isEmpty)) {\n throw new Error(\n `App keys are required. Please set app.keys in config/server.js (ex: keys: ['myKeyA', 'myKeyB'])`\n );\n }\n\n const config: Partial<koaSession.opts> = { ...defaultConfig, ...userConfig };\n\n strapi.server.use(koaSession(config, strapi.server.app));\n};\n"],"names":[],"mappings":";;AAIA,MAAM,gBAAgB;AAAA,EACpB,KAAK;AAAA,EACL,QAAQ;AAAA,EACR,YAAY;AAAA,EACZ,WAAW;AAAA,EACX,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,SAAS;AAAA,EACT,OAAO;AAAA,EACP,QAAQ,QAAQ,IAAI,aAAa;AAAA,EACjC,UAAU;AACZ;AAEO,MAAM,UAA4D,CACvE,YACA,EAAE,aACC;AACH,QAAM,EAAE,KAAS,IAAA,OAAO,OAAO;AAC3B,MAAA,CAAC,QAAQ,IAAI,KAAK,QAAQ,IAAI,KAAK,KAAK,KAAK,OAAO,GAAG;AACzD,UAAM,IAAI;AAAA,MACR;AAAA,IAAA;AAAA,EAEJ;AAEA,QAAM,SAAmC,EAAE,GAAG,eAAe,GAAG,WAAW;AAE3E,SAAO,OAAO,IAAI,WAAW,QAAQ,OAAO,OAAO,GAAG,CAAC;AACzD;"}
@@ -0,0 +1,33 @@
1
+ /**
2
+ * This migration is responsible for creating the draft counterpart for all the entries that were in a published state.
3
+ *
4
+ * In v4, entries could either be in a draft or published state, but not both at the same time.
5
+ * In v5, we introduced the concept of document, and an entry can be in a draft or published state.
6
+ *
7
+ * This means the migration needs to create the draft counterpart if an entry was published.
8
+ *
9
+ * This migration performs the following steps:
10
+ * 1. Creates draft entries for all published entries, without it's components, dynamic zones or relations.
11
+ * 2. Using the document service, discard those same drafts to copy its relations.
12
+ */
13
+ import type { Database, Migration } from '@strapi/database';
14
+ type DocumentVersion = {
15
+ documentId: string;
16
+ locale: string;
17
+ };
18
+ type Knex = Parameters<Migration['up']>[0];
19
+ /**
20
+ * Load a batch of versions to discard.
21
+ *
22
+ * Versions with only a draft version will be ignored.
23
+ * Only versions with a published version (which always have a draft version) will be discarded.
24
+ */
25
+ export declare function getBatchToDiscard({ db, trx, uid, batchSize, }: {
26
+ db: Database;
27
+ trx: Knex;
28
+ uid: string;
29
+ batchSize?: number;
30
+ }): AsyncGenerator<DocumentVersion[], void, unknown>;
31
+ export declare const discardDocumentDrafts: Migration;
32
+ export {};
33
+ //# sourceMappingURL=5.0.0-discard-drafts.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"5.0.0-discard-drafts.d.ts","sourceRoot":"","sources":["../../../src/migrations/database/5.0.0-discard-drafts.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAIH,OAAO,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAG5D,KAAK,eAAe,GAAG;IAAE,UAAU,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC;AAC9D,KAAK,IAAI,GAAG,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAqF3C;;;;;GAKG;AACH,wBAAuB,iBAAiB,CAAC,EACvC,EAAE,EACF,GAAG,EACH,GAAG,EACH,SAAgB,GACjB,EAAE;IACD,EAAE,EAAE,QAAQ,CAAC;IACb,GAAG,EAAE,IAAI,CAAC;IACV,GAAG,EAAE,MAAM,CAAC;IACZ,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,oDAuBA;AAwCD,eAAO,MAAM,qBAAqB,EAAE,SAQnC,CAAC"}
@@ -0,0 +1,94 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const strapiUtils = require("@strapi/utils");
4
+ const hasDraftAndPublish = async (trx, meta) => {
5
+ const hasTable = await trx.schema.hasTable(meta.tableName);
6
+ if (!hasTable) {
7
+ return false;
8
+ }
9
+ const uid = meta.uid;
10
+ const model = strapi.getModel(uid);
11
+ const hasDP = strapiUtils.contentTypes.hasDraftAndPublish(model);
12
+ if (!hasDP) {
13
+ return false;
14
+ }
15
+ return true;
16
+ };
17
+ async function copyPublishedEntriesToDraft({
18
+ db,
19
+ trx,
20
+ uid
21
+ }) {
22
+ const meta = db.metadata.get(uid);
23
+ const scalarAttributes = Object.values(meta.attributes).reduce((acc, attribute) => {
24
+ if (["id"].includes(attribute.columnName)) {
25
+ return acc;
26
+ }
27
+ if (strapiUtils.contentTypes.isScalarAttribute(attribute)) {
28
+ acc.push(attribute.columnName);
29
+ }
30
+ return acc;
31
+ }, []);
32
+ await trx.into(
33
+ trx.raw(`?? (${scalarAttributes.map(() => `??`).join(", ")})`, [
34
+ meta.tableName,
35
+ ...scalarAttributes
36
+ ])
37
+ ).insert((subQb) => {
38
+ subQb.select(
39
+ ...scalarAttributes.map((att) => {
40
+ if (att === "published_at") {
41
+ return trx.raw("NULL as ??", "published_at");
42
+ }
43
+ return att;
44
+ })
45
+ ).from(meta.tableName).whereNotNull("published_at");
46
+ });
47
+ }
48
+ async function* getBatchToDiscard({
49
+ db,
50
+ trx,
51
+ uid,
52
+ batchSize = 1e3
53
+ }) {
54
+ let offset = 0;
55
+ let hasMore = true;
56
+ while (hasMore) {
57
+ const batch = await db.queryBuilder(uid).select(["id", "documentId", "locale"]).where({ publishedAt: { $ne: null } }).limit(batchSize).offset(offset).orderBy("id").transacting(trx).execute();
58
+ if (batch.length < batchSize) {
59
+ hasMore = false;
60
+ }
61
+ offset += batchSize;
62
+ yield batch;
63
+ }
64
+ }
65
+ const migrateUp = async (trx, db) => {
66
+ const dpModels = [];
67
+ for (const meta of db.metadata.values()) {
68
+ const hasDP = await hasDraftAndPublish(trx, meta);
69
+ if (hasDP) {
70
+ dpModels.push(meta);
71
+ }
72
+ }
73
+ for (const model of dpModels) {
74
+ await copyPublishedEntriesToDraft({ db, trx, uid: model.uid });
75
+ }
76
+ for (const model of dpModels) {
77
+ const discardDraft = async (entry) => strapi.documents(model.uid).discardDraft({ documentId: entry.documentId, locale: entry.locale });
78
+ for await (const batch of getBatchToDiscard({ db, trx, uid: model.uid })) {
79
+ await strapiUtils.async.map(batch, discardDraft, { concurrency: 10 });
80
+ }
81
+ }
82
+ };
83
+ const discardDocumentDrafts = {
84
+ name: "core::5.0.0-discard-drafts",
85
+ async up(trx, db) {
86
+ await migrateUp(trx, db);
87
+ },
88
+ async down() {
89
+ throw new Error("not implemented");
90
+ }
91
+ };
92
+ exports.discardDocumentDrafts = discardDocumentDrafts;
93
+ exports.getBatchToDiscard = getBatchToDiscard;
94
+ //# sourceMappingURL=5.0.0-discard-drafts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"5.0.0-discard-drafts.js","sources":["../../../src/migrations/database/5.0.0-discard-drafts.ts"],"sourcesContent":["/**\n * This migration is responsible for creating the draft counterpart for all the entries that were in a published state.\n *\n * In v4, entries could either be in a draft or published state, but not both at the same time.\n * In v5, we introduced the concept of document, and an entry can be in a draft or published state.\n *\n * This means the migration needs to create the draft counterpart if an entry was published.\n *\n * This migration performs the following steps:\n * 1. Creates draft entries for all published entries, without it's components, dynamic zones or relations.\n * 2. Using the document service, discard those same drafts to copy its relations.\n */\n\n/* eslint-disable no-continue */\nimport type { UID } from '@strapi/types';\nimport type { Database, Migration } from '@strapi/database';\nimport { async, contentTypes } from '@strapi/utils';\n\ntype DocumentVersion = { documentId: string; locale: string };\ntype Knex = Parameters<Migration['up']>[0];\n\n/**\n * Check if the model has draft and publish enabled.\n */\nconst hasDraftAndPublish = async (trx: Knex, meta: any) => {\n const hasTable = await trx.schema.hasTable(meta.tableName);\n\n if (!hasTable) {\n return false;\n }\n\n const uid = meta.uid as UID.ContentType;\n const model = strapi.getModel(uid);\n const hasDP = contentTypes.hasDraftAndPublish(model);\n if (!hasDP) {\n return false;\n }\n\n return true;\n};\n\n/**\n * Copy all the published entries to draft entries, without it's components, dynamic zones or relations.\n * This ensures all necessary draft's exist before copying it's relations.\n */\nasync function copyPublishedEntriesToDraft({\n db,\n trx,\n uid,\n}: {\n db: Database;\n trx: Knex;\n uid: string;\n}) {\n // Extract all scalar attributes to use in the insert query\n const meta = db.metadata.get(uid);\n\n // Get scalar attributes that will be copied over the new draft\n const scalarAttributes = Object.values(meta.attributes).reduce((acc, attribute: any) => {\n if (['id'].includes(attribute.columnName)) {\n return acc;\n }\n\n if (contentTypes.isScalarAttribute(attribute)) {\n acc.push(attribute.columnName);\n }\n\n return acc;\n }, [] as string[]);\n\n /**\n * Query to copy the published entries into draft entries.\n *\n * INSERT INTO tableName (columnName1, columnName2, columnName3, ...)\n * SELECT columnName1, columnName2, columnName3, ...\n * FROM tableName\n */\n await trx\n // INSERT INTO tableName (columnName1, columnName2, columnName3, ...)\n .into(\n trx.raw(`?? (${scalarAttributes.map(() => `??`).join(', ')})`, [\n meta.tableName,\n ...scalarAttributes,\n ])\n )\n .insert((subQb: typeof trx) => {\n // SELECT columnName1, columnName2, columnName3, ...\n subQb\n .select(\n ...scalarAttributes.map((att: string) => {\n // Override 'publishedAt' and 'updatedAt' attributes\n if (att === 'published_at') {\n return trx.raw('NULL as ??', 'published_at');\n }\n\n return att;\n })\n )\n .from(meta.tableName)\n // Only select entries that were published\n .whereNotNull('published_at');\n });\n}\n\n/**\n * Load a batch of versions to discard.\n *\n * Versions with only a draft version will be ignored.\n * Only versions with a published version (which always have a draft version) will be discarded.\n */\nexport async function* getBatchToDiscard({\n db,\n trx,\n uid,\n batchSize = 1000,\n}: {\n db: Database;\n trx: Knex;\n uid: string;\n batchSize?: number;\n}) {\n let offset = 0;\n let hasMore = true;\n\n while (hasMore) {\n // Look for the published entries to discard\n const batch: DocumentVersion[] = await db\n .queryBuilder(uid)\n .select(['id', 'documentId', 'locale'])\n .where({ publishedAt: { $ne: null } })\n .limit(batchSize)\n .offset(offset)\n .orderBy('id')\n .transacting(trx)\n .execute();\n\n if (batch.length < batchSize) {\n hasMore = false;\n }\n\n offset += batchSize;\n yield batch;\n }\n}\n\n/**\n * 2 pass migration to create the draft entries for all the published entries.\n * And then discard the drafts to copy the relations.\n */\nconst migrateUp = async (trx: Knex, db: Database) => {\n const dpModels = [];\n for (const meta of db.metadata.values()) {\n const hasDP = await hasDraftAndPublish(trx, meta);\n if (hasDP) {\n dpModels.push(meta);\n }\n }\n\n /**\n * Create plain draft entries for all the entries that were published.\n */\n for (const model of dpModels) {\n await copyPublishedEntriesToDraft({ db, trx, uid: model.uid });\n }\n\n /**\n * Discard the drafts will copy the relations from the published entries to the newly created drafts.\n *\n * Load a batch of entries (batched to prevent loading millions of rows at once ),\n * and discard them using the document service.\n */\n for (const model of dpModels) {\n const discardDraft = async (entry: DocumentVersion) =>\n strapi\n .documents(model.uid as UID.ContentType)\n .discardDraft({ documentId: entry.documentId, locale: entry.locale });\n\n for await (const batch of getBatchToDiscard({ db, trx, uid: model.uid })) {\n await async.map(batch, discardDraft, { concurrency: 10 });\n }\n }\n};\n\nexport const discardDocumentDrafts: Migration = {\n name: 'core::5.0.0-discard-drafts',\n async up(trx, db) {\n await migrateUp(trx, db);\n },\n async down() {\n throw new Error('not implemented');\n },\n};\n"],"names":["contentTypes","async"],"mappings":";;;AAwBA,MAAM,qBAAqB,OAAO,KAAW,SAAc;AACzD,QAAM,WAAW,MAAM,IAAI,OAAO,SAAS,KAAK,SAAS;AAEzD,MAAI,CAAC,UAAU;AACN,WAAA;AAAA,EACT;AAEA,QAAM,MAAM,KAAK;AACX,QAAA,QAAQ,OAAO,SAAS,GAAG;AAC3B,QAAA,QAAQA,YAAAA,aAAa,mBAAmB,KAAK;AACnD,MAAI,CAAC,OAAO;AACH,WAAA;AAAA,EACT;AAEO,SAAA;AACT;AAMA,eAAe,4BAA4B;AAAA,EACzC;AAAA,EACA;AAAA,EACA;AACF,GAIG;AAED,QAAM,OAAO,GAAG,SAAS,IAAI,GAAG;AAG1B,QAAA,mBAAmB,OAAO,OAAO,KAAK,UAAU,EAAE,OAAO,CAAC,KAAK,cAAmB;AACtF,QAAI,CAAC,IAAI,EAAE,SAAS,UAAU,UAAU,GAAG;AAClC,aAAA;AAAA,IACT;AAEI,QAAAA,YAAA,aAAa,kBAAkB,SAAS,GAAG;AACzC,UAAA,KAAK,UAAU,UAAU;AAAA,IAC/B;AAEO,WAAA;AAAA,EACT,GAAG,CAAc,CAAA;AASjB,QAAM,IAEH;AAAA,IACC,IAAI,IAAI,OAAO,iBAAiB,IAAI,MAAM,IAAI,EAAE,KAAK,IAAI,CAAC,KAAK;AAAA,MAC7D,KAAK;AAAA,MACL,GAAG;AAAA,IAAA,CACJ;AAAA,EAAA,EAEF,OAAO,CAAC,UAAsB;AAG1B,UAAA;AAAA,MACC,GAAG,iBAAiB,IAAI,CAAC,QAAgB;AAEvC,YAAI,QAAQ,gBAAgB;AACnB,iBAAA,IAAI,IAAI,cAAc,cAAc;AAAA,QAC7C;AAEO,eAAA;AAAA,MAAA,CACR;AAAA,IAAA,EAEF,KAAK,KAAK,SAAS,EAEnB,aAAa,cAAc;AAAA,EAAA,CAC/B;AACL;AAQA,gBAAuB,kBAAkB;AAAA,EACvC;AAAA,EACA;AAAA,EACA;AAAA,EACA,YAAY;AACd,GAKG;AACD,MAAI,SAAS;AACb,MAAI,UAAU;AAEd,SAAO,SAAS;AAEd,UAAM,QAA2B,MAAM,GACpC,aAAa,GAAG,EAChB,OAAO,CAAC,MAAM,cAAc,QAAQ,CAAC,EACrC,MAAM,EAAE,aAAa,EAAE,KAAK,KAAO,EAAA,CAAC,EACpC,MAAM,SAAS,EACf,OAAO,MAAM,EACb,QAAQ,IAAI,EACZ,YAAY,GAAG,EACf,QAAQ;AAEP,QAAA,MAAM,SAAS,WAAW;AAClB,gBAAA;AAAA,IACZ;AAEU,cAAA;AACJ,UAAA;AAAA,EACR;AACF;AAMA,MAAM,YAAY,OAAO,KAAW,OAAiB;AACnD,QAAM,WAAW,CAAA;AACjB,aAAW,QAAQ,GAAG,SAAS,OAAA,GAAU;AACvC,UAAM,QAAQ,MAAM,mBAAmB,KAAK,IAAI;AAChD,QAAI,OAAO;AACT,eAAS,KAAK,IAAI;AAAA,IACpB;AAAA,EACF;AAKA,aAAW,SAAS,UAAU;AAC5B,UAAM,4BAA4B,EAAE,IAAI,KAAK,KAAK,MAAM,KAAK;AAAA,EAC/D;AAQA,aAAW,SAAS,UAAU;AAC5B,UAAM,eAAe,OAAO,UAC1B,OACG,UAAU,MAAM,GAAsB,EACtC,aAAa,EAAE,YAAY,MAAM,YAAY,QAAQ,MAAM,QAAQ;AAEvD,qBAAA,SAAS,kBAAkB,EAAE,IAAI,KAAK,KAAK,MAAM,IAAI,CAAC,GAAG;AACxE,YAAMC,YAAAA,MAAM,IAAI,OAAO,cAAc,EAAE,aAAa,IAAI;AAAA,IAC1D;AAAA,EACF;AACF;AAEO,MAAM,wBAAmC;AAAA,EAC9C,MAAM;AAAA,EACN,MAAM,GAAG,KAAK,IAAI;AACV,UAAA,UAAU,KAAK,EAAE;AAAA,EACzB;AAAA,EACA,MAAM,OAAO;AACL,UAAA,IAAI,MAAM,iBAAiB;AAAA,EACnC;AACF;;;"}
@@ -0,0 +1,94 @@
1
+ import { async, contentTypes } from "@strapi/utils";
2
+ const hasDraftAndPublish = async (trx, meta) => {
3
+ const hasTable = await trx.schema.hasTable(meta.tableName);
4
+ if (!hasTable) {
5
+ return false;
6
+ }
7
+ const uid = meta.uid;
8
+ const model = strapi.getModel(uid);
9
+ const hasDP = contentTypes.hasDraftAndPublish(model);
10
+ if (!hasDP) {
11
+ return false;
12
+ }
13
+ return true;
14
+ };
15
+ async function copyPublishedEntriesToDraft({
16
+ db,
17
+ trx,
18
+ uid
19
+ }) {
20
+ const meta = db.metadata.get(uid);
21
+ const scalarAttributes = Object.values(meta.attributes).reduce((acc, attribute) => {
22
+ if (["id"].includes(attribute.columnName)) {
23
+ return acc;
24
+ }
25
+ if (contentTypes.isScalarAttribute(attribute)) {
26
+ acc.push(attribute.columnName);
27
+ }
28
+ return acc;
29
+ }, []);
30
+ await trx.into(
31
+ trx.raw(`?? (${scalarAttributes.map(() => `??`).join(", ")})`, [
32
+ meta.tableName,
33
+ ...scalarAttributes
34
+ ])
35
+ ).insert((subQb) => {
36
+ subQb.select(
37
+ ...scalarAttributes.map((att) => {
38
+ if (att === "published_at") {
39
+ return trx.raw("NULL as ??", "published_at");
40
+ }
41
+ return att;
42
+ })
43
+ ).from(meta.tableName).whereNotNull("published_at");
44
+ });
45
+ }
46
+ async function* getBatchToDiscard({
47
+ db,
48
+ trx,
49
+ uid,
50
+ batchSize = 1e3
51
+ }) {
52
+ let offset = 0;
53
+ let hasMore = true;
54
+ while (hasMore) {
55
+ const batch = await db.queryBuilder(uid).select(["id", "documentId", "locale"]).where({ publishedAt: { $ne: null } }).limit(batchSize).offset(offset).orderBy("id").transacting(trx).execute();
56
+ if (batch.length < batchSize) {
57
+ hasMore = false;
58
+ }
59
+ offset += batchSize;
60
+ yield batch;
61
+ }
62
+ }
63
+ const migrateUp = async (trx, db) => {
64
+ const dpModels = [];
65
+ for (const meta of db.metadata.values()) {
66
+ const hasDP = await hasDraftAndPublish(trx, meta);
67
+ if (hasDP) {
68
+ dpModels.push(meta);
69
+ }
70
+ }
71
+ for (const model of dpModels) {
72
+ await copyPublishedEntriesToDraft({ db, trx, uid: model.uid });
73
+ }
74
+ for (const model of dpModels) {
75
+ const discardDraft = async (entry) => strapi.documents(model.uid).discardDraft({ documentId: entry.documentId, locale: entry.locale });
76
+ for await (const batch of getBatchToDiscard({ db, trx, uid: model.uid })) {
77
+ await async.map(batch, discardDraft, { concurrency: 10 });
78
+ }
79
+ }
80
+ };
81
+ const discardDocumentDrafts = {
82
+ name: "core::5.0.0-discard-drafts",
83
+ async up(trx, db) {
84
+ await migrateUp(trx, db);
85
+ },
86
+ async down() {
87
+ throw new Error("not implemented");
88
+ }
89
+ };
90
+ export {
91
+ discardDocumentDrafts,
92
+ getBatchToDiscard
93
+ };
94
+ //# sourceMappingURL=5.0.0-discard-drafts.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"5.0.0-discard-drafts.mjs","sources":["../../../src/migrations/database/5.0.0-discard-drafts.ts"],"sourcesContent":["/**\n * This migration is responsible for creating the draft counterpart for all the entries that were in a published state.\n *\n * In v4, entries could either be in a draft or published state, but not both at the same time.\n * In v5, we introduced the concept of document, and an entry can be in a draft or published state.\n *\n * This means the migration needs to create the draft counterpart if an entry was published.\n *\n * This migration performs the following steps:\n * 1. Creates draft entries for all published entries, without it's components, dynamic zones or relations.\n * 2. Using the document service, discard those same drafts to copy its relations.\n */\n\n/* eslint-disable no-continue */\nimport type { UID } from '@strapi/types';\nimport type { Database, Migration } from '@strapi/database';\nimport { async, contentTypes } from '@strapi/utils';\n\ntype DocumentVersion = { documentId: string; locale: string };\ntype Knex = Parameters<Migration['up']>[0];\n\n/**\n * Check if the model has draft and publish enabled.\n */\nconst hasDraftAndPublish = async (trx: Knex, meta: any) => {\n const hasTable = await trx.schema.hasTable(meta.tableName);\n\n if (!hasTable) {\n return false;\n }\n\n const uid = meta.uid as UID.ContentType;\n const model = strapi.getModel(uid);\n const hasDP = contentTypes.hasDraftAndPublish(model);\n if (!hasDP) {\n return false;\n }\n\n return true;\n};\n\n/**\n * Copy all the published entries to draft entries, without it's components, dynamic zones or relations.\n * This ensures all necessary draft's exist before copying it's relations.\n */\nasync function copyPublishedEntriesToDraft({\n db,\n trx,\n uid,\n}: {\n db: Database;\n trx: Knex;\n uid: string;\n}) {\n // Extract all scalar attributes to use in the insert query\n const meta = db.metadata.get(uid);\n\n // Get scalar attributes that will be copied over the new draft\n const scalarAttributes = Object.values(meta.attributes).reduce((acc, attribute: any) => {\n if (['id'].includes(attribute.columnName)) {\n return acc;\n }\n\n if (contentTypes.isScalarAttribute(attribute)) {\n acc.push(attribute.columnName);\n }\n\n return acc;\n }, [] as string[]);\n\n /**\n * Query to copy the published entries into draft entries.\n *\n * INSERT INTO tableName (columnName1, columnName2, columnName3, ...)\n * SELECT columnName1, columnName2, columnName3, ...\n * FROM tableName\n */\n await trx\n // INSERT INTO tableName (columnName1, columnName2, columnName3, ...)\n .into(\n trx.raw(`?? (${scalarAttributes.map(() => `??`).join(', ')})`, [\n meta.tableName,\n ...scalarAttributes,\n ])\n )\n .insert((subQb: typeof trx) => {\n // SELECT columnName1, columnName2, columnName3, ...\n subQb\n .select(\n ...scalarAttributes.map((att: string) => {\n // Override 'publishedAt' and 'updatedAt' attributes\n if (att === 'published_at') {\n return trx.raw('NULL as ??', 'published_at');\n }\n\n return att;\n })\n )\n .from(meta.tableName)\n // Only select entries that were published\n .whereNotNull('published_at');\n });\n}\n\n/**\n * Load a batch of versions to discard.\n *\n * Versions with only a draft version will be ignored.\n * Only versions with a published version (which always have a draft version) will be discarded.\n */\nexport async function* getBatchToDiscard({\n db,\n trx,\n uid,\n batchSize = 1000,\n}: {\n db: Database;\n trx: Knex;\n uid: string;\n batchSize?: number;\n}) {\n let offset = 0;\n let hasMore = true;\n\n while (hasMore) {\n // Look for the published entries to discard\n const batch: DocumentVersion[] = await db\n .queryBuilder(uid)\n .select(['id', 'documentId', 'locale'])\n .where({ publishedAt: { $ne: null } })\n .limit(batchSize)\n .offset(offset)\n .orderBy('id')\n .transacting(trx)\n .execute();\n\n if (batch.length < batchSize) {\n hasMore = false;\n }\n\n offset += batchSize;\n yield batch;\n }\n}\n\n/**\n * 2 pass migration to create the draft entries for all the published entries.\n * And then discard the drafts to copy the relations.\n */\nconst migrateUp = async (trx: Knex, db: Database) => {\n const dpModels = [];\n for (const meta of db.metadata.values()) {\n const hasDP = await hasDraftAndPublish(trx, meta);\n if (hasDP) {\n dpModels.push(meta);\n }\n }\n\n /**\n * Create plain draft entries for all the entries that were published.\n */\n for (const model of dpModels) {\n await copyPublishedEntriesToDraft({ db, trx, uid: model.uid });\n }\n\n /**\n * Discard the drafts will copy the relations from the published entries to the newly created drafts.\n *\n * Load a batch of entries (batched to prevent loading millions of rows at once ),\n * and discard them using the document service.\n */\n for (const model of dpModels) {\n const discardDraft = async (entry: DocumentVersion) =>\n strapi\n .documents(model.uid as UID.ContentType)\n .discardDraft({ documentId: entry.documentId, locale: entry.locale });\n\n for await (const batch of getBatchToDiscard({ db, trx, uid: model.uid })) {\n await async.map(batch, discardDraft, { concurrency: 10 });\n }\n }\n};\n\nexport const discardDocumentDrafts: Migration = {\n name: 'core::5.0.0-discard-drafts',\n async up(trx, db) {\n await migrateUp(trx, db);\n },\n async down() {\n throw new Error('not implemented');\n },\n};\n"],"names":[],"mappings":";AAwBA,MAAM,qBAAqB,OAAO,KAAW,SAAc;AACzD,QAAM,WAAW,MAAM,IAAI,OAAO,SAAS,KAAK,SAAS;AAEzD,MAAI,CAAC,UAAU;AACN,WAAA;AAAA,EACT;AAEA,QAAM,MAAM,KAAK;AACX,QAAA,QAAQ,OAAO,SAAS,GAAG;AAC3B,QAAA,QAAQ,aAAa,mBAAmB,KAAK;AACnD,MAAI,CAAC,OAAO;AACH,WAAA;AAAA,EACT;AAEO,SAAA;AACT;AAMA,eAAe,4BAA4B;AAAA,EACzC;AAAA,EACA;AAAA,EACA;AACF,GAIG;AAED,QAAM,OAAO,GAAG,SAAS,IAAI,GAAG;AAG1B,QAAA,mBAAmB,OAAO,OAAO,KAAK,UAAU,EAAE,OAAO,CAAC,KAAK,cAAmB;AACtF,QAAI,CAAC,IAAI,EAAE,SAAS,UAAU,UAAU,GAAG;AAClC,aAAA;AAAA,IACT;AAEI,QAAA,aAAa,kBAAkB,SAAS,GAAG;AACzC,UAAA,KAAK,UAAU,UAAU;AAAA,IAC/B;AAEO,WAAA;AAAA,EACT,GAAG,CAAc,CAAA;AASjB,QAAM,IAEH;AAAA,IACC,IAAI,IAAI,OAAO,iBAAiB,IAAI,MAAM,IAAI,EAAE,KAAK,IAAI,CAAC,KAAK;AAAA,MAC7D,KAAK;AAAA,MACL,GAAG;AAAA,IAAA,CACJ;AAAA,EAAA,EAEF,OAAO,CAAC,UAAsB;AAG1B,UAAA;AAAA,MACC,GAAG,iBAAiB,IAAI,CAAC,QAAgB;AAEvC,YAAI,QAAQ,gBAAgB;AACnB,iBAAA,IAAI,IAAI,cAAc,cAAc;AAAA,QAC7C;AAEO,eAAA;AAAA,MAAA,CACR;AAAA,IAAA,EAEF,KAAK,KAAK,SAAS,EAEnB,aAAa,cAAc;AAAA,EAAA,CAC/B;AACL;AAQA,gBAAuB,kBAAkB;AAAA,EACvC;AAAA,EACA;AAAA,EACA;AAAA,EACA,YAAY;AACd,GAKG;AACD,MAAI,SAAS;AACb,MAAI,UAAU;AAEd,SAAO,SAAS;AAEd,UAAM,QAA2B,MAAM,GACpC,aAAa,GAAG,EAChB,OAAO,CAAC,MAAM,cAAc,QAAQ,CAAC,EACrC,MAAM,EAAE,aAAa,EAAE,KAAK,KAAO,EAAA,CAAC,EACpC,MAAM,SAAS,EACf,OAAO,MAAM,EACb,QAAQ,IAAI,EACZ,YAAY,GAAG,EACf,QAAQ;AAEP,QAAA,MAAM,SAAS,WAAW;AAClB,gBAAA;AAAA,IACZ;AAEU,cAAA;AACJ,UAAA;AAAA,EACR;AACF;AAMA,MAAM,YAAY,OAAO,KAAW,OAAiB;AACnD,QAAM,WAAW,CAAA;AACjB,aAAW,QAAQ,GAAG,SAAS,OAAA,GAAU;AACvC,UAAM,QAAQ,MAAM,mBAAmB,KAAK,IAAI;AAChD,QAAI,OAAO;AACT,eAAS,KAAK,IAAI;AAAA,IACpB;AAAA,EACF;AAKA,aAAW,SAAS,UAAU;AAC5B,UAAM,4BAA4B,EAAE,IAAI,KAAK,KAAK,MAAM,KAAK;AAAA,EAC/D;AAQA,aAAW,SAAS,UAAU;AAC5B,UAAM,eAAe,OAAO,UAC1B,OACG,UAAU,MAAM,GAAsB,EACtC,aAAa,EAAE,YAAY,MAAM,YAAY,QAAQ,MAAM,QAAQ;AAEvD,qBAAA,SAAS,kBAAkB,EAAE,IAAI,KAAK,KAAK,MAAM,IAAI,CAAC,GAAG;AACxE,YAAM,MAAM,IAAI,OAAO,cAAc,EAAE,aAAa,IAAI;AAAA,IAC1D;AAAA,EACF;AACF;AAEO,MAAM,wBAAmC;AAAA,EAC9C,MAAM;AAAA,EACN,MAAM,GAAG,KAAK,IAAI;AACV,UAAA,UAAU,KAAK,EAAE;AAAA,EACzB;AAAA,EACA,MAAM,OAAO;AACL,UAAA,IAAI,MAAM,iBAAiB;AAAA,EACnC;AACF;"}
@@ -1,5 +1,5 @@
1
1
  import { Schema } from '@strapi/types';
2
- interface Input {
2
+ export interface Input {
3
3
  oldContentTypes: Record<string, Schema.ContentType>;
4
4
  contentTypes: Record<string, Schema.ContentType>;
5
5
  }
@@ -1 +1 @@
1
- {"version":3,"file":"draft-publish.d.ts","sourceRoot":"","sources":["../../src/migrations/draft-publish.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvC,UAAU,KAAK;IACb,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC;IACpD,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC;CAClD;AAED;;;;;;;GAOG;AACH,QAAA,MAAM,qBAAqB,sCAA6C,KAAK,kBAqE5E,CAAC;AAEF,QAAA,MAAM,sBAAsB,sCAA6C,KAAK,kBAqB7E,CAAC;AAEF,OAAO,EAAE,qBAAqB,IAAI,MAAM,EAAE,sBAAsB,IAAI,OAAO,EAAE,CAAC"}
1
+ {"version":3,"file":"draft-publish.d.ts","sourceRoot":"","sources":["../../src/migrations/draft-publish.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAIvC,MAAM,WAAW,KAAK;IACpB,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC;IACpD,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC;CAClD;AAED;;;;;;;GAOG;AACH,QAAA,MAAM,qBAAqB,sCAA6C,KAAK,kBAoC5E,CAAC;AAEF,QAAA,MAAM,sBAAsB,sCAA6C,KAAK,kBAqB7E,CAAC;AAEF,OAAO,EAAE,qBAAqB,IAAI,MAAM,EAAE,sBAAsB,IAAI,OAAO,EAAE,CAAC"}