@strapi/core 0.0.0-experimental.da85533897155e719d784f0271223c866d2f69ab → 0.0.0-experimental.dade06b8247a834854b897c534e3b7dff8eb010a

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 (825) hide show
  1. package/dist/Strapi.d.ts.map +1 -1
  2. package/dist/Strapi.js +430 -403
  3. package/dist/Strapi.js.map +1 -1
  4. package/dist/Strapi.mjs +429 -402
  5. package/dist/Strapi.mjs.map +1 -1
  6. package/dist/compile.js +23 -14
  7. package/dist/compile.js.map +1 -1
  8. package/dist/compile.mjs +22 -14
  9. package/dist/compile.mjs.map +1 -1
  10. package/dist/configuration/config-loader.js +110 -97
  11. package/dist/configuration/config-loader.js.map +1 -1
  12. package/dist/configuration/config-loader.mjs +109 -96
  13. package/dist/configuration/config-loader.mjs.map +1 -1
  14. package/dist/configuration/get-dirs.js +31 -29
  15. package/dist/configuration/get-dirs.js.map +1 -1
  16. package/dist/configuration/get-dirs.mjs +30 -30
  17. package/dist/configuration/get-dirs.mjs.map +1 -1
  18. package/dist/configuration/index.d.ts +1 -0
  19. package/dist/configuration/index.d.ts.map +1 -1
  20. package/dist/configuration/index.js +85 -73
  21. package/dist/configuration/index.js.map +1 -1
  22. package/dist/configuration/index.mjs +84 -69
  23. package/dist/configuration/index.mjs.map +1 -1
  24. package/dist/configuration/urls.d.ts.map +1 -1
  25. package/dist/configuration/urls.js +74 -61
  26. package/dist/configuration/urls.js.map +1 -1
  27. package/dist/configuration/urls.mjs +73 -62
  28. package/dist/configuration/urls.mjs.map +1 -1
  29. package/dist/container.js +27 -23
  30. package/dist/container.js.map +1 -1
  31. package/dist/container.mjs +26 -24
  32. package/dist/container.mjs.map +1 -1
  33. package/dist/core-api/controller/collection-type.js +77 -76
  34. package/dist/core-api/controller/collection-type.js.map +1 -1
  35. package/dist/core-api/controller/collection-type.mjs +76 -77
  36. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  37. package/dist/core-api/controller/index.d.ts.map +1 -1
  38. package/dist/core-api/controller/index.js +64 -48
  39. package/dist/core-api/controller/index.js.map +1 -1
  40. package/dist/core-api/controller/index.mjs +63 -49
  41. package/dist/core-api/controller/index.mjs.map +1 -1
  42. package/dist/core-api/controller/single-type.js +41 -40
  43. package/dist/core-api/controller/single-type.js.map +1 -1
  44. package/dist/core-api/controller/single-type.mjs +40 -41
  45. package/dist/core-api/controller/single-type.mjs.map +1 -1
  46. package/dist/core-api/controller/transform.d.ts +3 -2
  47. package/dist/core-api/controller/transform.d.ts.map +1 -1
  48. package/dist/core-api/controller/transform.js +83 -64
  49. package/dist/core-api/controller/transform.js.map +1 -1
  50. package/dist/core-api/controller/transform.mjs +82 -65
  51. package/dist/core-api/controller/transform.mjs.map +1 -1
  52. package/dist/core-api/routes/index.d.ts +4 -22
  53. package/dist/core-api/routes/index.d.ts.map +1 -1
  54. package/dist/core-api/routes/index.js +205 -61
  55. package/dist/core-api/routes/index.js.map +1 -1
  56. package/dist/core-api/routes/index.mjs +185 -62
  57. package/dist/core-api/routes/index.mjs.map +1 -1
  58. package/dist/core-api/routes/validation/attributes.d.ts +244 -0
  59. package/dist/core-api/routes/validation/attributes.d.ts.map +1 -0
  60. package/dist/core-api/routes/validation/attributes.js +560 -0
  61. package/dist/core-api/routes/validation/attributes.js.map +1 -0
  62. package/dist/core-api/routes/validation/attributes.mjs +521 -0
  63. package/dist/core-api/routes/validation/attributes.mjs.map +1 -0
  64. package/dist/core-api/routes/validation/common.d.ts +105 -0
  65. package/dist/core-api/routes/validation/common.d.ts.map +1 -0
  66. package/dist/core-api/routes/validation/common.js +116 -0
  67. package/dist/core-api/routes/validation/common.js.map +1 -0
  68. package/dist/core-api/routes/validation/common.mjs +95 -0
  69. package/dist/core-api/routes/validation/common.mjs.map +1 -0
  70. package/dist/core-api/routes/validation/component.d.ts +34 -0
  71. package/dist/core-api/routes/validation/component.d.ts.map +1 -0
  72. package/dist/core-api/routes/validation/component.js +45 -0
  73. package/dist/core-api/routes/validation/component.js.map +1 -0
  74. package/dist/core-api/routes/validation/component.mjs +43 -0
  75. package/dist/core-api/routes/validation/component.mjs.map +1 -0
  76. package/dist/core-api/routes/validation/constants.d.ts +8 -0
  77. package/dist/core-api/routes/validation/constants.d.ts.map +1 -0
  78. package/dist/core-api/routes/validation/constants.js +18 -0
  79. package/dist/core-api/routes/validation/constants.js.map +1 -0
  80. package/dist/core-api/routes/validation/constants.mjs +16 -0
  81. package/dist/core-api/routes/validation/constants.mjs.map +1 -0
  82. package/dist/core-api/routes/validation/content-type.d.ts +128 -0
  83. package/dist/core-api/routes/validation/content-type.d.ts.map +1 -0
  84. package/dist/core-api/routes/validation/content-type.js +201 -0
  85. package/dist/core-api/routes/validation/content-type.js.map +1 -0
  86. package/dist/core-api/routes/validation/content-type.mjs +180 -0
  87. package/dist/core-api/routes/validation/content-type.mjs.map +1 -0
  88. package/dist/core-api/routes/validation/index.d.ts +5 -0
  89. package/dist/core-api/routes/validation/index.d.ts.map +1 -0
  90. package/dist/core-api/routes/validation/mappers.d.ts +105 -0
  91. package/dist/core-api/routes/validation/mappers.d.ts.map +1 -0
  92. package/dist/core-api/routes/validation/mappers.js +238 -0
  93. package/dist/core-api/routes/validation/mappers.js.map +1 -0
  94. package/dist/core-api/routes/validation/mappers.mjs +214 -0
  95. package/dist/core-api/routes/validation/mappers.mjs.map +1 -0
  96. package/dist/core-api/routes/validation/utils.d.ts +47 -0
  97. package/dist/core-api/routes/validation/utils.d.ts.map +1 -0
  98. package/dist/core-api/routes/validation/utils.js +128 -0
  99. package/dist/core-api/routes/validation/utils.js.map +1 -0
  100. package/dist/core-api/routes/validation/utils.mjs +106 -0
  101. package/dist/core-api/routes/validation/utils.mjs.map +1 -0
  102. package/dist/core-api/service/collection-type.d.ts +2 -2
  103. package/dist/core-api/service/collection-type.js +73 -60
  104. package/dist/core-api/service/collection-type.js.map +1 -1
  105. package/dist/core-api/service/collection-type.mjs +72 -62
  106. package/dist/core-api/service/collection-type.mjs.map +1 -1
  107. package/dist/core-api/service/core-service.js +9 -8
  108. package/dist/core-api/service/core-service.js.map +1 -1
  109. package/dist/core-api/service/core-service.mjs +8 -9
  110. package/dist/core-api/service/core-service.mjs.map +1 -1
  111. package/dist/core-api/service/index.js +13 -13
  112. package/dist/core-api/service/index.js.map +1 -1
  113. package/dist/core-api/service/index.mjs +12 -14
  114. package/dist/core-api/service/index.mjs.map +1 -1
  115. package/dist/core-api/service/pagination.js +69 -43
  116. package/dist/core-api/service/pagination.js.map +1 -1
  117. package/dist/core-api/service/pagination.mjs +68 -47
  118. package/dist/core-api/service/pagination.mjs.map +1 -1
  119. package/dist/core-api/service/single-type.js +43 -39
  120. package/dist/core-api/service/single-type.js.map +1 -1
  121. package/dist/core-api/service/single-type.mjs +42 -41
  122. package/dist/core-api/service/single-type.mjs.map +1 -1
  123. package/dist/domain/content-type/index.d.ts.map +1 -1
  124. package/dist/domain/content-type/index.js +110 -99
  125. package/dist/domain/content-type/index.js.map +1 -1
  126. package/dist/domain/content-type/index.mjs +109 -99
  127. package/dist/domain/content-type/index.mjs.map +1 -1
  128. package/dist/domain/content-type/validator.js +84 -69
  129. package/dist/domain/content-type/validator.js.map +1 -1
  130. package/dist/domain/content-type/validator.mjs +83 -68
  131. package/dist/domain/content-type/validator.mjs.map +1 -1
  132. package/dist/domain/module/index.d.ts.map +1 -1
  133. package/dist/domain/module/index.js +112 -100
  134. package/dist/domain/module/index.js.map +1 -1
  135. package/dist/domain/module/index.mjs +111 -99
  136. package/dist/domain/module/index.mjs.map +1 -1
  137. package/dist/domain/module/validation.js +25 -20
  138. package/dist/domain/module/validation.js.map +1 -1
  139. package/dist/domain/module/validation.mjs +24 -21
  140. package/dist/domain/module/validation.mjs.map +1 -1
  141. package/dist/ee/index.d.ts +7 -0
  142. package/dist/ee/index.d.ts.map +1 -1
  143. package/dist/ee/index.js +197 -132
  144. package/dist/ee/index.js.map +1 -1
  145. package/dist/ee/index.mjs +196 -134
  146. package/dist/ee/index.mjs.map +1 -1
  147. package/dist/ee/license.d.ts +3 -1
  148. package/dist/ee/license.d.ts.map +1 -1
  149. package/dist/ee/license.js +105 -75
  150. package/dist/ee/license.js.map +1 -1
  151. package/dist/ee/license.mjs +103 -76
  152. package/dist/ee/license.mjs.map +1 -1
  153. package/dist/factories.d.ts +3 -1
  154. package/dist/factories.d.ts.map +1 -1
  155. package/dist/factories.js +80 -67
  156. package/dist/factories.js.map +1 -1
  157. package/dist/factories.mjs +77 -70
  158. package/dist/factories.mjs.map +1 -1
  159. package/dist/index.js +29 -26
  160. package/dist/index.js.map +1 -1
  161. package/dist/index.mjs +29 -29
  162. package/dist/index.mjs.map +1 -1
  163. package/dist/loaders/admin.d.ts.map +1 -1
  164. package/dist/loaders/admin.js +21 -20
  165. package/dist/loaders/admin.js.map +1 -1
  166. package/dist/loaders/admin.mjs +20 -20
  167. package/dist/loaders/admin.mjs.map +1 -1
  168. package/dist/loaders/apis.js +143 -120
  169. package/dist/loaders/apis.js.map +1 -1
  170. package/dist/loaders/apis.mjs +142 -119
  171. package/dist/loaders/apis.mjs.map +1 -1
  172. package/dist/loaders/components.js +33 -34
  173. package/dist/loaders/components.js.map +1 -1
  174. package/dist/loaders/components.mjs +32 -34
  175. package/dist/loaders/components.mjs.map +1 -1
  176. package/dist/loaders/index.js +22 -20
  177. package/dist/loaders/index.js.map +1 -1
  178. package/dist/loaders/index.mjs +21 -21
  179. package/dist/loaders/index.mjs.map +1 -1
  180. package/dist/loaders/middlewares.js +29 -25
  181. package/dist/loaders/middlewares.js.map +1 -1
  182. package/dist/loaders/middlewares.mjs +28 -25
  183. package/dist/loaders/middlewares.mjs.map +1 -1
  184. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  185. package/dist/loaders/plugins/get-enabled-plugins.js +125 -127
  186. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
  187. package/dist/loaders/plugins/get-enabled-plugins.mjs +124 -104
  188. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
  189. package/dist/loaders/plugins/get-user-plugins-config.js +25 -24
  190. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -1
  191. package/dist/loaders/plugins/get-user-plugins-config.mjs +24 -23
  192. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +1 -1
  193. package/dist/loaders/plugins/index.d.ts.map +1 -1
  194. package/dist/loaders/plugins/index.js +141 -104
  195. package/dist/loaders/plugins/index.js.map +1 -1
  196. package/dist/loaders/plugins/index.mjs +121 -104
  197. package/dist/loaders/plugins/index.mjs.map +1 -1
  198. package/dist/loaders/policies.js +24 -20
  199. package/dist/loaders/policies.js.map +1 -1
  200. package/dist/loaders/policies.mjs +23 -20
  201. package/dist/loaders/policies.mjs.map +1 -1
  202. package/dist/loaders/sanitizers.js +10 -4
  203. package/dist/loaders/sanitizers.js.map +1 -1
  204. package/dist/loaders/sanitizers.mjs +9 -6
  205. package/dist/loaders/sanitizers.mjs.map +1 -1
  206. package/dist/loaders/src-index.js +35 -27
  207. package/dist/loaders/src-index.js.map +1 -1
  208. package/dist/loaders/src-index.mjs +34 -29
  209. package/dist/loaders/src-index.mjs.map +1 -1
  210. package/dist/loaders/validators.js +9 -4
  211. package/dist/loaders/validators.js.map +1 -1
  212. package/dist/loaders/validators.mjs +8 -6
  213. package/dist/loaders/validators.mjs.map +1 -1
  214. package/dist/middlewares/body.d.ts.map +1 -1
  215. package/dist/middlewares/body.js +58 -54
  216. package/dist/middlewares/body.js.map +1 -1
  217. package/dist/middlewares/body.mjs +57 -51
  218. package/dist/middlewares/body.mjs.map +1 -1
  219. package/dist/middlewares/compression.js +6 -6
  220. package/dist/middlewares/compression.js.map +1 -1
  221. package/dist/middlewares/compression.mjs +5 -5
  222. package/dist/middlewares/compression.mjs.map +1 -1
  223. package/dist/middlewares/cors.d.ts +9 -1
  224. package/dist/middlewares/cors.d.ts.map +1 -1
  225. package/dist/middlewares/cors.js +81 -48
  226. package/dist/middlewares/cors.js.map +1 -1
  227. package/dist/middlewares/cors.mjs +78 -46
  228. package/dist/middlewares/cors.mjs.map +1 -1
  229. package/dist/middlewares/errors.js +32 -30
  230. package/dist/middlewares/errors.js.map +1 -1
  231. package/dist/middlewares/errors.mjs +31 -31
  232. package/dist/middlewares/errors.mjs.map +1 -1
  233. package/dist/middlewares/favicon.js +27 -17
  234. package/dist/middlewares/favicon.js.map +1 -1
  235. package/dist/middlewares/favicon.mjs +26 -16
  236. package/dist/middlewares/favicon.mjs.map +1 -1
  237. package/dist/middlewares/index.js +32 -30
  238. package/dist/middlewares/index.js.map +1 -1
  239. package/dist/middlewares/index.mjs +31 -31
  240. package/dist/middlewares/index.mjs.map +1 -1
  241. package/dist/middlewares/ip.js +6 -6
  242. package/dist/middlewares/ip.js.map +1 -1
  243. package/dist/middlewares/ip.mjs +5 -5
  244. package/dist/middlewares/ip.mjs.map +1 -1
  245. package/dist/middlewares/logger.js +10 -9
  246. package/dist/middlewares/logger.js.map +1 -1
  247. package/dist/middlewares/logger.mjs +9 -10
  248. package/dist/middlewares/logger.mjs.map +1 -1
  249. package/dist/middlewares/powered-by.js +13 -9
  250. package/dist/middlewares/powered-by.js.map +1 -1
  251. package/dist/middlewares/powered-by.mjs +12 -10
  252. package/dist/middlewares/powered-by.mjs.map +1 -1
  253. package/dist/middlewares/public.js +33 -29
  254. package/dist/middlewares/public.js.map +1 -1
  255. package/dist/middlewares/public.mjs +32 -28
  256. package/dist/middlewares/public.mjs.map +1 -1
  257. package/dist/middlewares/query.js +35 -32
  258. package/dist/middlewares/query.js.map +1 -1
  259. package/dist/middlewares/query.mjs +34 -31
  260. package/dist/middlewares/query.mjs.map +1 -1
  261. package/dist/middlewares/response-time.js +10 -9
  262. package/dist/middlewares/response-time.js.map +1 -1
  263. package/dist/middlewares/response-time.mjs +9 -10
  264. package/dist/middlewares/response-time.mjs.map +1 -1
  265. package/dist/middlewares/responses.js +14 -12
  266. package/dist/middlewares/responses.js.map +1 -1
  267. package/dist/middlewares/responses.mjs +13 -13
  268. package/dist/middlewares/responses.mjs.map +1 -1
  269. package/dist/middlewares/security.d.ts.map +1 -1
  270. package/dist/middlewares/security.js +109 -71
  271. package/dist/middlewares/security.js.map +1 -1
  272. package/dist/middlewares/security.mjs +108 -70
  273. package/dist/middlewares/security.mjs.map +1 -1
  274. package/dist/middlewares/session.js +26 -25
  275. package/dist/middlewares/session.js.map +1 -1
  276. package/dist/middlewares/session.mjs +25 -24
  277. package/dist/middlewares/session.mjs.map +1 -1
  278. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +14 -11
  279. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -1
  280. package/dist/migrations/database/5.0.0-discard-drafts.js +153 -35
  281. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -1
  282. package/dist/migrations/database/5.0.0-discard-drafts.mjs +152 -37
  283. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -1
  284. package/dist/migrations/draft-publish.d.ts +2 -2
  285. package/dist/migrations/draft-publish.d.ts.map +1 -1
  286. package/dist/migrations/draft-publish.js +61 -34
  287. package/dist/migrations/draft-publish.js.map +1 -1
  288. package/dist/migrations/draft-publish.mjs +60 -36
  289. package/dist/migrations/draft-publish.mjs.map +1 -1
  290. package/dist/migrations/first-published-at.d.ts +4 -0
  291. package/dist/migrations/first-published-at.d.ts.map +1 -0
  292. package/dist/migrations/first-published-at.js +51 -0
  293. package/dist/migrations/first-published-at.js.map +1 -0
  294. package/dist/migrations/first-published-at.mjs +49 -0
  295. package/dist/migrations/first-published-at.mjs.map +1 -0
  296. package/dist/migrations/i18n.d.ts +5 -0
  297. package/dist/migrations/i18n.d.ts.map +1 -0
  298. package/dist/migrations/i18n.js +71 -0
  299. package/dist/migrations/i18n.js.map +1 -0
  300. package/dist/migrations/i18n.mjs +68 -0
  301. package/dist/migrations/i18n.mjs.map +1 -0
  302. package/dist/migrations/index.d.ts +5 -0
  303. package/dist/migrations/index.d.ts.map +1 -0
  304. package/dist/migrations/index.js +34 -0
  305. package/dist/migrations/index.js.map +1 -0
  306. package/dist/migrations/index.mjs +31 -0
  307. package/dist/migrations/index.mjs.map +1 -0
  308. package/dist/package.json.js +186 -0
  309. package/dist/package.json.js.map +1 -0
  310. package/dist/package.json.mjs +163 -0
  311. package/dist/package.json.mjs.map +1 -0
  312. package/dist/providers/admin.d.ts.map +1 -1
  313. package/dist/providers/admin.js +27 -17
  314. package/dist/providers/admin.js.map +1 -1
  315. package/dist/providers/admin.mjs +26 -19
  316. package/dist/providers/admin.mjs.map +1 -1
  317. package/dist/providers/coreStore.js +13 -8
  318. package/dist/providers/coreStore.js.map +1 -1
  319. package/dist/providers/coreStore.mjs +12 -10
  320. package/dist/providers/coreStore.mjs.map +1 -1
  321. package/dist/providers/cron.js +19 -16
  322. package/dist/providers/cron.js.map +1 -1
  323. package/dist/providers/cron.mjs +18 -18
  324. package/dist/providers/cron.mjs.map +1 -1
  325. package/dist/providers/index.js +18 -9
  326. package/dist/providers/index.js.map +1 -1
  327. package/dist/providers/index.mjs +17 -10
  328. package/dist/providers/index.mjs.map +1 -1
  329. package/dist/providers/provider.js +4 -3
  330. package/dist/providers/provider.js.map +1 -1
  331. package/dist/providers/provider.mjs +3 -4
  332. package/dist/providers/provider.mjs.map +1 -1
  333. package/dist/providers/registries.js +37 -32
  334. package/dist/providers/registries.js.map +1 -1
  335. package/dist/providers/registries.mjs +36 -34
  336. package/dist/providers/registries.mjs.map +1 -1
  337. package/dist/providers/telemetry.js +19 -16
  338. package/dist/providers/telemetry.js.map +1 -1
  339. package/dist/providers/telemetry.mjs +18 -18
  340. package/dist/providers/telemetry.mjs.map +1 -1
  341. package/dist/providers/webhooks.js +28 -26
  342. package/dist/providers/webhooks.js.map +1 -1
  343. package/dist/providers/webhooks.mjs +27 -28
  344. package/dist/providers/webhooks.mjs.map +1 -1
  345. package/dist/registries/apis.js +23 -20
  346. package/dist/registries/apis.js.map +1 -1
  347. package/dist/registries/apis.mjs +22 -22
  348. package/dist/registries/apis.mjs.map +1 -1
  349. package/dist/registries/components.js +35 -37
  350. package/dist/registries/components.js.map +1 -1
  351. package/dist/registries/components.mjs +34 -39
  352. package/dist/registries/components.mjs.map +1 -1
  353. package/dist/registries/content-types.js +54 -59
  354. package/dist/registries/content-types.js.map +1 -1
  355. package/dist/registries/content-types.mjs +53 -61
  356. package/dist/registries/content-types.mjs.map +1 -1
  357. package/dist/registries/controllers.js +70 -71
  358. package/dist/registries/controllers.js.map +1 -1
  359. package/dist/registries/controllers.mjs +69 -73
  360. package/dist/registries/controllers.mjs.map +1 -1
  361. package/dist/registries/custom-fields.js +75 -65
  362. package/dist/registries/custom-fields.js.map +1 -1
  363. package/dist/registries/custom-fields.mjs +74 -67
  364. package/dist/registries/custom-fields.mjs.map +1 -1
  365. package/dist/registries/hooks.js +46 -49
  366. package/dist/registries/hooks.js.map +1 -1
  367. package/dist/registries/hooks.mjs +45 -51
  368. package/dist/registries/hooks.mjs.map +1 -1
  369. package/dist/registries/middlewares.js +49 -51
  370. package/dist/registries/middlewares.js.map +1 -1
  371. package/dist/registries/middlewares.mjs +48 -53
  372. package/dist/registries/middlewares.mjs.map +1 -1
  373. package/dist/registries/models.js +14 -13
  374. package/dist/registries/models.js.map +1 -1
  375. package/dist/registries/models.mjs +13 -14
  376. package/dist/registries/models.mjs.map +1 -1
  377. package/dist/registries/modules.js +39 -36
  378. package/dist/registries/modules.js.map +1 -1
  379. package/dist/registries/modules.mjs +38 -38
  380. package/dist/registries/modules.mjs.map +1 -1
  381. package/dist/registries/namespace.js +21 -20
  382. package/dist/registries/namespace.js.map +1 -1
  383. package/dist/registries/namespace.mjs +20 -23
  384. package/dist/registries/namespace.mjs.map +1 -1
  385. package/dist/registries/plugins.js +23 -20
  386. package/dist/registries/plugins.js.map +1 -1
  387. package/dist/registries/plugins.mjs +22 -22
  388. package/dist/registries/plugins.mjs.map +1 -1
  389. package/dist/registries/policies.js +103 -96
  390. package/dist/registries/policies.js.map +1 -1
  391. package/dist/registries/policies.mjs +102 -98
  392. package/dist/registries/policies.mjs.map +1 -1
  393. package/dist/registries/sanitizers.js +23 -22
  394. package/dist/registries/sanitizers.js.map +1 -1
  395. package/dist/registries/sanitizers.mjs +22 -22
  396. package/dist/registries/sanitizers.mjs.map +1 -1
  397. package/dist/registries/services.js +71 -71
  398. package/dist/registries/services.js.map +1 -1
  399. package/dist/registries/services.mjs +70 -73
  400. package/dist/registries/services.mjs.map +1 -1
  401. package/dist/registries/validators.js +23 -22
  402. package/dist/registries/validators.js.map +1 -1
  403. package/dist/registries/validators.mjs +22 -22
  404. package/dist/registries/validators.mjs.map +1 -1
  405. package/dist/services/auth/index.js +74 -74
  406. package/dist/services/auth/index.js.map +1 -1
  407. package/dist/services/auth/index.mjs +73 -74
  408. package/dist/services/auth/index.mjs.map +1 -1
  409. package/dist/services/config.js +47 -43
  410. package/dist/services/config.js.map +1 -1
  411. package/dist/services/config.mjs +46 -44
  412. package/dist/services/config.mjs.map +1 -1
  413. package/dist/services/content-api/index.d.ts +7 -3
  414. package/dist/services/content-api/index.d.ts.map +1 -1
  415. package/dist/services/content-api/index.js +80 -79
  416. package/dist/services/content-api/index.js.map +1 -1
  417. package/dist/services/content-api/index.mjs +79 -79
  418. package/dist/services/content-api/index.mjs.map +1 -1
  419. package/dist/services/content-api/permissions/engine.js +8 -5
  420. package/dist/services/content-api/permissions/engine.js.map +1 -1
  421. package/dist/services/content-api/permissions/engine.mjs +7 -5
  422. package/dist/services/content-api/permissions/engine.mjs.map +1 -1
  423. package/dist/services/content-api/permissions/index.d.ts +6 -2
  424. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  425. package/dist/services/content-api/permissions/index.js +101 -81
  426. package/dist/services/content-api/permissions/index.js.map +1 -1
  427. package/dist/services/content-api/permissions/index.mjs +100 -81
  428. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  429. package/dist/services/content-api/permissions/providers/action.d.ts +3 -1
  430. package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -1
  431. package/dist/services/content-api/permissions/providers/action.js +17 -14
  432. package/dist/services/content-api/permissions/providers/action.js.map +1 -1
  433. package/dist/services/content-api/permissions/providers/action.mjs +16 -16
  434. package/dist/services/content-api/permissions/providers/action.mjs.map +1 -1
  435. package/dist/services/content-api/permissions/providers/condition.d.ts +3 -1
  436. package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -1
  437. package/dist/services/content-api/permissions/providers/condition.js +17 -14
  438. package/dist/services/content-api/permissions/providers/condition.js.map +1 -1
  439. package/dist/services/content-api/permissions/providers/condition.mjs +16 -16
  440. package/dist/services/content-api/permissions/providers/condition.mjs.map +1 -1
  441. package/dist/services/content-source-maps.d.ts +12 -0
  442. package/dist/services/content-source-maps.d.ts.map +1 -0
  443. package/dist/services/content-source-maps.js +84 -0
  444. package/dist/services/content-source-maps.js.map +1 -0
  445. package/dist/services/content-source-maps.mjs +82 -0
  446. package/dist/services/content-source-maps.mjs.map +1 -0
  447. package/dist/services/core-store.d.ts +2 -2
  448. package/dist/services/core-store.d.ts.map +1 -1
  449. package/dist/services/core-store.js +115 -95
  450. package/dist/services/core-store.js.map +1 -1
  451. package/dist/services/core-store.mjs +114 -97
  452. package/dist/services/core-store.mjs.map +1 -1
  453. package/dist/services/cron.d.ts +3 -3
  454. package/dist/services/cron.d.ts.map +1 -1
  455. package/dist/services/cron.js +74 -60
  456. package/dist/services/cron.js.map +1 -1
  457. package/dist/services/cron.mjs +73 -62
  458. package/dist/services/cron.mjs.map +1 -1
  459. package/dist/services/custom-fields.js +9 -7
  460. package/dist/services/custom-fields.js.map +1 -1
  461. package/dist/services/custom-fields.mjs +8 -9
  462. package/dist/services/custom-fields.mjs.map +1 -1
  463. package/dist/services/document-service/attributes/index.js +23 -18
  464. package/dist/services/document-service/attributes/index.js.map +1 -1
  465. package/dist/services/document-service/attributes/index.mjs +22 -19
  466. package/dist/services/document-service/attributes/index.mjs.map +1 -1
  467. package/dist/services/document-service/attributes/transforms.js +16 -15
  468. package/dist/services/document-service/attributes/transforms.js.map +1 -1
  469. package/dist/services/document-service/attributes/transforms.mjs +15 -15
  470. package/dist/services/document-service/attributes/transforms.mjs.map +1 -1
  471. package/dist/services/document-service/common.d.ts +1 -1
  472. package/dist/services/document-service/common.d.ts.map +1 -1
  473. package/dist/services/document-service/common.js +5 -4
  474. package/dist/services/document-service/common.js.map +1 -1
  475. package/dist/services/document-service/common.mjs +4 -5
  476. package/dist/services/document-service/common.mjs.map +1 -1
  477. package/dist/services/document-service/components.d.ts.map +1 -1
  478. package/dist/services/document-service/components.js +255 -257
  479. package/dist/services/document-service/components.js.map +1 -1
  480. package/dist/services/document-service/components.mjs +254 -262
  481. package/dist/services/document-service/components.mjs.map +1 -1
  482. package/dist/services/document-service/draft-and-publish.d.ts +1 -1
  483. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  484. package/dist/services/document-service/draft-and-publish.js +88 -48
  485. package/dist/services/document-service/draft-and-publish.js.map +1 -1
  486. package/dist/services/document-service/draft-and-publish.mjs +87 -54
  487. package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
  488. package/dist/services/document-service/entries.d.ts +2 -2
  489. package/dist/services/document-service/entries.d.ts.map +1 -1
  490. package/dist/services/document-service/entries.js +151 -92
  491. package/dist/services/document-service/entries.js.map +1 -1
  492. package/dist/services/document-service/entries.mjs +150 -93
  493. package/dist/services/document-service/entries.mjs.map +1 -1
  494. package/dist/services/document-service/events.d.ts +1 -1
  495. package/dist/services/document-service/events.d.ts.map +1 -1
  496. package/dist/services/document-service/events.js +52 -40
  497. package/dist/services/document-service/events.js.map +1 -1
  498. package/dist/services/document-service/events.mjs +51 -41
  499. package/dist/services/document-service/events.mjs.map +1 -1
  500. package/dist/services/document-service/first-published-at.d.ts +7 -0
  501. package/dist/services/document-service/first-published-at.d.ts.map +1 -0
  502. package/dist/services/document-service/first-published-at.js +31 -0
  503. package/dist/services/document-service/first-published-at.js.map +1 -0
  504. package/dist/services/document-service/first-published-at.mjs +28 -0
  505. package/dist/services/document-service/first-published-at.mjs.map +1 -0
  506. package/dist/services/document-service/index.d.ts +2 -1
  507. package/dist/services/document-service/index.d.ts.map +1 -1
  508. package/dist/services/document-service/index.js +53 -32
  509. package/dist/services/document-service/index.js.map +1 -1
  510. package/dist/services/document-service/index.mjs +52 -33
  511. package/dist/services/document-service/index.mjs.map +1 -1
  512. package/dist/services/document-service/internationalization.d.ts +6 -1
  513. package/dist/services/document-service/internationalization.d.ts.map +1 -1
  514. package/dist/services/document-service/internationalization.js +94 -46
  515. package/dist/services/document-service/internationalization.js.map +1 -1
  516. package/dist/services/document-service/internationalization.mjs +92 -50
  517. package/dist/services/document-service/internationalization.mjs.map +1 -1
  518. package/dist/services/document-service/middlewares/errors.js +23 -19
  519. package/dist/services/document-service/middlewares/errors.js.map +1 -1
  520. package/dist/services/document-service/middlewares/errors.mjs +22 -20
  521. package/dist/services/document-service/middlewares/errors.mjs.map +1 -1
  522. package/dist/services/document-service/middlewares/middleware-manager.js +46 -44
  523. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -1
  524. package/dist/services/document-service/middlewares/middleware-manager.mjs +45 -45
  525. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -1
  526. package/dist/services/document-service/params.js +11 -5
  527. package/dist/services/document-service/params.js.map +1 -1
  528. package/dist/services/document-service/params.mjs +10 -6
  529. package/dist/services/document-service/params.mjs.map +1 -1
  530. package/dist/services/document-service/repository.d.ts.map +1 -1
  531. package/dist/services/document-service/repository.js +359 -269
  532. package/dist/services/document-service/repository.js.map +1 -1
  533. package/dist/services/document-service/repository.mjs +358 -270
  534. package/dist/services/document-service/repository.mjs.map +1 -1
  535. package/dist/services/document-service/transform/data.js +22 -12
  536. package/dist/services/document-service/transform/data.js.map +1 -1
  537. package/dist/services/document-service/transform/data.mjs +21 -13
  538. package/dist/services/document-service/transform/data.mjs.map +1 -1
  539. package/dist/services/document-service/transform/fields.js +26 -17
  540. package/dist/services/document-service/transform/fields.js.map +1 -1
  541. package/dist/services/document-service/transform/fields.mjs +25 -18
  542. package/dist/services/document-service/transform/fields.mjs.map +1 -1
  543. package/dist/services/document-service/transform/id-map.d.ts +1 -1
  544. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  545. package/dist/services/document-service/transform/id-map.js +116 -69
  546. package/dist/services/document-service/transform/id-map.js.map +1 -1
  547. package/dist/services/document-service/transform/id-map.mjs +115 -70
  548. package/dist/services/document-service/transform/id-map.mjs.map +1 -1
  549. package/dist/services/document-service/transform/id-transform.d.ts +1 -1
  550. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  551. package/dist/services/document-service/transform/id-transform.js +37 -29
  552. package/dist/services/document-service/transform/id-transform.js.map +1 -1
  553. package/dist/services/document-service/transform/id-transform.mjs +36 -30
  554. package/dist/services/document-service/transform/id-transform.mjs.map +1 -1
  555. package/dist/services/document-service/transform/populate.js +23 -18
  556. package/dist/services/document-service/transform/populate.js.map +1 -1
  557. package/dist/services/document-service/transform/populate.mjs +22 -19
  558. package/dist/services/document-service/transform/populate.mjs.map +1 -1
  559. package/dist/services/document-service/transform/query.js +11 -6
  560. package/dist/services/document-service/transform/query.js.map +1 -1
  561. package/dist/services/document-service/transform/query.mjs +10 -7
  562. package/dist/services/document-service/transform/query.mjs.map +1 -1
  563. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +1 -1
  564. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  565. package/dist/services/document-service/transform/relations/extract/data-ids.js +71 -48
  566. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
  567. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +70 -49
  568. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
  569. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  570. package/dist/services/document-service/transform/relations/transform/data-ids.js +97 -63
  571. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
  572. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +96 -64
  573. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
  574. package/dist/services/document-service/transform/relations/transform/default-locale.js +47 -29
  575. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -1
  576. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +46 -30
  577. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -1
  578. package/dist/services/document-service/transform/relations/utils/dp.d.ts +1 -1
  579. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  580. package/dist/services/document-service/transform/relations/utils/dp.js +52 -26
  581. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -1
  582. package/dist/services/document-service/transform/relations/utils/dp.mjs +51 -27
  583. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -1
  584. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +1 -1
  585. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  586. package/dist/services/document-service/transform/relations/utils/i18n.js +20 -18
  587. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
  588. package/dist/services/document-service/transform/relations/utils/i18n.mjs +19 -21
  589. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
  590. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -1
  591. package/dist/services/document-service/transform/relations/utils/map-relation.js +116 -77
  592. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -1
  593. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +115 -79
  594. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -1
  595. package/dist/services/document-service/utils/bidirectional-relations.d.ts +95 -0
  596. package/dist/services/document-service/utils/bidirectional-relations.d.ts.map +1 -0
  597. package/dist/services/document-service/utils/bidirectional-relations.js +148 -0
  598. package/dist/services/document-service/utils/bidirectional-relations.js.map +1 -0
  599. package/dist/services/document-service/utils/bidirectional-relations.mjs +145 -0
  600. package/dist/services/document-service/utils/bidirectional-relations.mjs.map +1 -0
  601. package/dist/services/document-service/utils/populate.d.ts +1 -1
  602. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  603. package/dist/services/document-service/utils/populate.js +67 -41
  604. package/dist/services/document-service/utils/populate.js.map +1 -1
  605. package/dist/services/document-service/utils/populate.mjs +66 -42
  606. package/dist/services/document-service/utils/populate.mjs.map +1 -1
  607. package/dist/services/document-service/utils/unidirectional-relations.d.ts +36 -0
  608. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -0
  609. package/dist/services/document-service/utils/unidirectional-relations.js +116 -0
  610. package/dist/services/document-service/utils/unidirectional-relations.js.map +1 -0
  611. package/dist/services/document-service/utils/unidirectional-relations.mjs +113 -0
  612. package/dist/services/document-service/utils/unidirectional-relations.mjs.map +1 -0
  613. package/dist/services/entity-service/index.js +230 -161
  614. package/dist/services/entity-service/index.js.map +1 -1
  615. package/dist/services/entity-service/index.mjs +229 -160
  616. package/dist/services/entity-service/index.mjs.map +1 -1
  617. package/dist/services/entity-validator/blocks-validator.js +135 -103
  618. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  619. package/dist/services/entity-validator/blocks-validator.mjs +134 -104
  620. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  621. package/dist/services/entity-validator/index.d.ts +1 -1
  622. package/dist/services/entity-validator/index.d.ts.map +1 -1
  623. package/dist/services/entity-validator/index.js +370 -362
  624. package/dist/services/entity-validator/index.js.map +1 -1
  625. package/dist/services/entity-validator/index.mjs +366 -359
  626. package/dist/services/entity-validator/index.mjs.map +1 -1
  627. package/dist/services/entity-validator/validators.d.ts +1 -0
  628. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  629. package/dist/services/entity-validator/validators.js +270 -209
  630. package/dist/services/entity-validator/validators.js.map +1 -1
  631. package/dist/services/entity-validator/validators.mjs +269 -215
  632. package/dist/services/entity-validator/validators.mjs.map +1 -1
  633. package/dist/services/errors.js +65 -65
  634. package/dist/services/errors.js.map +1 -1
  635. package/dist/services/errors.mjs +64 -66
  636. package/dist/services/errors.mjs.map +1 -1
  637. package/dist/services/event-hub.js +82 -69
  638. package/dist/services/event-hub.js.map +1 -1
  639. package/dist/services/event-hub.mjs +81 -71
  640. package/dist/services/event-hub.mjs.map +1 -1
  641. package/dist/services/features.js +19 -14
  642. package/dist/services/features.js.map +1 -1
  643. package/dist/services/features.mjs +18 -15
  644. package/dist/services/features.mjs.map +1 -1
  645. package/dist/services/fs.js +41 -40
  646. package/dist/services/fs.js.map +1 -1
  647. package/dist/services/fs.mjs +40 -39
  648. package/dist/services/fs.mjs.map +1 -1
  649. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  650. package/dist/services/metrics/admin-user-hash.js +13 -11
  651. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  652. package/dist/services/metrics/admin-user-hash.mjs +12 -10
  653. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  654. package/dist/services/metrics/index.d.ts +1 -1
  655. package/dist/services/metrics/index.d.ts.map +1 -1
  656. package/dist/services/metrics/index.js +47 -40
  657. package/dist/services/metrics/index.js.map +1 -1
  658. package/dist/services/metrics/index.mjs +46 -42
  659. package/dist/services/metrics/index.mjs.map +1 -1
  660. package/dist/services/metrics/is-truthy.js +13 -6
  661. package/dist/services/metrics/is-truthy.js.map +1 -1
  662. package/dist/services/metrics/is-truthy.mjs +12 -6
  663. package/dist/services/metrics/is-truthy.mjs.map +1 -1
  664. package/dist/services/metrics/middleware.d.ts.map +1 -1
  665. package/dist/services/metrics/middleware.js +37 -22
  666. package/dist/services/metrics/middleware.js.map +1 -1
  667. package/dist/services/metrics/middleware.mjs +36 -24
  668. package/dist/services/metrics/middleware.mjs.map +1 -1
  669. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  670. package/dist/services/metrics/rate-limiter.js +24 -19
  671. package/dist/services/metrics/rate-limiter.js.map +1 -1
  672. package/dist/services/metrics/rate-limiter.mjs +23 -21
  673. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  674. package/dist/services/metrics/sender.d.ts.map +1 -1
  675. package/dist/services/metrics/sender.js +78 -69
  676. package/dist/services/metrics/sender.js.map +1 -1
  677. package/dist/services/metrics/sender.mjs +77 -64
  678. package/dist/services/metrics/sender.mjs.map +1 -1
  679. package/dist/services/query-params.js +13 -10
  680. package/dist/services/query-params.js.map +1 -1
  681. package/dist/services/query-params.mjs +12 -12
  682. package/dist/services/query-params.mjs.map +1 -1
  683. package/dist/services/reloader.js +35 -32
  684. package/dist/services/reloader.js.map +1 -1
  685. package/dist/services/reloader.mjs +34 -33
  686. package/dist/services/reloader.mjs.map +1 -1
  687. package/dist/services/request-context.js +11 -8
  688. package/dist/services/request-context.js.map +1 -1
  689. package/dist/services/request-context.mjs +10 -10
  690. package/dist/services/request-context.mjs.map +1 -1
  691. package/dist/services/server/admin-api.js +11 -10
  692. package/dist/services/server/admin-api.js.map +1 -1
  693. package/dist/services/server/admin-api.mjs +10 -11
  694. package/dist/services/server/admin-api.mjs.map +1 -1
  695. package/dist/services/server/api.js +33 -27
  696. package/dist/services/server/api.js.map +1 -1
  697. package/dist/services/server/api.mjs +32 -26
  698. package/dist/services/server/api.mjs.map +1 -1
  699. package/dist/services/server/compose-endpoint.js +116 -105
  700. package/dist/services/server/compose-endpoint.js.map +1 -1
  701. package/dist/services/server/compose-endpoint.mjs +115 -105
  702. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  703. package/dist/services/server/content-api.js +11 -9
  704. package/dist/services/server/content-api.js.map +1 -1
  705. package/dist/services/server/content-api.mjs +10 -10
  706. package/dist/services/server/content-api.mjs.map +1 -1
  707. package/dist/services/server/http-server.js +48 -44
  708. package/dist/services/server/http-server.js.map +1 -1
  709. package/dist/services/server/http-server.mjs +47 -43
  710. package/dist/services/server/http-server.mjs.map +1 -1
  711. package/dist/services/server/index.js +85 -82
  712. package/dist/services/server/index.js.map +1 -1
  713. package/dist/services/server/index.mjs +84 -81
  714. package/dist/services/server/index.mjs.map +1 -1
  715. package/dist/services/server/koa.js +49 -47
  716. package/dist/services/server/koa.js.map +1 -1
  717. package/dist/services/server/koa.mjs +48 -44
  718. package/dist/services/server/koa.mjs.map +1 -1
  719. package/dist/services/server/middleware.js +86 -82
  720. package/dist/services/server/middleware.js.map +1 -1
  721. package/dist/services/server/middleware.mjs +85 -82
  722. package/dist/services/server/middleware.mjs.map +1 -1
  723. package/dist/services/server/policy.js +24 -17
  724. package/dist/services/server/policy.js.map +1 -1
  725. package/dist/services/server/policy.mjs +23 -18
  726. package/dist/services/server/policy.mjs.map +1 -1
  727. package/dist/services/server/register-middlewares.js +68 -61
  728. package/dist/services/server/register-middlewares.js.map +1 -1
  729. package/dist/services/server/register-middlewares.mjs +67 -63
  730. package/dist/services/server/register-middlewares.mjs.map +1 -1
  731. package/dist/services/server/register-routes.js +109 -66
  732. package/dist/services/server/register-routes.js.map +1 -1
  733. package/dist/services/server/register-routes.mjs +108 -66
  734. package/dist/services/server/register-routes.mjs.map +1 -1
  735. package/dist/services/server/routing.d.ts +10 -0
  736. package/dist/services/server/routing.d.ts.map +1 -1
  737. package/dist/services/server/routing.js +100 -81
  738. package/dist/services/server/routing.js.map +1 -1
  739. package/dist/services/server/routing.mjs +99 -81
  740. package/dist/services/server/routing.mjs.map +1 -1
  741. package/dist/services/utils/conditional-fields.d.ts +3 -0
  742. package/dist/services/utils/conditional-fields.d.ts.map +1 -0
  743. package/dist/services/utils/conditional-fields.js +22 -0
  744. package/dist/services/utils/conditional-fields.js.map +1 -0
  745. package/dist/services/utils/conditional-fields.mjs +20 -0
  746. package/dist/services/utils/conditional-fields.mjs.map +1 -0
  747. package/dist/services/utils/dynamic-zones.js +13 -14
  748. package/dist/services/utils/dynamic-zones.js.map +1 -1
  749. package/dist/services/utils/dynamic-zones.mjs +12 -16
  750. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  751. package/dist/services/webhook-runner.js +124 -122
  752. package/dist/services/webhook-runner.js.map +1 -1
  753. package/dist/services/webhook-runner.mjs +123 -121
  754. package/dist/services/webhook-runner.mjs.map +1 -1
  755. package/dist/services/webhook-store.js +132 -99
  756. package/dist/services/webhook-store.js.map +1 -1
  757. package/dist/services/webhook-store.mjs +131 -101
  758. package/dist/services/webhook-store.mjs.map +1 -1
  759. package/dist/services/worker-queue.js +44 -49
  760. package/dist/services/worker-queue.js.map +1 -1
  761. package/dist/services/worker-queue.mjs +43 -49
  762. package/dist/services/worker-queue.mjs.map +1 -1
  763. package/dist/utils/convert-custom-field-type.js +17 -20
  764. package/dist/utils/convert-custom-field-type.js.map +1 -1
  765. package/dist/utils/convert-custom-field-type.mjs +16 -21
  766. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  767. package/dist/utils/cron.js +64 -30
  768. package/dist/utils/cron.js.map +1 -1
  769. package/dist/utils/cron.mjs +63 -31
  770. package/dist/utils/cron.mjs.map +1 -1
  771. package/dist/utils/fetch.d.ts +5 -1
  772. package/dist/utils/fetch.d.ts.map +1 -1
  773. package/dist/utils/fetch.js +28 -18
  774. package/dist/utils/fetch.js.map +1 -1
  775. package/dist/utils/fetch.mjs +27 -19
  776. package/dist/utils/fetch.mjs.map +1 -1
  777. package/dist/utils/filepath-to-prop-path.js +20 -28
  778. package/dist/utils/filepath-to-prop-path.js.map +1 -1
  779. package/dist/utils/filepath-to-prop-path.mjs +19 -26
  780. package/dist/utils/filepath-to-prop-path.mjs.map +1 -1
  781. package/dist/utils/is-initialized.js +21 -12
  782. package/dist/utils/is-initialized.js.map +1 -1
  783. package/dist/utils/is-initialized.mjs +20 -13
  784. package/dist/utils/is-initialized.mjs.map +1 -1
  785. package/dist/utils/lifecycles.js +6 -5
  786. package/dist/utils/lifecycles.js.map +1 -1
  787. package/dist/utils/lifecycles.mjs +5 -6
  788. package/dist/utils/lifecycles.mjs.map +1 -1
  789. package/dist/utils/load-config-file.js +40 -38
  790. package/dist/utils/load-config-file.js.map +1 -1
  791. package/dist/utils/load-config-file.mjs +39 -36
  792. package/dist/utils/load-config-file.mjs.map +1 -1
  793. package/dist/utils/load-files.js +40 -35
  794. package/dist/utils/load-files.js.map +1 -1
  795. package/dist/utils/load-files.mjs +39 -32
  796. package/dist/utils/load-files.mjs.map +1 -1
  797. package/dist/utils/open-browser.js +8 -8
  798. package/dist/utils/open-browser.js.map +1 -1
  799. package/dist/utils/open-browser.mjs +7 -7
  800. package/dist/utils/open-browser.mjs.map +1 -1
  801. package/dist/utils/resolve-working-dirs.js +23 -10
  802. package/dist/utils/resolve-working-dirs.js.map +1 -1
  803. package/dist/utils/resolve-working-dirs.mjs +22 -9
  804. package/dist/utils/resolve-working-dirs.mjs.map +1 -1
  805. package/dist/utils/signals.js +20 -14
  806. package/dist/utils/signals.js.map +1 -1
  807. package/dist/utils/signals.mjs +19 -15
  808. package/dist/utils/signals.mjs.map +1 -1
  809. package/dist/utils/startup-logger.d.ts.map +1 -1
  810. package/dist/utils/startup-logger.js +107 -78
  811. package/dist/utils/startup-logger.js.map +1 -1
  812. package/dist/utils/startup-logger.mjs +106 -75
  813. package/dist/utils/startup-logger.mjs.map +1 -1
  814. package/dist/utils/transform-content-types-to-models.d.ts +550 -21
  815. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  816. package/dist/utils/transform-content-types-to-models.js +350 -261
  817. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  818. package/dist/utils/transform-content-types-to-models.mjs +349 -269
  819. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  820. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  821. package/dist/utils/update-notifier/index.js +68 -73
  822. package/dist/utils/update-notifier/index.js.map +1 -1
  823. package/dist/utils/update-notifier/index.mjs +67 -67
  824. package/dist/utils/update-notifier/index.mjs.map +1 -1
  825. package/package.json +35 -31
@@ -1,12 +1,13 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const responseTime = () => {
4
- return async (ctx, next) => {
5
- const start = Date.now();
6
- await next();
7
- const delta = Math.ceil(Date.now() - start);
8
- ctx.set("X-Response-Time", `${delta}ms`);
9
- };
1
+ 'use strict';
2
+
3
+ const responseTime = ()=>{
4
+ return async (ctx, next)=>{
5
+ const start = Date.now();
6
+ await next();
7
+ const delta = Math.ceil(Date.now() - start);
8
+ ctx.set('X-Response-Time', `${delta}ms`);
9
+ };
10
10
  };
11
+
11
12
  exports.responseTime = responseTime;
12
13
  //# sourceMappingURL=response-time.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"response-time.js","sources":["../../src/middlewares/response-time.ts"],"sourcesContent":["import type { Core } from '@strapi/types';\n\nexport const responseTime: Core.MiddlewareFactory = () => {\n return async (ctx, next) => {\n const start = Date.now();\n\n await next();\n\n const delta = Math.ceil(Date.now() - start);\n ctx.set('X-Response-Time', `${delta}ms`);\n };\n};\n"],"names":[],"mappings":";;AAEO,MAAM,eAAuC,MAAM;AACjD,SAAA,OAAO,KAAK,SAAS;AACpB,UAAA,QAAQ,KAAK;AAEnB,UAAM,KAAK;AAEX,UAAM,QAAQ,KAAK,KAAK,KAAK,IAAA,IAAQ,KAAK;AAC1C,QAAI,IAAI,mBAAmB,GAAG,KAAK,IAAI;AAAA,EAAA;AAE3C;;"}
1
+ {"version":3,"file":"response-time.js","sources":["../../src/middlewares/response-time.ts"],"sourcesContent":["import type { Core } from '@strapi/types';\n\nexport const responseTime: Core.MiddlewareFactory = () => {\n return async (ctx, next) => {\n const start = Date.now();\n\n await next();\n\n const delta = Math.ceil(Date.now() - start);\n ctx.set('X-Response-Time', `${delta}ms`);\n };\n};\n"],"names":["responseTime","ctx","next","start","Date","now","delta","Math","ceil","set"],"mappings":";;MAEaA,YAAuC,GAAA,IAAA;AAClD,IAAA,OAAO,OAAOC,GAAKC,EAAAA,IAAAA,GAAAA;QACjB,MAAMC,KAAAA,GAAQC,KAAKC,GAAG,EAAA;QAEtB,MAAMH,IAAAA,EAAAA;AAEN,QAAA,MAAMI,QAAQC,IAAKC,CAAAA,IAAI,CAACJ,IAAAA,CAAKC,GAAG,EAAKF,GAAAA,KAAAA,CAAAA;AACrCF,QAAAA,GAAAA,CAAIQ,GAAG,CAAC,iBAAA,EAAmB,CAAC,EAAEH,KAAAA,CAAM,EAAE,CAAC,CAAA;AACzC,KAAA;AACF;;;;"}
@@ -1,12 +1,11 @@
1
- const responseTime = () => {
2
- return async (ctx, next) => {
3
- const start = Date.now();
4
- await next();
5
- const delta = Math.ceil(Date.now() - start);
6
- ctx.set("X-Response-Time", `${delta}ms`);
7
- };
8
- };
9
- export {
10
- responseTime
1
+ const responseTime = ()=>{
2
+ return async (ctx, next)=>{
3
+ const start = Date.now();
4
+ await next();
5
+ const delta = Math.ceil(Date.now() - start);
6
+ ctx.set('X-Response-Time', `${delta}ms`);
7
+ };
11
8
  };
9
+
10
+ export { responseTime };
12
11
  //# sourceMappingURL=response-time.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"response-time.mjs","sources":["../../src/middlewares/response-time.ts"],"sourcesContent":["import type { Core } from '@strapi/types';\n\nexport const responseTime: Core.MiddlewareFactory = () => {\n return async (ctx, next) => {\n const start = Date.now();\n\n await next();\n\n const delta = Math.ceil(Date.now() - start);\n ctx.set('X-Response-Time', `${delta}ms`);\n };\n};\n"],"names":[],"mappings":"AAEO,MAAM,eAAuC,MAAM;AACjD,SAAA,OAAO,KAAK,SAAS;AACpB,UAAA,QAAQ,KAAK;AAEnB,UAAM,KAAK;AAEX,UAAM,QAAQ,KAAK,KAAK,KAAK,IAAA,IAAQ,KAAK;AAC1C,QAAI,IAAI,mBAAmB,GAAG,KAAK,IAAI;AAAA,EAAA;AAE3C;"}
1
+ {"version":3,"file":"response-time.mjs","sources":["../../src/middlewares/response-time.ts"],"sourcesContent":["import type { Core } from '@strapi/types';\n\nexport const responseTime: Core.MiddlewareFactory = () => {\n return async (ctx, next) => {\n const start = Date.now();\n\n await next();\n\n const delta = Math.ceil(Date.now() - start);\n ctx.set('X-Response-Time', `${delta}ms`);\n };\n};\n"],"names":["responseTime","ctx","next","start","Date","now","delta","Math","ceil","set"],"mappings":"MAEaA,YAAuC,GAAA,IAAA;AAClD,IAAA,OAAO,OAAOC,GAAKC,EAAAA,IAAAA,GAAAA;QACjB,MAAMC,KAAAA,GAAQC,KAAKC,GAAG,EAAA;QAEtB,MAAMH,IAAAA,EAAAA;AAEN,QAAA,MAAMI,QAAQC,IAAKC,CAAAA,IAAI,CAACJ,IAAAA,CAAKC,GAAG,EAAKF,GAAAA,KAAAA,CAAAA;AACrCF,QAAAA,GAAAA,CAAIQ,GAAG,CAAC,iBAAA,EAAmB,CAAC,EAAEH,KAAAA,CAAM,EAAE,CAAC,CAAA;AACzC,KAAA;AACF;;;;"}
@@ -1,15 +1,17 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const fp = require("lodash/fp");
4
- const responses = (config = {}) => {
5
- return async (ctx, next) => {
6
- await next();
7
- const { status } = ctx;
8
- const handler = config?.handlers?.[status];
9
- if (fp.isFunction(handler)) {
10
- await handler(ctx, next);
11
- }
12
- };
1
+ 'use strict';
2
+
3
+ var fp = require('lodash/fp');
4
+
5
+ const responses = (config = {})=>{
6
+ return async (ctx, next)=>{
7
+ await next();
8
+ const { status } = ctx;
9
+ const handler = config?.handlers?.[status];
10
+ if (fp.isFunction(handler)) {
11
+ await handler(ctx, next);
12
+ }
13
+ };
13
14
  };
15
+
14
16
  exports.responses = responses;
15
17
  //# sourceMappingURL=responses.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"responses.js","sources":["../../src/middlewares/responses.ts"],"sourcesContent":["import { isFunction } from 'lodash/fp';\nimport type { Core } from '@strapi/types';\n\nexport interface Config {\n handlers?: Record<number, Core.MiddlewareHandler>;\n}\n\nexport const responses: Core.MiddlewareFactory<Config> = (config = {}) => {\n return async (ctx, next) => {\n await next();\n\n const { status } = ctx;\n const handler = config?.handlers?.[status];\n\n if (isFunction(handler)) {\n await handler(ctx, next);\n }\n };\n};\n"],"names":["isFunction"],"mappings":";;;AAOO,MAAM,YAA4C,CAAC,SAAS,OAAO;AACjE,SAAA,OAAO,KAAK,SAAS;AAC1B,UAAM,KAAK;AAEL,UAAA,EAAE,OAAW,IAAA;AACb,UAAA,UAAU,QAAQ,WAAW,MAAM;AAErC,QAAAA,GAAAA,WAAW,OAAO,GAAG;AACjB,YAAA,QAAQ,KAAK,IAAI;AAAA,IACzB;AAAA,EAAA;AAEJ;;"}
1
+ {"version":3,"file":"responses.js","sources":["../../src/middlewares/responses.ts"],"sourcesContent":["import { isFunction } from 'lodash/fp';\nimport type { Core } from '@strapi/types';\n\nexport interface Config {\n handlers?: Record<number, Core.MiddlewareHandler>;\n}\n\nexport const responses: Core.MiddlewareFactory<Config> = (config = {}) => {\n return async (ctx, next) => {\n await next();\n\n const { status } = ctx;\n const handler = config?.handlers?.[status];\n\n if (isFunction(handler)) {\n await handler(ctx, next);\n }\n };\n};\n"],"names":["responses","config","ctx","next","status","handler","handlers","isFunction"],"mappings":";;;;AAOaA,MAAAA,SAAAA,GAA4C,CAACC,MAAAA,GAAS,EAAE,GAAA;AACnE,IAAA,OAAO,OAAOC,GAAKC,EAAAA,IAAAA,GAAAA;QACjB,MAAMA,IAAAA,EAAAA;QAEN,MAAM,EAAEC,MAAM,EAAE,GAAGF,GAAAA;AACnB,QAAA,MAAMG,OAAUJ,GAAAA,MAAAA,EAAQK,QAAU,GAACF,MAAO,CAAA;AAE1C,QAAA,IAAIG,cAAWF,OAAU,CAAA,EAAA;AACvB,YAAA,MAAMA,QAAQH,GAAKC,EAAAA,IAAAA,CAAAA;AACrB;AACF,KAAA;AACF;;;;"}
@@ -1,15 +1,15 @@
1
- import { isFunction } from "lodash/fp";
2
- const responses = (config = {}) => {
3
- return async (ctx, next) => {
4
- await next();
5
- const { status } = ctx;
6
- const handler = config?.handlers?.[status];
7
- if (isFunction(handler)) {
8
- await handler(ctx, next);
9
- }
10
- };
11
- };
12
- export {
13
- responses
1
+ import { isFunction } from 'lodash/fp';
2
+
3
+ const responses = (config = {})=>{
4
+ return async (ctx, next)=>{
5
+ await next();
6
+ const { status } = ctx;
7
+ const handler = config?.handlers?.[status];
8
+ if (isFunction(handler)) {
9
+ await handler(ctx, next);
10
+ }
11
+ };
14
12
  };
13
+
14
+ export { responses };
15
15
  //# sourceMappingURL=responses.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"responses.mjs","sources":["../../src/middlewares/responses.ts"],"sourcesContent":["import { isFunction } from 'lodash/fp';\nimport type { Core } from '@strapi/types';\n\nexport interface Config {\n handlers?: Record<number, Core.MiddlewareHandler>;\n}\n\nexport const responses: Core.MiddlewareFactory<Config> = (config = {}) => {\n return async (ctx, next) => {\n await next();\n\n const { status } = ctx;\n const handler = config?.handlers?.[status];\n\n if (isFunction(handler)) {\n await handler(ctx, next);\n }\n };\n};\n"],"names":[],"mappings":";AAOO,MAAM,YAA4C,CAAC,SAAS,OAAO;AACjE,SAAA,OAAO,KAAK,SAAS;AAC1B,UAAM,KAAK;AAEL,UAAA,EAAE,OAAW,IAAA;AACb,UAAA,UAAU,QAAQ,WAAW,MAAM;AAErC,QAAA,WAAW,OAAO,GAAG;AACjB,YAAA,QAAQ,KAAK,IAAI;AAAA,IACzB;AAAA,EAAA;AAEJ;"}
1
+ {"version":3,"file":"responses.mjs","sources":["../../src/middlewares/responses.ts"],"sourcesContent":["import { isFunction } from 'lodash/fp';\nimport type { Core } from '@strapi/types';\n\nexport interface Config {\n handlers?: Record<number, Core.MiddlewareHandler>;\n}\n\nexport const responses: Core.MiddlewareFactory<Config> = (config = {}) => {\n return async (ctx, next) => {\n await next();\n\n const { status } = ctx;\n const handler = config?.handlers?.[status];\n\n if (isFunction(handler)) {\n await handler(ctx, next);\n }\n };\n};\n"],"names":["responses","config","ctx","next","status","handler","handlers","isFunction"],"mappings":";;AAOaA,MAAAA,SAAAA,GAA4C,CAACC,MAAAA,GAAS,EAAE,GAAA;AACnE,IAAA,OAAO,OAAOC,GAAKC,EAAAA,IAAAA,GAAAA;QACjB,MAAMA,IAAAA,EAAAA;QAEN,MAAM,EAAEC,MAAM,EAAE,GAAGF,GAAAA;AACnB,QAAA,MAAMG,OAAUJ,GAAAA,MAAAA,EAAQK,QAAU,GAACF,MAAO,CAAA;AAE1C,QAAA,IAAIG,WAAWF,OAAU,CAAA,EAAA;AACvB,YAAA,MAAMA,QAAQH,GAAKC,EAAAA,IAAAA,CAAAA;AACrB;AACF,KAAA;AACF;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"security.d.ts","sourceRoot":"","sources":["../../src/middlewares/security.ts"],"names":[],"mappings":"AACA,OAAe,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAE/C,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAE1C,MAAM,MAAM,MAAM,GAAG,WAAW,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAkC3D,eAAO,MAAM,QAAQ,EAAE,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAkEjD,CAAC"}
1
+ {"version":3,"file":"security.d.ts","sourceRoot":"","sources":["../../src/middlewares/security.ts"],"names":[],"mappings":"AACA,OAAe,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAE/C,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAE1C,MAAM,MAAM,MAAM,GAAG,WAAW,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAkC3D,eAAO,MAAM,QAAQ,EAAE,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAmEjD,CAAC"}
@@ -1,78 +1,116 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const fp = 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
+
7
6
  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
7
+ crossOriginEmbedderPolicy: false,
8
+ crossOriginOpenerPolicy: false,
9
+ crossOriginResourcePolicy: false,
10
+ originAgentCluster: false,
11
+ contentSecurityPolicy: {
12
+ useDefaults: true,
13
+ directives: {
14
+ 'connect-src': [
15
+ "'self'",
16
+ 'https:'
17
+ ],
18
+ 'img-src': [
19
+ "'self'",
20
+ 'data:',
21
+ 'blob:',
22
+ 'https://market-assets.strapi.io'
23
+ ],
24
+ 'media-src': [
25
+ "'self'",
26
+ 'data:',
27
+ 'blob:'
28
+ ],
29
+ upgradeInsecureRequests: null
30
+ }
31
+ },
32
+ xssFilter: false,
33
+ hsts: {
34
+ maxAge: 31536000,
35
+ includeSubDomains: true
36
+ },
37
+ frameguard: {
38
+ action: 'sameorigin'
19
39
  }
20
- },
21
- xssFilter: false,
22
- hsts: {
23
- maxAge: 31536e3,
24
- includeSubDomains: true
25
- },
26
- frameguard: {
27
- action: "sameorigin"
28
- }
29
40
  };
30
- const mergeConfig = (existingConfig, newConfig) => {
31
- return fp.mergeWith(
32
- (obj, src) => Array.isArray(obj) && Array.isArray(src) ? obj.concat(src) : void 0,
33
- existingConfig,
34
- newConfig
35
- );
41
+ const mergeConfig = (existingConfig, newConfig)=>{
42
+ return fp.mergeWith((obj, src)=>Array.isArray(obj) && Array.isArray(src) ? obj.concat(src) : undefined, existingConfig, newConfig);
36
43
  };
37
- const security = (config, { strapi }) => (ctx, next) => {
38
- let helmetConfig = fp.defaultsDeep(defaults, config);
39
- const specialPaths = ["/documentation"];
40
- const directives = {
41
- "script-src": ["'self'", "'unsafe-inline'", "cdn.jsdelivr.net"],
42
- "img-src": ["'self'", "data:", "cdn.jsdelivr.net", "strapi.io"],
43
- "manifest-src": [],
44
- "frame-src": []
45
- };
46
- if (strapi.plugin("graphql")?.service("utils").playground.isEnabled()) {
47
- const { config: gqlConfig } = strapi.plugin("graphql");
48
- specialPaths.push(gqlConfig("endpoint"));
49
- directives["script-src"].push(`https: 'unsafe-inline'`);
50
- directives["img-src"].push(`'apollo-server-landing-page.cdn.apollographql.com'`);
51
- directives["manifest-src"].push(`'self'`);
52
- directives["manifest-src"].push("apollo-server-landing-page.cdn.apollographql.com");
53
- directives["frame-src"].push(`'self'`);
54
- directives["frame-src"].push("sandbox.embed.apollographql.com");
55
- }
56
- if (ctx.method === "GET" && specialPaths.some((str) => ctx.path.startsWith(str))) {
57
- helmetConfig = mergeConfig(helmetConfig, {
58
- crossOriginEmbedderPolicy: false,
59
- // TODO: only use this for graphql playground
60
- contentSecurityPolicy: {
61
- directives
62
- }
63
- });
64
- }
65
- if (["development", "test"].includes(process.env.NODE_ENV ?? "") && ctx.method === "GET" && ["/admin"].some((str) => ctx.path.startsWith(str))) {
66
- helmetConfig = mergeConfig(helmetConfig, {
67
- contentSecurityPolicy: {
68
- directives: {
69
- "script-src": ["'self'", "'unsafe-inline'"],
70
- "connect-src": ["'self'", "http:", "https:", "ws:"]
44
+ const security = (config, { strapi })=>(ctx, next)=>{
45
+ let helmetConfig = fp.defaultsDeep(defaults, config);
46
+ const specialPaths = [
47
+ '/documentation'
48
+ ];
49
+ const directives = {
50
+ 'script-src': [
51
+ "'self'",
52
+ "'unsafe-inline'",
53
+ 'cdn.jsdelivr.net'
54
+ ],
55
+ 'img-src': [
56
+ "'self'",
57
+ 'data:',
58
+ 'cdn.jsdelivr.net',
59
+ 'strapi.io'
60
+ ],
61
+ 'manifest-src': [],
62
+ 'frame-src': []
63
+ };
64
+ // if apollo graphql playground is enabled, add exceptions for it
65
+ if (strapi.plugin('graphql')?.service('utils').playground.isEnabled()) {
66
+ const { config: gqlConfig } = strapi.plugin('graphql');
67
+ specialPaths.push(gqlConfig('endpoint'));
68
+ directives['script-src'].push(`https: 'unsafe-inline'`);
69
+ directives['img-src'].push(`'apollo-server-landing-page.cdn.apollographql.com'`);
70
+ directives['manifest-src'].push(`'self'`);
71
+ directives['manifest-src'].push('apollo-server-landing-page.cdn.apollographql.com');
72
+ directives['frame-src'].push(`'self'`);
73
+ directives['frame-src'].push('sandbox.embed.apollographql.com');
71
74
  }
72
- }
73
- });
74
- }
75
- return helmet__default.default(helmetConfig)(ctx, next);
76
- };
75
+ // 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
76
+ if (ctx.method === 'GET' && specialPaths.some((str)=>ctx.path.startsWith(str))) {
77
+ helmetConfig = mergeConfig(helmetConfig, {
78
+ crossOriginEmbedderPolicy: false,
79
+ contentSecurityPolicy: {
80
+ directives
81
+ }
82
+ });
83
+ }
84
+ /**
85
+ * These are for vite's watch mode so it can accurately
86
+ * connect to the HMR websocket & reconnect on failure
87
+ * or when the server restarts.
88
+ *
89
+ * It only applies in development, and only on GET requests
90
+ * that are part of the admin route.
91
+ */ if ([
92
+ 'development',
93
+ 'test'
94
+ ].includes(process.env.NODE_ENV ?? '') && ctx.method === 'GET' && ctx.path.startsWith(strapi.config.get('admin.path'))) {
95
+ helmetConfig = mergeConfig(helmetConfig, {
96
+ contentSecurityPolicy: {
97
+ directives: {
98
+ 'script-src': [
99
+ "'self'",
100
+ "'unsafe-inline'"
101
+ ],
102
+ 'connect-src': [
103
+ "'self'",
104
+ 'http:',
105
+ 'https:',
106
+ 'ws:'
107
+ ]
108
+ }
109
+ }
110
+ });
111
+ }
112
+ return helmet(helmetConfig)(ctx, next);
113
+ };
114
+
77
115
  exports.security = security;
78
116
  //# sourceMappingURL=security.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"security.js","sources":["../../src/middlewares/security.ts"],"sourcesContent":["import { defaultsDeep, mergeWith } from 'lodash/fp';\nimport helmet, { KoaHelmet } from 'koa-helmet';\n\nimport type { Core } from '@strapi/types';\n\nexport type Config = NonNullable<Parameters<KoaHelmet>[0]>;\n\nconst defaults: Config = {\n crossOriginEmbedderPolicy: false,\n crossOriginOpenerPolicy: false,\n crossOriginResourcePolicy: false,\n originAgentCluster: false,\n contentSecurityPolicy: {\n useDefaults: true,\n directives: {\n 'connect-src': [\"'self'\", 'https:'],\n 'img-src': [\"'self'\", 'data:', 'blob:', 'https://market-assets.strapi.io'],\n 'media-src': [\"'self'\", 'data:', 'blob:'],\n upgradeInsecureRequests: null,\n },\n },\n xssFilter: false,\n hsts: {\n maxAge: 31536000,\n includeSubDomains: true,\n },\n frameguard: {\n action: 'sameorigin',\n },\n};\n\nconst mergeConfig = (existingConfig: Config, newConfig: Config) => {\n return mergeWith(\n (obj, src) => (Array.isArray(obj) && Array.isArray(src) ? obj.concat(src) : undefined),\n existingConfig,\n newConfig\n );\n};\n\nexport const security: Core.MiddlewareFactory<Config> =\n (config, { strapi }) =>\n (ctx, next) => {\n let helmetConfig: Config = defaultsDeep(defaults, config);\n\n const specialPaths = ['/documentation'];\n\n const directives: {\n 'script-src': string[];\n 'img-src': string[];\n 'manifest-src': string[];\n 'frame-src': string[];\n } = {\n 'script-src': [\"'self'\", \"'unsafe-inline'\", 'cdn.jsdelivr.net'],\n 'img-src': [\"'self'\", 'data:', 'cdn.jsdelivr.net', 'strapi.io'],\n 'manifest-src': [],\n 'frame-src': [],\n };\n\n // if apollo graphql playground is enabled, add exceptions for it\n if (strapi.plugin('graphql')?.service('utils').playground.isEnabled()) {\n const { config: gqlConfig } = strapi.plugin('graphql');\n specialPaths.push(gqlConfig('endpoint'));\n\n directives['script-src'].push(`https: 'unsafe-inline'`);\n directives['img-src'].push(`'apollo-server-landing-page.cdn.apollographql.com'`);\n directives['manifest-src'].push(`'self'`);\n directives['manifest-src'].push('apollo-server-landing-page.cdn.apollographql.com');\n directives['frame-src'].push(`'self'`);\n directives['frame-src'].push('sandbox.embed.apollographql.com');\n }\n\n // TODO: we shouldn't combine playground exceptions with documentation for all routes, we should first check the path and then return exceptions specific to that\n if (ctx.method === 'GET' && specialPaths.some((str) => ctx.path.startsWith(str))) {\n helmetConfig = mergeConfig(helmetConfig, {\n crossOriginEmbedderPolicy: false, // TODO: only use this for graphql playground\n contentSecurityPolicy: {\n directives,\n },\n });\n }\n\n /**\n * These are for vite's watch mode so it can accurately\n * connect to the HMR websocket & reconnect on failure\n * or when the server restarts.\n *\n * It only applies in development, and only on GET requests\n * that are part of the admin route.\n */\n if (\n ['development', 'test'].includes(process.env.NODE_ENV ?? '') &&\n ctx.method === 'GET' &&\n ['/admin'].some((str) => ctx.path.startsWith(str))\n ) {\n helmetConfig = mergeConfig(helmetConfig, {\n contentSecurityPolicy: {\n directives: {\n 'script-src': [\"'self'\", \"'unsafe-inline'\"],\n 'connect-src': [\"'self'\", 'http:', 'https:', 'ws:'],\n },\n },\n });\n }\n\n return helmet(helmetConfig)(ctx, next);\n };\n"],"names":["mergeWith","defaultsDeep","helmet"],"mappings":";;;;;;AAOA,MAAM,WAAmB;AAAA,EACvB,2BAA2B;AAAA,EAC3B,yBAAyB;AAAA,EACzB,2BAA2B;AAAA,EAC3B,oBAAoB;AAAA,EACpB,uBAAuB;AAAA,IACrB,aAAa;AAAA,IACb,YAAY;AAAA,MACV,eAAe,CAAC,UAAU,QAAQ;AAAA,MAClC,WAAW,CAAC,UAAU,SAAS,SAAS,iCAAiC;AAAA,MACzE,aAAa,CAAC,UAAU,SAAS,OAAO;AAAA,MACxC,yBAAyB;AAAA,IAC3B;AAAA,EACF;AAAA,EACA,WAAW;AAAA,EACX,MAAM;AAAA,IACJ,QAAQ;AAAA,IACR,mBAAmB;AAAA,EACrB;AAAA,EACA,YAAY;AAAA,IACV,QAAQ;AAAA,EACV;AACF;AAEA,MAAM,cAAc,CAAC,gBAAwB,cAAsB;AAC1D,SAAAA,GAAA;AAAA,IACL,CAAC,KAAK,QAAS,MAAM,QAAQ,GAAG,KAAK,MAAM,QAAQ,GAAG,IAAI,IAAI,OAAO,GAAG,IAAI;AAAA,IAC5E;AAAA,IACA;AAAA,EAAA;AAEJ;AAEa,MAAA,WACX,CAAC,QAAQ,EAAE,aACX,CAAC,KAAK,SAAS;AACT,MAAA,eAAuBC,GAAAA,aAAa,UAAU,MAAM;AAElD,QAAA,eAAe,CAAC,gBAAgB;AAEtC,QAAM,aAKF;AAAA,IACF,cAAc,CAAC,UAAU,mBAAmB,kBAAkB;AAAA,IAC9D,WAAW,CAAC,UAAU,SAAS,oBAAoB,WAAW;AAAA,IAC9D,gBAAgB,CAAC;AAAA,IACjB,aAAa,CAAC;AAAA,EAAA;AAIZ,MAAA,OAAO,OAAO,SAAS,GAAG,QAAQ,OAAO,EAAE,WAAW,aAAa;AACrE,UAAM,EAAE,QAAQ,UAAA,IAAc,OAAO,OAAO,SAAS;AACxC,iBAAA,KAAK,UAAU,UAAU,CAAC;AAE5B,eAAA,YAAY,EAAE,KAAK,wBAAwB;AAC3C,eAAA,SAAS,EAAE,KAAK,oDAAoD;AACpE,eAAA,cAAc,EAAE,KAAK,QAAQ;AAC7B,eAAA,cAAc,EAAE,KAAK,kDAAkD;AACvE,eAAA,WAAW,EAAE,KAAK,QAAQ;AAC1B,eAAA,WAAW,EAAE,KAAK,iCAAiC;AAAA,EAChE;AAGA,MAAI,IAAI,WAAW,SAAS,aAAa,KAAK,CAAC,QAAQ,IAAI,KAAK,WAAW,GAAG,CAAC,GAAG;AAChF,mBAAe,YAAY,cAAc;AAAA,MACvC,2BAA2B;AAAA;AAAA,MAC3B,uBAAuB;AAAA,QACrB;AAAA,MACF;AAAA,IAAA,CACD;AAAA,EACH;AAWE,MAAA,CAAC,eAAe,MAAM,EAAE,SAAS,QAAQ,IAAI,YAAY,EAAE,KAC3D,IAAI,WAAW,SACf,CAAC,QAAQ,EAAE,KAAK,CAAC,QAAQ,IAAI,KAAK,WAAW,GAAG,CAAC,GACjD;AACA,mBAAe,YAAY,cAAc;AAAA,MACvC,uBAAuB;AAAA,QACrB,YAAY;AAAA,UACV,cAAc,CAAC,UAAU,iBAAiB;AAAA,UAC1C,eAAe,CAAC,UAAU,SAAS,UAAU,KAAK;AAAA,QACpD;AAAA,MACF;AAAA,IAAA,CACD;AAAA,EACH;AAEA,SAAOC,gBAAO,QAAA,YAAY,EAAE,KAAK,IAAI;AACvC;;"}
1
+ {"version":3,"file":"security.js","sources":["../../src/middlewares/security.ts"],"sourcesContent":["import { defaultsDeep, mergeWith } from 'lodash/fp';\nimport helmet, { KoaHelmet } from 'koa-helmet';\n\nimport type { Core } from '@strapi/types';\n\nexport type Config = NonNullable<Parameters<KoaHelmet>[0]>;\n\nconst defaults: Config = {\n crossOriginEmbedderPolicy: false,\n crossOriginOpenerPolicy: false,\n crossOriginResourcePolicy: false,\n originAgentCluster: false,\n contentSecurityPolicy: {\n useDefaults: true,\n directives: {\n 'connect-src': [\"'self'\", 'https:'],\n 'img-src': [\"'self'\", 'data:', 'blob:', 'https://market-assets.strapi.io'],\n 'media-src': [\"'self'\", 'data:', 'blob:'],\n upgradeInsecureRequests: null,\n },\n },\n xssFilter: false,\n hsts: {\n maxAge: 31536000,\n includeSubDomains: true,\n },\n frameguard: {\n action: 'sameorigin',\n },\n};\n\nconst mergeConfig = (existingConfig: Config, newConfig: Config) => {\n return mergeWith(\n (obj, src) => (Array.isArray(obj) && Array.isArray(src) ? obj.concat(src) : undefined),\n existingConfig,\n newConfig\n );\n};\n\nexport const security: Core.MiddlewareFactory<Config> =\n (config, { strapi }) =>\n (ctx, next) => {\n let helmetConfig: Config = defaultsDeep(defaults, config);\n\n const specialPaths = ['/documentation'];\n\n const directives: {\n 'script-src': string[];\n 'img-src': string[];\n 'manifest-src': string[];\n 'frame-src': string[];\n } = {\n 'script-src': [\"'self'\", \"'unsafe-inline'\", 'cdn.jsdelivr.net'],\n 'img-src': [\"'self'\", 'data:', 'cdn.jsdelivr.net', 'strapi.io'],\n 'manifest-src': [],\n 'frame-src': [],\n };\n\n // if apollo graphql playground is enabled, add exceptions for it\n if (strapi.plugin('graphql')?.service('utils').playground.isEnabled()) {\n const { config: gqlConfig } = strapi.plugin('graphql');\n specialPaths.push(gqlConfig('endpoint'));\n\n directives['script-src'].push(`https: 'unsafe-inline'`);\n directives['img-src'].push(`'apollo-server-landing-page.cdn.apollographql.com'`);\n directives['manifest-src'].push(`'self'`);\n directives['manifest-src'].push('apollo-server-landing-page.cdn.apollographql.com');\n directives['frame-src'].push(`'self'`);\n directives['frame-src'].push('sandbox.embed.apollographql.com');\n }\n\n // TODO: we shouldn't combine playground exceptions with documentation for all routes, we should first check the path and then return exceptions specific to that\n if (ctx.method === 'GET' && specialPaths.some((str) => ctx.path.startsWith(str))) {\n helmetConfig = mergeConfig(helmetConfig, {\n crossOriginEmbedderPolicy: false, // TODO: only use this for graphql playground\n contentSecurityPolicy: {\n directives,\n },\n });\n }\n\n /**\n * These are for vite's watch mode so it can accurately\n * connect to the HMR websocket & reconnect on failure\n * or when the server restarts.\n *\n * It only applies in development, and only on GET requests\n * that are part of the admin route.\n */\n\n if (\n ['development', 'test'].includes(process.env.NODE_ENV ?? '') &&\n ctx.method === 'GET' &&\n ctx.path.startsWith(strapi.config.get('admin.path'))\n ) {\n helmetConfig = mergeConfig(helmetConfig, {\n contentSecurityPolicy: {\n directives: {\n 'script-src': [\"'self'\", \"'unsafe-inline'\"],\n 'connect-src': [\"'self'\", 'http:', 'https:', 'ws:'],\n },\n },\n });\n }\n\n return helmet(helmetConfig)(ctx, next);\n };\n"],"names":["defaults","crossOriginEmbedderPolicy","crossOriginOpenerPolicy","crossOriginResourcePolicy","originAgentCluster","contentSecurityPolicy","useDefaults","directives","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,76 +1,114 @@
1
- import { defaultsDeep, mergeWith } from "lodash/fp";
2
- import helmet from "koa-helmet";
1
+ import { defaultsDeep, mergeWith } from 'lodash/fp';
2
+ import helmet from 'koa-helmet';
3
+
3
4
  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 mergeConfig = (existingConfig, newConfig) => {
27
- return mergeWith(
28
- (obj, src) => Array.isArray(obj) && Array.isArray(src) ? obj.concat(src) : void 0,
29
- existingConfig,
30
- newConfig
31
- );
32
- };
33
- const security = (config, { strapi }) => (ctx, next) => {
34
- let helmetConfig = defaultsDeep(defaults, config);
35
- const specialPaths = ["/documentation"];
36
- const directives = {
37
- "script-src": ["'self'", "'unsafe-inline'", "cdn.jsdelivr.net"],
38
- "img-src": ["'self'", "data:", "cdn.jsdelivr.net", "strapi.io"],
39
- "manifest-src": [],
40
- "frame-src": []
41
- };
42
- if (strapi.plugin("graphql")?.service("utils").playground.isEnabled()) {
43
- const { config: gqlConfig } = strapi.plugin("graphql");
44
- specialPaths.push(gqlConfig("endpoint"));
45
- directives["script-src"].push(`https: 'unsafe-inline'`);
46
- directives["img-src"].push(`'apollo-server-landing-page.cdn.apollographql.com'`);
47
- directives["manifest-src"].push(`'self'`);
48
- directives["manifest-src"].push("apollo-server-landing-page.cdn.apollographql.com");
49
- directives["frame-src"].push(`'self'`);
50
- directives["frame-src"].push("sandbox.embed.apollographql.com");
51
- }
52
- if (ctx.method === "GET" && specialPaths.some((str) => ctx.path.startsWith(str))) {
53
- helmetConfig = mergeConfig(helmetConfig, {
54
- crossOriginEmbedderPolicy: false,
55
- // TODO: only use this for graphql playground
56
- contentSecurityPolicy: {
57
- directives
58
- }
59
- });
60
- }
61
- if (["development", "test"].includes(process.env.NODE_ENV ?? "") && ctx.method === "GET" && ["/admin"].some((str) => ctx.path.startsWith(str))) {
62
- helmetConfig = mergeConfig(helmetConfig, {
63
- contentSecurityPolicy: {
5
+ crossOriginEmbedderPolicy: false,
6
+ crossOriginOpenerPolicy: false,
7
+ crossOriginResourcePolicy: false,
8
+ originAgentCluster: false,
9
+ contentSecurityPolicy: {
10
+ useDefaults: true,
64
11
  directives: {
65
- "script-src": ["'self'", "'unsafe-inline'"],
66
- "connect-src": ["'self'", "http:", "https:", "ws:"]
12
+ 'connect-src': [
13
+ "'self'",
14
+ 'https:'
15
+ ],
16
+ 'img-src': [
17
+ "'self'",
18
+ 'data:',
19
+ 'blob:',
20
+ 'https://market-assets.strapi.io'
21
+ ],
22
+ 'media-src': [
23
+ "'self'",
24
+ 'data:',
25
+ 'blob:'
26
+ ],
27
+ upgradeInsecureRequests: null
67
28
  }
68
- }
69
- });
70
- }
71
- return helmet(helmetConfig)(ctx, next);
29
+ },
30
+ xssFilter: false,
31
+ hsts: {
32
+ maxAge: 31536000,
33
+ includeSubDomains: true
34
+ },
35
+ frameguard: {
36
+ action: 'sameorigin'
37
+ }
72
38
  };
73
- export {
74
- security
39
+ const mergeConfig = (existingConfig, newConfig)=>{
40
+ return mergeWith((obj, src)=>Array.isArray(obj) && Array.isArray(src) ? obj.concat(src) : undefined, existingConfig, newConfig);
75
41
  };
42
+ const security = (config, { strapi })=>(ctx, next)=>{
43
+ let helmetConfig = defaultsDeep(defaults, config);
44
+ const specialPaths = [
45
+ '/documentation'
46
+ ];
47
+ const directives = {
48
+ 'script-src': [
49
+ "'self'",
50
+ "'unsafe-inline'",
51
+ 'cdn.jsdelivr.net'
52
+ ],
53
+ 'img-src': [
54
+ "'self'",
55
+ 'data:',
56
+ 'cdn.jsdelivr.net',
57
+ 'strapi.io'
58
+ ],
59
+ 'manifest-src': [],
60
+ 'frame-src': []
61
+ };
62
+ // if apollo graphql playground is enabled, add exceptions for it
63
+ if (strapi.plugin('graphql')?.service('utils').playground.isEnabled()) {
64
+ const { config: gqlConfig } = strapi.plugin('graphql');
65
+ specialPaths.push(gqlConfig('endpoint'));
66
+ directives['script-src'].push(`https: 'unsafe-inline'`);
67
+ directives['img-src'].push(`'apollo-server-landing-page.cdn.apollographql.com'`);
68
+ directives['manifest-src'].push(`'self'`);
69
+ directives['manifest-src'].push('apollo-server-landing-page.cdn.apollographql.com');
70
+ directives['frame-src'].push(`'self'`);
71
+ directives['frame-src'].push('sandbox.embed.apollographql.com');
72
+ }
73
+ // 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
74
+ if (ctx.method === 'GET' && specialPaths.some((str)=>ctx.path.startsWith(str))) {
75
+ helmetConfig = mergeConfig(helmetConfig, {
76
+ crossOriginEmbedderPolicy: false,
77
+ contentSecurityPolicy: {
78
+ directives
79
+ }
80
+ });
81
+ }
82
+ /**
83
+ * These are for vite's watch mode so it can accurately
84
+ * connect to the HMR websocket & reconnect on failure
85
+ * or when the server restarts.
86
+ *
87
+ * It only applies in development, and only on GET requests
88
+ * that are part of the admin route.
89
+ */ if ([
90
+ 'development',
91
+ 'test'
92
+ ].includes(process.env.NODE_ENV ?? '') && ctx.method === 'GET' && ctx.path.startsWith(strapi.config.get('admin.path'))) {
93
+ helmetConfig = mergeConfig(helmetConfig, {
94
+ contentSecurityPolicy: {
95
+ directives: {
96
+ 'script-src': [
97
+ "'self'",
98
+ "'unsafe-inline'"
99
+ ],
100
+ 'connect-src': [
101
+ "'self'",
102
+ 'http:',
103
+ 'https:',
104
+ 'ws:'
105
+ ]
106
+ }
107
+ }
108
+ });
109
+ }
110
+ return helmet(helmetConfig)(ctx, next);
111
+ };
112
+
113
+ export { security };
76
114
  //# sourceMappingURL=security.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"security.mjs","sources":["../../src/middlewares/security.ts"],"sourcesContent":["import { defaultsDeep, mergeWith } from 'lodash/fp';\nimport helmet, { KoaHelmet } from 'koa-helmet';\n\nimport type { Core } from '@strapi/types';\n\nexport type Config = NonNullable<Parameters<KoaHelmet>[0]>;\n\nconst defaults: Config = {\n crossOriginEmbedderPolicy: false,\n crossOriginOpenerPolicy: false,\n crossOriginResourcePolicy: false,\n originAgentCluster: false,\n contentSecurityPolicy: {\n useDefaults: true,\n directives: {\n 'connect-src': [\"'self'\", 'https:'],\n 'img-src': [\"'self'\", 'data:', 'blob:', 'https://market-assets.strapi.io'],\n 'media-src': [\"'self'\", 'data:', 'blob:'],\n upgradeInsecureRequests: null,\n },\n },\n xssFilter: false,\n hsts: {\n maxAge: 31536000,\n includeSubDomains: true,\n },\n frameguard: {\n action: 'sameorigin',\n },\n};\n\nconst mergeConfig = (existingConfig: Config, newConfig: Config) => {\n return mergeWith(\n (obj, src) => (Array.isArray(obj) && Array.isArray(src) ? obj.concat(src) : undefined),\n existingConfig,\n newConfig\n );\n};\n\nexport const security: Core.MiddlewareFactory<Config> =\n (config, { strapi }) =>\n (ctx, next) => {\n let helmetConfig: Config = defaultsDeep(defaults, config);\n\n const specialPaths = ['/documentation'];\n\n const directives: {\n 'script-src': string[];\n 'img-src': string[];\n 'manifest-src': string[];\n 'frame-src': string[];\n } = {\n 'script-src': [\"'self'\", \"'unsafe-inline'\", 'cdn.jsdelivr.net'],\n 'img-src': [\"'self'\", 'data:', 'cdn.jsdelivr.net', 'strapi.io'],\n 'manifest-src': [],\n 'frame-src': [],\n };\n\n // if apollo graphql playground is enabled, add exceptions for it\n if (strapi.plugin('graphql')?.service('utils').playground.isEnabled()) {\n const { config: gqlConfig } = strapi.plugin('graphql');\n specialPaths.push(gqlConfig('endpoint'));\n\n directives['script-src'].push(`https: 'unsafe-inline'`);\n directives['img-src'].push(`'apollo-server-landing-page.cdn.apollographql.com'`);\n directives['manifest-src'].push(`'self'`);\n directives['manifest-src'].push('apollo-server-landing-page.cdn.apollographql.com');\n directives['frame-src'].push(`'self'`);\n directives['frame-src'].push('sandbox.embed.apollographql.com');\n }\n\n // TODO: we shouldn't combine playground exceptions with documentation for all routes, we should first check the path and then return exceptions specific to that\n if (ctx.method === 'GET' && specialPaths.some((str) => ctx.path.startsWith(str))) {\n helmetConfig = mergeConfig(helmetConfig, {\n crossOriginEmbedderPolicy: false, // TODO: only use this for graphql playground\n contentSecurityPolicy: {\n directives,\n },\n });\n }\n\n /**\n * These are for vite's watch mode so it can accurately\n * connect to the HMR websocket & reconnect on failure\n * or when the server restarts.\n *\n * It only applies in development, and only on GET requests\n * that are part of the admin route.\n */\n if (\n ['development', 'test'].includes(process.env.NODE_ENV ?? '') &&\n ctx.method === 'GET' &&\n ['/admin'].some((str) => ctx.path.startsWith(str))\n ) {\n helmetConfig = mergeConfig(helmetConfig, {\n contentSecurityPolicy: {\n directives: {\n 'script-src': [\"'self'\", \"'unsafe-inline'\"],\n 'connect-src': [\"'self'\", 'http:', 'https:', 'ws:'],\n },\n },\n });\n }\n\n return helmet(helmetConfig)(ctx, next);\n };\n"],"names":[],"mappings":";;AAOA,MAAM,WAAmB;AAAA,EACvB,2BAA2B;AAAA,EAC3B,yBAAyB;AAAA,EACzB,2BAA2B;AAAA,EAC3B,oBAAoB;AAAA,EACpB,uBAAuB;AAAA,IACrB,aAAa;AAAA,IACb,YAAY;AAAA,MACV,eAAe,CAAC,UAAU,QAAQ;AAAA,MAClC,WAAW,CAAC,UAAU,SAAS,SAAS,iCAAiC;AAAA,MACzE,aAAa,CAAC,UAAU,SAAS,OAAO;AAAA,MACxC,yBAAyB;AAAA,IAC3B;AAAA,EACF;AAAA,EACA,WAAW;AAAA,EACX,MAAM;AAAA,IACJ,QAAQ;AAAA,IACR,mBAAmB;AAAA,EACrB;AAAA,EACA,YAAY;AAAA,IACV,QAAQ;AAAA,EACV;AACF;AAEA,MAAM,cAAc,CAAC,gBAAwB,cAAsB;AAC1D,SAAA;AAAA,IACL,CAAC,KAAK,QAAS,MAAM,QAAQ,GAAG,KAAK,MAAM,QAAQ,GAAG,IAAI,IAAI,OAAO,GAAG,IAAI;AAAA,IAC5E;AAAA,IACA;AAAA,EAAA;AAEJ;AAEa,MAAA,WACX,CAAC,QAAQ,EAAE,aACX,CAAC,KAAK,SAAS;AACT,MAAA,eAAuB,aAAa,UAAU,MAAM;AAElD,QAAA,eAAe,CAAC,gBAAgB;AAEtC,QAAM,aAKF;AAAA,IACF,cAAc,CAAC,UAAU,mBAAmB,kBAAkB;AAAA,IAC9D,WAAW,CAAC,UAAU,SAAS,oBAAoB,WAAW;AAAA,IAC9D,gBAAgB,CAAC;AAAA,IACjB,aAAa,CAAC;AAAA,EAAA;AAIZ,MAAA,OAAO,OAAO,SAAS,GAAG,QAAQ,OAAO,EAAE,WAAW,aAAa;AACrE,UAAM,EAAE,QAAQ,UAAA,IAAc,OAAO,OAAO,SAAS;AACxC,iBAAA,KAAK,UAAU,UAAU,CAAC;AAE5B,eAAA,YAAY,EAAE,KAAK,wBAAwB;AAC3C,eAAA,SAAS,EAAE,KAAK,oDAAoD;AACpE,eAAA,cAAc,EAAE,KAAK,QAAQ;AAC7B,eAAA,cAAc,EAAE,KAAK,kDAAkD;AACvE,eAAA,WAAW,EAAE,KAAK,QAAQ;AAC1B,eAAA,WAAW,EAAE,KAAK,iCAAiC;AAAA,EAChE;AAGA,MAAI,IAAI,WAAW,SAAS,aAAa,KAAK,CAAC,QAAQ,IAAI,KAAK,WAAW,GAAG,CAAC,GAAG;AAChF,mBAAe,YAAY,cAAc;AAAA,MACvC,2BAA2B;AAAA;AAAA,MAC3B,uBAAuB;AAAA,QACrB;AAAA,MACF;AAAA,IAAA,CACD;AAAA,EACH;AAWE,MAAA,CAAC,eAAe,MAAM,EAAE,SAAS,QAAQ,IAAI,YAAY,EAAE,KAC3D,IAAI,WAAW,SACf,CAAC,QAAQ,EAAE,KAAK,CAAC,QAAQ,IAAI,KAAK,WAAW,GAAG,CAAC,GACjD;AACA,mBAAe,YAAY,cAAc;AAAA,MACvC,uBAAuB;AAAA,QACrB,YAAY;AAAA,UACV,cAAc,CAAC,UAAU,iBAAiB;AAAA,UAC1C,eAAe,CAAC,UAAU,SAAS,UAAU,KAAK;AAAA,QACpD;AAAA,MACF;AAAA,IAAA,CACD;AAAA,EACH;AAEA,SAAO,OAAO,YAAY,EAAE,KAAK,IAAI;AACvC;"}
1
+ {"version":3,"file":"security.mjs","sources":["../../src/middlewares/security.ts"],"sourcesContent":["import { defaultsDeep, mergeWith } from 'lodash/fp';\nimport helmet, { KoaHelmet } from 'koa-helmet';\n\nimport type { Core } from '@strapi/types';\n\nexport type Config = NonNullable<Parameters<KoaHelmet>[0]>;\n\nconst defaults: Config = {\n crossOriginEmbedderPolicy: false,\n crossOriginOpenerPolicy: false,\n crossOriginResourcePolicy: false,\n originAgentCluster: false,\n contentSecurityPolicy: {\n useDefaults: true,\n directives: {\n 'connect-src': [\"'self'\", 'https:'],\n 'img-src': [\"'self'\", 'data:', 'blob:', 'https://market-assets.strapi.io'],\n 'media-src': [\"'self'\", 'data:', 'blob:'],\n upgradeInsecureRequests: null,\n },\n },\n xssFilter: false,\n hsts: {\n maxAge: 31536000,\n includeSubDomains: true,\n },\n frameguard: {\n action: 'sameorigin',\n },\n};\n\nconst mergeConfig = (existingConfig: Config, newConfig: Config) => {\n return mergeWith(\n (obj, src) => (Array.isArray(obj) && Array.isArray(src) ? obj.concat(src) : undefined),\n existingConfig,\n newConfig\n );\n};\n\nexport const security: Core.MiddlewareFactory<Config> =\n (config, { strapi }) =>\n (ctx, next) => {\n let helmetConfig: Config = defaultsDeep(defaults, config);\n\n const specialPaths = ['/documentation'];\n\n const directives: {\n 'script-src': string[];\n 'img-src': string[];\n 'manifest-src': string[];\n 'frame-src': string[];\n } = {\n 'script-src': [\"'self'\", \"'unsafe-inline'\", 'cdn.jsdelivr.net'],\n 'img-src': [\"'self'\", 'data:', 'cdn.jsdelivr.net', 'strapi.io'],\n 'manifest-src': [],\n 'frame-src': [],\n };\n\n // if apollo graphql playground is enabled, add exceptions for it\n if (strapi.plugin('graphql')?.service('utils').playground.isEnabled()) {\n const { config: gqlConfig } = strapi.plugin('graphql');\n specialPaths.push(gqlConfig('endpoint'));\n\n directives['script-src'].push(`https: 'unsafe-inline'`);\n directives['img-src'].push(`'apollo-server-landing-page.cdn.apollographql.com'`);\n directives['manifest-src'].push(`'self'`);\n directives['manifest-src'].push('apollo-server-landing-page.cdn.apollographql.com');\n directives['frame-src'].push(`'self'`);\n directives['frame-src'].push('sandbox.embed.apollographql.com');\n }\n\n // TODO: we shouldn't combine playground exceptions with documentation for all routes, we should first check the path and then return exceptions specific to that\n if (ctx.method === 'GET' && specialPaths.some((str) => ctx.path.startsWith(str))) {\n helmetConfig = mergeConfig(helmetConfig, {\n crossOriginEmbedderPolicy: false, // TODO: only use this for graphql playground\n contentSecurityPolicy: {\n directives,\n },\n });\n }\n\n /**\n * These are for vite's watch mode so it can accurately\n * connect to the HMR websocket & reconnect on failure\n * or when the server restarts.\n *\n * It only applies in development, and only on GET requests\n * that are part of the admin route.\n */\n\n if (\n ['development', 'test'].includes(process.env.NODE_ENV ?? '') &&\n ctx.method === 'GET' &&\n ctx.path.startsWith(strapi.config.get('admin.path'))\n ) {\n helmetConfig = mergeConfig(helmetConfig, {\n contentSecurityPolicy: {\n directives: {\n 'script-src': [\"'self'\", \"'unsafe-inline'\"],\n 'connect-src': [\"'self'\", 'http:', 'https:', 'ws:'],\n },\n },\n });\n }\n\n return helmet(helmetConfig)(ctx, next);\n };\n"],"names":["defaults","crossOriginEmbedderPolicy","crossOriginOpenerPolicy","crossOriginResourcePolicy","originAgentCluster","contentSecurityPolicy","useDefaults","directives","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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"}