@strapi/core 0.0.0-experimental.e3e48deb89bd0a1b6cc69b698696566fa7854a95 → 0.0.0-experimental.e4103be75de4e986d3c7eacedc971623d1dd2d63

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.

Potentially problematic release.


This version of @strapi/core might be problematic. Click here for more details.

Files changed (1098) hide show
  1. package/LICENSE +18 -3
  2. package/dist/Strapi.d.ts +50 -58
  3. package/dist/Strapi.d.ts.map +1 -1
  4. package/dist/Strapi.js +456 -439
  5. package/dist/Strapi.js.map +1 -1
  6. package/dist/Strapi.mjs +447 -450
  7. package/dist/Strapi.mjs.map +1 -1
  8. package/dist/compile.js +23 -14
  9. package/dist/compile.js.map +1 -1
  10. package/dist/compile.mjs +22 -14
  11. package/dist/compile.mjs.map +1 -1
  12. package/dist/configuration/config-loader.d.ts.map +1 -1
  13. package/dist/configuration/config-loader.js +110 -93
  14. package/dist/configuration/config-loader.js.map +1 -1
  15. package/dist/configuration/config-loader.mjs +109 -92
  16. package/dist/configuration/config-loader.mjs.map +1 -1
  17. package/dist/configuration/get-dirs.d.ts +10 -0
  18. package/dist/configuration/get-dirs.d.ts.map +1 -0
  19. package/dist/configuration/get-dirs.js +33 -0
  20. package/dist/configuration/get-dirs.js.map +1 -0
  21. package/dist/configuration/get-dirs.mjs +31 -0
  22. package/dist/configuration/get-dirs.mjs.map +1 -0
  23. package/dist/configuration/index.d.ts +5 -7
  24. package/dist/configuration/index.d.ts.map +1 -1
  25. package/dist/configuration/index.js +86 -72
  26. package/dist/configuration/index.js.map +1 -1
  27. package/dist/configuration/index.mjs +84 -68
  28. package/dist/configuration/index.mjs.map +1 -1
  29. package/dist/configuration/urls.d.ts.map +1 -1
  30. package/dist/configuration/urls.js +74 -61
  31. package/dist/configuration/urls.js.map +1 -1
  32. package/dist/configuration/urls.mjs +73 -62
  33. package/dist/configuration/urls.mjs.map +1 -1
  34. package/dist/constants.d.ts +3 -0
  35. package/dist/constants.d.ts.map +1 -0
  36. package/dist/constants.js +6 -0
  37. package/dist/constants.js.map +1 -0
  38. package/dist/constants.mjs +4 -0
  39. package/dist/constants.mjs.map +1 -0
  40. package/dist/container.d.ts +2 -2
  41. package/dist/container.d.ts.map +1 -1
  42. package/dist/container.js +27 -23
  43. package/dist/container.js.map +1 -1
  44. package/dist/container.mjs +26 -24
  45. package/dist/container.mjs.map +1 -1
  46. package/dist/core-api/controller/collection-type.d.ts +3 -3
  47. package/dist/core-api/controller/collection-type.d.ts.map +1 -1
  48. package/dist/core-api/controller/collection-type.js +77 -73
  49. package/dist/core-api/controller/collection-type.js.map +1 -1
  50. package/dist/core-api/controller/collection-type.mjs +76 -74
  51. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  52. package/dist/core-api/controller/index.d.ts +3 -3
  53. package/dist/core-api/controller/index.d.ts.map +1 -1
  54. package/dist/core-api/controller/index.js +64 -48
  55. package/dist/core-api/controller/index.js.map +1 -1
  56. package/dist/core-api/controller/index.mjs +63 -49
  57. package/dist/core-api/controller/index.mjs.map +1 -1
  58. package/dist/core-api/controller/single-type.d.ts +3 -3
  59. package/dist/core-api/controller/single-type.d.ts.map +1 -1
  60. package/dist/core-api/controller/single-type.js +41 -39
  61. package/dist/core-api/controller/single-type.js.map +1 -1
  62. package/dist/core-api/controller/single-type.mjs +40 -40
  63. package/dist/core-api/controller/single-type.mjs.map +1 -1
  64. package/dist/core-api/controller/transform.d.ts +5 -4
  65. package/dist/core-api/controller/transform.d.ts.map +1 -1
  66. package/dist/core-api/controller/transform.js +83 -67
  67. package/dist/core-api/controller/transform.js.map +1 -1
  68. package/dist/core-api/controller/transform.mjs +82 -68
  69. package/dist/core-api/controller/transform.mjs.map +1 -1
  70. package/dist/core-api/routes/index.d.ts +4 -22
  71. package/dist/core-api/routes/index.d.ts.map +1 -1
  72. package/dist/core-api/routes/index.js +205 -61
  73. package/dist/core-api/routes/index.js.map +1 -1
  74. package/dist/core-api/routes/index.mjs +185 -62
  75. package/dist/core-api/routes/index.mjs.map +1 -1
  76. package/dist/core-api/routes/validation/attributes.d.ts +244 -0
  77. package/dist/core-api/routes/validation/attributes.d.ts.map +1 -0
  78. package/dist/core-api/routes/validation/attributes.js +560 -0
  79. package/dist/core-api/routes/validation/attributes.js.map +1 -0
  80. package/dist/core-api/routes/validation/attributes.mjs +521 -0
  81. package/dist/core-api/routes/validation/attributes.mjs.map +1 -0
  82. package/dist/core-api/routes/validation/common.d.ts +105 -0
  83. package/dist/core-api/routes/validation/common.d.ts.map +1 -0
  84. package/dist/core-api/routes/validation/common.js +116 -0
  85. package/dist/core-api/routes/validation/common.js.map +1 -0
  86. package/dist/core-api/routes/validation/common.mjs +95 -0
  87. package/dist/core-api/routes/validation/common.mjs.map +1 -0
  88. package/dist/core-api/routes/validation/component.d.ts +34 -0
  89. package/dist/core-api/routes/validation/component.d.ts.map +1 -0
  90. package/dist/core-api/routes/validation/component.js +45 -0
  91. package/dist/core-api/routes/validation/component.js.map +1 -0
  92. package/dist/core-api/routes/validation/component.mjs +43 -0
  93. package/dist/core-api/routes/validation/component.mjs.map +1 -0
  94. package/dist/core-api/routes/validation/constants.d.ts +8 -0
  95. package/dist/core-api/routes/validation/constants.d.ts.map +1 -0
  96. package/dist/core-api/routes/validation/constants.js +18 -0
  97. package/dist/core-api/routes/validation/constants.js.map +1 -0
  98. package/dist/core-api/routes/validation/constants.mjs +16 -0
  99. package/dist/core-api/routes/validation/constants.mjs.map +1 -0
  100. package/dist/core-api/routes/validation/content-type.d.ts +128 -0
  101. package/dist/core-api/routes/validation/content-type.d.ts.map +1 -0
  102. package/dist/core-api/routes/validation/content-type.js +201 -0
  103. package/dist/core-api/routes/validation/content-type.js.map +1 -0
  104. package/dist/core-api/routes/validation/content-type.mjs +180 -0
  105. package/dist/core-api/routes/validation/content-type.mjs.map +1 -0
  106. package/dist/core-api/routes/validation/index.d.ts +5 -0
  107. package/dist/core-api/routes/validation/index.d.ts.map +1 -0
  108. package/dist/core-api/routes/validation/mappers.d.ts +105 -0
  109. package/dist/core-api/routes/validation/mappers.d.ts.map +1 -0
  110. package/dist/core-api/routes/validation/mappers.js +273 -0
  111. package/dist/core-api/routes/validation/mappers.js.map +1 -0
  112. package/dist/core-api/routes/validation/mappers.mjs +249 -0
  113. package/dist/core-api/routes/validation/mappers.mjs.map +1 -0
  114. package/dist/core-api/routes/validation/utils.d.ts +47 -0
  115. package/dist/core-api/routes/validation/utils.d.ts.map +1 -0
  116. package/dist/core-api/routes/validation/utils.js +128 -0
  117. package/dist/core-api/routes/validation/utils.js.map +1 -0
  118. package/dist/core-api/routes/validation/utils.mjs +106 -0
  119. package/dist/core-api/routes/validation/utils.mjs.map +1 -0
  120. package/dist/core-api/service/collection-type.d.ts +11 -17
  121. package/dist/core-api/service/collection-type.d.ts.map +1 -1
  122. package/dist/core-api/service/collection-type.js +73 -49
  123. package/dist/core-api/service/collection-type.js.map +1 -1
  124. package/dist/core-api/service/collection-type.mjs +72 -51
  125. package/dist/core-api/service/collection-type.mjs.map +1 -1
  126. package/dist/core-api/service/core-service.js +9 -8
  127. package/dist/core-api/service/core-service.js.map +1 -1
  128. package/dist/core-api/service/core-service.mjs +8 -9
  129. package/dist/core-api/service/core-service.mjs.map +1 -1
  130. package/dist/core-api/service/index.d.ts +3 -3
  131. package/dist/core-api/service/index.d.ts.map +1 -1
  132. package/dist/core-api/service/index.js +13 -13
  133. package/dist/core-api/service/index.js.map +1 -1
  134. package/dist/core-api/service/index.mjs +12 -14
  135. package/dist/core-api/service/index.mjs.map +1 -1
  136. package/dist/core-api/service/pagination.d.ts +4 -11
  137. package/dist/core-api/service/pagination.d.ts.map +1 -1
  138. package/dist/core-api/service/pagination.js +68 -68
  139. package/dist/core-api/service/pagination.js.map +1 -1
  140. package/dist/core-api/service/pagination.mjs +66 -71
  141. package/dist/core-api/service/pagination.mjs.map +1 -1
  142. package/dist/core-api/service/single-type.d.ts +4 -4
  143. package/dist/core-api/service/single-type.d.ts.map +1 -1
  144. package/dist/core-api/service/single-type.js +43 -32
  145. package/dist/core-api/service/single-type.js.map +1 -1
  146. package/dist/core-api/service/single-type.mjs +42 -34
  147. package/dist/core-api/service/single-type.mjs.map +1 -1
  148. package/dist/domain/content-type/index.d.ts +1 -1
  149. package/dist/domain/content-type/index.d.ts.map +1 -1
  150. package/dist/domain/content-type/index.js +110 -99
  151. package/dist/domain/content-type/index.js.map +1 -1
  152. package/dist/domain/content-type/index.mjs +109 -99
  153. package/dist/domain/content-type/index.mjs.map +1 -1
  154. package/dist/domain/content-type/validator.js +84 -69
  155. package/dist/domain/content-type/validator.js.map +1 -1
  156. package/dist/domain/content-type/validator.mjs +83 -68
  157. package/dist/domain/content-type/validator.mjs.map +1 -1
  158. package/dist/domain/module/index.d.ts +24 -23
  159. package/dist/domain/module/index.d.ts.map +1 -1
  160. package/dist/domain/module/index.js +112 -99
  161. package/dist/domain/module/index.js.map +1 -1
  162. package/dist/domain/module/index.mjs +111 -98
  163. package/dist/domain/module/index.mjs.map +1 -1
  164. package/dist/domain/module/validation.js +25 -20
  165. package/dist/domain/module/validation.js.map +1 -1
  166. package/dist/domain/module/validation.mjs +24 -21
  167. package/dist/domain/module/validation.mjs.map +1 -1
  168. package/dist/ee/index.d.ts +11 -2
  169. package/dist/ee/index.d.ts.map +1 -1
  170. package/dist/ee/index.js +197 -132
  171. package/dist/ee/index.js.map +1 -1
  172. package/dist/ee/index.mjs +196 -134
  173. package/dist/ee/index.mjs.map +1 -1
  174. package/dist/ee/license.d.ts +5 -3
  175. package/dist/ee/license.d.ts.map +1 -1
  176. package/dist/ee/license.js +105 -74
  177. package/dist/ee/license.js.map +1 -1
  178. package/dist/ee/license.mjs +103 -75
  179. package/dist/ee/license.mjs.map +1 -1
  180. package/dist/factories.d.ts +13 -11
  181. package/dist/factories.d.ts.map +1 -1
  182. package/dist/factories.js +80 -63
  183. package/dist/factories.js.map +1 -1
  184. package/dist/factories.mjs +77 -66
  185. package/dist/factories.mjs.map +1 -1
  186. package/dist/index.d.ts +18 -2
  187. package/dist/index.d.ts.map +1 -1
  188. package/dist/index.js +32 -5
  189. package/dist/index.js.map +1 -1
  190. package/dist/index.mjs +29 -5
  191. package/dist/index.mjs.map +1 -1
  192. package/dist/loaders/admin.d.ts +2 -2
  193. package/dist/loaders/admin.d.ts.map +1 -1
  194. package/dist/loaders/admin.js +21 -21
  195. package/dist/loaders/admin.js.map +1 -1
  196. package/dist/loaders/admin.mjs +20 -21
  197. package/dist/loaders/admin.mjs.map +1 -1
  198. package/dist/loaders/apis.d.ts +2 -2
  199. package/dist/loaders/apis.d.ts.map +1 -1
  200. package/dist/loaders/apis.js +143 -120
  201. package/dist/loaders/apis.js.map +1 -1
  202. package/dist/loaders/apis.mjs +142 -119
  203. package/dist/loaders/apis.mjs.map +1 -1
  204. package/dist/loaders/components.d.ts +2 -2
  205. package/dist/loaders/components.d.ts.map +1 -1
  206. package/dist/loaders/components.js +33 -34
  207. package/dist/loaders/components.js.map +1 -1
  208. package/dist/loaders/components.mjs +32 -34
  209. package/dist/loaders/components.mjs.map +1 -1
  210. package/dist/loaders/index.d.ts +2 -2
  211. package/dist/loaders/index.d.ts.map +1 -1
  212. package/dist/loaders/index.js +22 -22
  213. package/dist/loaders/index.js.map +1 -1
  214. package/dist/loaders/index.mjs +21 -23
  215. package/dist/loaders/index.mjs.map +1 -1
  216. package/dist/loaders/middlewares.d.ts +2 -2
  217. package/dist/loaders/middlewares.d.ts.map +1 -1
  218. package/dist/loaders/middlewares.js +29 -25
  219. package/dist/loaders/middlewares.js.map +1 -1
  220. package/dist/loaders/middlewares.mjs +28 -25
  221. package/dist/loaders/middlewares.mjs.map +1 -1
  222. package/dist/loaders/plugins/get-enabled-plugins.d.ts +2 -2
  223. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  224. package/dist/loaders/plugins/get-enabled-plugins.js +125 -100
  225. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
  226. package/dist/loaders/plugins/get-enabled-plugins.mjs +124 -99
  227. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
  228. package/dist/loaders/plugins/get-user-plugins-config.js +25 -24
  229. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -1
  230. package/dist/loaders/plugins/get-user-plugins-config.mjs +24 -23
  231. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +1 -1
  232. package/dist/loaders/plugins/index.d.ts +2 -2
  233. package/dist/loaders/plugins/index.d.ts.map +1 -1
  234. package/dist/loaders/plugins/index.js +141 -104
  235. package/dist/loaders/plugins/index.js.map +1 -1
  236. package/dist/loaders/plugins/index.mjs +121 -104
  237. package/dist/loaders/plugins/index.mjs.map +1 -1
  238. package/dist/loaders/policies.d.ts +2 -2
  239. package/dist/loaders/policies.d.ts.map +1 -1
  240. package/dist/loaders/policies.js +24 -20
  241. package/dist/loaders/policies.js.map +1 -1
  242. package/dist/loaders/policies.mjs +23 -20
  243. package/dist/loaders/policies.mjs.map +1 -1
  244. package/dist/loaders/sanitizers.d.ts +2 -2
  245. package/dist/loaders/sanitizers.d.ts.map +1 -1
  246. package/dist/loaders/sanitizers.js +10 -4
  247. package/dist/loaders/sanitizers.js.map +1 -1
  248. package/dist/loaders/sanitizers.mjs +9 -6
  249. package/dist/loaders/sanitizers.mjs.map +1 -1
  250. package/dist/loaders/src-index.d.ts +2 -2
  251. package/dist/loaders/src-index.d.ts.map +1 -1
  252. package/dist/loaders/src-index.js +35 -27
  253. package/dist/loaders/src-index.js.map +1 -1
  254. package/dist/loaders/src-index.mjs +34 -29
  255. package/dist/loaders/src-index.mjs.map +1 -1
  256. package/dist/loaders/validators.d.ts +2 -2
  257. package/dist/loaders/validators.d.ts.map +1 -1
  258. package/dist/loaders/validators.js +9 -4
  259. package/dist/loaders/validators.js.map +1 -1
  260. package/dist/loaders/validators.mjs +8 -6
  261. package/dist/loaders/validators.mjs.map +1 -1
  262. package/dist/middlewares/body.d.ts +4 -4
  263. package/dist/middlewares/body.d.ts.map +1 -1
  264. package/dist/middlewares/body.js +58 -54
  265. package/dist/middlewares/body.js.map +1 -1
  266. package/dist/middlewares/body.mjs +57 -51
  267. package/dist/middlewares/body.mjs.map +1 -1
  268. package/dist/middlewares/compression.d.ts +2 -2
  269. package/dist/middlewares/compression.d.ts.map +1 -1
  270. package/dist/middlewares/compression.js +6 -6
  271. package/dist/middlewares/compression.js.map +1 -1
  272. package/dist/middlewares/compression.mjs +5 -5
  273. package/dist/middlewares/compression.mjs.map +1 -1
  274. package/dist/middlewares/cors.d.ts +11 -3
  275. package/dist/middlewares/cors.d.ts.map +1 -1
  276. package/dist/middlewares/cors.js +81 -46
  277. package/dist/middlewares/cors.js.map +1 -1
  278. package/dist/middlewares/cors.mjs +78 -44
  279. package/dist/middlewares/cors.mjs.map +1 -1
  280. package/dist/middlewares/errors.d.ts +2 -2
  281. package/dist/middlewares/errors.d.ts.map +1 -1
  282. package/dist/middlewares/errors.js +32 -30
  283. package/dist/middlewares/errors.js.map +1 -1
  284. package/dist/middlewares/errors.mjs +31 -31
  285. package/dist/middlewares/errors.mjs.map +1 -1
  286. package/dist/middlewares/favicon.d.ts +2 -2
  287. package/dist/middlewares/favicon.d.ts.map +1 -1
  288. package/dist/middlewares/favicon.js +27 -17
  289. package/dist/middlewares/favicon.js.map +1 -1
  290. package/dist/middlewares/favicon.mjs +26 -16
  291. package/dist/middlewares/favicon.mjs.map +1 -1
  292. package/dist/middlewares/index.d.ts +2 -2
  293. package/dist/middlewares/index.d.ts.map +1 -1
  294. package/dist/middlewares/index.js +32 -30
  295. package/dist/middlewares/index.js.map +1 -1
  296. package/dist/middlewares/index.mjs +31 -31
  297. package/dist/middlewares/index.mjs.map +1 -1
  298. package/dist/middlewares/ip.d.ts +2 -2
  299. package/dist/middlewares/ip.d.ts.map +1 -1
  300. package/dist/middlewares/ip.js +6 -6
  301. package/dist/middlewares/ip.js.map +1 -1
  302. package/dist/middlewares/ip.mjs +5 -5
  303. package/dist/middlewares/ip.mjs.map +1 -1
  304. package/dist/middlewares/logger.d.ts +2 -2
  305. package/dist/middlewares/logger.d.ts.map +1 -1
  306. package/dist/middlewares/logger.js +10 -9
  307. package/dist/middlewares/logger.js.map +1 -1
  308. package/dist/middlewares/logger.mjs +9 -10
  309. package/dist/middlewares/logger.mjs.map +1 -1
  310. package/dist/middlewares/powered-by.d.ts +2 -2
  311. package/dist/middlewares/powered-by.d.ts.map +1 -1
  312. package/dist/middlewares/powered-by.js +13 -9
  313. package/dist/middlewares/powered-by.js.map +1 -1
  314. package/dist/middlewares/powered-by.mjs +12 -10
  315. package/dist/middlewares/powered-by.mjs.map +1 -1
  316. package/dist/middlewares/public.d.ts +2 -2
  317. package/dist/middlewares/public.d.ts.map +1 -1
  318. package/dist/middlewares/public.js +33 -29
  319. package/dist/middlewares/public.js.map +1 -1
  320. package/dist/middlewares/public.mjs +32 -28
  321. package/dist/middlewares/public.mjs.map +1 -1
  322. package/dist/middlewares/query.d.ts +2 -2
  323. package/dist/middlewares/query.d.ts.map +1 -1
  324. package/dist/middlewares/query.js +35 -32
  325. package/dist/middlewares/query.js.map +1 -1
  326. package/dist/middlewares/query.mjs +34 -31
  327. package/dist/middlewares/query.mjs.map +1 -1
  328. package/dist/middlewares/response-time.d.ts +2 -2
  329. package/dist/middlewares/response-time.d.ts.map +1 -1
  330. package/dist/middlewares/response-time.js +10 -9
  331. package/dist/middlewares/response-time.js.map +1 -1
  332. package/dist/middlewares/response-time.mjs +9 -10
  333. package/dist/middlewares/response-time.mjs.map +1 -1
  334. package/dist/middlewares/responses.d.ts +3 -3
  335. package/dist/middlewares/responses.d.ts.map +1 -1
  336. package/dist/middlewares/responses.js +14 -12
  337. package/dist/middlewares/responses.js.map +1 -1
  338. package/dist/middlewares/responses.mjs +13 -13
  339. package/dist/middlewares/responses.mjs.map +1 -1
  340. package/dist/middlewares/security.d.ts +2 -2
  341. package/dist/middlewares/security.d.ts.map +1 -1
  342. package/dist/middlewares/security.js +97 -65
  343. package/dist/middlewares/security.js.map +1 -1
  344. package/dist/middlewares/security.mjs +95 -63
  345. package/dist/middlewares/security.mjs.map +1 -1
  346. package/dist/middlewares/session.d.ts +2 -2
  347. package/dist/middlewares/session.d.ts.map +1 -1
  348. package/dist/middlewares/session.js +26 -25
  349. package/dist/middlewares/session.js.map +1 -1
  350. package/dist/middlewares/session.mjs +25 -24
  351. package/dist/middlewares/session.mjs.map +1 -1
  352. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +33 -0
  353. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -0
  354. package/dist/migrations/database/5.0.0-discard-drafts.js +168 -0
  355. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -0
  356. package/dist/migrations/database/5.0.0-discard-drafts.mjs +165 -0
  357. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -0
  358. package/dist/migrations/draft-publish.d.ts +2 -2
  359. package/dist/migrations/draft-publish.d.ts.map +1 -1
  360. package/dist/migrations/draft-publish.js +59 -49
  361. package/dist/migrations/draft-publish.js.map +1 -1
  362. package/dist/migrations/draft-publish.mjs +58 -51
  363. package/dist/migrations/draft-publish.mjs.map +1 -1
  364. package/dist/migrations/first-published-at.d.ts +4 -0
  365. package/dist/migrations/first-published-at.d.ts.map +1 -0
  366. package/dist/migrations/first-published-at.js +51 -0
  367. package/dist/migrations/first-published-at.js.map +1 -0
  368. package/dist/migrations/first-published-at.mjs +49 -0
  369. package/dist/migrations/first-published-at.mjs.map +1 -0
  370. package/dist/migrations/i18n.d.ts +5 -0
  371. package/dist/migrations/i18n.d.ts.map +1 -0
  372. package/dist/migrations/i18n.js +71 -0
  373. package/dist/migrations/i18n.js.map +1 -0
  374. package/dist/migrations/i18n.mjs +68 -0
  375. package/dist/migrations/i18n.mjs.map +1 -0
  376. package/dist/migrations/index.d.ts +5 -0
  377. package/dist/migrations/index.d.ts.map +1 -0
  378. package/dist/migrations/index.js +34 -0
  379. package/dist/migrations/index.js.map +1 -0
  380. package/dist/migrations/index.mjs +31 -0
  381. package/dist/migrations/index.mjs.map +1 -0
  382. package/dist/package.json.js +187 -0
  383. package/dist/package.json.js.map +1 -0
  384. package/dist/package.json.mjs +164 -0
  385. package/dist/package.json.mjs.map +1 -0
  386. package/dist/providers/admin.d.ts +3 -0
  387. package/dist/providers/admin.d.ts.map +1 -0
  388. package/dist/providers/admin.js +30 -0
  389. package/dist/providers/admin.js.map +1 -0
  390. package/dist/providers/admin.mjs +28 -0
  391. package/dist/providers/admin.mjs.map +1 -0
  392. package/dist/providers/coreStore.d.ts +3 -0
  393. package/dist/providers/coreStore.d.ts.map +1 -0
  394. package/dist/providers/coreStore.js +16 -0
  395. package/dist/providers/coreStore.js.map +1 -0
  396. package/dist/providers/coreStore.mjs +14 -0
  397. package/dist/providers/coreStore.mjs.map +1 -0
  398. package/dist/providers/cron.d.ts +3 -0
  399. package/dist/providers/cron.d.ts.map +1 -0
  400. package/dist/providers/cron.js +23 -0
  401. package/dist/providers/cron.js.map +1 -0
  402. package/dist/providers/cron.mjs +21 -0
  403. package/dist/providers/cron.mjs.map +1 -0
  404. package/dist/providers/index.d.ts +3 -0
  405. package/dist/providers/index.d.ts.map +1 -0
  406. package/dist/providers/index.js +22 -0
  407. package/dist/providers/index.js.map +1 -0
  408. package/dist/providers/index.mjs +20 -0
  409. package/dist/providers/index.mjs.map +1 -0
  410. package/dist/providers/provider.d.ts +9 -0
  411. package/dist/providers/provider.d.ts.map +1 -0
  412. package/dist/providers/provider.js +6 -0
  413. package/dist/providers/provider.js.map +1 -0
  414. package/dist/providers/provider.mjs +4 -0
  415. package/dist/providers/provider.mjs.map +1 -0
  416. package/dist/providers/registries.d.ts +3 -0
  417. package/dist/providers/registries.d.ts.map +1 -0
  418. package/dist/providers/registries.js +40 -0
  419. package/dist/providers/registries.js.map +1 -0
  420. package/dist/providers/registries.mjs +38 -0
  421. package/dist/providers/registries.mjs.map +1 -0
  422. package/dist/providers/session-manager.d.ts +3 -0
  423. package/dist/providers/session-manager.d.ts.map +1 -0
  424. package/dist/providers/session-manager.js +23 -0
  425. package/dist/providers/session-manager.js.map +1 -0
  426. package/dist/providers/session-manager.mjs +21 -0
  427. package/dist/providers/session-manager.mjs.map +1 -0
  428. package/dist/providers/telemetry.d.ts +3 -0
  429. package/dist/providers/telemetry.d.ts.map +1 -0
  430. package/dist/providers/telemetry.js +22 -0
  431. package/dist/providers/telemetry.js.map +1 -0
  432. package/dist/providers/telemetry.mjs +20 -0
  433. package/dist/providers/telemetry.mjs.map +1 -0
  434. package/dist/providers/webhooks.d.ts +3 -0
  435. package/dist/providers/webhooks.d.ts.map +1 -0
  436. package/dist/providers/webhooks.js +32 -0
  437. package/dist/providers/webhooks.js.map +1 -0
  438. package/dist/providers/webhooks.mjs +30 -0
  439. package/dist/providers/webhooks.mjs.map +1 -0
  440. package/dist/registries/apis.d.ts +2 -2
  441. package/dist/registries/apis.d.ts.map +1 -1
  442. package/dist/registries/apis.js +23 -20
  443. package/dist/registries/apis.js.map +1 -1
  444. package/dist/registries/apis.mjs +22 -22
  445. package/dist/registries/apis.mjs.map +1 -1
  446. package/dist/registries/components.d.ts +6 -6
  447. package/dist/registries/components.d.ts.map +1 -1
  448. package/dist/registries/components.js +35 -37
  449. package/dist/registries/components.js.map +1 -1
  450. package/dist/registries/components.mjs +34 -39
  451. package/dist/registries/components.mjs.map +1 -1
  452. package/dist/registries/content-types.d.ts +5 -5
  453. package/dist/registries/content-types.d.ts.map +1 -1
  454. package/dist/registries/content-types.js +54 -59
  455. package/dist/registries/content-types.js.map +1 -1
  456. package/dist/registries/content-types.mjs +53 -61
  457. package/dist/registries/content-types.mjs.map +1 -1
  458. package/dist/registries/controllers.d.ts +10 -10
  459. package/dist/registries/controllers.d.ts.map +1 -1
  460. package/dist/registries/controllers.js +70 -71
  461. package/dist/registries/controllers.js.map +1 -1
  462. package/dist/registries/controllers.mjs +69 -73
  463. package/dist/registries/controllers.mjs.map +1 -1
  464. package/dist/registries/custom-fields.d.ts +3 -3
  465. package/dist/registries/custom-fields.d.ts.map +1 -1
  466. package/dist/registries/custom-fields.js +75 -65
  467. package/dist/registries/custom-fields.js.map +1 -1
  468. package/dist/registries/custom-fields.mjs +74 -67
  469. package/dist/registries/custom-fields.mjs.map +1 -1
  470. package/dist/registries/hooks.js +46 -49
  471. package/dist/registries/hooks.js.map +1 -1
  472. package/dist/registries/hooks.mjs +45 -51
  473. package/dist/registries/hooks.mjs.map +1 -1
  474. package/dist/registries/index.d.ts +0 -1
  475. package/dist/registries/index.d.ts.map +1 -1
  476. package/dist/registries/middlewares.d.ts +6 -6
  477. package/dist/registries/middlewares.d.ts.map +1 -1
  478. package/dist/registries/middlewares.js +49 -51
  479. package/dist/registries/middlewares.js.map +1 -1
  480. package/dist/registries/middlewares.mjs +48 -53
  481. package/dist/registries/middlewares.mjs.map +1 -1
  482. package/dist/registries/models.js +14 -13
  483. package/dist/registries/models.js.map +1 -1
  484. package/dist/registries/models.mjs +13 -14
  485. package/dist/registries/models.mjs.map +1 -1
  486. package/dist/registries/modules.d.ts +2 -2
  487. package/dist/registries/modules.d.ts.map +1 -1
  488. package/dist/registries/modules.js +39 -36
  489. package/dist/registries/modules.js.map +1 -1
  490. package/dist/registries/modules.mjs +38 -38
  491. package/dist/registries/modules.mjs.map +1 -1
  492. package/dist/registries/namespace.js +21 -20
  493. package/dist/registries/namespace.js.map +1 -1
  494. package/dist/registries/namespace.mjs +20 -23
  495. package/dist/registries/namespace.mjs.map +1 -1
  496. package/dist/registries/plugins.d.ts +5 -5
  497. package/dist/registries/plugins.d.ts.map +1 -1
  498. package/dist/registries/plugins.js +23 -20
  499. package/dist/registries/plugins.js.map +1 -1
  500. package/dist/registries/plugins.mjs +22 -22
  501. package/dist/registries/plugins.mjs.map +1 -1
  502. package/dist/registries/policies.d.ts +22 -10
  503. package/dist/registries/policies.d.ts.map +1 -1
  504. package/dist/registries/policies.js +107 -54
  505. package/dist/registries/policies.js.map +1 -1
  506. package/dist/registries/policies.mjs +106 -56
  507. package/dist/registries/policies.mjs.map +1 -1
  508. package/dist/registries/sanitizers.js +23 -22
  509. package/dist/registries/sanitizers.js.map +1 -1
  510. package/dist/registries/sanitizers.mjs +22 -22
  511. package/dist/registries/sanitizers.mjs.map +1 -1
  512. package/dist/registries/services.d.ts +8 -8
  513. package/dist/registries/services.d.ts.map +1 -1
  514. package/dist/registries/services.js +71 -71
  515. package/dist/registries/services.js.map +1 -1
  516. package/dist/registries/services.mjs +70 -73
  517. package/dist/registries/services.mjs.map +1 -1
  518. package/dist/registries/validators.js +23 -22
  519. package/dist/registries/validators.js.map +1 -1
  520. package/dist/registries/validators.mjs +22 -22
  521. package/dist/registries/validators.mjs.map +1 -1
  522. package/dist/services/auth/index.d.ts +4 -4
  523. package/dist/services/auth/index.d.ts.map +1 -1
  524. package/dist/services/auth/index.js +74 -74
  525. package/dist/services/auth/index.js.map +1 -1
  526. package/dist/services/auth/index.mjs +73 -74
  527. package/dist/services/auth/index.mjs.map +1 -1
  528. package/dist/services/config.d.ts +3 -0
  529. package/dist/services/config.d.ts.map +1 -0
  530. package/dist/services/config.js +51 -0
  531. package/dist/services/config.js.map +1 -0
  532. package/dist/services/config.mjs +49 -0
  533. package/dist/services/config.mjs.map +1 -0
  534. package/dist/services/content-api/index.d.ts +31 -15
  535. package/dist/services/content-api/index.d.ts.map +1 -1
  536. package/dist/services/content-api/index.js +80 -53
  537. package/dist/services/content-api/index.js.map +1 -1
  538. package/dist/services/content-api/index.mjs +79 -53
  539. package/dist/services/content-api/index.mjs.map +1 -1
  540. package/dist/services/content-api/permissions/engine.js +8 -5
  541. package/dist/services/content-api/permissions/engine.js.map +1 -1
  542. package/dist/services/content-api/permissions/engine.mjs +7 -5
  543. package/dist/services/content-api/permissions/engine.mjs.map +1 -1
  544. package/dist/services/content-api/permissions/index.d.ts +13 -15
  545. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  546. package/dist/services/content-api/permissions/index.js +101 -81
  547. package/dist/services/content-api/permissions/index.js.map +1 -1
  548. package/dist/services/content-api/permissions/index.mjs +100 -81
  549. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  550. package/dist/services/content-api/permissions/providers/action.d.ts +5 -6
  551. package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -1
  552. package/dist/services/content-api/permissions/providers/action.js +17 -14
  553. package/dist/services/content-api/permissions/providers/action.js.map +1 -1
  554. package/dist/services/content-api/permissions/providers/action.mjs +16 -16
  555. package/dist/services/content-api/permissions/providers/action.mjs.map +1 -1
  556. package/dist/services/content-api/permissions/providers/condition.d.ts +5 -6
  557. package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -1
  558. package/dist/services/content-api/permissions/providers/condition.js +17 -14
  559. package/dist/services/content-api/permissions/providers/condition.js.map +1 -1
  560. package/dist/services/content-api/permissions/providers/condition.mjs +16 -16
  561. package/dist/services/content-api/permissions/providers/condition.mjs.map +1 -1
  562. package/dist/services/content-source-maps.d.ts +13 -0
  563. package/dist/services/content-source-maps.d.ts.map +1 -0
  564. package/dist/services/content-source-maps.js +108 -0
  565. package/dist/services/content-source-maps.js.map +1 -0
  566. package/dist/services/content-source-maps.mjs +106 -0
  567. package/dist/services/content-source-maps.mjs.map +1 -0
  568. package/dist/services/core-store.d.ts +2 -2
  569. package/dist/services/core-store.d.ts.map +1 -1
  570. package/dist/services/core-store.js +115 -95
  571. package/dist/services/core-store.js.map +1 -1
  572. package/dist/services/core-store.mjs +114 -97
  573. package/dist/services/core-store.mjs.map +1 -1
  574. package/dist/services/cron.d.ts +5 -5
  575. package/dist/services/cron.d.ts.map +1 -1
  576. package/dist/services/cron.js +74 -60
  577. package/dist/services/cron.js.map +1 -1
  578. package/dist/services/cron.mjs +73 -62
  579. package/dist/services/cron.mjs.map +1 -1
  580. package/dist/services/custom-fields.d.ts +2 -2
  581. package/dist/services/custom-fields.d.ts.map +1 -1
  582. package/dist/services/custom-fields.js +9 -7
  583. package/dist/services/custom-fields.js.map +1 -1
  584. package/dist/services/custom-fields.mjs +8 -9
  585. package/dist/services/custom-fields.mjs.map +1 -1
  586. package/dist/services/document-service/attributes/index.d.ts +6 -0
  587. package/dist/services/document-service/attributes/index.d.ts.map +1 -0
  588. package/dist/services/document-service/attributes/index.js +27 -0
  589. package/dist/services/document-service/attributes/index.js.map +1 -0
  590. package/dist/services/document-service/attributes/index.mjs +25 -0
  591. package/dist/services/document-service/attributes/index.mjs.map +1 -0
  592. package/dist/services/document-service/attributes/transforms.d.ts +10 -0
  593. package/dist/services/document-service/attributes/transforms.d.ts.map +1 -0
  594. package/dist/services/document-service/attributes/transforms.js +21 -0
  595. package/dist/services/document-service/attributes/transforms.js.map +1 -0
  596. package/dist/services/document-service/attributes/transforms.mjs +19 -0
  597. package/dist/services/document-service/attributes/transforms.mjs.map +1 -0
  598. package/dist/services/document-service/common.d.ts +2 -2
  599. package/dist/services/document-service/common.d.ts.map +1 -1
  600. package/dist/services/document-service/common.js +5 -4
  601. package/dist/services/document-service/common.js.map +1 -1
  602. package/dist/services/document-service/common.mjs +4 -5
  603. package/dist/services/document-service/common.mjs.map +1 -1
  604. package/dist/services/document-service/components.d.ts +55 -1
  605. package/dist/services/document-service/components.d.ts.map +1 -1
  606. package/dist/services/document-service/components.js +395 -0
  607. package/dist/services/document-service/components.js.map +1 -0
  608. package/dist/services/document-service/components.mjs +384 -0
  609. package/dist/services/document-service/components.mjs.map +1 -0
  610. package/dist/services/document-service/draft-and-publish.d.ts +7 -7
  611. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  612. package/dist/services/document-service/draft-and-publish.js +94 -54
  613. package/dist/services/document-service/draft-and-publish.js.map +1 -1
  614. package/dist/services/document-service/draft-and-publish.mjs +87 -54
  615. package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
  616. package/dist/services/document-service/entries.d.ts +10 -0
  617. package/dist/services/document-service/entries.d.ts.map +1 -0
  618. package/dist/services/document-service/entries.js +155 -0
  619. package/dist/services/document-service/entries.js.map +1 -0
  620. package/dist/services/document-service/entries.mjs +153 -0
  621. package/dist/services/document-service/entries.mjs.map +1 -0
  622. package/dist/services/document-service/events.d.ts +25 -0
  623. package/dist/services/document-service/events.d.ts.map +1 -0
  624. package/dist/services/document-service/events.js +59 -0
  625. package/dist/services/document-service/events.js.map +1 -0
  626. package/dist/services/document-service/events.mjs +57 -0
  627. package/dist/services/document-service/events.mjs.map +1 -0
  628. package/dist/services/document-service/first-published-at.d.ts +7 -0
  629. package/dist/services/document-service/first-published-at.d.ts.map +1 -0
  630. package/dist/services/document-service/first-published-at.js +31 -0
  631. package/dist/services/document-service/first-published-at.js.map +1 -0
  632. package/dist/services/document-service/first-published-at.mjs +28 -0
  633. package/dist/services/document-service/first-published-at.mjs.map +1 -0
  634. package/dist/services/document-service/index.d.ts +3 -4
  635. package/dist/services/document-service/index.d.ts.map +1 -1
  636. package/dist/services/document-service/index.js +53 -19
  637. package/dist/services/document-service/index.js.map +1 -1
  638. package/dist/services/document-service/index.mjs +52 -20
  639. package/dist/services/document-service/index.mjs.map +1 -1
  640. package/dist/services/document-service/internationalization.d.ts +11 -6
  641. package/dist/services/document-service/internationalization.d.ts.map +1 -1
  642. package/dist/services/document-service/internationalization.js +98 -41
  643. package/dist/services/document-service/internationalization.js.map +1 -1
  644. package/dist/services/document-service/internationalization.mjs +92 -41
  645. package/dist/services/document-service/internationalization.mjs.map +1 -1
  646. package/dist/services/document-service/middlewares/errors.d.ts +6 -0
  647. package/dist/services/document-service/middlewares/errors.d.ts.map +1 -0
  648. package/dist/services/document-service/middlewares/errors.js +29 -0
  649. package/dist/services/document-service/middlewares/errors.js.map +1 -0
  650. package/dist/services/document-service/middlewares/errors.mjs +27 -0
  651. package/dist/services/document-service/middlewares/errors.mjs.map +1 -0
  652. package/dist/services/document-service/middlewares/index.d.ts +3 -0
  653. package/dist/services/document-service/middlewares/index.d.ts.map +1 -0
  654. package/dist/services/document-service/middlewares/middleware-manager.d.ts +10 -0
  655. package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -0
  656. package/dist/services/document-service/middlewares/middleware-manager.js +51 -0
  657. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -0
  658. package/dist/services/document-service/middlewares/middleware-manager.mjs +49 -0
  659. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -0
  660. package/dist/services/document-service/params.d.ts +3 -1
  661. package/dist/services/document-service/params.d.ts.map +1 -1
  662. package/dist/services/document-service/params.js +14 -0
  663. package/dist/services/document-service/params.js.map +1 -0
  664. package/dist/services/document-service/params.mjs +12 -0
  665. package/dist/services/document-service/params.mjs.map +1 -0
  666. package/dist/services/document-service/repository.d.ts.map +1 -1
  667. package/dist/services/document-service/repository.js +362 -285
  668. package/dist/services/document-service/repository.js.map +1 -1
  669. package/dist/services/document-service/repository.mjs +361 -286
  670. package/dist/services/document-service/repository.mjs.map +1 -1
  671. package/dist/services/document-service/transform/data.d.ts.map +1 -1
  672. package/dist/services/document-service/transform/data.js +22 -10
  673. package/dist/services/document-service/transform/data.js.map +1 -1
  674. package/dist/services/document-service/transform/data.mjs +21 -11
  675. package/dist/services/document-service/transform/data.mjs.map +1 -1
  676. package/dist/services/document-service/transform/fields.d.ts +2 -2
  677. package/dist/services/document-service/transform/fields.d.ts.map +1 -1
  678. package/dist/services/document-service/transform/fields.js +26 -17
  679. package/dist/services/document-service/transform/fields.js.map +1 -1
  680. package/dist/services/document-service/transform/fields.mjs +25 -18
  681. package/dist/services/document-service/transform/fields.mjs.map +1 -1
  682. package/dist/services/document-service/transform/id-map.d.ts +3 -3
  683. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  684. package/dist/services/document-service/transform/id-map.js +116 -69
  685. package/dist/services/document-service/transform/id-map.js.map +1 -1
  686. package/dist/services/document-service/transform/id-map.mjs +115 -70
  687. package/dist/services/document-service/transform/id-map.mjs.map +1 -1
  688. package/dist/services/document-service/transform/id-transform.d.ts +2 -2
  689. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  690. package/dist/services/document-service/transform/id-transform.js +38 -30
  691. package/dist/services/document-service/transform/id-transform.js.map +1 -1
  692. package/dist/services/document-service/transform/id-transform.mjs +36 -30
  693. package/dist/services/document-service/transform/id-transform.mjs.map +1 -1
  694. package/dist/services/document-service/transform/populate.d.ts +2 -2
  695. package/dist/services/document-service/transform/populate.d.ts.map +1 -1
  696. package/dist/services/document-service/transform/populate.js +23 -18
  697. package/dist/services/document-service/transform/populate.js.map +1 -1
  698. package/dist/services/document-service/transform/populate.mjs +22 -19
  699. package/dist/services/document-service/transform/populate.mjs.map +1 -1
  700. package/dist/services/document-service/transform/query.d.ts +5 -0
  701. package/dist/services/document-service/transform/query.d.ts.map +1 -0
  702. package/dist/services/document-service/transform/query.js +14 -0
  703. package/dist/services/document-service/transform/query.js.map +1 -0
  704. package/dist/services/document-service/transform/query.mjs +12 -0
  705. package/dist/services/document-service/transform/query.mjs.map +1 -0
  706. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +8 -7
  707. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  708. package/dist/services/document-service/transform/relations/extract/data-ids.js +75 -85
  709. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
  710. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +74 -86
  711. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
  712. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +8 -4
  713. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  714. package/dist/services/document-service/transform/relations/transform/data-ids.js +103 -134
  715. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
  716. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +102 -135
  717. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
  718. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts +9 -0
  719. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts.map +1 -0
  720. package/dist/services/document-service/transform/relations/transform/default-locale.js +50 -0
  721. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -0
  722. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +48 -0
  723. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -0
  724. package/dist/services/document-service/transform/relations/utils/dp.d.ts +3 -3
  725. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  726. package/dist/services/document-service/transform/relations/utils/dp.js +53 -22
  727. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -1
  728. package/dist/services/document-service/transform/relations/utils/dp.mjs +52 -23
  729. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -1
  730. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +6 -6
  731. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  732. package/dist/services/document-service/transform/relations/utils/i18n.js +19 -23
  733. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
  734. package/dist/services/document-service/transform/relations/utils/i18n.mjs +18 -26
  735. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
  736. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts +6 -0
  737. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -0
  738. package/dist/services/document-service/transform/relations/utils/map-relation.js +130 -0
  739. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -0
  740. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +127 -0
  741. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -0
  742. package/dist/services/document-service/transform/relations/utils/types.d.ts +6 -0
  743. package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -1
  744. package/dist/services/document-service/transform/types.d.ts +3 -3
  745. package/dist/services/document-service/transform/types.d.ts.map +1 -1
  746. package/dist/services/document-service/utils/bidirectional-relations.d.ts +95 -0
  747. package/dist/services/document-service/utils/bidirectional-relations.d.ts.map +1 -0
  748. package/dist/services/document-service/utils/bidirectional-relations.js +148 -0
  749. package/dist/services/document-service/utils/bidirectional-relations.js.map +1 -0
  750. package/dist/services/document-service/utils/bidirectional-relations.mjs +145 -0
  751. package/dist/services/document-service/utils/bidirectional-relations.mjs.map +1 -0
  752. package/dist/services/document-service/utils/clean-component-join-table.d.ts +7 -0
  753. package/dist/services/document-service/utils/clean-component-join-table.d.ts.map +1 -0
  754. package/dist/services/document-service/utils/populate.d.ts +2 -2
  755. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  756. package/dist/services/document-service/utils/populate.js +67 -37
  757. package/dist/services/document-service/utils/populate.js.map +1 -1
  758. package/dist/services/document-service/utils/populate.mjs +66 -38
  759. package/dist/services/document-service/utils/populate.mjs.map +1 -1
  760. package/dist/services/document-service/utils/unidirectional-relations.d.ts +53 -0
  761. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -0
  762. package/dist/services/document-service/utils/unidirectional-relations.js +131 -0
  763. package/dist/services/document-service/utils/unidirectional-relations.js.map +1 -0
  764. package/dist/services/document-service/utils/unidirectional-relations.mjs +128 -0
  765. package/dist/services/document-service/utils/unidirectional-relations.mjs.map +1 -0
  766. package/dist/services/entity-service/index.d.ts +4 -4
  767. package/dist/services/entity-service/index.d.ts.map +1 -1
  768. package/dist/services/entity-service/index.js +230 -155
  769. package/dist/services/entity-service/index.js.map +1 -1
  770. package/dist/services/entity-service/index.mjs +229 -154
  771. package/dist/services/entity-service/index.mjs.map +1 -1
  772. package/dist/services/entity-validator/blocks-validator.d.ts +1 -2
  773. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
  774. package/dist/services/entity-validator/blocks-validator.js +137 -104
  775. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  776. package/dist/services/entity-validator/blocks-validator.mjs +135 -105
  777. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  778. package/dist/services/entity-validator/index.d.ts +16 -2
  779. package/dist/services/entity-validator/index.d.ts.map +1 -1
  780. package/dist/services/entity-validator/index.js +371 -300
  781. package/dist/services/entity-validator/index.js.map +1 -1
  782. package/dist/services/entity-validator/index.mjs +367 -297
  783. package/dist/services/entity-validator/index.mjs.map +1 -1
  784. package/dist/services/entity-validator/validators.d.ts +37 -25
  785. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  786. package/dist/services/entity-validator/validators.js +286 -105
  787. package/dist/services/entity-validator/validators.js.map +1 -1
  788. package/dist/services/entity-validator/validators.mjs +277 -103
  789. package/dist/services/entity-validator/validators.mjs.map +1 -1
  790. package/dist/services/errors.js +65 -65
  791. package/dist/services/errors.js.map +1 -1
  792. package/dist/services/errors.mjs +64 -66
  793. package/dist/services/errors.mjs.map +1 -1
  794. package/dist/services/event-hub.d.ts +1 -0
  795. package/dist/services/event-hub.d.ts.map +1 -1
  796. package/dist/services/event-hub.js +82 -64
  797. package/dist/services/event-hub.js.map +1 -1
  798. package/dist/services/event-hub.mjs +81 -66
  799. package/dist/services/event-hub.mjs.map +1 -1
  800. package/dist/services/features.d.ts +3 -3
  801. package/dist/services/features.d.ts.map +1 -1
  802. package/dist/services/features.js +19 -14
  803. package/dist/services/features.js.map +1 -1
  804. package/dist/services/features.mjs +18 -15
  805. package/dist/services/features.mjs.map +1 -1
  806. package/dist/services/fs.d.ts +2 -2
  807. package/dist/services/fs.d.ts.map +1 -1
  808. package/dist/services/fs.js +41 -40
  809. package/dist/services/fs.js.map +1 -1
  810. package/dist/services/fs.mjs +40 -39
  811. package/dist/services/fs.mjs.map +1 -1
  812. package/dist/services/metrics/admin-user-hash.d.ts +2 -2
  813. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  814. package/dist/services/metrics/admin-user-hash.js +13 -11
  815. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  816. package/dist/services/metrics/admin-user-hash.mjs +12 -10
  817. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  818. package/dist/services/metrics/index.d.ts +3 -3
  819. package/dist/services/metrics/index.d.ts.map +1 -1
  820. package/dist/services/metrics/index.js +48 -40
  821. package/dist/services/metrics/index.js.map +1 -1
  822. package/dist/services/metrics/index.mjs +47 -42
  823. package/dist/services/metrics/index.mjs.map +1 -1
  824. package/dist/services/metrics/is-truthy.js +13 -6
  825. package/dist/services/metrics/is-truthy.js.map +1 -1
  826. package/dist/services/metrics/is-truthy.mjs +12 -6
  827. package/dist/services/metrics/is-truthy.mjs.map +1 -1
  828. package/dist/services/metrics/middleware.d.ts +4 -3
  829. package/dist/services/metrics/middleware.d.ts.map +1 -1
  830. package/dist/services/metrics/middleware.js +37 -22
  831. package/dist/services/metrics/middleware.js.map +1 -1
  832. package/dist/services/metrics/middleware.mjs +36 -24
  833. package/dist/services/metrics/middleware.mjs.map +1 -1
  834. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  835. package/dist/services/metrics/rate-limiter.js +24 -19
  836. package/dist/services/metrics/rate-limiter.js.map +1 -1
  837. package/dist/services/metrics/rate-limiter.mjs +23 -21
  838. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  839. package/dist/services/metrics/sender.d.ts +3 -3
  840. package/dist/services/metrics/sender.d.ts.map +1 -1
  841. package/dist/services/metrics/sender.js +79 -69
  842. package/dist/services/metrics/sender.js.map +1 -1
  843. package/dist/services/metrics/sender.mjs +78 -64
  844. package/dist/services/metrics/sender.mjs.map +1 -1
  845. package/dist/services/query-params.d.ts +7 -0
  846. package/dist/services/query-params.d.ts.map +1 -0
  847. package/dist/services/query-params.js +15 -0
  848. package/dist/services/query-params.js.map +1 -0
  849. package/dist/services/query-params.mjs +13 -0
  850. package/dist/services/query-params.mjs.map +1 -0
  851. package/dist/services/reloader.d.ts +7 -0
  852. package/dist/services/reloader.d.ts.map +1 -0
  853. package/dist/services/reloader.js +39 -0
  854. package/dist/services/reloader.js.map +1 -0
  855. package/dist/services/reloader.mjs +37 -0
  856. package/dist/services/reloader.mjs.map +1 -0
  857. package/dist/services/request-context.js +11 -8
  858. package/dist/services/request-context.js.map +1 -1
  859. package/dist/services/request-context.mjs +10 -10
  860. package/dist/services/request-context.mjs.map +1 -1
  861. package/dist/services/server/admin-api.d.ts +3 -3
  862. package/dist/services/server/admin-api.d.ts.map +1 -1
  863. package/dist/services/server/admin-api.js +11 -10
  864. package/dist/services/server/admin-api.js.map +1 -1
  865. package/dist/services/server/admin-api.mjs +10 -11
  866. package/dist/services/server/admin-api.mjs.map +1 -1
  867. package/dist/services/server/api.d.ts +3 -3
  868. package/dist/services/server/api.d.ts.map +1 -1
  869. package/dist/services/server/api.js +33 -27
  870. package/dist/services/server/api.js.map +1 -1
  871. package/dist/services/server/api.mjs +32 -26
  872. package/dist/services/server/api.mjs.map +1 -1
  873. package/dist/services/server/compose-endpoint.d.ts +2 -2
  874. package/dist/services/server/compose-endpoint.d.ts.map +1 -1
  875. package/dist/services/server/compose-endpoint.js +116 -106
  876. package/dist/services/server/compose-endpoint.js.map +1 -1
  877. package/dist/services/server/compose-endpoint.mjs +115 -106
  878. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  879. package/dist/services/server/content-api.d.ts +3 -3
  880. package/dist/services/server/content-api.d.ts.map +1 -1
  881. package/dist/services/server/content-api.js +11 -9
  882. package/dist/services/server/content-api.js.map +1 -1
  883. package/dist/services/server/content-api.mjs +10 -10
  884. package/dist/services/server/content-api.mjs.map +1 -1
  885. package/dist/services/server/http-server.d.ts +2 -2
  886. package/dist/services/server/http-server.d.ts.map +1 -1
  887. package/dist/services/server/http-server.js +48 -44
  888. package/dist/services/server/http-server.js.map +1 -1
  889. package/dist/services/server/http-server.mjs +47 -43
  890. package/dist/services/server/http-server.mjs.map +1 -1
  891. package/dist/services/server/index.d.ts +2 -2
  892. package/dist/services/server/index.d.ts.map +1 -1
  893. package/dist/services/server/index.js +85 -83
  894. package/dist/services/server/index.js.map +1 -1
  895. package/dist/services/server/index.mjs +84 -82
  896. package/dist/services/server/index.mjs.map +1 -1
  897. package/dist/services/server/koa.d.ts.map +1 -1
  898. package/dist/services/server/koa.js +49 -47
  899. package/dist/services/server/koa.js.map +1 -1
  900. package/dist/services/server/koa.mjs +48 -44
  901. package/dist/services/server/koa.mjs.map +1 -1
  902. package/dist/services/server/middleware.d.ts +4 -4
  903. package/dist/services/server/middleware.d.ts.map +1 -1
  904. package/dist/services/server/middleware.js +86 -82
  905. package/dist/services/server/middleware.js.map +1 -1
  906. package/dist/services/server/middleware.mjs +85 -82
  907. package/dist/services/server/middleware.mjs.map +1 -1
  908. package/dist/services/server/policy.d.ts +3 -3
  909. package/dist/services/server/policy.d.ts.map +1 -1
  910. package/dist/services/server/policy.js +25 -18
  911. package/dist/services/server/policy.js.map +1 -1
  912. package/dist/services/server/policy.mjs +23 -18
  913. package/dist/services/server/policy.mjs.map +1 -1
  914. package/dist/services/server/register-middlewares.d.ts +2 -2
  915. package/dist/services/server/register-middlewares.d.ts.map +1 -1
  916. package/dist/services/server/register-middlewares.js +68 -61
  917. package/dist/services/server/register-middlewares.js.map +1 -1
  918. package/dist/services/server/register-middlewares.mjs +67 -63
  919. package/dist/services/server/register-middlewares.mjs.map +1 -1
  920. package/dist/services/server/register-routes.d.ts +2 -2
  921. package/dist/services/server/register-routes.d.ts.map +1 -1
  922. package/dist/services/server/register-routes.js +109 -66
  923. package/dist/services/server/register-routes.js.map +1 -1
  924. package/dist/services/server/register-routes.mjs +108 -66
  925. package/dist/services/server/register-routes.mjs.map +1 -1
  926. package/dist/services/server/routing.d.ts +15 -5
  927. package/dist/services/server/routing.d.ts.map +1 -1
  928. package/dist/services/server/routing.js +100 -81
  929. package/dist/services/server/routing.js.map +1 -1
  930. package/dist/services/server/routing.mjs +99 -81
  931. package/dist/services/server/routing.mjs.map +1 -1
  932. package/dist/services/session-manager.d.ts +167 -0
  933. package/dist/services/session-manager.d.ts.map +1 -0
  934. package/dist/services/session-manager.js +529 -0
  935. package/dist/services/session-manager.js.map +1 -0
  936. package/dist/services/session-manager.mjs +526 -0
  937. package/dist/services/session-manager.mjs.map +1 -0
  938. package/dist/services/utils/conditional-fields.d.ts +3 -0
  939. package/dist/services/utils/conditional-fields.d.ts.map +1 -0
  940. package/dist/services/utils/conditional-fields.js +22 -0
  941. package/dist/services/utils/conditional-fields.js.map +1 -0
  942. package/dist/services/utils/conditional-fields.mjs +20 -0
  943. package/dist/services/utils/conditional-fields.mjs.map +1 -0
  944. package/dist/services/utils/dynamic-zones.d.ts.map +1 -1
  945. package/dist/services/utils/dynamic-zones.js +13 -13
  946. package/dist/services/utils/dynamic-zones.js.map +1 -1
  947. package/dist/services/utils/dynamic-zones.mjs +12 -15
  948. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  949. package/dist/services/webhook-runner.d.ts +2 -1
  950. package/dist/services/webhook-runner.d.ts.map +1 -1
  951. package/dist/services/webhook-runner.js +124 -122
  952. package/dist/services/webhook-runner.js.map +1 -1
  953. package/dist/services/webhook-runner.mjs +123 -121
  954. package/dist/services/webhook-runner.mjs.map +1 -1
  955. package/dist/services/webhook-store.d.ts +2 -8
  956. package/dist/services/webhook-store.d.ts.map +1 -1
  957. package/dist/services/webhook-store.js +132 -93
  958. package/dist/services/webhook-store.js.map +1 -1
  959. package/dist/services/webhook-store.mjs +131 -95
  960. package/dist/services/webhook-store.mjs.map +1 -1
  961. package/dist/services/worker-queue.js +44 -49
  962. package/dist/services/worker-queue.js.map +1 -1
  963. package/dist/services/worker-queue.mjs +43 -49
  964. package/dist/services/worker-queue.mjs.map +1 -1
  965. package/dist/utils/convert-custom-field-type.d.ts +2 -2
  966. package/dist/utils/convert-custom-field-type.d.ts.map +1 -1
  967. package/dist/utils/convert-custom-field-type.js +17 -20
  968. package/dist/utils/convert-custom-field-type.js.map +1 -1
  969. package/dist/utils/convert-custom-field-type.mjs +16 -21
  970. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  971. package/dist/utils/cron.js +64 -30
  972. package/dist/utils/cron.js.map +1 -1
  973. package/dist/utils/cron.mjs +63 -31
  974. package/dist/utils/cron.mjs.map +1 -1
  975. package/dist/utils/fetch.d.ts +7 -3
  976. package/dist/utils/fetch.d.ts.map +1 -1
  977. package/dist/utils/fetch.js +28 -17
  978. package/dist/utils/fetch.js.map +1 -1
  979. package/dist/utils/fetch.mjs +27 -18
  980. package/dist/utils/fetch.mjs.map +1 -1
  981. package/dist/utils/filepath-to-prop-path.d.ts +1 -1
  982. package/dist/utils/filepath-to-prop-path.d.ts.map +1 -1
  983. package/dist/utils/filepath-to-prop-path.js +22 -9
  984. package/dist/utils/filepath-to-prop-path.js.map +1 -1
  985. package/dist/utils/filepath-to-prop-path.mjs +20 -7
  986. package/dist/utils/filepath-to-prop-path.mjs.map +1 -1
  987. package/dist/utils/index.d.ts +2 -1
  988. package/dist/utils/index.d.ts.map +1 -1
  989. package/dist/utils/is-initialized.d.ts +2 -2
  990. package/dist/utils/is-initialized.d.ts.map +1 -1
  991. package/dist/utils/is-initialized.js +21 -12
  992. package/dist/utils/is-initialized.js.map +1 -1
  993. package/dist/utils/is-initialized.mjs +20 -13
  994. package/dist/utils/is-initialized.mjs.map +1 -1
  995. package/dist/utils/lifecycles.js +6 -5
  996. package/dist/utils/lifecycles.js.map +1 -1
  997. package/dist/utils/lifecycles.mjs +5 -6
  998. package/dist/utils/lifecycles.mjs.map +1 -1
  999. package/dist/utils/load-config-file.js +40 -38
  1000. package/dist/utils/load-config-file.js.map +1 -1
  1001. package/dist/utils/load-config-file.mjs +39 -36
  1002. package/dist/utils/load-config-file.mjs.map +1 -1
  1003. package/dist/utils/load-files.d.ts.map +1 -1
  1004. package/dist/utils/load-files.js +40 -35
  1005. package/dist/utils/load-files.js.map +1 -1
  1006. package/dist/utils/load-files.mjs +39 -32
  1007. package/dist/utils/load-files.mjs.map +1 -1
  1008. package/dist/utils/open-browser.d.ts +2 -2
  1009. package/dist/utils/open-browser.d.ts.map +1 -1
  1010. package/dist/utils/open-browser.js +8 -8
  1011. package/dist/utils/open-browser.js.map +1 -1
  1012. package/dist/utils/open-browser.mjs +7 -7
  1013. package/dist/utils/open-browser.mjs.map +1 -1
  1014. package/dist/utils/resolve-working-dirs.d.ts +19 -0
  1015. package/dist/utils/resolve-working-dirs.d.ts.map +1 -0
  1016. package/dist/utils/resolve-working-dirs.js +26 -0
  1017. package/dist/utils/resolve-working-dirs.js.map +1 -0
  1018. package/dist/utils/resolve-working-dirs.mjs +24 -0
  1019. package/dist/utils/resolve-working-dirs.mjs.map +1 -0
  1020. package/dist/utils/signals.d.ts +2 -2
  1021. package/dist/utils/signals.d.ts.map +1 -1
  1022. package/dist/utils/signals.js +20 -14
  1023. package/dist/utils/signals.js.map +1 -1
  1024. package/dist/utils/signals.mjs +19 -15
  1025. package/dist/utils/signals.mjs.map +1 -1
  1026. package/dist/utils/startup-logger.d.ts +2 -2
  1027. package/dist/utils/startup-logger.d.ts.map +1 -1
  1028. package/dist/utils/startup-logger.js +107 -78
  1029. package/dist/utils/startup-logger.js.map +1 -1
  1030. package/dist/utils/startup-logger.mjs +106 -75
  1031. package/dist/utils/startup-logger.mjs.map +1 -1
  1032. package/dist/utils/transform-content-types-to-models.d.ts +574 -90
  1033. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  1034. package/dist/utils/transform-content-types-to-models.js +357 -217
  1035. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  1036. package/dist/utils/transform-content-types-to-models.mjs +351 -220
  1037. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  1038. package/dist/utils/update-notifier/index.d.ts +2 -7
  1039. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  1040. package/dist/utils/update-notifier/index.js +66 -74
  1041. package/dist/utils/update-notifier/index.js.map +1 -1
  1042. package/dist/utils/update-notifier/index.mjs +65 -68
  1043. package/dist/utils/update-notifier/index.mjs.map +1 -1
  1044. package/package.json +49 -41
  1045. package/dist/registries/config.d.ts +0 -4
  1046. package/dist/registries/config.d.ts.map +0 -1
  1047. package/dist/registries/config.js +0 -31
  1048. package/dist/registries/config.js.map +0 -1
  1049. package/dist/registries/config.mjs +0 -32
  1050. package/dist/registries/config.mjs.map +0 -1
  1051. package/dist/services/document-service/middlewares.d.ts +0 -8
  1052. package/dist/services/document-service/middlewares.d.ts.map +0 -1
  1053. package/dist/services/document-service/middlewares.js +0 -46
  1054. package/dist/services/document-service/middlewares.js.map +0 -1
  1055. package/dist/services/document-service/middlewares.mjs +0 -46
  1056. package/dist/services/document-service/middlewares.mjs.map +0 -1
  1057. package/dist/services/document-service/transform/filters.d.ts +0 -3
  1058. package/dist/services/document-service/transform/filters.d.ts.map +0 -1
  1059. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts +0 -4
  1060. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts.map +0 -1
  1061. package/dist/services/document-service/transform/relations/utils/data.js +0 -12
  1062. package/dist/services/document-service/transform/relations/utils/data.js.map +0 -1
  1063. package/dist/services/document-service/transform/relations/utils/data.mjs +0 -12
  1064. package/dist/services/document-service/transform/relations/utils/data.mjs.map +0 -1
  1065. package/dist/services/document-service/transform/sort.d.ts +0 -5
  1066. package/dist/services/document-service/transform/sort.d.ts.map +0 -1
  1067. package/dist/services/document-service/transform/utils.d.ts +0 -9
  1068. package/dist/services/document-service/transform/utils.d.ts.map +0 -1
  1069. package/dist/services/entity-service/attributes/index.d.ts +0 -6
  1070. package/dist/services/entity-service/attributes/index.d.ts.map +0 -1
  1071. package/dist/services/entity-service/attributes/index.js +0 -22
  1072. package/dist/services/entity-service/attributes/index.js.map +0 -1
  1073. package/dist/services/entity-service/attributes/index.mjs +0 -22
  1074. package/dist/services/entity-service/attributes/index.mjs.map +0 -1
  1075. package/dist/services/entity-service/attributes/transforms.d.ts +0 -10
  1076. package/dist/services/entity-service/attributes/transforms.d.ts.map +0 -1
  1077. package/dist/services/entity-service/attributes/transforms.js +0 -20
  1078. package/dist/services/entity-service/attributes/transforms.js.map +0 -1
  1079. package/dist/services/entity-service/attributes/transforms.mjs +0 -19
  1080. package/dist/services/entity-service/attributes/transforms.mjs.map +0 -1
  1081. package/dist/services/entity-service/components.d.ts +0 -20
  1082. package/dist/services/entity-service/components.d.ts.map +0 -1
  1083. package/dist/services/entity-service/components.js +0 -298
  1084. package/dist/services/entity-service/components.js.map +0 -1
  1085. package/dist/services/entity-service/components.mjs +0 -296
  1086. package/dist/services/entity-service/components.mjs.map +0 -1
  1087. package/dist/services/entity-service/params.d.ts +0 -8
  1088. package/dist/services/entity-service/params.d.ts.map +0 -1
  1089. package/dist/services/entity-service/params.js +0 -8
  1090. package/dist/services/entity-service/params.js.map +0 -1
  1091. package/dist/services/entity-service/params.mjs +0 -8
  1092. package/dist/services/entity-service/params.mjs.map +0 -1
  1093. package/dist/utils/get-dirs.d.ts +0 -9
  1094. package/dist/utils/get-dirs.d.ts.map +0 -1
  1095. package/dist/utils/get-dirs.js +0 -30
  1096. package/dist/utils/get-dirs.js.map +0 -1
  1097. package/dist/utils/get-dirs.mjs +0 -30
  1098. package/dist/utils/get-dirs.mjs.map +0 -1
@@ -1,71 +1,103 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const _ = require("lodash/fp");
4
- const helmet = require("koa-helmet");
5
- const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
6
- const helmet__default = /* @__PURE__ */ _interopDefault(helmet);
1
+ 'use strict';
2
+
3
+ var fp = require('lodash/fp');
4
+ var helmet = require('koa-helmet');
5
+ var strapiUtils = require('@strapi/utils');
6
+
7
7
  const defaults = {
8
- crossOriginEmbedderPolicy: false,
9
- crossOriginOpenerPolicy: false,
10
- crossOriginResourcePolicy: false,
11
- originAgentCluster: false,
12
- contentSecurityPolicy: {
13
- useDefaults: true,
14
- directives: {
15
- "connect-src": ["'self'", "https:"],
16
- "img-src": ["'self'", "data:", "blob:", "https://market-assets.strapi.io"],
17
- "media-src": ["'self'", "data:", "blob:"],
18
- upgradeInsecureRequests: null
19
- }
20
- },
21
- xssFilter: false,
22
- hsts: {
23
- maxAge: 31536e3,
24
- includeSubDomains: true
25
- },
26
- frameguard: {
27
- action: "sameorigin"
28
- }
29
- };
30
- const security = (config, { strapi }) => (ctx, next) => {
31
- let helmetConfig = _.defaultsDeep(defaults, config);
32
- const specialPaths = ["/documentation"];
33
- const directives = {
34
- "script-src": ["'self'", "'unsafe-inline'", "cdn.jsdelivr.net"],
35
- "img-src": ["'self'", "data:", "cdn.jsdelivr.net", "strapi.io"],
36
- "manifest-src": [],
37
- "frame-src": []
38
- };
39
- if (strapi.plugin("graphql")?.service("utils").playground.isEnabled()) {
40
- const { config: gqlConfig } = strapi.plugin("graphql");
41
- specialPaths.push(gqlConfig("endpoint"));
42
- directives["script-src"].push(`https: 'unsafe-inline'`);
43
- directives["img-src"].push(`'apollo-server-landing-page.cdn.apollographql.com'`);
44
- directives["manifest-src"].push(`'self'`);
45
- directives["manifest-src"].push("apollo-server-landing-page.cdn.apollographql.com");
46
- directives["frame-src"].push(`'self'`);
47
- directives["frame-src"].push("sandbox.embed.apollographql.com");
48
- }
49
- if (ctx.method === "GET" && specialPaths.some((str) => ctx.path.startsWith(str))) {
50
- helmetConfig = _.merge(helmetConfig, {
51
- crossOriginEmbedderPolicy: false,
52
- // TODO: only use this for graphql playground
53
- contentSecurityPolicy: {
54
- directives
55
- }
56
- });
57
- }
58
- if (process.env.NODE_ENV === "development" && ctx.method === "GET" && ["/admin"].some((str) => ctx.path.startsWith(str))) {
59
- helmetConfig = _.merge(helmetConfig, {
60
- contentSecurityPolicy: {
8
+ crossOriginEmbedderPolicy: false,
9
+ crossOriginOpenerPolicy: false,
10
+ crossOriginResourcePolicy: false,
11
+ originAgentCluster: false,
12
+ contentSecurityPolicy: {
13
+ useDefaults: true,
61
14
  directives: {
62
- "script-src": ["'self'", "'unsafe-inline'"],
63
- "connect-src": ["'self'", "http:", "https:", "ws:"]
15
+ ...strapiUtils.CSP_DEFAULTS,
16
+ upgradeInsecureRequests: null
64
17
  }
65
- }
66
- });
67
- }
68
- return helmet__default.default(helmetConfig)(ctx, next);
18
+ },
19
+ xssFilter: false,
20
+ hsts: {
21
+ maxAge: 31536000,
22
+ includeSubDomains: true
23
+ },
24
+ frameguard: {
25
+ action: 'sameorigin'
26
+ }
27
+ };
28
+ const mergeConfig = (existingConfig, newConfig)=>{
29
+ return fp.mergeWith((obj, src)=>Array.isArray(obj) && Array.isArray(src) ? obj.concat(src) : undefined, existingConfig, newConfig);
69
30
  };
31
+ const security = (config, { strapi })=>(ctx, next)=>{
32
+ let helmetConfig = fp.defaultsDeep(defaults, config);
33
+ const specialPaths = [
34
+ '/documentation'
35
+ ];
36
+ const directives = {
37
+ 'script-src': [
38
+ "'self'",
39
+ "'unsafe-inline'",
40
+ 'cdn.jsdelivr.net'
41
+ ],
42
+ 'img-src': [
43
+ "'self'",
44
+ 'data:',
45
+ 'cdn.jsdelivr.net',
46
+ 'strapi.io'
47
+ ],
48
+ 'manifest-src': [],
49
+ 'frame-src': []
50
+ };
51
+ // if apollo graphql playground is enabled, add exceptions for it
52
+ if (strapi.plugin('graphql')?.service('utils').playground.isEnabled()) {
53
+ const { config: gqlConfig } = strapi.plugin('graphql');
54
+ specialPaths.push(gqlConfig('endpoint'));
55
+ directives['script-src'].push(`https: 'unsafe-inline'`);
56
+ directives['img-src'].push(`'apollo-server-landing-page.cdn.apollographql.com'`);
57
+ directives['manifest-src'].push(`'self'`);
58
+ directives['manifest-src'].push('apollo-server-landing-page.cdn.apollographql.com');
59
+ directives['frame-src'].push(`'self'`);
60
+ directives['frame-src'].push('sandbox.embed.apollographql.com');
61
+ }
62
+ // 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
63
+ if (ctx.method === 'GET' && specialPaths.some((str)=>ctx.path.startsWith(str))) {
64
+ helmetConfig = mergeConfig(helmetConfig, {
65
+ crossOriginEmbedderPolicy: false,
66
+ contentSecurityPolicy: {
67
+ directives
68
+ }
69
+ });
70
+ }
71
+ /**
72
+ * These are for vite's watch mode so it can accurately
73
+ * connect to the HMR websocket & reconnect on failure
74
+ * or when the server restarts.
75
+ *
76
+ * It only applies in development, and only on GET requests
77
+ * that are part of the admin route.
78
+ */ if ([
79
+ 'development',
80
+ 'test'
81
+ ].includes(process.env.NODE_ENV ?? '') && ctx.method === 'GET' && ctx.path.startsWith(strapi.config.get('admin.path'))) {
82
+ helmetConfig = mergeConfig(helmetConfig, {
83
+ contentSecurityPolicy: {
84
+ directives: {
85
+ 'script-src': [
86
+ "'self'",
87
+ "'unsafe-inline'"
88
+ ],
89
+ 'connect-src': [
90
+ "'self'",
91
+ 'http:',
92
+ 'https:',
93
+ 'ws:'
94
+ ]
95
+ }
96
+ }
97
+ });
98
+ }
99
+ return helmet(helmetConfig)(ctx, next);
100
+ };
101
+
70
102
  exports.security = security;
71
103
  //# sourceMappingURL=security.js.map
@@ -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 /**\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 if (\n process.env.NODE_ENV === 'development' &&\n ctx.method === 'GET' &&\n ['/admin'].some((str) => ctx.path.startsWith(str))\n ) {\n helmetConfig = merge(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":["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;AAUA,MACE,QAAQ,IAAI,aAAa,iBACzB,IAAI,WAAW,SACf,CAAC,QAAQ,EAAE,KAAK,CAAC,QAAQ,IAAI,KAAK,WAAW,GAAG,CAAC,GACjD;AACA,mBAAeA,QAAM,cAAc;AAAA,MACjC,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
+ {"version":3,"file":"security.js","sources":["../../src/middlewares/security.ts"],"sourcesContent":["import { defaultsDeep, mergeWith } from 'lodash/fp';\nimport helmet, { KoaHelmet } from 'koa-helmet';\nimport { CSP_DEFAULTS } from '@strapi/utils';\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 ...CSP_DEFAULTS,\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 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":["defaults","crossOriginEmbedderPolicy","crossOriginOpenerPolicy","crossOriginResourcePolicy","originAgentCluster","contentSecurityPolicy","useDefaults","directives","CSP_DEFAULTS","upgradeInsecureRequests","xssFilter","hsts","maxAge","includeSubDomains","frameguard","action","mergeConfig","existingConfig","newConfig","mergeWith","obj","src","Array","isArray","concat","undefined","security","config","strapi","ctx","next","helmetConfig","defaultsDeep","specialPaths","plugin","service","playground","isEnabled","gqlConfig","push","method","some","str","path","startsWith","includes","process","env","NODE_ENV","get","helmet"],"mappings":"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"}
@@ -1,69 +1,101 @@
1
- import { defaultsDeep, merge } from "lodash/fp";
2
- import helmet from "koa-helmet";
1
+ import { defaultsDeep, mergeWith } from 'lodash/fp';
2
+ import helmet from 'koa-helmet';
3
+ import { CSP_DEFAULTS } from '@strapi/utils';
4
+
3
5
  const defaults = {
4
- crossOriginEmbedderPolicy: false,
5
- crossOriginOpenerPolicy: false,
6
- crossOriginResourcePolicy: false,
7
- originAgentCluster: false,
8
- contentSecurityPolicy: {
9
- useDefaults: true,
10
- directives: {
11
- "connect-src": ["'self'", "https:"],
12
- "img-src": ["'self'", "data:", "blob:", "https://market-assets.strapi.io"],
13
- "media-src": ["'self'", "data:", "blob:"],
14
- upgradeInsecureRequests: null
15
- }
16
- },
17
- xssFilter: false,
18
- hsts: {
19
- maxAge: 31536e3,
20
- includeSubDomains: true
21
- },
22
- frameguard: {
23
- action: "sameorigin"
24
- }
25
- };
26
- const security = (config, { strapi }) => (ctx, next) => {
27
- let helmetConfig = defaultsDeep(defaults, config);
28
- const specialPaths = ["/documentation"];
29
- const directives = {
30
- "script-src": ["'self'", "'unsafe-inline'", "cdn.jsdelivr.net"],
31
- "img-src": ["'self'", "data:", "cdn.jsdelivr.net", "strapi.io"],
32
- "manifest-src": [],
33
- "frame-src": []
34
- };
35
- if (strapi.plugin("graphql")?.service("utils").playground.isEnabled()) {
36
- const { config: gqlConfig } = strapi.plugin("graphql");
37
- specialPaths.push(gqlConfig("endpoint"));
38
- directives["script-src"].push(`https: 'unsafe-inline'`);
39
- directives["img-src"].push(`'apollo-server-landing-page.cdn.apollographql.com'`);
40
- directives["manifest-src"].push(`'self'`);
41
- directives["manifest-src"].push("apollo-server-landing-page.cdn.apollographql.com");
42
- directives["frame-src"].push(`'self'`);
43
- directives["frame-src"].push("sandbox.embed.apollographql.com");
44
- }
45
- if (ctx.method === "GET" && specialPaths.some((str) => ctx.path.startsWith(str))) {
46
- helmetConfig = merge(helmetConfig, {
47
- crossOriginEmbedderPolicy: false,
48
- // TODO: only use this for graphql playground
49
- contentSecurityPolicy: {
50
- directives
51
- }
52
- });
53
- }
54
- if (process.env.NODE_ENV === "development" && ctx.method === "GET" && ["/admin"].some((str) => ctx.path.startsWith(str))) {
55
- helmetConfig = merge(helmetConfig, {
56
- contentSecurityPolicy: {
6
+ crossOriginEmbedderPolicy: false,
7
+ crossOriginOpenerPolicy: false,
8
+ crossOriginResourcePolicy: false,
9
+ originAgentCluster: false,
10
+ contentSecurityPolicy: {
11
+ useDefaults: true,
57
12
  directives: {
58
- "script-src": ["'self'", "'unsafe-inline'"],
59
- "connect-src": ["'self'", "http:", "https:", "ws:"]
13
+ ...CSP_DEFAULTS,
14
+ upgradeInsecureRequests: null
60
15
  }
61
- }
62
- });
63
- }
64
- return helmet(helmetConfig)(ctx, next);
16
+ },
17
+ xssFilter: false,
18
+ hsts: {
19
+ maxAge: 31536000,
20
+ includeSubDomains: true
21
+ },
22
+ frameguard: {
23
+ action: 'sameorigin'
24
+ }
65
25
  };
66
- export {
67
- security
26
+ const mergeConfig = (existingConfig, newConfig)=>{
27
+ return mergeWith((obj, src)=>Array.isArray(obj) && Array.isArray(src) ? obj.concat(src) : undefined, existingConfig, newConfig);
68
28
  };
29
+ const security = (config, { strapi })=>(ctx, next)=>{
30
+ let helmetConfig = defaultsDeep(defaults, config);
31
+ const specialPaths = [
32
+ '/documentation'
33
+ ];
34
+ const directives = {
35
+ 'script-src': [
36
+ "'self'",
37
+ "'unsafe-inline'",
38
+ 'cdn.jsdelivr.net'
39
+ ],
40
+ 'img-src': [
41
+ "'self'",
42
+ 'data:',
43
+ 'cdn.jsdelivr.net',
44
+ 'strapi.io'
45
+ ],
46
+ 'manifest-src': [],
47
+ 'frame-src': []
48
+ };
49
+ // if apollo graphql playground is enabled, add exceptions for it
50
+ if (strapi.plugin('graphql')?.service('utils').playground.isEnabled()) {
51
+ const { config: gqlConfig } = strapi.plugin('graphql');
52
+ specialPaths.push(gqlConfig('endpoint'));
53
+ directives['script-src'].push(`https: 'unsafe-inline'`);
54
+ directives['img-src'].push(`'apollo-server-landing-page.cdn.apollographql.com'`);
55
+ directives['manifest-src'].push(`'self'`);
56
+ directives['manifest-src'].push('apollo-server-landing-page.cdn.apollographql.com');
57
+ directives['frame-src'].push(`'self'`);
58
+ directives['frame-src'].push('sandbox.embed.apollographql.com');
59
+ }
60
+ // 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
61
+ if (ctx.method === 'GET' && specialPaths.some((str)=>ctx.path.startsWith(str))) {
62
+ helmetConfig = mergeConfig(helmetConfig, {
63
+ crossOriginEmbedderPolicy: false,
64
+ contentSecurityPolicy: {
65
+ directives
66
+ }
67
+ });
68
+ }
69
+ /**
70
+ * These are for vite's watch mode so it can accurately
71
+ * connect to the HMR websocket & reconnect on failure
72
+ * or when the server restarts.
73
+ *
74
+ * It only applies in development, and only on GET requests
75
+ * that are part of the admin route.
76
+ */ if ([
77
+ 'development',
78
+ 'test'
79
+ ].includes(process.env.NODE_ENV ?? '') && ctx.method === 'GET' && ctx.path.startsWith(strapi.config.get('admin.path'))) {
80
+ helmetConfig = mergeConfig(helmetConfig, {
81
+ contentSecurityPolicy: {
82
+ directives: {
83
+ 'script-src': [
84
+ "'self'",
85
+ "'unsafe-inline'"
86
+ ],
87
+ 'connect-src': [
88
+ "'self'",
89
+ 'http:',
90
+ 'https:',
91
+ 'ws:'
92
+ ]
93
+ }
94
+ }
95
+ });
96
+ }
97
+ return helmet(helmetConfig)(ctx, next);
98
+ };
99
+
100
+ export { security };
69
101
  //# sourceMappingURL=security.mjs.map
@@ -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 /**\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 if (\n process.env.NODE_ENV === 'development' &&\n ctx.method === 'GET' &&\n ['/admin'].some((str) => ctx.path.startsWith(str))\n ) {\n helmetConfig = merge(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,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;AAUA,MACE,QAAQ,IAAI,aAAa,iBACzB,IAAI,WAAW,SACf,CAAC,QAAQ,EAAE,KAAK,CAAC,QAAQ,IAAI,KAAK,WAAW,GAAG,CAAC,GACjD;AACA,mBAAe,MAAM,cAAc;AAAA,MACjC,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
+ {"version":3,"file":"security.mjs","sources":["../../src/middlewares/security.ts"],"sourcesContent":["import { defaultsDeep, mergeWith } from 'lodash/fp';\nimport helmet, { KoaHelmet } from 'koa-helmet';\nimport { CSP_DEFAULTS } from '@strapi/utils';\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 ...CSP_DEFAULTS,\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 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":["defaults","crossOriginEmbedderPolicy","crossOriginOpenerPolicy","crossOriginResourcePolicy","originAgentCluster","contentSecurityPolicy","useDefaults","directives","CSP_DEFAULTS","upgradeInsecureRequests","xssFilter","hsts","maxAge","includeSubDomains","frameguard","action","mergeConfig","existingConfig","newConfig","mergeWith","obj","src","Array","isArray","concat","undefined","security","config","strapi","ctx","next","helmetConfig","defaultsDeep","specialPaths","plugin","service","playground","isEnabled","gqlConfig","push","method","some","str","path","startsWith","includes","process","env","NODE_ENV","get","helmet"],"mappings":"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"}
@@ -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,30 +1,31 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const _ = require("lodash/fp");
4
- const koaSession = require("koa-session");
5
- const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
6
- const koaSession__default = /* @__PURE__ */ _interopDefault(koaSession);
1
+ 'use strict';
2
+
3
+ var fp = require('lodash/fp');
4
+ var koaSession = require('koa-session');
5
+
7
6
  const defaultConfig = {
8
- key: "koa.sess",
9
- maxAge: 864e5,
10
- autoCommit: true,
11
- overwrite: true,
12
- httpOnly: true,
13
- signed: true,
14
- rolling: false,
15
- renew: false,
16
- secure: process.env.NODE_ENV === "production",
17
- sameSite: void 0
7
+ key: 'koa.sess',
8
+ maxAge: 86400000,
9
+ autoCommit: true,
10
+ overwrite: true,
11
+ httpOnly: true,
12
+ signed: true,
13
+ rolling: false,
14
+ renew: false,
15
+ secure: process.env.NODE_ENV === 'production',
16
+ sameSite: undefined
18
17
  };
19
- const session = (userConfig, { strapi }) => {
20
- const { keys } = strapi.server.app;
21
- if (!_.isArray(keys) || _.isEmpty(keys) || keys.some(_.isEmpty)) {
22
- throw new Error(
23
- `App keys are required. Please set app.keys in config/server.js (ex: keys: ['myKeyA', 'myKeyB'])`
24
- );
25
- }
26
- const config = { ...defaultConfig, ...userConfig };
27
- strapi.server.use(koaSession__default.default(config, strapi.server.app));
18
+ const session = (userConfig, { strapi })=>{
19
+ const { keys } = strapi.server.app;
20
+ if (!fp.isArray(keys) || fp.isEmpty(keys) || keys.some(fp.isEmpty)) {
21
+ throw new Error(`App keys are required. Please set app.keys in config/server.js (ex: keys: ['myKeyA', 'myKeyB'])`);
22
+ }
23
+ const config = {
24
+ ...defaultConfig,
25
+ ...userConfig
26
+ };
27
+ strapi.server.use(koaSession(config, strapi.server.app));
28
28
  };
29
+
29
30
  exports.session = session;
30
31
  //# sourceMappingURL=session.js.map
@@ -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":["defaultConfig","key","maxAge","autoCommit","overwrite","httpOnly","signed","rolling","renew","secure","process","env","NODE_ENV","sameSite","undefined","session","userConfig","strapi","keys","server","app","isArray","isEmpty","some","Error","config","use","koaSession"],"mappings":";;;;;AAIA,MAAMA,aAAgB,GAAA;IACpBC,GAAK,EAAA,UAAA;IACLC,MAAQ,EAAA,QAAA;IACRC,UAAY,EAAA,IAAA;IACZC,SAAW,EAAA,IAAA;IACXC,QAAU,EAAA,IAAA;IACVC,MAAQ,EAAA,IAAA;IACRC,OAAS,EAAA,KAAA;IACTC,KAAO,EAAA,KAAA;AACPC,IAAAA,MAAAA,EAAQC,OAAQC,CAAAA,GAAG,CAACC,QAAQ,KAAK,YAAA;IACjCC,QAAUC,EAAAA;AACZ,CAAA;MAEaC,OAA4D,GAAA,CACvEC,UACA,EAAA,EAAEC,MAAM,EAAE,GAAA;AAEV,IAAA,MAAM,EAAEC,IAAI,EAAE,GAAGD,MAAOE,CAAAA,MAAM,CAACC,GAAG;IAClC,IAAI,CAACC,WAAQH,IAASI,CAAAA,IAAAA,UAAAA,CAAQJ,SAASA,IAAKK,CAAAA,IAAI,CAACD,UAAU,CAAA,EAAA;AACzD,QAAA,MAAM,IAAIE,KAAAA,CACR,CAAC,+FAA+F,CAAC,CAAA;AAErG;AAEA,IAAA,MAAMC,MAAmC,GAAA;AAAE,QAAA,GAAGzB,aAAa;AAAE,QAAA,GAAGgB;AAAW,KAAA;IAE3EC,MAAOE,CAAAA,MAAM,CAACO,GAAG,CAACC,WAAWF,MAAQR,EAAAA,MAAAA,CAAOE,MAAM,CAACC,GAAG,CAAA,CAAA;AACxD;;;;"}
@@ -1,28 +1,29 @@
1
- import { isArray, isEmpty } from "lodash/fp";
2
- import koaSession from "koa-session";
1
+ import { isArray, isEmpty } from 'lodash/fp';
2
+ import koaSession from 'koa-session';
3
+
3
4
  const defaultConfig = {
4
- key: "koa.sess",
5
- maxAge: 864e5,
6
- autoCommit: true,
7
- overwrite: true,
8
- httpOnly: true,
9
- signed: true,
10
- rolling: false,
11
- renew: false,
12
- secure: process.env.NODE_ENV === "production",
13
- sameSite: void 0
5
+ key: 'koa.sess',
6
+ maxAge: 86400000,
7
+ autoCommit: true,
8
+ overwrite: true,
9
+ httpOnly: true,
10
+ signed: true,
11
+ rolling: false,
12
+ renew: false,
13
+ secure: process.env.NODE_ENV === 'production',
14
+ sameSite: undefined
14
15
  };
15
- const session = (userConfig, { strapi }) => {
16
- const { keys } = strapi.server.app;
17
- if (!isArray(keys) || isEmpty(keys) || keys.some(isEmpty)) {
18
- throw new Error(
19
- `App keys are required. Please set app.keys in config/server.js (ex: keys: ['myKeyA', 'myKeyB'])`
20
- );
21
- }
22
- const config = { ...defaultConfig, ...userConfig };
23
- strapi.server.use(koaSession(config, strapi.server.app));
24
- };
25
- export {
26
- session
16
+ const session = (userConfig, { strapi })=>{
17
+ const { keys } = strapi.server.app;
18
+ if (!isArray(keys) || isEmpty(keys) || keys.some(isEmpty)) {
19
+ throw new Error(`App keys are required. Please set app.keys in config/server.js (ex: keys: ['myKeyA', 'myKeyB'])`);
20
+ }
21
+ const config = {
22
+ ...defaultConfig,
23
+ ...userConfig
24
+ };
25
+ strapi.server.use(koaSession(config, strapi.server.app));
27
26
  };
27
+
28
+ export { session };
28
29
  //# sourceMappingURL=session.mjs.map
@@ -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":["defaultConfig","key","maxAge","autoCommit","overwrite","httpOnly","signed","rolling","renew","secure","process","env","NODE_ENV","sameSite","undefined","session","userConfig","strapi","keys","server","app","isArray","isEmpty","some","Error","config","use","koaSession"],"mappings":";;;AAIA,MAAMA,aAAgB,GAAA;IACpBC,GAAK,EAAA,UAAA;IACLC,MAAQ,EAAA,QAAA;IACRC,UAAY,EAAA,IAAA;IACZC,SAAW,EAAA,IAAA;IACXC,QAAU,EAAA,IAAA;IACVC,MAAQ,EAAA,IAAA;IACRC,OAAS,EAAA,KAAA;IACTC,KAAO,EAAA,KAAA;AACPC,IAAAA,MAAAA,EAAQC,OAAQC,CAAAA,GAAG,CAACC,QAAQ,KAAK,YAAA;IACjCC,QAAUC,EAAAA;AACZ,CAAA;MAEaC,OAA4D,GAAA,CACvEC,UACA,EAAA,EAAEC,MAAM,EAAE,GAAA;AAEV,IAAA,MAAM,EAAEC,IAAI,EAAE,GAAGD,MAAOE,CAAAA,MAAM,CAACC,GAAG;IAClC,IAAI,CAACC,QAAQH,IAASI,CAAAA,IAAAA,OAAAA,CAAQJ,SAASA,IAAKK,CAAAA,IAAI,CAACD,OAAU,CAAA,EAAA;AACzD,QAAA,MAAM,IAAIE,KAAAA,CACR,CAAC,+FAA+F,CAAC,CAAA;AAErG;AAEA,IAAA,MAAMC,MAAmC,GAAA;AAAE,QAAA,GAAGzB,aAAa;AAAE,QAAA,GAAGgB;AAAW,KAAA;IAE3EC,MAAOE,CAAAA,MAAM,CAACO,GAAG,CAACC,WAAWF,MAAQR,EAAAA,MAAAA,CAAOE,MAAM,CAACC,GAAG,CAAA,CAAA;AACxD;;;;"}
@@ -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, defaultBatchSize, }: {
26
+ db: Database;
27
+ trx: Knex;
28
+ uid: string;
29
+ defaultBatchSize?: 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;AAI5D,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,gBAAuB,GACxB,EAAE;IACD,EAAE,EAAE,QAAQ,CAAC;IACb,GAAG,EAAE,IAAI,CAAC;IACV,GAAG,EAAE,MAAM,CAAC;IACZ,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B,oDAgCA;AA2DD,eAAO,MAAM,qBAAqB,EAAE,SAQnC,CAAC"}