@strapi/core 0.0.0-experimental.74c69aeafc770d59d5b3d5d37cd249934ef395ba → 0.0.0-experimental.75b9c6babc2f67877cfc879041cfff9fb966e742

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 (744) hide show
  1. package/LICENSE +18 -3
  2. package/dist/Strapi.d.ts +3 -1
  3. package/dist/Strapi.d.ts.map +1 -1
  4. package/dist/configuration/index.d.ts.map +1 -1
  5. package/dist/core-api/controller/collection-type.d.ts.map +1 -1
  6. package/dist/core-api/controller/single-type.d.ts.map +1 -1
  7. package/dist/core-api/routes/index.d.ts.map +1 -1
  8. package/dist/core-api/service/collection-type.d.ts +3 -9
  9. package/dist/core-api/service/collection-type.d.ts.map +1 -1
  10. package/dist/core-api/service/pagination.d.ts +4 -11
  11. package/dist/core-api/service/pagination.d.ts.map +1 -1
  12. package/dist/core-api/service/single-type.d.ts.map +1 -1
  13. package/dist/ee/index.d.ts.map +1 -1
  14. package/dist/ee/license.d.ts.map +1 -1
  15. package/dist/factories.d.ts +2 -2
  16. package/dist/factories.d.ts.map +1 -1
  17. package/dist/index.d.ts +14 -0
  18. package/dist/index.d.ts.map +1 -1
  19. package/dist/index.js +9954 -27
  20. package/dist/index.js.map +1 -1
  21. package/dist/index.mjs +9932 -29
  22. package/dist/index.mjs.map +1 -1
  23. package/dist/loaders/apis.d.ts.map +1 -1
  24. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  25. package/dist/loaders/plugins/index.d.ts.map +1 -1
  26. package/dist/middlewares/body.d.ts.map +1 -1
  27. package/dist/middlewares/cors.d.ts.map +1 -1
  28. package/dist/middlewares/query.d.ts.map +1 -1
  29. package/dist/middlewares/security.d.ts.map +1 -1
  30. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +33 -0
  31. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -0
  32. package/dist/migrations/draft-publish.d.ts +2 -2
  33. package/dist/migrations/draft-publish.d.ts.map +1 -1
  34. package/dist/migrations/i18n.d.ts +5 -0
  35. package/dist/migrations/i18n.d.ts.map +1 -0
  36. package/dist/migrations/index.d.ts +5 -0
  37. package/dist/migrations/index.d.ts.map +1 -0
  38. package/dist/providers/admin.d.ts.map +1 -1
  39. package/dist/providers/registries.d.ts.map +1 -1
  40. package/dist/registries/policies.d.ts +1 -1
  41. package/dist/registries/policies.d.ts.map +1 -1
  42. package/dist/services/content-api/index.d.ts +10 -12
  43. package/dist/services/content-api/index.d.ts.map +1 -1
  44. package/dist/services/content-api/permissions/index.d.ts +10 -12
  45. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  46. package/dist/services/content-api/permissions/providers/action.d.ts +5 -6
  47. package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -1
  48. package/dist/services/content-api/permissions/providers/condition.d.ts +5 -6
  49. package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -1
  50. package/dist/services/core-store.d.ts.map +1 -1
  51. package/dist/services/cron.d.ts +3 -3
  52. package/dist/services/cron.d.ts.map +1 -1
  53. package/dist/services/document-service/attributes/index.d.ts +4 -4
  54. package/dist/services/document-service/attributes/index.d.ts.map +1 -1
  55. package/dist/services/document-service/common.d.ts +1 -1
  56. package/dist/services/document-service/common.d.ts.map +1 -1
  57. package/dist/services/document-service/components.d.ts +8 -80
  58. package/dist/services/document-service/components.d.ts.map +1 -1
  59. package/dist/services/document-service/draft-and-publish.d.ts +1 -1
  60. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  61. package/dist/services/document-service/entries.d.ts +5 -3
  62. package/dist/services/document-service/entries.d.ts.map +1 -1
  63. package/dist/services/document-service/events.d.ts +25 -0
  64. package/dist/services/document-service/events.d.ts.map +1 -0
  65. package/dist/services/document-service/index.d.ts +2 -1
  66. package/dist/services/document-service/index.d.ts.map +1 -1
  67. package/dist/services/document-service/internationalization.d.ts.map +1 -1
  68. package/dist/services/document-service/middlewares/middleware-manager.d.ts +5 -2
  69. package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -1
  70. package/dist/services/document-service/params.d.ts +1 -5
  71. package/dist/services/document-service/params.d.ts.map +1 -1
  72. package/dist/services/document-service/repository.d.ts.map +1 -1
  73. package/dist/services/document-service/transform/id-map.d.ts +1 -1
  74. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  75. package/dist/services/document-service/transform/id-transform.d.ts +1 -1
  76. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  77. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +1 -1
  78. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  79. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  80. package/dist/services/document-service/transform/relations/utils/dp.d.ts +1 -1
  81. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  82. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +1 -1
  83. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  84. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -1
  85. package/dist/services/document-service/utils/populate.d.ts +1 -1
  86. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  87. package/dist/services/document-service/utils/unidirectional-relations.d.ts +36 -0
  88. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -0
  89. package/dist/services/entity-service/index.d.ts.map +1 -1
  90. package/dist/services/entity-validator/blocks-validator.d.ts +1 -2
  91. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
  92. package/dist/services/entity-validator/index.d.ts +15 -1
  93. package/dist/services/entity-validator/index.d.ts.map +1 -1
  94. package/dist/services/entity-validator/validators.d.ts +36 -25
  95. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  96. package/dist/services/event-hub.d.ts +1 -0
  97. package/dist/services/event-hub.d.ts.map +1 -1
  98. package/dist/services/metrics/middleware.d.ts.map +1 -1
  99. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  100. package/dist/services/server/compose-endpoint.d.ts.map +1 -1
  101. package/dist/services/server/koa.d.ts.map +1 -1
  102. package/dist/services/webhook-runner.d.ts +2 -1
  103. package/dist/services/webhook-runner.d.ts.map +1 -1
  104. package/dist/services/webhook-store.d.ts +2 -8
  105. package/dist/services/webhook-store.d.ts.map +1 -1
  106. package/dist/utils/fetch.d.ts.map +1 -1
  107. package/dist/utils/filepath-to-prop-path.d.ts +1 -1
  108. package/dist/utils/filepath-to-prop-path.d.ts.map +1 -1
  109. package/dist/utils/load-files.d.ts.map +1 -1
  110. package/dist/utils/startup-logger.d.ts.map +1 -1
  111. package/dist/utils/transform-content-types-to-models.d.ts +355 -23
  112. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  113. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  114. package/package.json +37 -34
  115. package/dist/Strapi.js +0 -387
  116. package/dist/Strapi.js.map +0 -1
  117. package/dist/Strapi.mjs +0 -385
  118. package/dist/Strapi.mjs.map +0 -1
  119. package/dist/compile.js +0 -18
  120. package/dist/compile.js.map +0 -1
  121. package/dist/compile.mjs +0 -17
  122. package/dist/compile.mjs.map +0 -1
  123. package/dist/configuration/config-loader.js +0 -106
  124. package/dist/configuration/config-loader.js.map +0 -1
  125. package/dist/configuration/config-loader.mjs +0 -104
  126. package/dist/configuration/config-loader.mjs.map +0 -1
  127. package/dist/configuration/get-dirs.js +0 -31
  128. package/dist/configuration/get-dirs.js.map +0 -1
  129. package/dist/configuration/get-dirs.mjs +0 -31
  130. package/dist/configuration/get-dirs.mjs.map +0 -1
  131. package/dist/configuration/index.js +0 -80
  132. package/dist/configuration/index.js.map +0 -1
  133. package/dist/configuration/index.mjs +0 -75
  134. package/dist/configuration/index.mjs.map +0 -1
  135. package/dist/configuration/urls.js +0 -68
  136. package/dist/configuration/urls.js.map +0 -1
  137. package/dist/configuration/urls.mjs +0 -66
  138. package/dist/configuration/urls.mjs.map +0 -1
  139. package/dist/container.js +0 -30
  140. package/dist/container.js.map +0 -1
  141. package/dist/container.mjs +0 -30
  142. package/dist/container.mjs.map +0 -1
  143. package/dist/core-api/controller/collection-type.js +0 -81
  144. package/dist/core-api/controller/collection-type.js.map +0 -1
  145. package/dist/core-api/controller/collection-type.mjs +0 -81
  146. package/dist/core-api/controller/collection-type.mjs.map +0 -1
  147. package/dist/core-api/controller/index.js +0 -52
  148. package/dist/core-api/controller/index.js.map +0 -1
  149. package/dist/core-api/controller/index.mjs +0 -52
  150. package/dist/core-api/controller/index.mjs.map +0 -1
  151. package/dist/core-api/controller/single-type.js +0 -45
  152. package/dist/core-api/controller/single-type.js.map +0 -1
  153. package/dist/core-api/controller/single-type.mjs +0 -45
  154. package/dist/core-api/controller/single-type.mjs.map +0 -1
  155. package/dist/core-api/controller/transform.js +0 -76
  156. package/dist/core-api/controller/transform.js.map +0 -1
  157. package/dist/core-api/controller/transform.mjs +0 -76
  158. package/dist/core-api/controller/transform.mjs.map +0 -1
  159. package/dist/core-api/routes/index.js +0 -67
  160. package/dist/core-api/routes/index.js.map +0 -1
  161. package/dist/core-api/routes/index.mjs +0 -67
  162. package/dist/core-api/routes/index.mjs.map +0 -1
  163. package/dist/core-api/service/collection-type.js +0 -65
  164. package/dist/core-api/service/collection-type.js.map +0 -1
  165. package/dist/core-api/service/collection-type.mjs +0 -65
  166. package/dist/core-api/service/collection-type.mjs.map +0 -1
  167. package/dist/core-api/service/core-service.js +0 -12
  168. package/dist/core-api/service/core-service.js.map +0 -1
  169. package/dist/core-api/service/core-service.mjs +0 -12
  170. package/dist/core-api/service/core-service.mjs.map +0 -1
  171. package/dist/core-api/service/index.js +0 -16
  172. package/dist/core-api/service/index.js.map +0 -1
  173. package/dist/core-api/service/index.mjs +0 -16
  174. package/dist/core-api/service/index.mjs.map +0 -1
  175. package/dist/core-api/service/pagination.js +0 -78
  176. package/dist/core-api/service/pagination.js.map +0 -1
  177. package/dist/core-api/service/pagination.mjs +0 -78
  178. package/dist/core-api/service/pagination.mjs.map +0 -1
  179. package/dist/core-api/service/single-type.js +0 -45
  180. package/dist/core-api/service/single-type.js.map +0 -1
  181. package/dist/core-api/service/single-type.mjs +0 -45
  182. package/dist/core-api/service/single-type.mjs.map +0 -1
  183. package/dist/domain/content-type/index.js +0 -111
  184. package/dist/domain/content-type/index.js.map +0 -1
  185. package/dist/domain/content-type/index.mjs +0 -109
  186. package/dist/domain/content-type/index.mjs.map +0 -1
  187. package/dist/domain/content-type/validator.js +0 -77
  188. package/dist/domain/content-type/validator.js.map +0 -1
  189. package/dist/domain/content-type/validator.mjs +0 -75
  190. package/dist/domain/content-type/validator.mjs.map +0 -1
  191. package/dist/domain/module/index.js +0 -107
  192. package/dist/domain/module/index.js.map +0 -1
  193. package/dist/domain/module/index.mjs +0 -105
  194. package/dist/domain/module/index.mjs.map +0 -1
  195. package/dist/domain/module/validation.js +0 -25
  196. package/dist/domain/module/validation.js.map +0 -1
  197. package/dist/domain/module/validation.mjs +0 -25
  198. package/dist/domain/module/validation.mjs.map +0 -1
  199. package/dist/ee/index.js +0 -153
  200. package/dist/ee/index.js.map +0 -1
  201. package/dist/ee/index.mjs +0 -154
  202. package/dist/ee/index.mjs.map +0 -1
  203. package/dist/ee/license.js +0 -90
  204. package/dist/ee/license.js.map +0 -1
  205. package/dist/ee/license.mjs +0 -87
  206. package/dist/ee/license.mjs.map +0 -1
  207. package/dist/factories.js +0 -80
  208. package/dist/factories.js.map +0 -1
  209. package/dist/factories.mjs +0 -80
  210. package/dist/factories.mjs.map +0 -1
  211. package/dist/loaders/admin.js +0 -26
  212. package/dist/loaders/admin.js.map +0 -1
  213. package/dist/loaders/admin.mjs +0 -25
  214. package/dist/loaders/admin.mjs.map +0 -1
  215. package/dist/loaders/apis.js +0 -137
  216. package/dist/loaders/apis.js.map +0 -1
  217. package/dist/loaders/apis.mjs +0 -135
  218. package/dist/loaders/apis.mjs.map +0 -1
  219. package/dist/loaders/components.js +0 -38
  220. package/dist/loaders/components.js.map +0 -1
  221. package/dist/loaders/components.mjs +0 -37
  222. package/dist/loaders/components.mjs.map +0 -1
  223. package/dist/loaders/index.js +0 -24
  224. package/dist/loaders/index.js.map +0 -1
  225. package/dist/loaders/index.mjs +0 -24
  226. package/dist/loaders/index.mjs.map +0 -1
  227. package/dist/loaders/middlewares.js +0 -31
  228. package/dist/loaders/middlewares.js.map +0 -1
  229. package/dist/loaders/middlewares.mjs +0 -30
  230. package/dist/loaders/middlewares.mjs.map +0 -1
  231. package/dist/loaders/plugins/get-enabled-plugins.js +0 -113
  232. package/dist/loaders/plugins/get-enabled-plugins.js.map +0 -1
  233. package/dist/loaders/plugins/get-enabled-plugins.mjs +0 -111
  234. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +0 -1
  235. package/dist/loaders/plugins/get-user-plugins-config.js +0 -27
  236. package/dist/loaders/plugins/get-user-plugins-config.js.map +0 -1
  237. package/dist/loaders/plugins/get-user-plugins-config.mjs +0 -25
  238. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +0 -1
  239. package/dist/loaders/plugins/index.js +0 -118
  240. package/dist/loaders/plugins/index.js.map +0 -1
  241. package/dist/loaders/plugins/index.mjs +0 -117
  242. package/dist/loaders/plugins/index.mjs.map +0 -1
  243. package/dist/loaders/policies.js +0 -25
  244. package/dist/loaders/policies.js.map +0 -1
  245. package/dist/loaders/policies.mjs +0 -24
  246. package/dist/loaders/policies.mjs.map +0 -1
  247. package/dist/loaders/sanitizers.js +0 -6
  248. package/dist/loaders/sanitizers.js.map +0 -1
  249. package/dist/loaders/sanitizers.mjs +0 -7
  250. package/dist/loaders/sanitizers.mjs.map +0 -1
  251. package/dist/loaders/src-index.js +0 -33
  252. package/dist/loaders/src-index.js.map +0 -1
  253. package/dist/loaders/src-index.mjs +0 -34
  254. package/dist/loaders/src-index.mjs.map +0 -1
  255. package/dist/loaders/validators.js +0 -6
  256. package/dist/loaders/validators.js.map +0 -1
  257. package/dist/loaders/validators.mjs +0 -7
  258. package/dist/loaders/validators.mjs.map +0 -1
  259. package/dist/middlewares/body.js +0 -65
  260. package/dist/middlewares/body.js.map +0 -1
  261. package/dist/middlewares/body.mjs +0 -61
  262. package/dist/middlewares/body.mjs.map +0 -1
  263. package/dist/middlewares/compression.js +0 -8
  264. package/dist/middlewares/compression.js.map +0 -1
  265. package/dist/middlewares/compression.mjs +0 -6
  266. package/dist/middlewares/compression.mjs.map +0 -1
  267. package/dist/middlewares/cors.js +0 -51
  268. package/dist/middlewares/cors.js.map +0 -1
  269. package/dist/middlewares/cors.mjs +0 -49
  270. package/dist/middlewares/cors.mjs.map +0 -1
  271. package/dist/middlewares/errors.js +0 -33
  272. package/dist/middlewares/errors.js.map +0 -1
  273. package/dist/middlewares/errors.mjs +0 -33
  274. package/dist/middlewares/errors.mjs.map +0 -1
  275. package/dist/middlewares/favicon.js +0 -22
  276. package/dist/middlewares/favicon.js.map +0 -1
  277. package/dist/middlewares/favicon.mjs +0 -20
  278. package/dist/middlewares/favicon.mjs.map +0 -1
  279. package/dist/middlewares/index.js +0 -34
  280. package/dist/middlewares/index.js.map +0 -1
  281. package/dist/middlewares/index.mjs +0 -34
  282. package/dist/middlewares/index.mjs.map +0 -1
  283. package/dist/middlewares/ip.js +0 -8
  284. package/dist/middlewares/ip.js.map +0 -1
  285. package/dist/middlewares/ip.mjs +0 -6
  286. package/dist/middlewares/ip.mjs.map +0 -1
  287. package/dist/middlewares/logger.js +0 -12
  288. package/dist/middlewares/logger.js.map +0 -1
  289. package/dist/middlewares/logger.mjs +0 -12
  290. package/dist/middlewares/logger.mjs.map +0 -1
  291. package/dist/middlewares/powered-by.js +0 -14
  292. package/dist/middlewares/powered-by.js.map +0 -1
  293. package/dist/middlewares/powered-by.mjs +0 -14
  294. package/dist/middlewares/powered-by.mjs.map +0 -1
  295. package/dist/middlewares/public.js +0 -34
  296. package/dist/middlewares/public.js.map +0 -1
  297. package/dist/middlewares/public.mjs +0 -32
  298. package/dist/middlewares/public.mjs.map +0 -1
  299. package/dist/middlewares/query.js +0 -40
  300. package/dist/middlewares/query.js.map +0 -1
  301. package/dist/middlewares/query.mjs +0 -38
  302. package/dist/middlewares/query.mjs.map +0 -1
  303. package/dist/middlewares/response-time.js +0 -12
  304. package/dist/middlewares/response-time.js.map +0 -1
  305. package/dist/middlewares/response-time.mjs +0 -12
  306. package/dist/middlewares/response-time.mjs.map +0 -1
  307. package/dist/middlewares/responses.js +0 -15
  308. package/dist/middlewares/responses.js.map +0 -1
  309. package/dist/middlewares/responses.mjs +0 -15
  310. package/dist/middlewares/responses.mjs.map +0 -1
  311. package/dist/middlewares/security.js +0 -71
  312. package/dist/middlewares/security.js.map +0 -1
  313. package/dist/middlewares/security.mjs +0 -69
  314. package/dist/middlewares/security.mjs.map +0 -1
  315. package/dist/middlewares/session.js +0 -30
  316. package/dist/middlewares/session.js.map +0 -1
  317. package/dist/middlewares/session.mjs +0 -28
  318. package/dist/middlewares/session.mjs.map +0 -1
  319. package/dist/migrations/draft-publish.js +0 -59
  320. package/dist/migrations/draft-publish.js.map +0 -1
  321. package/dist/migrations/draft-publish.mjs +0 -59
  322. package/dist/migrations/draft-publish.mjs.map +0 -1
  323. package/dist/providers/admin.js +0 -20
  324. package/dist/providers/admin.js.map +0 -1
  325. package/dist/providers/admin.mjs +0 -21
  326. package/dist/providers/admin.mjs.map +0 -1
  327. package/dist/providers/coreStore.js +0 -11
  328. package/dist/providers/coreStore.js.map +0 -1
  329. package/dist/providers/coreStore.mjs +0 -12
  330. package/dist/providers/coreStore.mjs.map +0 -1
  331. package/dist/providers/cron.js +0 -20
  332. package/dist/providers/cron.js.map +0 -1
  333. package/dist/providers/cron.mjs +0 -21
  334. package/dist/providers/cron.mjs.map +0 -1
  335. package/dist/providers/index.js +0 -11
  336. package/dist/providers/index.js.map +0 -1
  337. package/dist/providers/index.mjs +0 -11
  338. package/dist/providers/index.mjs.map +0 -1
  339. package/dist/providers/provider.js +0 -5
  340. package/dist/providers/provider.js.map +0 -1
  341. package/dist/providers/provider.mjs +0 -5
  342. package/dist/providers/provider.mjs.map +0 -1
  343. package/dist/providers/registries.js +0 -33
  344. package/dist/providers/registries.js.map +0 -1
  345. package/dist/providers/registries.mjs +0 -34
  346. package/dist/providers/registries.mjs.map +0 -1
  347. package/dist/providers/telemetry.js +0 -19
  348. package/dist/providers/telemetry.js.map +0 -1
  349. package/dist/providers/telemetry.mjs +0 -20
  350. package/dist/providers/telemetry.mjs.map +0 -1
  351. package/dist/providers/webhooks.js +0 -30
  352. package/dist/providers/webhooks.js.map +0 -1
  353. package/dist/providers/webhooks.mjs +0 -31
  354. package/dist/providers/webhooks.mjs.map +0 -1
  355. package/dist/registries/apis.js +0 -23
  356. package/dist/registries/apis.js.map +0 -1
  357. package/dist/registries/apis.mjs +0 -24
  358. package/dist/registries/apis.mjs.map +0 -1
  359. package/dist/registries/components.js +0 -45
  360. package/dist/registries/components.js.map +0 -1
  361. package/dist/registries/components.mjs +0 -46
  362. package/dist/registries/components.mjs.map +0 -1
  363. package/dist/registries/content-types.js +0 -70
  364. package/dist/registries/content-types.js.map +0 -1
  365. package/dist/registries/content-types.mjs +0 -71
  366. package/dist/registries/content-types.mjs.map +0 -1
  367. package/dist/registries/controllers.js +0 -80
  368. package/dist/registries/controllers.js.map +0 -1
  369. package/dist/registries/controllers.mjs +0 -81
  370. package/dist/registries/controllers.mjs.map +0 -1
  371. package/dist/registries/custom-fields.js +0 -71
  372. package/dist/registries/custom-fields.js.map +0 -1
  373. package/dist/registries/custom-fields.mjs +0 -72
  374. package/dist/registries/custom-fields.mjs.map +0 -1
  375. package/dist/registries/hooks.js +0 -58
  376. package/dist/registries/hooks.js.map +0 -1
  377. package/dist/registries/hooks.mjs +0 -59
  378. package/dist/registries/hooks.mjs.map +0 -1
  379. package/dist/registries/middlewares.js +0 -60
  380. package/dist/registries/middlewares.js.map +0 -1
  381. package/dist/registries/middlewares.mjs +0 -61
  382. package/dist/registries/middlewares.mjs.map +0 -1
  383. package/dist/registries/models.js +0 -16
  384. package/dist/registries/models.js.map +0 -1
  385. package/dist/registries/models.mjs +0 -16
  386. package/dist/registries/models.mjs.map +0 -1
  387. package/dist/registries/modules.js +0 -39
  388. package/dist/registries/modules.js.map +0 -1
  389. package/dist/registries/modules.mjs +0 -40
  390. package/dist/registries/modules.mjs.map +0 -1
  391. package/dist/registries/namespace.js +0 -27
  392. package/dist/registries/namespace.js.map +0 -1
  393. package/dist/registries/namespace.mjs +0 -27
  394. package/dist/registries/namespace.mjs.map +0 -1
  395. package/dist/registries/plugins.js +0 -23
  396. package/dist/registries/plugins.js.map +0 -1
  397. package/dist/registries/plugins.mjs +0 -24
  398. package/dist/registries/plugins.mjs.map +0 -1
  399. package/dist/registries/policies.js +0 -108
  400. package/dist/registries/policies.js.map +0 -1
  401. package/dist/registries/policies.mjs +0 -109
  402. package/dist/registries/policies.mjs.map +0 -1
  403. package/dist/registries/sanitizers.js +0 -25
  404. package/dist/registries/sanitizers.js.map +0 -1
  405. package/dist/registries/sanitizers.mjs +0 -24
  406. package/dist/registries/sanitizers.mjs.map +0 -1
  407. package/dist/registries/services.js +0 -80
  408. package/dist/registries/services.js.map +0 -1
  409. package/dist/registries/services.mjs +0 -81
  410. package/dist/registries/services.mjs.map +0 -1
  411. package/dist/registries/validators.js +0 -25
  412. package/dist/registries/validators.js.map +0 -1
  413. package/dist/registries/validators.mjs +0 -24
  414. package/dist/registries/validators.mjs.map +0 -1
  415. package/dist/services/auth/index.js +0 -81
  416. package/dist/services/auth/index.js.map +0 -1
  417. package/dist/services/auth/index.mjs +0 -80
  418. package/dist/services/auth/index.mjs.map +0 -1
  419. package/dist/services/config.js +0 -47
  420. package/dist/services/config.js.map +0 -1
  421. package/dist/services/config.mjs +0 -47
  422. package/dist/services/config.mjs.map +0 -1
  423. package/dist/services/content-api/index.js +0 -85
  424. package/dist/services/content-api/index.js.map +0 -1
  425. package/dist/services/content-api/index.mjs +0 -84
  426. package/dist/services/content-api/index.mjs.map +0 -1
  427. package/dist/services/content-api/permissions/engine.js +0 -7
  428. package/dist/services/content-api/permissions/engine.js.map +0 -1
  429. package/dist/services/content-api/permissions/engine.mjs +0 -6
  430. package/dist/services/content-api/permissions/engine.mjs.map +0 -1
  431. package/dist/services/content-api/permissions/index.js +0 -87
  432. package/dist/services/content-api/permissions/index.js.map +0 -1
  433. package/dist/services/content-api/permissions/index.mjs +0 -86
  434. package/dist/services/content-api/permissions/index.mjs.map +0 -1
  435. package/dist/services/content-api/permissions/providers/action.js +0 -16
  436. package/dist/services/content-api/permissions/providers/action.js.map +0 -1
  437. package/dist/services/content-api/permissions/providers/action.mjs +0 -17
  438. package/dist/services/content-api/permissions/providers/action.mjs.map +0 -1
  439. package/dist/services/content-api/permissions/providers/condition.js +0 -16
  440. package/dist/services/content-api/permissions/providers/condition.js.map +0 -1
  441. package/dist/services/content-api/permissions/providers/condition.mjs +0 -17
  442. package/dist/services/content-api/permissions/providers/condition.mjs.map +0 -1
  443. package/dist/services/core-store.js +0 -107
  444. package/dist/services/core-store.js.map +0 -1
  445. package/dist/services/core-store.mjs +0 -107
  446. package/dist/services/core-store.mjs.map +0 -1
  447. package/dist/services/cron.js +0 -63
  448. package/dist/services/cron.js.map +0 -1
  449. package/dist/services/cron.mjs +0 -64
  450. package/dist/services/cron.mjs.map +0 -1
  451. package/dist/services/custom-fields.js +0 -10
  452. package/dist/services/custom-fields.js.map +0 -1
  453. package/dist/services/custom-fields.mjs +0 -11
  454. package/dist/services/custom-fields.mjs.map +0 -1
  455. package/dist/services/document-service/attributes/index.js +0 -22
  456. package/dist/services/document-service/attributes/index.js.map +0 -1
  457. package/dist/services/document-service/attributes/index.mjs +0 -22
  458. package/dist/services/document-service/attributes/index.mjs.map +0 -1
  459. package/dist/services/document-service/attributes/transforms.js +0 -20
  460. package/dist/services/document-service/attributes/transforms.js.map +0 -1
  461. package/dist/services/document-service/attributes/transforms.mjs +0 -19
  462. package/dist/services/document-service/attributes/transforms.mjs.map +0 -1
  463. package/dist/services/document-service/common.js +0 -7
  464. package/dist/services/document-service/common.js.map +0 -1
  465. package/dist/services/document-service/common.mjs +0 -7
  466. package/dist/services/document-service/common.mjs.map +0 -1
  467. package/dist/services/document-service/components.js +0 -289
  468. package/dist/services/document-service/components.js.map +0 -1
  469. package/dist/services/document-service/components.mjs +0 -287
  470. package/dist/services/document-service/components.mjs.map +0 -1
  471. package/dist/services/document-service/document-engine.d.ts +0 -2
  472. package/dist/services/document-service/document-engine.d.ts.map +0 -1
  473. package/dist/services/document-service/draft-and-publish.js +0 -69
  474. package/dist/services/document-service/draft-and-publish.js.map +0 -1
  475. package/dist/services/document-service/draft-and-publish.mjs +0 -69
  476. package/dist/services/document-service/draft-and-publish.mjs.map +0 -1
  477. package/dist/services/document-service/entries.js +0 -62
  478. package/dist/services/document-service/entries.js.map +0 -1
  479. package/dist/services/document-service/entries.mjs +0 -62
  480. package/dist/services/document-service/entries.mjs.map +0 -1
  481. package/dist/services/document-service/index.js +0 -28
  482. package/dist/services/document-service/index.js.map +0 -1
  483. package/dist/services/document-service/index.mjs +0 -28
  484. package/dist/services/document-service/index.mjs.map +0 -1
  485. package/dist/services/document-service/internationalization.js +0 -54
  486. package/dist/services/document-service/internationalization.js.map +0 -1
  487. package/dist/services/document-service/internationalization.mjs +0 -54
  488. package/dist/services/document-service/internationalization.mjs.map +0 -1
  489. package/dist/services/document-service/middlewares/errors.js +0 -25
  490. package/dist/services/document-service/middlewares/errors.js.map +0 -1
  491. package/dist/services/document-service/middlewares/errors.mjs +0 -25
  492. package/dist/services/document-service/middlewares/errors.mjs.map +0 -1
  493. package/dist/services/document-service/middlewares/middleware-manager.js +0 -46
  494. package/dist/services/document-service/middlewares/middleware-manager.js.map +0 -1
  495. package/dist/services/document-service/middlewares/middleware-manager.mjs +0 -46
  496. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +0 -1
  497. package/dist/services/document-service/params.js +0 -8
  498. package/dist/services/document-service/params.js.map +0 -1
  499. package/dist/services/document-service/params.mjs +0 -8
  500. package/dist/services/document-service/params.mjs.map +0 -1
  501. package/dist/services/document-service/repository.js +0 -276
  502. package/dist/services/document-service/repository.js.map +0 -1
  503. package/dist/services/document-service/repository.mjs +0 -276
  504. package/dist/services/document-service/repository.mjs.map +0 -1
  505. package/dist/services/document-service/transform/data.js +0 -15
  506. package/dist/services/document-service/transform/data.js.map +0 -1
  507. package/dist/services/document-service/transform/data.mjs +0 -15
  508. package/dist/services/document-service/transform/data.mjs.map +0 -1
  509. package/dist/services/document-service/transform/fields.js +0 -24
  510. package/dist/services/document-service/transform/fields.js.map +0 -1
  511. package/dist/services/document-service/transform/fields.mjs +0 -24
  512. package/dist/services/document-service/transform/fields.mjs.map +0 -1
  513. package/dist/services/document-service/transform/id-map.js +0 -78
  514. package/dist/services/document-service/transform/id-map.js.map +0 -1
  515. package/dist/services/document-service/transform/id-map.mjs +0 -78
  516. package/dist/services/document-service/transform/id-map.mjs.map +0 -1
  517. package/dist/services/document-service/transform/id-transform.js +0 -33
  518. package/dist/services/document-service/transform/id-transform.js.map +0 -1
  519. package/dist/services/document-service/transform/id-transform.mjs +0 -33
  520. package/dist/services/document-service/transform/id-transform.mjs.map +0 -1
  521. package/dist/services/document-service/transform/populate.js +0 -21
  522. package/dist/services/document-service/transform/populate.js.map +0 -1
  523. package/dist/services/document-service/transform/populate.mjs +0 -21
  524. package/dist/services/document-service/transform/populate.mjs.map +0 -1
  525. package/dist/services/document-service/transform/query.js +0 -9
  526. package/dist/services/document-service/transform/query.js.map +0 -1
  527. package/dist/services/document-service/transform/query.mjs +0 -9
  528. package/dist/services/document-service/transform/query.mjs.map +0 -1
  529. package/dist/services/document-service/transform/relations/extract/data-ids.js +0 -54
  530. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +0 -1
  531. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +0 -54
  532. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +0 -1
  533. package/dist/services/document-service/transform/relations/transform/data-ids.js +0 -73
  534. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +0 -1
  535. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +0 -73
  536. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +0 -1
  537. package/dist/services/document-service/transform/relations/transform/default-locale.js +0 -32
  538. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +0 -1
  539. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +0 -32
  540. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +0 -1
  541. package/dist/services/document-service/transform/relations/utils/dp.js +0 -30
  542. package/dist/services/document-service/transform/relations/utils/dp.js.map +0 -1
  543. package/dist/services/document-service/transform/relations/utils/dp.mjs +0 -30
  544. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +0 -1
  545. package/dist/services/document-service/transform/relations/utils/i18n.js +0 -25
  546. package/dist/services/document-service/transform/relations/utils/i18n.js.map +0 -1
  547. package/dist/services/document-service/transform/relations/utils/i18n.mjs +0 -25
  548. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +0 -1
  549. package/dist/services/document-service/transform/relations/utils/map-relation.js +0 -87
  550. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +0 -1
  551. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +0 -87
  552. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +0 -1
  553. package/dist/services/document-service/utils/populate.js +0 -41
  554. package/dist/services/document-service/utils/populate.js.map +0 -1
  555. package/dist/services/document-service/utils/populate.mjs +0 -41
  556. package/dist/services/document-service/utils/populate.mjs.map +0 -1
  557. package/dist/services/entity-service/index.js +0 -169
  558. package/dist/services/entity-service/index.js.map +0 -1
  559. package/dist/services/entity-service/index.mjs +0 -167
  560. package/dist/services/entity-service/index.mjs.map +0 -1
  561. package/dist/services/entity-validator/blocks-validator.js +0 -127
  562. package/dist/services/entity-validator/blocks-validator.js.map +0 -1
  563. package/dist/services/entity-validator/blocks-validator.mjs +0 -128
  564. package/dist/services/entity-validator/blocks-validator.mjs.map +0 -1
  565. package/dist/services/entity-validator/index.js +0 -333
  566. package/dist/services/entity-validator/index.js.map +0 -1
  567. package/dist/services/entity-validator/index.mjs +0 -332
  568. package/dist/services/entity-validator/index.mjs.map +0 -1
  569. package/dist/services/entity-validator/validators.js +0 -126
  570. package/dist/services/entity-validator/validators.js.map +0 -1
  571. package/dist/services/entity-validator/validators.mjs +0 -124
  572. package/dist/services/entity-validator/validators.mjs.map +0 -1
  573. package/dist/services/errors.js +0 -76
  574. package/dist/services/errors.js.map +0 -1
  575. package/dist/services/errors.mjs +0 -74
  576. package/dist/services/errors.mjs.map +0 -1
  577. package/dist/services/event-hub.js +0 -67
  578. package/dist/services/event-hub.js.map +0 -1
  579. package/dist/services/event-hub.mjs +0 -68
  580. package/dist/services/event-hub.mjs.map +0 -1
  581. package/dist/services/features.js +0 -17
  582. package/dist/services/features.js.map +0 -1
  583. package/dist/services/features.mjs +0 -17
  584. package/dist/services/features.mjs.map +0 -1
  585. package/dist/services/fs.js +0 -51
  586. package/dist/services/fs.js.map +0 -1
  587. package/dist/services/fs.mjs +0 -49
  588. package/dist/services/fs.mjs.map +0 -1
  589. package/dist/services/metrics/admin-user-hash.js +0 -14
  590. package/dist/services/metrics/admin-user-hash.js.map +0 -1
  591. package/dist/services/metrics/admin-user-hash.mjs +0 -12
  592. package/dist/services/metrics/admin-user-hash.mjs.map +0 -1
  593. package/dist/services/metrics/index.js +0 -45
  594. package/dist/services/metrics/index.js.map +0 -1
  595. package/dist/services/metrics/index.mjs +0 -46
  596. package/dist/services/metrics/index.mjs.map +0 -1
  597. package/dist/services/metrics/is-truthy.js +0 -9
  598. package/dist/services/metrics/is-truthy.js.map +0 -1
  599. package/dist/services/metrics/is-truthy.mjs +0 -8
  600. package/dist/services/metrics/is-truthy.mjs.map +0 -1
  601. package/dist/services/metrics/middleware.js +0 -25
  602. package/dist/services/metrics/middleware.js.map +0 -1
  603. package/dist/services/metrics/middleware.mjs +0 -26
  604. package/dist/services/metrics/middleware.mjs.map +0 -1
  605. package/dist/services/metrics/rate-limiter.js +0 -21
  606. package/dist/services/metrics/rate-limiter.js.map +0 -1
  607. package/dist/services/metrics/rate-limiter.mjs +0 -22
  608. package/dist/services/metrics/rate-limiter.mjs.map +0 -1
  609. package/dist/services/metrics/sender.js +0 -76
  610. package/dist/services/metrics/sender.js.map +0 -1
  611. package/dist/services/metrics/sender.mjs +0 -70
  612. package/dist/services/metrics/sender.mjs.map +0 -1
  613. package/dist/services/query-params.js +0 -12
  614. package/dist/services/query-params.js.map +0 -1
  615. package/dist/services/query-params.mjs +0 -13
  616. package/dist/services/query-params.mjs.map +0 -1
  617. package/dist/services/reloader.js +0 -36
  618. package/dist/services/reloader.js.map +0 -1
  619. package/dist/services/reloader.mjs +0 -36
  620. package/dist/services/reloader.mjs.map +0 -1
  621. package/dist/services/request-context.js +0 -13
  622. package/dist/services/request-context.js.map +0 -1
  623. package/dist/services/request-context.mjs +0 -14
  624. package/dist/services/request-context.mjs.map +0 -1
  625. package/dist/services/server/admin-api.js +0 -13
  626. package/dist/services/server/admin-api.js.map +0 -1
  627. package/dist/services/server/admin-api.mjs +0 -13
  628. package/dist/services/server/admin-api.mjs.map +0 -1
  629. package/dist/services/server/api.js +0 -30
  630. package/dist/services/server/api.js.map +0 -1
  631. package/dist/services/server/api.mjs +0 -28
  632. package/dist/services/server/api.mjs.map +0 -1
  633. package/dist/services/server/compose-endpoint.js +0 -117
  634. package/dist/services/server/compose-endpoint.js.map +0 -1
  635. package/dist/services/server/compose-endpoint.mjs +0 -116
  636. package/dist/services/server/compose-endpoint.mjs.map +0 -1
  637. package/dist/services/server/content-api.js +0 -12
  638. package/dist/services/server/content-api.js.map +0 -1
  639. package/dist/services/server/content-api.mjs +0 -12
  640. package/dist/services/server/content-api.mjs.map +0 -1
  641. package/dist/services/server/http-server.js +0 -50
  642. package/dist/services/server/http-server.js.map +0 -1
  643. package/dist/services/server/http-server.mjs +0 -48
  644. package/dist/services/server/http-server.mjs.map +0 -1
  645. package/dist/services/server/index.js +0 -87
  646. package/dist/services/server/index.js.map +0 -1
  647. package/dist/services/server/index.mjs +0 -85
  648. package/dist/services/server/index.mjs.map +0 -1
  649. package/dist/services/server/koa.js +0 -52
  650. package/dist/services/server/koa.js.map +0 -1
  651. package/dist/services/server/koa.mjs +0 -48
  652. package/dist/services/server/koa.mjs.map +0 -1
  653. package/dist/services/server/middleware.js +0 -92
  654. package/dist/services/server/middleware.js.map +0 -1
  655. package/dist/services/server/middleware.mjs +0 -90
  656. package/dist/services/server/middleware.mjs.map +0 -1
  657. package/dist/services/server/policy.js +0 -20
  658. package/dist/services/server/policy.js.map +0 -1
  659. package/dist/services/server/policy.mjs +0 -20
  660. package/dist/services/server/policy.mjs.map +0 -1
  661. package/dist/services/server/register-middlewares.js +0 -72
  662. package/dist/services/server/register-middlewares.js.map +0 -1
  663. package/dist/services/server/register-middlewares.mjs +0 -73
  664. package/dist/services/server/register-middlewares.mjs.map +0 -1
  665. package/dist/services/server/register-routes.js +0 -76
  666. package/dist/services/server/register-routes.js.map +0 -1
  667. package/dist/services/server/register-routes.mjs +0 -75
  668. package/dist/services/server/register-routes.mjs.map +0 -1
  669. package/dist/services/server/routing.js +0 -91
  670. package/dist/services/server/routing.js.map +0 -1
  671. package/dist/services/server/routing.mjs +0 -89
  672. package/dist/services/server/routing.mjs.map +0 -1
  673. package/dist/services/utils/dynamic-zones.js +0 -17
  674. package/dist/services/utils/dynamic-zones.js.map +0 -1
  675. package/dist/services/utils/dynamic-zones.mjs +0 -18
  676. package/dist/services/utils/dynamic-zones.mjs.map +0 -1
  677. package/dist/services/webhook-runner.js +0 -133
  678. package/dist/services/webhook-runner.js.map +0 -1
  679. package/dist/services/webhook-runner.mjs +0 -131
  680. package/dist/services/webhook-runner.mjs.map +0 -1
  681. package/dist/services/webhook-store.js +0 -103
  682. package/dist/services/webhook-store.js.map +0 -1
  683. package/dist/services/webhook-store.mjs +0 -103
  684. package/dist/services/webhook-store.mjs.map +0 -1
  685. package/dist/services/worker-queue.js +0 -56
  686. package/dist/services/worker-queue.js.map +0 -1
  687. package/dist/services/worker-queue.mjs +0 -55
  688. package/dist/services/worker-queue.mjs.map +0 -1
  689. package/dist/utils/convert-custom-field-type.js +0 -24
  690. package/dist/utils/convert-custom-field-type.js.map +0 -1
  691. package/dist/utils/convert-custom-field-type.mjs +0 -24
  692. package/dist/utils/convert-custom-field-type.mjs.map +0 -1
  693. package/dist/utils/cron.js +0 -38
  694. package/dist/utils/cron.js.map +0 -1
  695. package/dist/utils/cron.mjs +0 -38
  696. package/dist/utils/cron.mjs.map +0 -1
  697. package/dist/utils/fetch.js +0 -20
  698. package/dist/utils/fetch.js.map +0 -1
  699. package/dist/utils/fetch.mjs +0 -20
  700. package/dist/utils/fetch.mjs.map +0 -1
  701. package/dist/utils/filepath-to-prop-path.js +0 -12
  702. package/dist/utils/filepath-to-prop-path.js.map +0 -1
  703. package/dist/utils/filepath-to-prop-path.mjs +0 -10
  704. package/dist/utils/filepath-to-prop-path.mjs.map +0 -1
  705. package/dist/utils/is-initialized.js +0 -16
  706. package/dist/utils/is-initialized.js.map +0 -1
  707. package/dist/utils/is-initialized.mjs +0 -16
  708. package/dist/utils/is-initialized.mjs.map +0 -1
  709. package/dist/utils/lifecycles.js +0 -9
  710. package/dist/utils/lifecycles.js.map +0 -1
  711. package/dist/utils/lifecycles.mjs +0 -9
  712. package/dist/utils/lifecycles.mjs.map +0 -1
  713. package/dist/utils/load-config-file.js +0 -45
  714. package/dist/utils/load-config-file.js.map +0 -1
  715. package/dist/utils/load-config-file.mjs +0 -42
  716. package/dist/utils/load-config-file.mjs.map +0 -1
  717. package/dist/utils/load-files.js +0 -39
  718. package/dist/utils/load-files.js.map +0 -1
  719. package/dist/utils/load-files.mjs +0 -35
  720. package/dist/utils/load-files.mjs.map +0 -1
  721. package/dist/utils/open-browser.js +0 -11
  722. package/dist/utils/open-browser.js.map +0 -1
  723. package/dist/utils/open-browser.mjs +0 -9
  724. package/dist/utils/open-browser.mjs.map +0 -1
  725. package/dist/utils/resolve-working-dirs.js +0 -13
  726. package/dist/utils/resolve-working-dirs.js.map +0 -1
  727. package/dist/utils/resolve-working-dirs.mjs +0 -11
  728. package/dist/utils/resolve-working-dirs.mjs.map +0 -1
  729. package/dist/utils/signals.js +0 -17
  730. package/dist/utils/signals.js.map +0 -1
  731. package/dist/utils/signals.mjs +0 -17
  732. package/dist/utils/signals.mjs.map +0 -1
  733. package/dist/utils/startup-logger.js +0 -81
  734. package/dist/utils/startup-logger.js.map +0 -1
  735. package/dist/utils/startup-logger.mjs +0 -77
  736. package/dist/utils/startup-logger.mjs.map +0 -1
  737. package/dist/utils/transform-content-types-to-models.js +0 -275
  738. package/dist/utils/transform-content-types-to-models.js.map +0 -1
  739. package/dist/utils/transform-content-types-to-models.mjs +0 -272
  740. package/dist/utils/transform-content-types-to-models.mjs.map +0 -1
  741. package/dist/utils/update-notifier/index.js +0 -85
  742. package/dist/utils/update-notifier/index.js.map +0 -1
  743. package/dist/utils/update-notifier/index.mjs +0 -78
  744. package/dist/utils/update-notifier/index.mjs.map +0 -1
@@ -1,64 +0,0 @@
1
- import { Job } from "node-schedule";
2
- import { isFunction } from "lodash/fp";
3
- const createCronService = () => {
4
- let jobsSpecs = [];
5
- let running = false;
6
- return {
7
- add(tasks = {}) {
8
- for (const taskExpression of Object.keys(tasks)) {
9
- const taskValue = tasks[taskExpression];
10
- let fn;
11
- let options;
12
- let taskName;
13
- if (isFunction(taskValue)) {
14
- taskName = null;
15
- fn = taskValue.bind(tasks);
16
- options = taskExpression;
17
- } else if (isFunction(taskValue.task)) {
18
- taskName = taskExpression;
19
- fn = taskValue.task.bind(taskValue);
20
- options = taskValue.options;
21
- } else {
22
- throw new Error(
23
- `Could not schedule a cron job for "${taskExpression}": no function found.`
24
- );
25
- }
26
- const fnWithStrapi = (...args) => fn({ strapi }, ...args);
27
- const job = new Job(fnWithStrapi);
28
- jobsSpecs.push({ job, options, name: taskName });
29
- if (running) {
30
- job.schedule(options);
31
- }
32
- }
33
- return this;
34
- },
35
- remove(name) {
36
- if (!name) {
37
- throw new Error("You must provide a name to remove a cron job.");
38
- }
39
- jobsSpecs.filter(({ name: jobSpecName }) => jobSpecName === name).forEach(({ job }) => job.cancel());
40
- jobsSpecs = jobsSpecs.filter(({ name: jobSpecName }) => jobSpecName !== name);
41
- return this;
42
- },
43
- start() {
44
- jobsSpecs.forEach(({ job, options }) => job.schedule(options));
45
- running = true;
46
- return this;
47
- },
48
- stop() {
49
- jobsSpecs.forEach(({ job }) => job.cancel());
50
- running = false;
51
- return this;
52
- },
53
- destroy() {
54
- this.stop();
55
- jobsSpecs = [];
56
- return this;
57
- },
58
- jobs: jobsSpecs
59
- };
60
- };
61
- export {
62
- createCronService as default
63
- };
64
- //# sourceMappingURL=cron.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"cron.mjs","sources":["../../src/services/cron.ts"],"sourcesContent":["import { Job } from 'node-schedule';\nimport { isFunction } from 'lodash/fp';\nimport type { Core } from '@strapi/types';\n\ninterface JobSpec {\n job: Job;\n options: string | number | Date;\n name: string | null;\n}\n\ntype TaskFn = ({ strapi }: { strapi: Core.Strapi }, ...args: unknown[]) => Promise<unknown>;\n\ntype Task =\n | TaskFn\n | {\n task: TaskFn;\n options: string;\n };\n\ninterface Tasks {\n [key: string]: Task;\n}\n\nconst createCronService = () => {\n let jobsSpecs: JobSpec[] = [];\n let running = false;\n\n return {\n add(tasks: Tasks = {}) {\n for (const taskExpression of Object.keys(tasks)) {\n const taskValue = tasks[taskExpression];\n\n let fn: TaskFn;\n let options: string | number | Date;\n let taskName: string | null;\n if (isFunction(taskValue)) {\n // don't use task name if key is the rule\n taskName = null;\n fn = taskValue.bind(tasks);\n options = taskExpression;\n } else if (isFunction(taskValue.task)) {\n // set task name if key is not the rule\n taskName = taskExpression;\n fn = taskValue.task.bind(taskValue);\n options = taskValue.options;\n } else {\n throw new Error(\n `Could not schedule a cron job for \"${taskExpression}\": no function found.`\n );\n }\n\n const fnWithStrapi = (...args: unknown[]) => fn({ strapi }, ...args);\n\n // const job = new Job(null, fnWithStrapi);\n const job = new Job(fnWithStrapi);\n jobsSpecs.push({ job, options, name: taskName });\n\n if (running) {\n job.schedule(options);\n }\n }\n return this;\n },\n\n remove(name: string) {\n if (!name) {\n throw new Error('You must provide a name to remove a cron job.');\n }\n\n jobsSpecs\n .filter(({ name: jobSpecName }) => jobSpecName === name)\n .forEach(({ job }) => job.cancel());\n\n jobsSpecs = jobsSpecs.filter(({ name: jobSpecName }) => jobSpecName !== name);\n return this;\n },\n\n start() {\n jobsSpecs.forEach(({ job, options }) => job.schedule(options));\n running = true;\n return this;\n },\n\n stop() {\n jobsSpecs.forEach(({ job }) => job.cancel());\n running = false;\n return this;\n },\n\n destroy() {\n this.stop();\n jobsSpecs = [];\n return this;\n },\n jobs: jobsSpecs,\n };\n};\n\nexport default createCronService;\n"],"names":[],"mappings":";;AAuBA,MAAM,oBAAoB,MAAM;AAC9B,MAAI,YAAuB,CAAA;AAC3B,MAAI,UAAU;AAEP,SAAA;AAAA,IACL,IAAI,QAAe,IAAI;AACrB,iBAAW,kBAAkB,OAAO,KAAK,KAAK,GAAG;AACzC,cAAA,YAAY,MAAM,cAAc;AAElC,YAAA;AACA,YAAA;AACA,YAAA;AACA,YAAA,WAAW,SAAS,GAAG;AAEd,qBAAA;AACN,eAAA,UAAU,KAAK,KAAK;AACf,oBAAA;AAAA,QACD,WAAA,WAAW,UAAU,IAAI,GAAG;AAE1B,qBAAA;AACN,eAAA,UAAU,KAAK,KAAK,SAAS;AAClC,oBAAU,UAAU;AAAA,QAAA,OACf;AACL,gBAAM,IAAI;AAAA,YACR,sCAAsC,cAAc;AAAA,UAAA;AAAA,QAExD;AAEM,cAAA,eAAe,IAAI,SAAoB,GAAG,EAAE,OAAO,GAAG,GAAG,IAAI;AAG7D,cAAA,MAAM,IAAI,IAAI,YAAY;AAChC,kBAAU,KAAK,EAAE,KAAK,SAAS,MAAM,UAAU;AAE/C,YAAI,SAAS;AACX,cAAI,SAAS,OAAO;AAAA,QACtB;AAAA,MACF;AACO,aAAA;AAAA,IACT;AAAA,IAEA,OAAO,MAAc;AACnB,UAAI,CAAC,MAAM;AACH,cAAA,IAAI,MAAM,+CAA+C;AAAA,MACjE;AAEA,gBACG,OAAO,CAAC,EAAE,MAAM,YAAA,MAAkB,gBAAgB,IAAI,EACtD,QAAQ,CAAC,EAAE,IAAA,MAAU,IAAI,OAAQ,CAAA;AAExB,kBAAA,UAAU,OAAO,CAAC,EAAE,MAAM,YAAY,MAAM,gBAAgB,IAAI;AACrE,aAAA;AAAA,IACT;AAAA,IAEA,QAAQ;AACI,gBAAA,QAAQ,CAAC,EAAE,KAAK,QAAc,MAAA,IAAI,SAAS,OAAO,CAAC;AACnD,gBAAA;AACH,aAAA;AAAA,IACT;AAAA,IAEA,OAAO;AACL,gBAAU,QAAQ,CAAC,EAAE,IAAU,MAAA,IAAI,QAAQ;AACjC,gBAAA;AACH,aAAA;AAAA,IACT;AAAA,IAEA,UAAU;AACR,WAAK,KAAK;AACV,kBAAY,CAAA;AACL,aAAA;AAAA,IACT;AAAA,IACA,MAAM;AAAA,EAAA;AAEV;"}
@@ -1,10 +0,0 @@
1
- "use strict";
2
- const createCustomFields = (strapi) => {
3
- return {
4
- register(customField) {
5
- strapi.get("custom-fields").add(customField);
6
- }
7
- };
8
- };
9
- module.exports = createCustomFields;
10
- //# sourceMappingURL=custom-fields.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"custom-fields.js","sources":["../../src/services/custom-fields.ts"],"sourcesContent":["import type { Core, Modules } from '@strapi/types';\n\nconst createCustomFields = (strapi: Core.Strapi): Modules.CustomFields.CustomFields => {\n return {\n register(customField) {\n strapi.get('custom-fields').add(customField);\n },\n };\n};\n\nexport default createCustomFields;\n"],"names":[],"mappings":";AAEM,MAAA,qBAAqB,CAAC,WAA2D;AAC9E,SAAA;AAAA,IACL,SAAS,aAAa;AACpB,aAAO,IAAI,eAAe,EAAE,IAAI,WAAW;AAAA,IAC7C;AAAA,EAAA;AAEJ;;"}
@@ -1,11 +0,0 @@
1
- const createCustomFields = (strapi) => {
2
- return {
3
- register(customField) {
4
- strapi.get("custom-fields").add(customField);
5
- }
6
- };
7
- };
8
- export {
9
- createCustomFields as default
10
- };
11
- //# sourceMappingURL=custom-fields.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"custom-fields.mjs","sources":["../../src/services/custom-fields.ts"],"sourcesContent":["import type { Core, Modules } from '@strapi/types';\n\nconst createCustomFields = (strapi: Core.Strapi): Modules.CustomFields.CustomFields => {\n return {\n register(customField) {\n strapi.get('custom-fields').add(customField);\n },\n };\n};\n\nexport default createCustomFields;\n"],"names":[],"mappings":"AAEM,MAAA,qBAAqB,CAAC,WAA2D;AAC9E,SAAA;AAAA,IACL,SAAS,aAAa;AACpB,aAAO,IAAI,eAAe,EAAE,IAAI,WAAW;AAAA,IAC7C;AAAA,EAAA;AAEJ;"}
@@ -1,22 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const transforms = require("./transforms.js");
4
- const applyTransforms = (data, context) => {
5
- const { contentType } = context;
6
- const attributeNames = Object.keys(data);
7
- for (const attributeName of attributeNames) {
8
- const value = data[attributeName];
9
- const attribute = contentType.attributes[attributeName];
10
- if (!attribute) {
11
- continue;
12
- }
13
- const transform = transforms[attribute.type];
14
- if (transform) {
15
- const attributeContext = { ...context, attributeName, attribute };
16
- data[attributeName] = transform(value, attributeContext);
17
- }
18
- }
19
- return data;
20
- };
21
- exports.applyTransforms = applyTransforms;
22
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sources":["../../../../src/services/document-service/attributes/index.ts"],"sourcesContent":["import type { UID, Modules, Schema } from '@strapi/types';\nimport transforms from './transforms';\n\nconst applyTransforms = <TUID extends UID.ContentType>(\n data: Modules.EntityService.Params.Data.Input<TUID>,\n context: {\n contentType: Schema.ContentType<TUID>;\n }\n) => {\n const { contentType } = context;\n\n const attributeNames = Object.keys(data) as Array<keyof typeof data & string>;\n\n for (const attributeName of attributeNames) {\n const value = data[attributeName];\n\n const attribute = contentType.attributes[attributeName];\n\n if (!attribute) {\n continue;\n }\n\n const transform = transforms[attribute.type];\n\n if (transform) {\n const attributeContext = { ...context, attributeName, attribute };\n\n data[attributeName] = transform(value, attributeContext);\n }\n }\n\n return data;\n};\n\nexport { applyTransforms };\n"],"names":[],"mappings":";;;AAGM,MAAA,kBAAkB,CACtB,MACA,YAGG;AACG,QAAA,EAAE,YAAgB,IAAA;AAElB,QAAA,iBAAiB,OAAO,KAAK,IAAI;AAEvC,aAAW,iBAAiB,gBAAgB;AACpC,UAAA,QAAQ,KAAK,aAAa;AAE1B,UAAA,YAAY,YAAY,WAAW,aAAa;AAEtD,QAAI,CAAC,WAAW;AACd;AAAA,IACF;AAEM,UAAA,YAAY,WAAW,UAAU,IAAI;AAE3C,QAAI,WAAW;AACb,YAAM,mBAAmB,EAAE,GAAG,SAAS,eAAe,UAAU;AAEhE,WAAK,aAAa,IAAI,UAAU,OAAO,gBAAgB;AAAA,IACzD;AAAA,EACF;AAEO,SAAA;AACT;;"}
@@ -1,22 +0,0 @@
1
- import transforms from "./transforms.mjs";
2
- const applyTransforms = (data, context) => {
3
- const { contentType } = context;
4
- const attributeNames = Object.keys(data);
5
- for (const attributeName of attributeNames) {
6
- const value = data[attributeName];
7
- const attribute = contentType.attributes[attributeName];
8
- if (!attribute) {
9
- continue;
10
- }
11
- const transform = transforms[attribute.type];
12
- if (transform) {
13
- const attributeContext = { ...context, attributeName, attribute };
14
- data[attributeName] = transform(value, attributeContext);
15
- }
16
- }
17
- return data;
18
- };
19
- export {
20
- applyTransforms
21
- };
22
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.mjs","sources":["../../../../src/services/document-service/attributes/index.ts"],"sourcesContent":["import type { UID, Modules, Schema } from '@strapi/types';\nimport transforms from './transforms';\n\nconst applyTransforms = <TUID extends UID.ContentType>(\n data: Modules.EntityService.Params.Data.Input<TUID>,\n context: {\n contentType: Schema.ContentType<TUID>;\n }\n) => {\n const { contentType } = context;\n\n const attributeNames = Object.keys(data) as Array<keyof typeof data & string>;\n\n for (const attributeName of attributeNames) {\n const value = data[attributeName];\n\n const attribute = contentType.attributes[attributeName];\n\n if (!attribute) {\n continue;\n }\n\n const transform = transforms[attribute.type];\n\n if (transform) {\n const attributeContext = { ...context, attributeName, attribute };\n\n data[attributeName] = transform(value, attributeContext);\n }\n }\n\n return data;\n};\n\nexport { applyTransforms };\n"],"names":[],"mappings":";AAGM,MAAA,kBAAkB,CACtB,MACA,YAGG;AACG,QAAA,EAAE,YAAgB,IAAA;AAElB,QAAA,iBAAiB,OAAO,KAAK,IAAI;AAEvC,aAAW,iBAAiB,gBAAgB;AACpC,UAAA,QAAQ,KAAK,aAAa;AAE1B,UAAA,YAAY,YAAY,WAAW,aAAa;AAEtD,QAAI,CAAC,WAAW;AACd;AAAA,IACF;AAEM,UAAA,YAAY,WAAW,UAAU,IAAI;AAE3C,QAAI,WAAW;AACb,YAAM,mBAAmB,EAAE,GAAG,SAAS,eAAe,UAAU;AAEhE,WAAK,aAAa,IAAI,UAAU,OAAO,gBAAgB;AAAA,IACzD;AAAA,EACF;AAEO,SAAA;AACT;"}
@@ -1,20 +0,0 @@
1
- "use strict";
2
- const _ = require("lodash/fp");
3
- const bcrypt = require("bcryptjs");
4
- const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
5
- const bcrypt__default = /* @__PURE__ */ _interopDefault(bcrypt);
6
- const transforms = {
7
- password(value, context) {
8
- const { attribute } = context;
9
- if (attribute.type !== "password") {
10
- throw new Error("Invalid attribute type");
11
- }
12
- if (!_.isString(value) && !(value instanceof Buffer)) {
13
- return value;
14
- }
15
- const rounds = _.toNumber(_.getOr(10, "encryption.rounds", attribute));
16
- return bcrypt__default.default.hashSync(value.toString(), rounds);
17
- }
18
- };
19
- module.exports = transforms;
20
- //# sourceMappingURL=transforms.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"transforms.js","sources":["../../../../src/services/document-service/attributes/transforms.ts"],"sourcesContent":["import { getOr, toNumber, isString } from 'lodash/fp';\nimport type { Schema } from '@strapi/types';\nimport bcrypt from 'bcryptjs';\n\ntype Transforms = {\n [TKind in Schema.Attribute.Kind]?: (\n value: unknown,\n context: {\n attribute: Schema.Attribute.AnyAttribute;\n attributeName: string;\n }\n ) => any;\n};\n\nconst transforms: Transforms = {\n password(value, context) {\n const { attribute } = context;\n\n if (attribute.type !== 'password') {\n throw new Error('Invalid attribute type');\n }\n\n if (!isString(value) && !(value instanceof Buffer)) {\n return value;\n }\n\n const rounds = toNumber(getOr(10, 'encryption.rounds', attribute));\n\n return bcrypt.hashSync(value.toString(), rounds);\n },\n};\n\nexport default transforms;\n"],"names":["isString","toNumber","getOr","bcrypt"],"mappings":";;;;;AAcA,MAAM,aAAyB;AAAA,EAC7B,SAAS,OAAO,SAAS;AACjB,UAAA,EAAE,UAAc,IAAA;AAElB,QAAA,UAAU,SAAS,YAAY;AAC3B,YAAA,IAAI,MAAM,wBAAwB;AAAA,IAC1C;AAEA,QAAI,CAACA,EAAS,SAAA,KAAK,KAAK,EAAE,iBAAiB,SAAS;AAC3C,aAAA;AAAA,IACT;AAEA,UAAM,SAASC,EAAAA,SAASC,EAAA,MAAM,IAAI,qBAAqB,SAAS,CAAC;AAEjE,WAAOC,gBAAAA,QAAO,SAAS,MAAM,YAAY,MAAM;AAAA,EACjD;AACF;;"}
@@ -1,19 +0,0 @@
1
- import { isString, toNumber, getOr } from "lodash/fp";
2
- import bcrypt from "bcryptjs";
3
- const transforms = {
4
- password(value, context) {
5
- const { attribute } = context;
6
- if (attribute.type !== "password") {
7
- throw new Error("Invalid attribute type");
8
- }
9
- if (!isString(value) && !(value instanceof Buffer)) {
10
- return value;
11
- }
12
- const rounds = toNumber(getOr(10, "encryption.rounds", attribute));
13
- return bcrypt.hashSync(value.toString(), rounds);
14
- }
15
- };
16
- export {
17
- transforms as default
18
- };
19
- //# sourceMappingURL=transforms.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"transforms.mjs","sources":["../../../../src/services/document-service/attributes/transforms.ts"],"sourcesContent":["import { getOr, toNumber, isString } from 'lodash/fp';\nimport type { Schema } from '@strapi/types';\nimport bcrypt from 'bcryptjs';\n\ntype Transforms = {\n [TKind in Schema.Attribute.Kind]?: (\n value: unknown,\n context: {\n attribute: Schema.Attribute.AnyAttribute;\n attributeName: string;\n }\n ) => any;\n};\n\nconst transforms: Transforms = {\n password(value, context) {\n const { attribute } = context;\n\n if (attribute.type !== 'password') {\n throw new Error('Invalid attribute type');\n }\n\n if (!isString(value) && !(value instanceof Buffer)) {\n return value;\n }\n\n const rounds = toNumber(getOr(10, 'encryption.rounds', attribute));\n\n return bcrypt.hashSync(value.toString(), rounds);\n },\n};\n\nexport default transforms;\n"],"names":[],"mappings":";;AAcA,MAAM,aAAyB;AAAA,EAC7B,SAAS,OAAO,SAAS;AACjB,UAAA,EAAE,UAAc,IAAA;AAElB,QAAA,UAAU,SAAS,YAAY;AAC3B,YAAA,IAAI,MAAM,wBAAwB;AAAA,IAC1C;AAEA,QAAI,CAAC,SAAS,KAAK,KAAK,EAAE,iBAAiB,SAAS;AAC3C,aAAA;AAAA,IACT;AAEA,UAAM,SAAS,SAAS,MAAM,IAAI,qBAAqB,SAAS,CAAC;AAEjE,WAAO,OAAO,SAAS,MAAM,YAAY,MAAM;AAAA,EACjD;AACF;"}
@@ -1,7 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const wrapInTransaction = (fn) => {
4
- return (...args) => strapi.db.transaction?.(() => fn(...args));
5
- };
6
- exports.wrapInTransaction = wrapInTransaction;
7
- //# sourceMappingURL=common.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"common.js","sources":["../../../src/services/document-service/common.ts"],"sourcesContent":["import type { UID, Modules } from '@strapi/types';\n\nexport type RepositoryFactoryMethod = <TContentTypeUID extends UID.ContentType>(\n uid: TContentTypeUID\n) => Modules.Documents.ServiceInstance<TContentTypeUID>;\n\nexport const wrapInTransaction = (fn: (...args: any) => any) => {\n return (...args: any[]) => strapi.db.transaction?.(() => fn(...args));\n};\n"],"names":[],"mappings":";;AAMa,MAAA,oBAAoB,CAAC,OAA8B;AACvD,SAAA,IAAI,SAAgB,OAAO,GAAG,cAAc,MAAM,GAAG,GAAG,IAAI,CAAC;AACtE;;"}
@@ -1,7 +0,0 @@
1
- const wrapInTransaction = (fn) => {
2
- return (...args) => strapi.db.transaction?.(() => fn(...args));
3
- };
4
- export {
5
- wrapInTransaction
6
- };
7
- //# sourceMappingURL=common.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"common.mjs","sources":["../../../src/services/document-service/common.ts"],"sourcesContent":["import type { UID, Modules } from '@strapi/types';\n\nexport type RepositoryFactoryMethod = <TContentTypeUID extends UID.ContentType>(\n uid: TContentTypeUID\n) => Modules.Documents.ServiceInstance<TContentTypeUID>;\n\nexport const wrapInTransaction = (fn: (...args: any) => any) => {\n return (...args: any[]) => strapi.db.transaction?.(() => fn(...args));\n};\n"],"names":[],"mappings":"AAMa,MAAA,oBAAoB,CAAC,OAA8B;AACvD,SAAA,IAAI,SAAgB,OAAO,GAAG,cAAc,MAAM,GAAG,GAAG,IAAI,CAAC;AACtE;"}
@@ -1,289 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const _$1 = require("lodash");
4
- const _ = require("lodash/fp");
5
- const strapiUtils = require("@strapi/utils");
6
- const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
7
- const ___default = /* @__PURE__ */ _interopDefault(_$1);
8
- function omitComponentData(contentType, data) {
9
- const { attributes } = contentType;
10
- const componentAttributes = Object.keys(attributes).filter(
11
- (attributeName) => strapiUtils.contentTypes.isComponentAttribute(attributes[attributeName])
12
- );
13
- return _.omit(componentAttributes, data);
14
- }
15
- const createComponents = async (uid, data) => {
16
- const { attributes = {} } = strapi.getModel(uid);
17
- const componentBody = {};
18
- const attributeNames = Object.keys(attributes);
19
- for (const attributeName of attributeNames) {
20
- const attribute = attributes[attributeName];
21
- if (!_.has(attributeName, data) || !strapiUtils.contentTypes.isComponentAttribute(attribute)) {
22
- continue;
23
- }
24
- if (attribute.type === "component") {
25
- const { component: componentUID, repeatable = false } = attribute;
26
- const componentValue = data[attributeName];
27
- if (componentValue === null) {
28
- continue;
29
- }
30
- if (repeatable === true) {
31
- if (!Array.isArray(componentValue)) {
32
- throw new Error("Expected an array to create repeatable component");
33
- }
34
- const components = await strapiUtils.async.map(
35
- componentValue,
36
- (value) => createComponent(componentUID, value)
37
- );
38
- componentBody[attributeName] = components.map(({ id }) => {
39
- return {
40
- id,
41
- __pivot: {
42
- field: attributeName,
43
- component_type: componentUID
44
- }
45
- };
46
- });
47
- } else {
48
- const component = await createComponent(
49
- componentUID,
50
- componentValue
51
- );
52
- componentBody[attributeName] = {
53
- id: component.id,
54
- __pivot: {
55
- field: attributeName,
56
- component_type: componentUID
57
- }
58
- };
59
- }
60
- continue;
61
- }
62
- if (attribute.type === "dynamiczone") {
63
- const dynamiczoneValues = data[attributeName];
64
- if (!Array.isArray(dynamiczoneValues)) {
65
- throw new Error("Expected an array to create repeatable component");
66
- }
67
- const createDynamicZoneComponents = async (value) => {
68
- const { id } = await createComponent(value.__component, value);
69
- return {
70
- id,
71
- __component: value.__component,
72
- __pivot: {
73
- field: attributeName
74
- }
75
- };
76
- };
77
- componentBody[attributeName] = await strapiUtils.async.map(
78
- dynamiczoneValues,
79
- createDynamicZoneComponents
80
- );
81
- continue;
82
- }
83
- }
84
- return componentBody;
85
- };
86
- const getComponents = async (uid, entity) => {
87
- const componentAttributes = strapiUtils.contentTypes.getComponentAttributes(strapi.getModel(uid));
88
- if (___default.default.isEmpty(componentAttributes)) {
89
- return {};
90
- }
91
- return strapi.db.query(uid).load(entity, componentAttributes);
92
- };
93
- const updateComponents = async (uid, entityToUpdate, data) => {
94
- const { attributes = {} } = strapi.getModel(uid);
95
- const componentBody = {};
96
- for (const attributeName of Object.keys(attributes)) {
97
- const attribute = attributes[attributeName];
98
- if (!_.has(attributeName, data)) {
99
- continue;
100
- }
101
- if (attribute.type === "component") {
102
- const { component: componentUID, repeatable = false } = attribute;
103
- const componentValue = data[attributeName];
104
- await deleteOldComponents(uid, componentUID, entityToUpdate, attributeName, componentValue);
105
- if (repeatable === true) {
106
- if (!Array.isArray(componentValue)) {
107
- throw new Error("Expected an array to create repeatable component");
108
- }
109
- const components = await strapiUtils.async.map(
110
- componentValue,
111
- (value) => updateOrCreateComponent(componentUID, value)
112
- );
113
- componentBody[attributeName] = components.filter(___default.default.negate(___default.default.isNil)).map(({ id }) => {
114
- return {
115
- id,
116
- __pivot: {
117
- field: attributeName,
118
- component_type: componentUID
119
- }
120
- };
121
- });
122
- } else {
123
- const component = await updateOrCreateComponent(componentUID, componentValue);
124
- componentBody[attributeName] = component && {
125
- id: component.id,
126
- __pivot: {
127
- field: attributeName,
128
- component_type: componentUID
129
- }
130
- };
131
- }
132
- } else if (attribute.type === "dynamiczone") {
133
- const dynamiczoneValues = data[attributeName];
134
- await deleteOldDZComponents(uid, entityToUpdate, attributeName, dynamiczoneValues);
135
- if (!Array.isArray(dynamiczoneValues)) {
136
- throw new Error("Expected an array to create repeatable component");
137
- }
138
- componentBody[attributeName] = await strapiUtils.async.map(dynamiczoneValues, async (value) => {
139
- const { id } = await updateOrCreateComponent(value.__component, value);
140
- return {
141
- id,
142
- __component: value.__component,
143
- __pivot: {
144
- field: attributeName
145
- }
146
- };
147
- });
148
- }
149
- }
150
- return componentBody;
151
- };
152
- const pickStringifiedId = ({
153
- id
154
- }) => {
155
- if (typeof id === "string") {
156
- return id;
157
- }
158
- return `${id}`;
159
- };
160
- const deleteOldComponents = async (uid, componentUID, entityToUpdate, attributeName, componentValue) => {
161
- const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
162
- const idsToKeep = ___default.default.castArray(componentValue).filter(_.has("id")).map(pickStringifiedId);
163
- const allIds = ___default.default.castArray(previousValue).filter(_.has("id")).map(pickStringifiedId);
164
- idsToKeep.forEach((id) => {
165
- if (!allIds.includes(id)) {
166
- throw new strapiUtils.errors.ApplicationError(
167
- `Some of the provided components in ${attributeName} are not related to the entity`
168
- );
169
- }
170
- });
171
- const idsToDelete = ___default.default.difference(allIds, idsToKeep);
172
- if (idsToDelete.length > 0) {
173
- for (const idToDelete of idsToDelete) {
174
- await deleteComponent(componentUID, { id: idToDelete });
175
- }
176
- }
177
- };
178
- const deleteOldDZComponents = async (uid, entityToUpdate, attributeName, dynamiczoneValues) => {
179
- const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
180
- const idsToKeep = ___default.default.castArray(dynamiczoneValues).filter(_.has("id")).map((v) => ({
181
- id: pickStringifiedId(v),
182
- __component: v.__component
183
- }));
184
- const allIds = ___default.default.castArray(previousValue).filter(_.has("id")).map((v) => ({
185
- id: pickStringifiedId(v),
186
- __component: v.__component
187
- }));
188
- idsToKeep.forEach(({ id, __component }) => {
189
- if (!allIds.find((el) => el.id === id && el.__component === __component)) {
190
- const err = new Error(
191
- `Some of the provided components in ${attributeName} are not related to the entity`
192
- );
193
- Object.assign(err, { status: 400 });
194
- throw err;
195
- }
196
- });
197
- const idsToDelete = allIds.reduce((acc, { id, __component }) => {
198
- if (!idsToKeep.find((el) => el.id === id && el.__component === __component)) {
199
- acc.push({ id, __component });
200
- }
201
- return acc;
202
- }, []);
203
- if (idsToDelete.length > 0) {
204
- for (const idToDelete of idsToDelete) {
205
- const { id, __component } = idToDelete;
206
- await deleteComponent(__component, { id });
207
- }
208
- }
209
- };
210
- const deleteComponents = async (uid, entityToDelete, { loadComponents = true } = {}) => {
211
- const { attributes = {} } = strapi.getModel(uid);
212
- const attributeNames = Object.keys(attributes);
213
- for (const attributeName of attributeNames) {
214
- const attribute = attributes[attributeName];
215
- if (attribute.type === "component" || attribute.type === "dynamiczone") {
216
- let value;
217
- if (loadComponents) {
218
- value = await strapi.db.query(uid).load(entityToDelete, attributeName);
219
- } else {
220
- value = entityToDelete[attributeName];
221
- }
222
- if (!value) {
223
- continue;
224
- }
225
- if (attribute.type === "component") {
226
- const { component: componentUID } = attribute;
227
- await strapiUtils.async.map(
228
- ___default.default.castArray(value),
229
- (subValue) => deleteComponent(componentUID, subValue)
230
- );
231
- } else {
232
- await strapiUtils.async.map(
233
- ___default.default.castArray(value),
234
- (subValue) => deleteComponent(subValue.__component, subValue)
235
- );
236
- }
237
- continue;
238
- }
239
- }
240
- };
241
- const createComponent = async (uid, data) => {
242
- const model = strapi.getModel(uid);
243
- const componentData = await createComponents(uid, data);
244
- const transform = _.pipe(
245
- // Make sure we don't save the component with a pre-defined ID
246
- _.omit("id"),
247
- // Remove the component data from the original data object ...
248
- (payload) => omitComponentData(model, payload),
249
- // ... and assign the newly created component instead
250
- _.assign(componentData)
251
- );
252
- return strapi.db.query(uid).create({ data: transform(data) });
253
- };
254
- const updateComponent = async (uid, componentToUpdate, data) => {
255
- const model = strapi.getModel(uid);
256
- const componentData = await updateComponents(uid, componentToUpdate, data);
257
- return strapi.db.query(uid).update({
258
- where: {
259
- id: componentToUpdate.id
260
- },
261
- data: Object.assign(omitComponentData(model, data), componentData)
262
- });
263
- };
264
- const updateOrCreateComponent = (componentUID, value) => {
265
- if (value === null) {
266
- return null;
267
- }
268
- if ("id" in value && typeof value.id !== "undefined") {
269
- return updateComponent(componentUID, { id: value.id }, value);
270
- }
271
- return createComponent(componentUID, value);
272
- };
273
- const deleteComponent = async (uid, componentToDelete) => {
274
- await deleteComponents(uid, componentToDelete);
275
- await strapi.db.query(uid).delete({ where: { id: componentToDelete.id } });
276
- };
277
- const assignComponentData = (data, componentData, {
278
- contentType
279
- }) => {
280
- return Object.assign(omitComponentData(contentType, data), componentData);
281
- };
282
- exports.assignComponentData = assignComponentData;
283
- exports.createComponents = createComponents;
284
- exports.deleteComponent = deleteComponent;
285
- exports.deleteComponents = deleteComponents;
286
- exports.getComponents = getComponents;
287
- exports.omitComponentData = omitComponentData;
288
- exports.updateComponents = updateComponents;
289
- //# sourceMappingURL=components.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"components.js","sources":["../../../src/services/document-service/components.ts"],"sourcesContent":["import _ from 'lodash';\nimport { has, omit, pipe, assign } from 'lodash/fp';\nimport type { Struct, Utils, UID, Schema, Data, Modules } from '@strapi/types';\nimport { contentTypes as contentTypesUtils, async, errors } from '@strapi/utils';\n\ntype LoadedComponents<TUID extends UID.Schema> = Data.Entity<\n TUID,\n Schema.AttributeNamesByType<TUID, 'component' | 'dynamiczone'>\n>;\n\ntype SingleComponentValue = Schema.Attribute.ComponentValue<UID.Component, false>;\ntype RepeatableComponentValue = Schema.Attribute.ComponentValue<UID.Component, true>;\n\ntype ComponentValue = SingleComponentValue | RepeatableComponentValue;\n\ntype DynamicZoneValue = Schema.Attribute.DynamicZoneValue<UID.Component[]>;\n\ntype ComponentBody = {\n [key: string]: ComponentValue | DynamicZoneValue;\n};\n\nfunction omitComponentData(\n contentType: Struct.ContentTypeSchema,\n data: Modules.EntityService.Params.Data.Input<Struct.ContentTypeSchema['uid']>\n): Partial<Modules.EntityService.Params.Data.Input<Struct.ContentTypeSchema['uid']>>;\nfunction omitComponentData(\n contentType: Struct.ComponentSchema,\n data: Modules.EntityService.Params.Data.Input<Struct.ComponentSchema['uid']>\n): Partial<Modules.EntityService.Params.Data.Input<Struct.ComponentSchema['uid']>>;\nfunction omitComponentData(\n contentType: Struct.Schema,\n data: Modules.EntityService.Params.Data.Input<\n Struct.ContentTypeSchema['uid'] | Struct.ComponentSchema['uid']\n >\n): Partial<\n Modules.EntityService.Params.Data.Input<\n Struct.ContentTypeSchema['uid'] | Struct.ComponentSchema['uid']\n >\n> {\n const { attributes } = contentType;\n const componentAttributes = Object.keys(attributes).filter((attributeName) =>\n contentTypesUtils.isComponentAttribute(attributes[attributeName])\n );\n\n return omit(componentAttributes, data);\n}\n\n// NOTE: we could generalize the logic to allow CRUD of relation directly in the DB layer\nconst createComponents = async <\n TUID extends UID.Schema,\n TData extends Modules.EntityService.Params.Data.Input<TUID>,\n>(\n uid: TUID,\n data: TData\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const componentBody: ComponentBody = {};\n\n const attributeNames = Object.keys(attributes);\n\n for (const attributeName of attributeNames) {\n const attribute = attributes[attributeName];\n\n if (!has(attributeName, data) || !contentTypesUtils.isComponentAttribute(attribute)) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID, repeatable = false } = attribute;\n\n const componentValue = data[attributeName as keyof TData];\n\n if (componentValue === null) {\n continue;\n }\n\n if (repeatable === true) {\n if (!Array.isArray(componentValue)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n const components: RepeatableComponentValue = await async.map(componentValue, (value: any) =>\n createComponent(componentUID, value)\n );\n\n componentBody[attributeName] = components.map(({ id }) => {\n return {\n id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n });\n } else {\n const component = await createComponent(\n componentUID,\n componentValue as Modules.EntityService.Params.Data.Input<UID.Component>\n );\n\n componentBody[attributeName] = {\n id: component.id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n }\n\n continue;\n }\n\n if (attribute.type === 'dynamiczone') {\n const dynamiczoneValues = data[\n attributeName as keyof TData\n ] as Modules.EntityService.Params.Attribute.GetValue<Schema.Attribute.DynamicZone>;\n\n if (!Array.isArray(dynamiczoneValues)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n const createDynamicZoneComponents = async (\n value: Utils.Array.Values<typeof dynamiczoneValues>\n ) => {\n const { id } = await createComponent(value.__component, value);\n return {\n id,\n __component: value.__component,\n __pivot: {\n field: attributeName,\n },\n };\n };\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n componentBody[attributeName] = await async.map(\n dynamiczoneValues,\n createDynamicZoneComponents\n );\n\n continue;\n }\n }\n\n return componentBody;\n};\n\nconst getComponents = async <TUID extends UID.Schema>(\n uid: TUID,\n entity: { id: Modules.EntityService.Params.Attribute.ID }\n): Promise<LoadedComponents<TUID>> => {\n const componentAttributes = contentTypesUtils.getComponentAttributes(strapi.getModel(uid));\n\n if (_.isEmpty(componentAttributes)) {\n return {} as LoadedComponents<TUID>;\n }\n\n return strapi.db.query(uid).load(entity, componentAttributes) as Promise<LoadedComponents<TUID>>;\n};\n\n/*\n delete old components\n create or update\n*/\nconst updateComponents = async <\n TUID extends UID.Schema,\n TData extends Partial<Modules.EntityService.Params.Data.Input<TUID>>,\n>(\n uid: TUID,\n entityToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n data: TData\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const componentBody: ComponentBody = {};\n\n for (const attributeName of Object.keys(attributes)) {\n const attribute = attributes[attributeName];\n\n if (!has(attributeName, data)) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID, repeatable = false } = attribute;\n\n const componentValue = data[attributeName as keyof TData] as ComponentValue;\n\n await deleteOldComponents(uid, componentUID, entityToUpdate, attributeName, componentValue);\n\n if (repeatable === true) {\n if (!Array.isArray(componentValue)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n const components: RepeatableComponentValue = await async.map(componentValue, (value: any) =>\n updateOrCreateComponent(componentUID, value)\n );\n\n componentBody[attributeName] = components.filter(_.negate(_.isNil)).map(({ id }) => {\n return {\n id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n });\n } else {\n const component = await updateOrCreateComponent(componentUID, componentValue);\n componentBody[attributeName] = component && {\n id: component.id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n }\n } else if (attribute.type === 'dynamiczone') {\n const dynamiczoneValues = data[attributeName as keyof TData] as DynamicZoneValue;\n\n await deleteOldDZComponents(uid, entityToUpdate, attributeName, dynamiczoneValues);\n\n if (!Array.isArray(dynamiczoneValues)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n componentBody[attributeName] = await async.map(dynamiczoneValues, async (value: any) => {\n const { id } = await updateOrCreateComponent(value.__component, value);\n\n return {\n id,\n __component: value.__component,\n __pivot: {\n field: attributeName,\n },\n };\n });\n }\n }\n\n return componentBody;\n};\n\nconst pickStringifiedId = ({\n id,\n}: {\n id: Modules.EntityService.Params.Attribute.ID;\n}): Modules.EntityService.Params.Attribute.ID & string => {\n if (typeof id === 'string') {\n return id;\n }\n\n return `${id}`;\n};\n\nconst deleteOldComponents = async <TUID extends UID.Schema>(\n uid: TUID,\n componentUID: UID.Component,\n entityToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n attributeName: string,\n componentValue: ComponentValue\n) => {\n const previousValue = (await strapi.db\n .query(uid)\n .load(entityToUpdate, attributeName)) as ComponentValue;\n\n const idsToKeep = _.castArray(componentValue).filter(has('id')).map(pickStringifiedId);\n const allIds = _.castArray(previousValue).filter(has('id')).map(pickStringifiedId);\n\n idsToKeep.forEach((id) => {\n if (!allIds.includes(id)) {\n throw new errors.ApplicationError(\n `Some of the provided components in ${attributeName} are not related to the entity`\n );\n }\n });\n\n const idsToDelete = _.difference(allIds, idsToKeep);\n\n if (idsToDelete.length > 0) {\n for (const idToDelete of idsToDelete) {\n await deleteComponent(componentUID, { id: idToDelete });\n }\n }\n};\n\nconst deleteOldDZComponents = async <TUID extends UID.Schema>(\n uid: TUID,\n entityToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n attributeName: string,\n dynamiczoneValues: DynamicZoneValue\n) => {\n const previousValue = (await strapi.db\n .query(uid)\n .load(entityToUpdate, attributeName)) as DynamicZoneValue;\n\n const idsToKeep = _.castArray(dynamiczoneValues)\n .filter(has('id'))\n .map((v) => ({\n id: pickStringifiedId(v),\n __component: v.__component,\n }));\n\n const allIds = _.castArray(previousValue)\n .filter(has('id'))\n .map((v) => ({\n id: pickStringifiedId(v),\n __component: v.__component,\n }));\n\n idsToKeep.forEach(({ id, __component }) => {\n if (!allIds.find((el) => el.id === id && el.__component === __component)) {\n const err = new Error(\n `Some of the provided components in ${attributeName} are not related to the entity`\n );\n\n Object.assign(err, { status: 400 });\n throw err;\n }\n });\n\n type IdsToDelete = DynamicZoneValue;\n\n const idsToDelete = allIds.reduce((acc, { id, __component }) => {\n if (!idsToKeep.find((el) => el.id === id && el.__component === __component)) {\n acc.push({ id, __component });\n }\n\n return acc;\n }, [] as IdsToDelete);\n\n if (idsToDelete.length > 0) {\n for (const idToDelete of idsToDelete) {\n const { id, __component } = idToDelete;\n await deleteComponent(__component, { id });\n }\n }\n};\n\nconst deleteComponents = async <TUID extends UID.Schema, TEntity extends Data.Entity<TUID>>(\n uid: TUID,\n entityToDelete: TEntity,\n { loadComponents = true } = {}\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const attributeNames = Object.keys(attributes);\n\n for (const attributeName of attributeNames) {\n const attribute = attributes[attributeName];\n\n if (attribute.type === 'component' || attribute.type === 'dynamiczone') {\n let value;\n if (loadComponents) {\n value = await strapi.db.query(uid).load(entityToDelete, attributeName);\n } else {\n value = entityToDelete[attributeName as keyof TEntity];\n }\n\n if (!value) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID } = attribute;\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n await async.map(_.castArray(value), (subValue: any) =>\n deleteComponent(componentUID, subValue)\n );\n } else {\n // delete dynamic zone components\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n await async.map(_.castArray(value), (subValue: any) =>\n deleteComponent(subValue.__component, subValue)\n );\n }\n\n continue;\n }\n }\n};\n\n/** *************************\n Component queries\n************************** */\n\n// components can have nested compos so this must be recursive\nconst createComponent = async <TUID extends UID.Component>(\n uid: TUID,\n data: Modules.EntityService.Params.Data.Input<TUID>\n) => {\n const model = strapi.getModel(uid);\n\n const componentData = await createComponents(uid, data);\n const transform = pipe(\n // Make sure we don't save the component with a pre-defined ID\n omit('id'),\n // Remove the component data from the original data object ...\n (payload) => omitComponentData(model, payload),\n // ... and assign the newly created component instead\n assign(componentData)\n );\n\n return strapi.db.query(uid).create({ data: transform(data) });\n};\n\n// components can have nested compos so this must be recursive\nconst updateComponent = async <TUID extends UID.Component>(\n uid: TUID,\n componentToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n data: Modules.EntityService.Params.Data.Input<TUID>\n) => {\n const model = strapi.getModel(uid);\n\n const componentData = await updateComponents(uid, componentToUpdate, data);\n\n return strapi.db.query(uid).update({\n where: {\n id: componentToUpdate.id,\n },\n data: Object.assign(omitComponentData(model, data), componentData),\n });\n};\n\nconst updateOrCreateComponent = <TUID extends UID.Component>(\n componentUID: TUID,\n value: Modules.EntityService.Params.Data.Input<TUID>\n) => {\n if (value === null) {\n return null;\n }\n\n // update\n if ('id' in value && typeof value.id !== 'undefined') {\n // TODO: verify the compo is associated with the entity\n return updateComponent(componentUID, { id: value.id }, value);\n }\n\n // create\n return createComponent(componentUID, value);\n};\n\nconst deleteComponent = async <TUID extends UID.Component>(\n uid: TUID,\n componentToDelete: Data.Component<TUID>\n) => {\n await deleteComponents(uid, componentToDelete);\n await strapi.db.query(uid).delete({ where: { id: componentToDelete.id } });\n};\n\nconst assignComponentData = <TUID extends UID.ContentType>(\n data: Modules.EntityService.Params.Data.Input<TUID>,\n componentData: ComponentBody,\n {\n contentType,\n }: {\n contentType: Schema.ContentType<TUID>;\n }\n) => {\n return Object.assign(omitComponentData(contentType, data), componentData);\n};\n\nexport {\n omitComponentData,\n assignComponentData,\n getComponents,\n createComponents,\n updateComponents,\n deleteComponents,\n deleteComponent,\n};\n"],"names":["contentTypesUtils","omit","has","async","_","errors","pipe","assign"],"mappings":"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"}