@strapi/database 5.12.1 → 5.12.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (321) hide show
  1. package/dist/connection.js +43 -0
  2. package/dist/connection.js.map +1 -0
  3. package/dist/connection.mjs +41 -0
  4. package/dist/connection.mjs.map +1 -0
  5. package/dist/dialects/dialect.js +54 -0
  6. package/dist/dialects/dialect.js.map +1 -0
  7. package/dist/dialects/dialect.mjs +52 -0
  8. package/dist/dialects/dialect.mjs.map +1 -0
  9. package/dist/dialects/index.js +44 -0
  10. package/dist/dialects/index.js.map +1 -0
  11. package/dist/dialects/index.mjs +42 -0
  12. package/dist/dialects/index.mjs.map +1 -0
  13. package/dist/dialects/mysql/constants.js +8 -0
  14. package/dist/dialects/mysql/constants.js.map +1 -0
  15. package/dist/dialects/mysql/constants.mjs +5 -0
  16. package/dist/dialects/mysql/constants.mjs.map +1 -0
  17. package/dist/dialects/mysql/database-inspector.js +35 -0
  18. package/dist/dialects/mysql/database-inspector.js.map +1 -0
  19. package/dist/dialects/mysql/database-inspector.mjs +33 -0
  20. package/dist/dialects/mysql/database-inspector.mjs.map +1 -0
  21. package/dist/dialects/mysql/index.js +75 -0
  22. package/dist/dialects/mysql/index.js.map +1 -0
  23. package/dist/dialects/mysql/index.mjs +73 -0
  24. package/dist/dialects/mysql/index.mjs.map +1 -0
  25. package/dist/dialects/mysql/schema-inspector.js +297 -0
  26. package/dist/dialects/mysql/schema-inspector.js.map +1 -0
  27. package/dist/dialects/mysql/schema-inspector.mjs +295 -0
  28. package/dist/dialects/mysql/schema-inspector.mjs.map +1 -0
  29. package/dist/dialects/postgresql/index.js +62 -0
  30. package/dist/dialects/postgresql/index.js.map +1 -0
  31. package/dist/dialects/postgresql/index.mjs +60 -0
  32. package/dist/dialects/postgresql/index.mjs.map +1 -0
  33. package/dist/dialects/postgresql/schema-inspector.js +316 -0
  34. package/dist/dialects/postgresql/schema-inspector.js.map +1 -0
  35. package/dist/dialects/postgresql/schema-inspector.mjs +314 -0
  36. package/dist/dialects/postgresql/schema-inspector.mjs.map +1 -0
  37. package/dist/dialects/sqlite/index.js +82 -0
  38. package/dist/dialects/sqlite/index.js.map +1 -0
  39. package/dist/dialects/sqlite/index.mjs +80 -0
  40. package/dist/dialects/sqlite/index.mjs.map +1 -0
  41. package/dist/dialects/sqlite/schema-inspector.js +211 -0
  42. package/dist/dialects/sqlite/schema-inspector.js.map +1 -0
  43. package/dist/dialects/sqlite/schema-inspector.mjs +209 -0
  44. package/dist/dialects/sqlite/schema-inspector.mjs.map +1 -0
  45. package/dist/entity-manager/entity-repository.js +139 -0
  46. package/dist/entity-manager/entity-repository.js.map +1 -0
  47. package/dist/entity-manager/entity-repository.mjs +137 -0
  48. package/dist/entity-manager/entity-repository.mjs.map +1 -0
  49. package/dist/entity-manager/index.js +1186 -0
  50. package/dist/entity-manager/index.js.map +1 -0
  51. package/dist/entity-manager/index.mjs +1184 -0
  52. package/dist/entity-manager/index.mjs.map +1 -0
  53. package/dist/entity-manager/morph-relations.js +73 -0
  54. package/dist/entity-manager/morph-relations.js.map +1 -0
  55. package/dist/entity-manager/morph-relations.mjs +69 -0
  56. package/dist/entity-manager/morph-relations.mjs.map +1 -0
  57. package/dist/entity-manager/regular-relations.js +247 -0
  58. package/dist/entity-manager/regular-relations.js.map +1 -0
  59. package/dist/entity-manager/regular-relations.mjs +242 -0
  60. package/dist/entity-manager/regular-relations.mjs.map +1 -0
  61. package/dist/entity-manager/relations-orderer.js +221 -0
  62. package/dist/entity-manager/relations-orderer.js.map +1 -0
  63. package/dist/entity-manager/relations-orderer.mjs +218 -0
  64. package/dist/entity-manager/relations-orderer.mjs.map +1 -0
  65. package/dist/errors/database.js +13 -0
  66. package/dist/errors/database.js.map +1 -0
  67. package/dist/errors/database.mjs +11 -0
  68. package/dist/errors/database.mjs.map +1 -0
  69. package/dist/errors/index.js +18 -0
  70. package/dist/errors/index.js.map +1 -0
  71. package/dist/errors/index.mjs +7 -0
  72. package/dist/errors/index.mjs.map +1 -0
  73. package/dist/errors/invalid-date.js +13 -0
  74. package/dist/errors/invalid-date.js.map +1 -0
  75. package/dist/errors/invalid-date.mjs +11 -0
  76. package/dist/errors/invalid-date.mjs.map +1 -0
  77. package/dist/errors/invalid-datetime.js +13 -0
  78. package/dist/errors/invalid-datetime.js.map +1 -0
  79. package/dist/errors/invalid-datetime.mjs +11 -0
  80. package/dist/errors/invalid-datetime.mjs.map +1 -0
  81. package/dist/errors/invalid-relation.js +13 -0
  82. package/dist/errors/invalid-relation.js.map +1 -0
  83. package/dist/errors/invalid-relation.mjs +11 -0
  84. package/dist/errors/invalid-relation.mjs.map +1 -0
  85. package/dist/errors/invalid-time.js +13 -0
  86. package/dist/errors/invalid-time.js.map +1 -0
  87. package/dist/errors/invalid-time.mjs +11 -0
  88. package/dist/errors/invalid-time.mjs.map +1 -0
  89. package/dist/errors/not-null.js +17 -0
  90. package/dist/errors/not-null.js.map +1 -0
  91. package/dist/errors/not-null.mjs +15 -0
  92. package/dist/errors/not-null.mjs.map +1 -0
  93. package/dist/fields/biginteger.js +9 -0
  94. package/dist/fields/biginteger.js.map +1 -0
  95. package/dist/fields/biginteger.mjs +7 -0
  96. package/dist/fields/biginteger.mjs.map +1 -0
  97. package/dist/fields/boolean.js +48 -0
  98. package/dist/fields/boolean.js.map +1 -0
  99. package/dist/fields/boolean.mjs +46 -0
  100. package/dist/fields/boolean.mjs.map +1 -0
  101. package/dist/fields/date.js +16 -0
  102. package/dist/fields/date.js.map +1 -0
  103. package/dist/fields/date.mjs +14 -0
  104. package/dist/fields/date.mjs.map +1 -0
  105. package/dist/fields/datetime.js +37 -0
  106. package/dist/fields/datetime.js.map +1 -0
  107. package/dist/fields/datetime.mjs +16 -0
  108. package/dist/fields/datetime.mjs.map +1 -0
  109. package/dist/fields/field.js +16 -0
  110. package/dist/fields/field.js.map +1 -0
  111. package/dist/fields/field.mjs +14 -0
  112. package/dist/fields/field.mjs.map +1 -0
  113. package/dist/fields/index.js +45 -0
  114. package/dist/fields/index.js.map +1 -0
  115. package/dist/fields/index.mjs +43 -0
  116. package/dist/fields/index.mjs.map +1 -0
  117. package/dist/fields/json.js +36 -0
  118. package/dist/fields/json.js.map +1 -0
  119. package/dist/fields/json.mjs +34 -0
  120. package/dist/fields/json.mjs.map +1 -0
  121. package/dist/fields/number.js +20 -0
  122. package/dist/fields/number.js.map +1 -0
  123. package/dist/fields/number.mjs +18 -0
  124. package/dist/fields/number.mjs.map +1 -0
  125. package/dist/fields/shared/parsers.js +91 -0
  126. package/dist/fields/shared/parsers.js.map +1 -0
  127. package/dist/fields/shared/parsers.mjs +68 -0
  128. package/dist/fields/shared/parsers.mjs.map +1 -0
  129. package/dist/fields/string.js +16 -0
  130. package/dist/fields/string.js.map +1 -0
  131. package/dist/fields/string.mjs +14 -0
  132. package/dist/fields/string.mjs.map +1 -0
  133. package/dist/fields/time.js +17 -0
  134. package/dist/fields/time.js.map +1 -0
  135. package/dist/fields/time.mjs +15 -0
  136. package/dist/fields/time.mjs.map +1 -0
  137. package/dist/fields/timestamp.js +37 -0
  138. package/dist/fields/timestamp.js.map +1 -0
  139. package/dist/fields/timestamp.mjs +16 -0
  140. package/dist/fields/timestamp.mjs.map +1 -0
  141. package/dist/index.js +33 -8569
  142. package/dist/index.js.map +1 -1
  143. package/dist/index.mjs +16 -8532
  144. package/dist/index.mjs.map +1 -1
  145. package/dist/lifecycles/index.js +73 -0
  146. package/dist/lifecycles/index.js.map +1 -0
  147. package/dist/lifecycles/index.mjs +71 -0
  148. package/dist/lifecycles/index.mjs.map +1 -0
  149. package/dist/lifecycles/subscribers/index.js +10 -0
  150. package/dist/lifecycles/subscribers/index.js.map +1 -0
  151. package/dist/lifecycles/subscribers/index.mjs +8 -0
  152. package/dist/lifecycles/subscribers/index.mjs.map +1 -0
  153. package/dist/lifecycles/subscribers/models-lifecycles.js +13 -0
  154. package/dist/lifecycles/subscribers/models-lifecycles.js.map +1 -0
  155. package/dist/lifecycles/subscribers/models-lifecycles.mjs +11 -0
  156. package/dist/lifecycles/subscribers/models-lifecycles.mjs.map +1 -0
  157. package/dist/lifecycles/subscribers/timestamps.js +55 -0
  158. package/dist/lifecycles/subscribers/timestamps.js.map +1 -0
  159. package/dist/lifecycles/subscribers/timestamps.mjs +53 -0
  160. package/dist/lifecycles/subscribers/timestamps.mjs.map +1 -0
  161. package/dist/metadata/index.js +24 -0
  162. package/dist/metadata/index.js.map +1 -0
  163. package/dist/metadata/index.mjs +16 -0
  164. package/dist/metadata/index.mjs.map +1 -0
  165. package/dist/metadata/metadata.js +100 -0
  166. package/dist/metadata/metadata.js.map +1 -0
  167. package/dist/metadata/metadata.mjs +98 -0
  168. package/dist/metadata/metadata.mjs.map +1 -0
  169. package/dist/metadata/relations.js +545 -0
  170. package/dist/metadata/relations.js.map +1 -0
  171. package/dist/metadata/relations.mjs +536 -0
  172. package/dist/metadata/relations.mjs.map +1 -0
  173. package/dist/migrations/common.js +8 -0
  174. package/dist/migrations/common.js.map +1 -0
  175. package/dist/migrations/common.mjs +6 -0
  176. package/dist/migrations/common.mjs.map +1 -0
  177. package/dist/migrations/index.js +39 -0
  178. package/dist/migrations/index.js.map +1 -0
  179. package/dist/migrations/index.mjs +37 -0
  180. package/dist/migrations/index.mjs.map +1 -0
  181. package/dist/migrations/internal-migrations/5.0.0-01-convert-identifiers-long-than-max-length.js +179 -0
  182. package/dist/migrations/internal-migrations/5.0.0-01-convert-identifiers-long-than-max-length.js.map +1 -0
  183. package/dist/migrations/internal-migrations/5.0.0-01-convert-identifiers-long-than-max-length.mjs +177 -0
  184. package/dist/migrations/internal-migrations/5.0.0-01-convert-identifiers-long-than-max-length.mjs.map +1 -0
  185. package/dist/migrations/internal-migrations/5.0.0-02-document-id.js +125 -0
  186. package/dist/migrations/internal-migrations/5.0.0-02-document-id.js.map +1 -0
  187. package/dist/migrations/internal-migrations/5.0.0-02-document-id.mjs +123 -0
  188. package/dist/migrations/internal-migrations/5.0.0-02-document-id.mjs.map +1 -0
  189. package/dist/migrations/internal-migrations/5.0.0-03-locale.js +41 -0
  190. package/dist/migrations/internal-migrations/5.0.0-03-locale.js.map +1 -0
  191. package/dist/migrations/internal-migrations/5.0.0-03-locale.mjs +39 -0
  192. package/dist/migrations/internal-migrations/5.0.0-03-locale.mjs.map +1 -0
  193. package/dist/migrations/internal-migrations/5.0.0-04-published-at.js +45 -0
  194. package/dist/migrations/internal-migrations/5.0.0-04-published-at.js.map +1 -0
  195. package/dist/migrations/internal-migrations/5.0.0-04-published-at.mjs +43 -0
  196. package/dist/migrations/internal-migrations/5.0.0-04-published-at.mjs.map +1 -0
  197. package/dist/migrations/internal-migrations/5.0.0-05-drop-slug-unique-index.js +43 -0
  198. package/dist/migrations/internal-migrations/5.0.0-05-drop-slug-unique-index.js.map +1 -0
  199. package/dist/migrations/internal-migrations/5.0.0-05-drop-slug-unique-index.mjs +41 -0
  200. package/dist/migrations/internal-migrations/5.0.0-05-drop-slug-unique-index.mjs.map +1 -0
  201. package/dist/migrations/internal-migrations/index.js +26 -0
  202. package/dist/migrations/internal-migrations/index.js.map +1 -0
  203. package/dist/migrations/internal-migrations/index.mjs +24 -0
  204. package/dist/migrations/internal-migrations/index.mjs.map +1 -0
  205. package/dist/migrations/internal.js +63 -0
  206. package/dist/migrations/internal.js.map +1 -0
  207. package/dist/migrations/internal.mjs +61 -0
  208. package/dist/migrations/internal.mjs.map +1 -0
  209. package/dist/migrations/logger.js +24 -0
  210. package/dist/migrations/logger.js.map +1 -0
  211. package/dist/migrations/logger.mjs +22 -0
  212. package/dist/migrations/logger.mjs.map +1 -0
  213. package/dist/migrations/storage.js +39 -0
  214. package/dist/migrations/storage.js.map +1 -0
  215. package/dist/migrations/storage.mjs +37 -0
  216. package/dist/migrations/storage.mjs.map +1 -0
  217. package/dist/migrations/users.js +87 -0
  218. package/dist/migrations/users.js.map +1 -0
  219. package/dist/migrations/users.mjs +85 -0
  220. package/dist/migrations/users.mjs.map +1 -0
  221. package/dist/query/helpers/join.js +127 -0
  222. package/dist/query/helpers/join.js.map +1 -0
  223. package/dist/query/helpers/join.mjs +122 -0
  224. package/dist/query/helpers/join.mjs.map +1 -0
  225. package/dist/query/helpers/order-by.js +167 -0
  226. package/dist/query/helpers/order-by.js.map +1 -0
  227. package/dist/query/helpers/order-by.mjs +163 -0
  228. package/dist/query/helpers/order-by.mjs.map +1 -0
  229. package/dist/query/helpers/populate/apply.js +592 -0
  230. package/dist/query/helpers/populate/apply.js.map +1 -0
  231. package/dist/query/helpers/populate/apply.mjs +590 -0
  232. package/dist/query/helpers/populate/apply.mjs.map +1 -0
  233. package/dist/query/helpers/populate/process.js +92 -0
  234. package/dist/query/helpers/populate/process.js.map +1 -0
  235. package/dist/query/helpers/populate/process.mjs +90 -0
  236. package/dist/query/helpers/populate/process.mjs.map +1 -0
  237. package/dist/query/helpers/search.js +67 -0
  238. package/dist/query/helpers/search.js.map +1 -0
  239. package/dist/query/helpers/search.mjs +65 -0
  240. package/dist/query/helpers/search.mjs.map +1 -0
  241. package/dist/query/helpers/streams/readable.js +131 -0
  242. package/dist/query/helpers/streams/readable.js.map +1 -0
  243. package/dist/query/helpers/streams/readable.mjs +129 -0
  244. package/dist/query/helpers/streams/readable.mjs.map +1 -0
  245. package/dist/query/helpers/transform.js +77 -0
  246. package/dist/query/helpers/transform.js.map +1 -0
  247. package/dist/query/helpers/transform.mjs +73 -0
  248. package/dist/query/helpers/transform.mjs.map +1 -0
  249. package/dist/query/helpers/where.js +372 -0
  250. package/dist/query/helpers/where.js.map +1 -0
  251. package/dist/query/helpers/where.mjs +369 -0
  252. package/dist/query/helpers/where.mjs.map +1 -0
  253. package/dist/query/query-builder.js +507 -0
  254. package/dist/query/query-builder.js.map +1 -0
  255. package/dist/query/query-builder.mjs +505 -0
  256. package/dist/query/query-builder.mjs.map +1 -0
  257. package/dist/repairs/index.js +13 -0
  258. package/dist/repairs/index.js.map +1 -0
  259. package/dist/repairs/index.mjs +11 -0
  260. package/dist/repairs/index.mjs.map +1 -0
  261. package/dist/repairs/operations/remove-orphan-morph-types.js +54 -0
  262. package/dist/repairs/operations/remove-orphan-morph-types.js.map +1 -0
  263. package/dist/repairs/operations/remove-orphan-morph-types.mjs +52 -0
  264. package/dist/repairs/operations/remove-orphan-morph-types.mjs.map +1 -0
  265. package/dist/schema/builder.js +354 -0
  266. package/dist/schema/builder.js.map +1 -0
  267. package/dist/schema/builder.mjs +352 -0
  268. package/dist/schema/builder.mjs.map +1 -0
  269. package/dist/schema/diff.js +379 -0
  270. package/dist/schema/diff.js.map +1 -0
  271. package/dist/schema/diff.mjs +377 -0
  272. package/dist/schema/diff.mjs.map +1 -0
  273. package/dist/schema/index.js +93 -0
  274. package/dist/schema/index.js.map +1 -0
  275. package/dist/schema/index.mjs +91 -0
  276. package/dist/schema/index.mjs.map +1 -0
  277. package/dist/schema/schema.js +266 -0
  278. package/dist/schema/schema.js.map +1 -0
  279. package/dist/schema/schema.mjs +264 -0
  280. package/dist/schema/schema.mjs.map +1 -0
  281. package/dist/schema/storage.js +58 -0
  282. package/dist/schema/storage.js.map +1 -0
  283. package/dist/schema/storage.mjs +56 -0
  284. package/dist/schema/storage.mjs.map +1 -0
  285. package/dist/transaction-context.js +65 -0
  286. package/dist/transaction-context.js.map +1 -0
  287. package/dist/transaction-context.mjs +63 -0
  288. package/dist/transaction-context.mjs.map +1 -0
  289. package/dist/utils/async-curry.js +19 -0
  290. package/dist/utils/async-curry.js.map +1 -0
  291. package/dist/utils/async-curry.mjs +17 -0
  292. package/dist/utils/async-curry.mjs.map +1 -0
  293. package/dist/utils/identifiers/hash.js +30 -0
  294. package/dist/utils/identifiers/hash.js.map +1 -0
  295. package/dist/utils/identifiers/hash.mjs +28 -0
  296. package/dist/utils/identifiers/hash.mjs.map +1 -0
  297. package/dist/utils/identifiers/index.js +414 -0
  298. package/dist/utils/identifiers/index.js.map +1 -0
  299. package/dist/utils/identifiers/index.mjs +411 -0
  300. package/dist/utils/identifiers/index.mjs.map +1 -0
  301. package/dist/utils/knex.js +21 -0
  302. package/dist/utils/knex.js.map +1 -0
  303. package/dist/utils/knex.mjs +18 -0
  304. package/dist/utils/knex.mjs.map +1 -0
  305. package/dist/utils/types.js +51 -0
  306. package/dist/utils/types.js.map +1 -0
  307. package/dist/utils/types.mjs +44 -0
  308. package/dist/utils/types.mjs.map +1 -0
  309. package/dist/validations/index.js +12 -0
  310. package/dist/validations/index.js.map +1 -0
  311. package/dist/validations/index.mjs +10 -0
  312. package/dist/validations/index.mjs.map +1 -0
  313. package/dist/validations/relations/bidirectional.js +64 -0
  314. package/dist/validations/relations/bidirectional.js.map +1 -0
  315. package/dist/validations/relations/bidirectional.mjs +62 -0
  316. package/dist/validations/relations/bidirectional.mjs.map +1 -0
  317. package/dist/validations/relations/index.js +13 -0
  318. package/dist/validations/relations/index.js.map +1 -0
  319. package/dist/validations/relations/index.mjs +11 -0
  320. package/dist/validations/relations/index.mjs.map +1 -0
  321. package/package.json +4 -4
@@ -0,0 +1 @@
1
+ {"version":3,"file":"readable.js","sources":["../../../../src/query/helpers/streams/readable.ts"],"sourcesContent":["import { Readable } from 'stream';\nimport { isFinite } from 'lodash/fp';\nimport type { Knex } from 'knex';\nimport type { QueryBuilder } from '../../query-builder';\nimport type { Database } from '../../..';\n\nimport { applyPopulate } from '../populate';\nimport { fromRow } from '../transform';\nimport { Meta } from '../../../metadata';\n\nconst knexQueryDone = Symbol('knexQueryDone');\nconst knexPerformingQuery = Symbol('knexPerformingQuery');\n\ninterface ReadableStrapiQueryOptions {\n qb: QueryBuilder;\n uid: string;\n db: Database;\n mapResults?: boolean;\n batchSize?: number;\n}\n\nclass ReadableStrapiQuery extends Readable {\n _offset: number;\n\n _limit: number | null;\n\n _fetched: number;\n\n _query: Knex.QueryBuilder;\n\n _qb: QueryBuilder;\n\n _db: Database;\n\n _uid: string;\n\n _meta: Meta;\n\n _batchSize: number;\n\n _mapResults: boolean;\n\n [knexPerformingQuery]: boolean;\n\n constructor({ qb, db, uid, mapResults = true, batchSize = 500 }: ReadableStrapiQueryOptions) {\n super({ objectMode: true, highWaterMark: batchSize });\n\n // Extract offset & limit from the query-builder's state\n const { offset, limit } = qb.state;\n\n // Original offset value\n this._offset = isFinite(offset) ? Number(offset) : 0;\n\n // Max amount of entities to fetch, force null as undefined value\n this._limit = isFinite(limit) ? Number(limit) : null;\n\n // Total amount of entities fetched\n this._fetched = 0;\n\n /**\n * Original query\n */\n this._query = qb.getKnexQuery();\n\n // Query Builder instance\n this._qb = qb;\n\n // Database related properties\n this._db = db;\n this._uid = uid;\n this._meta = db.metadata.get(uid);\n\n // Stream params\n this._batchSize = batchSize;\n this._mapResults = mapResults;\n\n // States\n this[knexPerformingQuery] = false;\n }\n\n _destroy(err: Error, cb: (err?: Error) => void) {\n // If the stream is destroyed while a query is being made, then wait for a\n // kQueryDone event to be emitted before actually destroying the stream\n if (this[knexPerformingQuery]) {\n this.once(knexQueryDone, (er) => cb(err || er));\n } else {\n cb(err);\n }\n }\n\n /**\n * Custom ._read() implementation\n *\n * NOTE: Here \"size\" means the number of entities to be read from the database.\n * Not the actual byte size, as it would mean that we need to return partial entities.\n *\n */\n async _read(size: number) {\n const query = this._query;\n\n // Remove the original offset & limit properties from the query\n // Theoretically, they would be replaced by calling them again, but this is just to be sure\n query.clear('limit').clear('offset');\n\n // Define the maximum read size based on the limit and the requested size\n // NOTE: size is equal to _batchSize by default. Since we want to allow customizing it on\n // the fly, we need to use its value instead of batchSize when computing the maxReadSize value\n const maxReadSize =\n // if no limit is defined in the query, use the given size,\n // otherwise, use the smallest value between the two\n this._limit === null ? size : Math.min(size, this._limit);\n\n // Compute the limit for the next query\n const limit =\n // If a limit is defined\n this._limit !== null &&\n // And reading `maxReadSize` would fetch too many entities (> _limit)\n this._fetched + maxReadSize > this._limit\n ? // Then adjust the limit so that it only get the remaining entities\n this._limit - this._fetched\n : // Else, use the max read size\n maxReadSize;\n\n // If we don't have anything left to read (_limit === _fetched),\n // don't bother making the query and end the stream by pushing null\n if (limit <= 0) {\n this.push(null);\n return;\n }\n\n // Compute the offset (base offset + number of entities already fetched)\n const offset = this._offset + this._fetched;\n\n // Update the query with the new values (offset + limit)\n query.offset(offset).limit(limit);\n\n // Lock the ._destroy()\n this[knexPerformingQuery] = true;\n\n let results;\n let count;\n let err;\n\n try {\n // Execute the query and store the results & count\n results = await query;\n\n const { populate } = this._qb.state;\n\n // Applies the populate if needed\n if (populate) {\n await applyPopulate(results, populate, { qb: this._qb, uid: this._uid, db: this._db });\n }\n\n // Map results if asked to\n if (this._mapResults) {\n results = fromRow(this._meta, results);\n }\n\n count = results.length;\n } catch (e) {\n err = e;\n }\n\n // Unlock the ._destroy()\n this[knexPerformingQuery] = false;\n\n // Tell ._destroy() that it's now safe to close the db connection\n if (this.destroyed) {\n this.emit(knexQueryDone);\n return;\n }\n\n // If there is an error, destroy with the given error\n if (err) {\n this.destroy(err as Error);\n return;\n }\n\n // Update the amount of fetched entities\n this._fetched += count;\n\n // While there is at least one value to unpack\n for (const result of results) {\n this.push(result);\n }\n\n // If the amount of fetched entities is smaller than the\n // maximum read size, Then push null to close the stream\n if (this._fetched === this._limit || count < this._batchSize) {\n this.push(null);\n }\n }\n}\n\nexport default ReadableStrapiQuery;\n"],"names":["knexQueryDone","Symbol","knexPerformingQuery","ReadableStrapiQuery","Readable","_destroy","err","cb","once","er","_read","size","query","_query","clear","maxReadSize","_limit","Math","min","limit","_fetched","push","offset","_offset","results","count","populate","_qb","state","applyPopulate","qb","uid","_uid","db","_db","_mapResults","fromRow","_meta","length","e","destroyed","emit","destroy","result","_batchSize","constructor","mapResults","batchSize","objectMode","highWaterMark","isFinite","Number","getKnexQuery","metadata","get"],"mappings":"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"}
@@ -0,0 +1,129 @@
1
+ import { Readable } from 'stream';
2
+ import { isFinite } from 'lodash/fp';
3
+ import applyPopulate from '../populate/apply.mjs';
4
+ import { fromRow } from '../transform.mjs';
5
+
6
+ const knexQueryDone = Symbol('knexQueryDone');
7
+ const knexPerformingQuery = Symbol('knexPerformingQuery');
8
+ class ReadableStrapiQuery extends Readable {
9
+ _destroy(err, cb) {
10
+ // If the stream is destroyed while a query is being made, then wait for a
11
+ // kQueryDone event to be emitted before actually destroying the stream
12
+ if (this[knexPerformingQuery]) {
13
+ this.once(knexQueryDone, (er)=>cb(err || er));
14
+ } else {
15
+ cb(err);
16
+ }
17
+ }
18
+ /**
19
+ * Custom ._read() implementation
20
+ *
21
+ * NOTE: Here "size" means the number of entities to be read from the database.
22
+ * Not the actual byte size, as it would mean that we need to return partial entities.
23
+ *
24
+ */ async _read(size) {
25
+ const query = this._query;
26
+ // Remove the original offset & limit properties from the query
27
+ // Theoretically, they would be replaced by calling them again, but this is just to be sure
28
+ query.clear('limit').clear('offset');
29
+ // Define the maximum read size based on the limit and the requested size
30
+ // NOTE: size is equal to _batchSize by default. Since we want to allow customizing it on
31
+ // the fly, we need to use its value instead of batchSize when computing the maxReadSize value
32
+ const maxReadSize = // if no limit is defined in the query, use the given size,
33
+ // otherwise, use the smallest value between the two
34
+ this._limit === null ? size : Math.min(size, this._limit);
35
+ // Compute the limit for the next query
36
+ const limit = // If a limit is defined
37
+ this._limit !== null && // And reading `maxReadSize` would fetch too many entities (> _limit)
38
+ this._fetched + maxReadSize > this._limit ? this._limit - this._fetched : maxReadSize;
39
+ // If we don't have anything left to read (_limit === _fetched),
40
+ // don't bother making the query and end the stream by pushing null
41
+ if (limit <= 0) {
42
+ this.push(null);
43
+ return;
44
+ }
45
+ // Compute the offset (base offset + number of entities already fetched)
46
+ const offset = this._offset + this._fetched;
47
+ // Update the query with the new values (offset + limit)
48
+ query.offset(offset).limit(limit);
49
+ // Lock the ._destroy()
50
+ this[knexPerformingQuery] = true;
51
+ let results;
52
+ let count;
53
+ let err;
54
+ try {
55
+ // Execute the query and store the results & count
56
+ results = await query;
57
+ const { populate } = this._qb.state;
58
+ // Applies the populate if needed
59
+ if (populate) {
60
+ await applyPopulate(results, populate, {
61
+ qb: this._qb,
62
+ uid: this._uid,
63
+ db: this._db
64
+ });
65
+ }
66
+ // Map results if asked to
67
+ if (this._mapResults) {
68
+ results = fromRow(this._meta, results);
69
+ }
70
+ count = results.length;
71
+ } catch (e) {
72
+ err = e;
73
+ }
74
+ // Unlock the ._destroy()
75
+ this[knexPerformingQuery] = false;
76
+ // Tell ._destroy() that it's now safe to close the db connection
77
+ if (this.destroyed) {
78
+ this.emit(knexQueryDone);
79
+ return;
80
+ }
81
+ // If there is an error, destroy with the given error
82
+ if (err) {
83
+ this.destroy(err);
84
+ return;
85
+ }
86
+ // Update the amount of fetched entities
87
+ this._fetched += count;
88
+ // While there is at least one value to unpack
89
+ for (const result of results){
90
+ this.push(result);
91
+ }
92
+ // If the amount of fetched entities is smaller than the
93
+ // maximum read size, Then push null to close the stream
94
+ if (this._fetched === this._limit || count < this._batchSize) {
95
+ this.push(null);
96
+ }
97
+ }
98
+ constructor({ qb, db, uid, mapResults = true, batchSize = 500 }){
99
+ super({
100
+ objectMode: true,
101
+ highWaterMark: batchSize
102
+ });
103
+ // Extract offset & limit from the query-builder's state
104
+ const { offset, limit } = qb.state;
105
+ // Original offset value
106
+ this._offset = isFinite(offset) ? Number(offset) : 0;
107
+ // Max amount of entities to fetch, force null as undefined value
108
+ this._limit = isFinite(limit) ? Number(limit) : null;
109
+ // Total amount of entities fetched
110
+ this._fetched = 0;
111
+ /**
112
+ * Original query
113
+ */ this._query = qb.getKnexQuery();
114
+ // Query Builder instance
115
+ this._qb = qb;
116
+ // Database related properties
117
+ this._db = db;
118
+ this._uid = uid;
119
+ this._meta = db.metadata.get(uid);
120
+ // Stream params
121
+ this._batchSize = batchSize;
122
+ this._mapResults = mapResults;
123
+ // States
124
+ this[knexPerformingQuery] = false;
125
+ }
126
+ }
127
+
128
+ export { ReadableStrapiQuery as default };
129
+ //# sourceMappingURL=readable.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"readable.mjs","sources":["../../../../src/query/helpers/streams/readable.ts"],"sourcesContent":["import { Readable } from 'stream';\nimport { isFinite } from 'lodash/fp';\nimport type { Knex } from 'knex';\nimport type { QueryBuilder } from '../../query-builder';\nimport type { Database } from '../../..';\n\nimport { applyPopulate } from '../populate';\nimport { fromRow } from '../transform';\nimport { Meta } from '../../../metadata';\n\nconst knexQueryDone = Symbol('knexQueryDone');\nconst knexPerformingQuery = Symbol('knexPerformingQuery');\n\ninterface ReadableStrapiQueryOptions {\n qb: QueryBuilder;\n uid: string;\n db: Database;\n mapResults?: boolean;\n batchSize?: number;\n}\n\nclass ReadableStrapiQuery extends Readable {\n _offset: number;\n\n _limit: number | null;\n\n _fetched: number;\n\n _query: Knex.QueryBuilder;\n\n _qb: QueryBuilder;\n\n _db: Database;\n\n _uid: string;\n\n _meta: Meta;\n\n _batchSize: number;\n\n _mapResults: boolean;\n\n [knexPerformingQuery]: boolean;\n\n constructor({ qb, db, uid, mapResults = true, batchSize = 500 }: ReadableStrapiQueryOptions) {\n super({ objectMode: true, highWaterMark: batchSize });\n\n // Extract offset & limit from the query-builder's state\n const { offset, limit } = qb.state;\n\n // Original offset value\n this._offset = isFinite(offset) ? Number(offset) : 0;\n\n // Max amount of entities to fetch, force null as undefined value\n this._limit = isFinite(limit) ? Number(limit) : null;\n\n // Total amount of entities fetched\n this._fetched = 0;\n\n /**\n * Original query\n */\n this._query = qb.getKnexQuery();\n\n // Query Builder instance\n this._qb = qb;\n\n // Database related properties\n this._db = db;\n this._uid = uid;\n this._meta = db.metadata.get(uid);\n\n // Stream params\n this._batchSize = batchSize;\n this._mapResults = mapResults;\n\n // States\n this[knexPerformingQuery] = false;\n }\n\n _destroy(err: Error, cb: (err?: Error) => void) {\n // If the stream is destroyed while a query is being made, then wait for a\n // kQueryDone event to be emitted before actually destroying the stream\n if (this[knexPerformingQuery]) {\n this.once(knexQueryDone, (er) => cb(err || er));\n } else {\n cb(err);\n }\n }\n\n /**\n * Custom ._read() implementation\n *\n * NOTE: Here \"size\" means the number of entities to be read from the database.\n * Not the actual byte size, as it would mean that we need to return partial entities.\n *\n */\n async _read(size: number) {\n const query = this._query;\n\n // Remove the original offset & limit properties from the query\n // Theoretically, they would be replaced by calling them again, but this is just to be sure\n query.clear('limit').clear('offset');\n\n // Define the maximum read size based on the limit and the requested size\n // NOTE: size is equal to _batchSize by default. Since we want to allow customizing it on\n // the fly, we need to use its value instead of batchSize when computing the maxReadSize value\n const maxReadSize =\n // if no limit is defined in the query, use the given size,\n // otherwise, use the smallest value between the two\n this._limit === null ? size : Math.min(size, this._limit);\n\n // Compute the limit for the next query\n const limit =\n // If a limit is defined\n this._limit !== null &&\n // And reading `maxReadSize` would fetch too many entities (> _limit)\n this._fetched + maxReadSize > this._limit\n ? // Then adjust the limit so that it only get the remaining entities\n this._limit - this._fetched\n : // Else, use the max read size\n maxReadSize;\n\n // If we don't have anything left to read (_limit === _fetched),\n // don't bother making the query and end the stream by pushing null\n if (limit <= 0) {\n this.push(null);\n return;\n }\n\n // Compute the offset (base offset + number of entities already fetched)\n const offset = this._offset + this._fetched;\n\n // Update the query with the new values (offset + limit)\n query.offset(offset).limit(limit);\n\n // Lock the ._destroy()\n this[knexPerformingQuery] = true;\n\n let results;\n let count;\n let err;\n\n try {\n // Execute the query and store the results & count\n results = await query;\n\n const { populate } = this._qb.state;\n\n // Applies the populate if needed\n if (populate) {\n await applyPopulate(results, populate, { qb: this._qb, uid: this._uid, db: this._db });\n }\n\n // Map results if asked to\n if (this._mapResults) {\n results = fromRow(this._meta, results);\n }\n\n count = results.length;\n } catch (e) {\n err = e;\n }\n\n // Unlock the ._destroy()\n this[knexPerformingQuery] = false;\n\n // Tell ._destroy() that it's now safe to close the db connection\n if (this.destroyed) {\n this.emit(knexQueryDone);\n return;\n }\n\n // If there is an error, destroy with the given error\n if (err) {\n this.destroy(err as Error);\n return;\n }\n\n // Update the amount of fetched entities\n this._fetched += count;\n\n // While there is at least one value to unpack\n for (const result of results) {\n this.push(result);\n }\n\n // If the amount of fetched entities is smaller than the\n // maximum read size, Then push null to close the stream\n if (this._fetched === this._limit || count < this._batchSize) {\n this.push(null);\n }\n }\n}\n\nexport default ReadableStrapiQuery;\n"],"names":["knexQueryDone","Symbol","knexPerformingQuery","ReadableStrapiQuery","Readable","_destroy","err","cb","once","er","_read","size","query","_query","clear","maxReadSize","_limit","Math","min","limit","_fetched","push","offset","_offset","results","count","populate","_qb","state","applyPopulate","qb","uid","_uid","db","_db","_mapResults","fromRow","_meta","length","e","destroyed","emit","destroy","result","_batchSize","constructor","mapResults","batchSize","objectMode","highWaterMark","isFinite","Number","getKnexQuery","metadata","get"],"mappings":"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"}
@@ -0,0 +1,77 @@
1
+ 'use strict';
2
+
3
+ var _ = require('lodash/fp');
4
+ var types = require('../../utils/types.js');
5
+ var index = require('../../fields/index.js');
6
+
7
+ const fromSingleRow = (meta, row)=>{
8
+ const { attributes } = meta;
9
+ if (_.isNil(row)) {
10
+ return null;
11
+ }
12
+ const obj = {};
13
+ for(const column in row){
14
+ if (!_.has(column, meta.columnToAttribute)) {
15
+ continue;
16
+ }
17
+ const attributeName = meta.columnToAttribute[column];
18
+ const attribute = attributes[attributeName];
19
+ if (types.isScalar(attribute.type)) {
20
+ const field = index.createField(attribute);
21
+ const val = row[column] === null ? null : field.fromDB(row[column]);
22
+ obj[attributeName] = val;
23
+ }
24
+ if (types.isRelation(attribute.type)) {
25
+ obj[attributeName] = row[column];
26
+ }
27
+ }
28
+ return obj;
29
+ };
30
+ const fromRow = (meta, row)=>{
31
+ if (_.isNil(row)) {
32
+ return null;
33
+ }
34
+ if (Array.isArray(row)) {
35
+ return row.map((singleRow)=>fromSingleRow(meta, singleRow));
36
+ }
37
+ return fromSingleRow(meta, row);
38
+ };
39
+ const toSingleRow = (meta, data = {})=>{
40
+ if (_.isNil(data)) {
41
+ return data;
42
+ }
43
+ const { attributes } = meta;
44
+ for (const key of Object.keys(data)){
45
+ const attribute = attributes[key];
46
+ if (!attribute || !('columnName' in attribute) || !attribute.columnName || attribute.columnName === key) {
47
+ continue;
48
+ }
49
+ data[attribute.columnName] = data[key];
50
+ delete data[key];
51
+ }
52
+ return data;
53
+ };
54
+ function toRow(meta, data) {
55
+ if (_.isNil(data)) {
56
+ return data;
57
+ }
58
+ if (_.isArray(data)) {
59
+ return data.map((datum)=>toSingleRow(meta, datum));
60
+ }
61
+ return toSingleRow(meta, data);
62
+ }
63
+ const toColumnName = (meta, name)=>{
64
+ if (!name) {
65
+ throw new Error('Name cannot be null');
66
+ }
67
+ const attribute = meta.attributes[name];
68
+ if (!attribute) {
69
+ return name;
70
+ }
71
+ return 'columnName' in attribute && attribute.columnName || name;
72
+ };
73
+
74
+ exports.fromRow = fromRow;
75
+ exports.toColumnName = toColumnName;
76
+ exports.toRow = toRow;
77
+ //# sourceMappingURL=transform.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transform.js","sources":["../../../src/query/helpers/transform.ts"],"sourcesContent":["import _ from 'lodash/fp';\n\nimport * as types from '../../utils/types';\nimport { createField } from '../../fields';\n\nimport type { Meta } from '../../metadata';\n\ntype Row = Record<string, unknown> | null;\nexport type Rec = Record<string, unknown> | null;\n\nconst fromSingleRow = (meta: Meta, row: Row): Rec => {\n const { attributes } = meta;\n\n if (_.isNil(row)) {\n return null;\n }\n\n const obj: Rec = {};\n\n for (const column in row) {\n if (!_.has(column, meta.columnToAttribute)) {\n continue;\n }\n\n const attributeName = meta.columnToAttribute[column];\n const attribute = attributes[attributeName];\n\n if (types.isScalar(attribute.type)) {\n const field = createField(attribute);\n\n const val = row[column] === null ? null : field.fromDB(row[column]);\n\n obj[attributeName] = val;\n }\n\n if (types.isRelation(attribute.type)) {\n obj[attributeName] = row[column];\n }\n }\n\n return obj;\n};\n\nconst fromRow = (meta: Meta, row: Row | Row[] | undefined) => {\n if (_.isNil(row)) {\n return null;\n }\n\n if (Array.isArray(row)) {\n return row.map((singleRow) => fromSingleRow(meta, singleRow));\n }\n\n return fromSingleRow(meta, row);\n};\n\nconst toSingleRow = (meta: Meta, data: Rec = {}): Row => {\n if (_.isNil(data)) {\n return data;\n }\n\n const { attributes } = meta;\n\n for (const key of Object.keys(data)) {\n const attribute = attributes[key];\n\n if (\n !attribute ||\n !('columnName' in attribute) ||\n !attribute.columnName ||\n attribute.columnName === key\n ) {\n continue;\n }\n\n data[attribute.columnName] = data[key];\n delete data[key];\n }\n\n return data;\n};\n\nfunction toRow<TData extends Rec | Rec[] | null>(\n meta: Meta,\n data: TData\n): TData extends null ? null : TData extends Rec[] ? Row[] : Rec;\nfunction toRow(meta: Meta, data: Rec | Rec[] | null): Row | Row[] | null {\n if (_.isNil(data)) {\n return data;\n }\n\n if (_.isArray(data)) {\n return data.map((datum) => toSingleRow(meta, datum));\n }\n\n return toSingleRow(meta, data);\n}\n\nconst toColumnName = (meta: Meta, name: null | string) => {\n if (!name) {\n throw new Error('Name cannot be null');\n }\n\n const attribute = meta.attributes[name];\n\n if (!attribute) {\n return name;\n }\n\n return ('columnName' in attribute && attribute.columnName) || name;\n};\n\nexport { toRow, fromRow, toColumnName };\n"],"names":["fromSingleRow","meta","row","attributes","_","isNil","obj","column","has","columnToAttribute","attributeName","attribute","types","type","field","createField","val","fromDB","fromRow","Array","isArray","map","singleRow","toSingleRow","data","key","Object","keys","columnName","toRow","datum","toColumnName","name","Error"],"mappings":"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"}
@@ -0,0 +1,73 @@
1
+ import _ from 'lodash/fp';
2
+ import { isScalar, isRelation } from '../../utils/types.mjs';
3
+ import { createField } from '../../fields/index.mjs';
4
+
5
+ const fromSingleRow = (meta, row)=>{
6
+ const { attributes } = meta;
7
+ if (_.isNil(row)) {
8
+ return null;
9
+ }
10
+ const obj = {};
11
+ for(const column in row){
12
+ if (!_.has(column, meta.columnToAttribute)) {
13
+ continue;
14
+ }
15
+ const attributeName = meta.columnToAttribute[column];
16
+ const attribute = attributes[attributeName];
17
+ if (isScalar(attribute.type)) {
18
+ const field = createField(attribute);
19
+ const val = row[column] === null ? null : field.fromDB(row[column]);
20
+ obj[attributeName] = val;
21
+ }
22
+ if (isRelation(attribute.type)) {
23
+ obj[attributeName] = row[column];
24
+ }
25
+ }
26
+ return obj;
27
+ };
28
+ const fromRow = (meta, row)=>{
29
+ if (_.isNil(row)) {
30
+ return null;
31
+ }
32
+ if (Array.isArray(row)) {
33
+ return row.map((singleRow)=>fromSingleRow(meta, singleRow));
34
+ }
35
+ return fromSingleRow(meta, row);
36
+ };
37
+ const toSingleRow = (meta, data = {})=>{
38
+ if (_.isNil(data)) {
39
+ return data;
40
+ }
41
+ const { attributes } = meta;
42
+ for (const key of Object.keys(data)){
43
+ const attribute = attributes[key];
44
+ if (!attribute || !('columnName' in attribute) || !attribute.columnName || attribute.columnName === key) {
45
+ continue;
46
+ }
47
+ data[attribute.columnName] = data[key];
48
+ delete data[key];
49
+ }
50
+ return data;
51
+ };
52
+ function toRow(meta, data) {
53
+ if (_.isNil(data)) {
54
+ return data;
55
+ }
56
+ if (_.isArray(data)) {
57
+ return data.map((datum)=>toSingleRow(meta, datum));
58
+ }
59
+ return toSingleRow(meta, data);
60
+ }
61
+ const toColumnName = (meta, name)=>{
62
+ if (!name) {
63
+ throw new Error('Name cannot be null');
64
+ }
65
+ const attribute = meta.attributes[name];
66
+ if (!attribute) {
67
+ return name;
68
+ }
69
+ return 'columnName' in attribute && attribute.columnName || name;
70
+ };
71
+
72
+ export { fromRow, toColumnName, toRow };
73
+ //# sourceMappingURL=transform.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transform.mjs","sources":["../../../src/query/helpers/transform.ts"],"sourcesContent":["import _ from 'lodash/fp';\n\nimport * as types from '../../utils/types';\nimport { createField } from '../../fields';\n\nimport type { Meta } from '../../metadata';\n\ntype Row = Record<string, unknown> | null;\nexport type Rec = Record<string, unknown> | null;\n\nconst fromSingleRow = (meta: Meta, row: Row): Rec => {\n const { attributes } = meta;\n\n if (_.isNil(row)) {\n return null;\n }\n\n const obj: Rec = {};\n\n for (const column in row) {\n if (!_.has(column, meta.columnToAttribute)) {\n continue;\n }\n\n const attributeName = meta.columnToAttribute[column];\n const attribute = attributes[attributeName];\n\n if (types.isScalar(attribute.type)) {\n const field = createField(attribute);\n\n const val = row[column] === null ? null : field.fromDB(row[column]);\n\n obj[attributeName] = val;\n }\n\n if (types.isRelation(attribute.type)) {\n obj[attributeName] = row[column];\n }\n }\n\n return obj;\n};\n\nconst fromRow = (meta: Meta, row: Row | Row[] | undefined) => {\n if (_.isNil(row)) {\n return null;\n }\n\n if (Array.isArray(row)) {\n return row.map((singleRow) => fromSingleRow(meta, singleRow));\n }\n\n return fromSingleRow(meta, row);\n};\n\nconst toSingleRow = (meta: Meta, data: Rec = {}): Row => {\n if (_.isNil(data)) {\n return data;\n }\n\n const { attributes } = meta;\n\n for (const key of Object.keys(data)) {\n const attribute = attributes[key];\n\n if (\n !attribute ||\n !('columnName' in attribute) ||\n !attribute.columnName ||\n attribute.columnName === key\n ) {\n continue;\n }\n\n data[attribute.columnName] = data[key];\n delete data[key];\n }\n\n return data;\n};\n\nfunction toRow<TData extends Rec | Rec[] | null>(\n meta: Meta,\n data: TData\n): TData extends null ? null : TData extends Rec[] ? Row[] : Rec;\nfunction toRow(meta: Meta, data: Rec | Rec[] | null): Row | Row[] | null {\n if (_.isNil(data)) {\n return data;\n }\n\n if (_.isArray(data)) {\n return data.map((datum) => toSingleRow(meta, datum));\n }\n\n return toSingleRow(meta, data);\n}\n\nconst toColumnName = (meta: Meta, name: null | string) => {\n if (!name) {\n throw new Error('Name cannot be null');\n }\n\n const attribute = meta.attributes[name];\n\n if (!attribute) {\n return name;\n }\n\n return ('columnName' in attribute && attribute.columnName) || name;\n};\n\nexport { toRow, fromRow, toColumnName };\n"],"names":["fromSingleRow","meta","row","attributes","_","isNil","obj","column","has","columnToAttribute","attributeName","attribute","types","type","field","createField","val","fromDB","fromRow","Array","isArray","map","singleRow","toSingleRow","data","key","Object","keys","columnName","toRow","datum","toColumnName","name","Error"],"mappings":"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"}