@nocobase/database 0.5.0-alpha.38 → 0.7.0-alpha.0

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 (458) hide show
  1. package/LICENSE +201 -21
  2. package/esm/collection-importer.d.ts +7 -0
  3. package/esm/collection-importer.js +49 -0
  4. package/esm/collection-importer.js.map +1 -0
  5. package/esm/collection.d.ts +73 -0
  6. package/esm/collection.js +224 -0
  7. package/esm/collection.js.map +1 -0
  8. package/esm/database.d.ts +101 -0
  9. package/esm/database.js +275 -0
  10. package/esm/database.js.map +1 -0
  11. package/esm/fields/array-field.d.ts +11 -0
  12. package/esm/fields/array-field.js +26 -0
  13. package/esm/fields/array-field.js.map +1 -0
  14. package/esm/fields/belongs-to-field.d.ts +12 -0
  15. package/esm/fields/belongs-to-field.js +57 -0
  16. package/esm/fields/belongs-to-field.js.map +1 -0
  17. package/esm/fields/belongs-to-many-field.d.ts +11 -0
  18. package/esm/fields/belongs-to-many-field.js +55 -0
  19. package/esm/fields/belongs-to-many-field.js.map +1 -0
  20. package/esm/fields/boolean-field.d.ts +8 -0
  21. package/esm/fields/boolean-field.js +8 -0
  22. package/esm/fields/boolean-field.js.map +1 -0
  23. package/esm/fields/context-field.d.ts +13 -0
  24. package/esm/fields/context-field.js +43 -0
  25. package/esm/fields/context-field.js.map +1 -0
  26. package/esm/fields/date-field.d.ts +8 -0
  27. package/esm/fields/date-field.js +8 -0
  28. package/esm/fields/date-field.js.map +1 -0
  29. package/esm/fields/field.d.ts +37 -0
  30. package/esm/fields/field.js +74 -0
  31. package/esm/fields/field.js.map +1 -0
  32. package/esm/fields/has-inverse-field.d.ts +4 -0
  33. package/esm/fields/has-inverse-field.js +2 -0
  34. package/esm/fields/has-inverse-field.js.map +1 -0
  35. package/esm/fields/has-many-field.d.ts +64 -0
  36. package/esm/fields/has-many-field.js +58 -0
  37. package/esm/fields/has-many-field.js.map +1 -0
  38. package/esm/fields/has-one-field.d.ts +64 -0
  39. package/esm/fields/has-one-field.js +57 -0
  40. package/esm/fields/has-one-field.js.map +1 -0
  41. package/esm/fields/index.d.ts +40 -0
  42. package/esm/fields/index.js +21 -0
  43. package/esm/fields/index.js.map +1 -0
  44. package/esm/fields/json-field.d.ts +14 -0
  45. package/esm/fields/json-field.js +17 -0
  46. package/esm/fields/json-field.js.map +1 -0
  47. package/esm/fields/number-field.d.ts +32 -0
  48. package/esm/fields/number-field.js +28 -0
  49. package/esm/fields/number-field.js.map +1 -0
  50. package/esm/fields/password-field.d.ts +21 -0
  51. package/esm/fields/password-field.js +71 -0
  52. package/esm/fields/password-field.js.map +1 -0
  53. package/esm/fields/radio-field.d.ts +14 -0
  54. package/esm/fields/radio-field.js +49 -0
  55. package/esm/fields/radio-field.js.map +1 -0
  56. package/esm/fields/relation-field.d.ts +20 -0
  57. package/esm/fields/relation-field.js +27 -0
  58. package/esm/fields/relation-field.js.map +1 -0
  59. package/esm/fields/sort-field.d.ts +16 -0
  60. package/esm/fields/sort-field.js +90 -0
  61. package/esm/fields/sort-field.js.map +1 -0
  62. package/esm/fields/string-field.d.ts +8 -0
  63. package/esm/fields/string-field.js +8 -0
  64. package/esm/fields/string-field.js.map +1 -0
  65. package/esm/fields/text-field.d.ts +8 -0
  66. package/esm/fields/text-field.js +8 -0
  67. package/esm/fields/text-field.js.map +1 -0
  68. package/esm/fields/time-field.d.ts +8 -0
  69. package/esm/fields/time-field.js +8 -0
  70. package/esm/fields/time-field.js.map +1 -0
  71. package/esm/fields/uid-field.d.ts +10 -0
  72. package/esm/fields/uid-field.js +27 -0
  73. package/esm/fields/uid-field.js.map +1 -0
  74. package/esm/fields/virtual-field.d.ts +8 -0
  75. package/esm/fields/virtual-field.js +8 -0
  76. package/esm/fields/virtual-field.js.map +1 -0
  77. package/esm/filter-parser.d.ts +27 -0
  78. package/esm/filter-parser.js +185 -0
  79. package/esm/filter-parser.js.map +1 -0
  80. package/esm/index.d.ts +15 -0
  81. package/esm/index.js +16 -0
  82. package/esm/index.js.map +1 -0
  83. package/esm/magic-attribute-model.d.ts +7 -0
  84. package/esm/magic-attribute-model.js +70 -0
  85. package/esm/magic-attribute-model.js.map +1 -0
  86. package/esm/mock-database.d.ts +22 -0
  87. package/esm/mock-database.js +34 -0
  88. package/esm/mock-database.js.map +1 -0
  89. package/esm/model-hook.d.ts +12 -0
  90. package/esm/model-hook.js +61 -0
  91. package/esm/model-hook.js.map +1 -0
  92. package/esm/model.d.ts +15 -0
  93. package/esm/model.js +80 -0
  94. package/esm/model.js.map +1 -0
  95. package/esm/operators/array.d.ts +26 -0
  96. package/esm/operators/array.js +105 -0
  97. package/esm/operators/array.js.map +1 -0
  98. package/esm/operators/association.d.ts +10 -0
  99. package/esm/operators/association.js +14 -0
  100. package/esm/operators/association.js.map +1 -0
  101. package/esm/operators/date.d.ts +34 -0
  102. package/esm/operators/date.js +35 -0
  103. package/esm/operators/date.js.map +1 -0
  104. package/esm/operators/empty.d.ts +28 -0
  105. package/esm/operators/empty.js +58 -0
  106. package/esm/operators/empty.js.map +1 -0
  107. package/esm/operators/index.d.ts +2 -0
  108. package/esm/operators/index.js +2 -0
  109. package/esm/operators/index.js.map +1 -0
  110. package/esm/operators/ne.d.ts +10 -0
  111. package/esm/operators/ne.js +12 -0
  112. package/esm/operators/ne.js.map +1 -0
  113. package/esm/operators/string.d.ts +21 -0
  114. package/esm/operators/string.js +35 -0
  115. package/esm/operators/string.js.map +1 -0
  116. package/esm/operators/utils.d.ts +4 -0
  117. package/esm/operators/utils.js +11 -0
  118. package/esm/operators/utils.js.map +1 -0
  119. package/esm/options-parser.d.ts +31 -0
  120. package/esm/options-parser.js +225 -0
  121. package/esm/options-parser.js.map +1 -0
  122. package/esm/playground.d.ts +1 -0
  123. package/esm/playground.js +53 -0
  124. package/esm/playground.js.map +1 -0
  125. package/esm/relation-repository/belongs-to-many-repository.d.ts +36 -0
  126. package/esm/relation-repository/belongs-to-many-repository.js +199 -0
  127. package/esm/relation-repository/belongs-to-many-repository.js.map +1 -0
  128. package/esm/relation-repository/belongs-to-repository.d.ts +17 -0
  129. package/esm/relation-repository/belongs-to-repository.js +4 -0
  130. package/esm/relation-repository/belongs-to-repository.js.map +1 -0
  131. package/esm/relation-repository/hasmany-repository.d.ts +23 -0
  132. package/esm/relation-repository/hasmany-repository.js +125 -0
  133. package/esm/relation-repository/hasmany-repository.js.map +1 -0
  134. package/esm/relation-repository/hasone-repository.d.ts +17 -0
  135. package/esm/relation-repository/hasone-repository.js +4 -0
  136. package/esm/relation-repository/hasone-repository.js.map +1 -0
  137. package/esm/relation-repository/multiple-relation-repository.d.ts +23 -0
  138. package/esm/relation-repository/multiple-relation-repository.js +149 -0
  139. package/esm/relation-repository/multiple-relation-repository.js.map +1 -0
  140. package/esm/relation-repository/relation-repository.d.ts +32 -0
  141. package/esm/relation-repository/relation-repository.js +93 -0
  142. package/esm/relation-repository/relation-repository.js.map +1 -0
  143. package/esm/relation-repository/single-relation-repository.d.ts +23 -0
  144. package/esm/relation-repository/single-relation-repository.js +96 -0
  145. package/esm/relation-repository/single-relation-repository.js.map +1 -0
  146. package/esm/relation-repository/types.d.ts +7 -0
  147. package/esm/relation-repository/types.js +2 -0
  148. package/esm/relation-repository/types.js.map +1 -0
  149. package/esm/repository.d.ts +165 -0
  150. package/esm/repository.js +276 -0
  151. package/esm/repository.js.map +1 -0
  152. package/esm/transaction-decorator.d.ts +1 -0
  153. package/esm/transaction-decorator.js +63 -0
  154. package/esm/transaction-decorator.js.map +1 -0
  155. package/esm/update-associations.d.ts +60 -0
  156. package/esm/update-associations.js +362 -0
  157. package/esm/update-associations.js.map +1 -0
  158. package/esm/update-guard.d.ts +26 -0
  159. package/esm/update-guard.js +122 -0
  160. package/esm/update-guard.js.map +1 -0
  161. package/lib/collection-importer.d.ts +7 -0
  162. package/lib/collection-importer.js +75 -0
  163. package/lib/collection-importer.js.map +1 -0
  164. package/lib/collection.d.ts +73 -0
  165. package/lib/collection.js +231 -0
  166. package/lib/collection.js.map +1 -0
  167. package/lib/database.d.ts +93 -43
  168. package/lib/database.js +277 -471
  169. package/lib/database.js.map +1 -1
  170. package/lib/fields/array-field.d.ts +11 -0
  171. package/lib/fields/array-field.js +30 -0
  172. package/lib/fields/array-field.js.map +1 -0
  173. package/lib/fields/belongs-to-field.d.ts +12 -0
  174. package/lib/fields/belongs-to-field.js +61 -0
  175. package/lib/fields/belongs-to-field.js.map +1 -0
  176. package/lib/fields/belongs-to-many-field.d.ts +11 -0
  177. package/lib/fields/belongs-to-many-field.js +59 -0
  178. package/lib/fields/belongs-to-many-field.js.map +1 -0
  179. package/lib/fields/boolean-field.d.ts +8 -0
  180. package/lib/fields/boolean-field.js +12 -0
  181. package/lib/fields/boolean-field.js.map +1 -0
  182. package/lib/fields/context-field.d.ts +13 -0
  183. package/lib/fields/context-field.js +47 -0
  184. package/lib/fields/context-field.js.map +1 -0
  185. package/lib/fields/date-field.d.ts +8 -0
  186. package/lib/fields/date-field.js +12 -0
  187. package/lib/fields/date-field.js.map +1 -0
  188. package/lib/fields/field.d.ts +37 -0
  189. package/lib/fields/field.js +81 -0
  190. package/lib/fields/field.js.map +1 -0
  191. package/lib/fields/has-inverse-field.d.ts +4 -0
  192. package/lib/fields/has-inverse-field.js +3 -0
  193. package/lib/fields/has-inverse-field.js.map +1 -0
  194. package/lib/fields/has-many-field.d.ts +64 -0
  195. package/lib/fields/has-many-field.js +62 -0
  196. package/lib/fields/has-many-field.js.map +1 -0
  197. package/lib/fields/has-one-field.d.ts +64 -0
  198. package/lib/fields/has-one-field.js +61 -0
  199. package/lib/fields/has-one-field.js.map +1 -0
  200. package/lib/fields/index.d.ts +40 -10
  201. package/lib/fields/index.js +31 -138
  202. package/lib/fields/index.js.map +1 -1
  203. package/lib/fields/json-field.d.ts +14 -0
  204. package/lib/fields/json-field.js +22 -0
  205. package/lib/fields/json-field.js.map +1 -0
  206. package/lib/fields/number-field.d.ts +32 -0
  207. package/lib/fields/number-field.js +36 -0
  208. package/lib/fields/number-field.js.map +1 -0
  209. package/lib/fields/password-field.d.ts +21 -0
  210. package/lib/fields/password-field.js +78 -0
  211. package/lib/fields/password-field.js.map +1 -0
  212. package/lib/fields/radio-field.d.ts +14 -0
  213. package/lib/fields/radio-field.js +53 -0
  214. package/lib/fields/radio-field.js.map +1 -0
  215. package/lib/fields/relation-field.d.ts +20 -0
  216. package/lib/fields/relation-field.js +31 -0
  217. package/lib/fields/relation-field.js.map +1 -0
  218. package/lib/fields/sort-field.d.ts +16 -0
  219. package/lib/fields/sort-field.js +94 -0
  220. package/lib/fields/sort-field.js.map +1 -0
  221. package/lib/fields/string-field.d.ts +8 -0
  222. package/lib/fields/string-field.js +12 -0
  223. package/lib/fields/string-field.js.map +1 -0
  224. package/lib/fields/text-field.d.ts +8 -0
  225. package/lib/fields/text-field.js +12 -0
  226. package/lib/fields/text-field.js.map +1 -0
  227. package/lib/fields/time-field.d.ts +8 -0
  228. package/lib/fields/time-field.js +12 -0
  229. package/lib/fields/time-field.js.map +1 -0
  230. package/lib/fields/uid-field.d.ts +10 -0
  231. package/lib/fields/uid-field.js +31 -0
  232. package/lib/fields/uid-field.js.map +1 -0
  233. package/lib/fields/virtual-field.d.ts +8 -0
  234. package/lib/fields/virtual-field.js +12 -0
  235. package/lib/fields/virtual-field.js.map +1 -0
  236. package/lib/filter-parser.d.ts +27 -0
  237. package/lib/filter-parser.js +191 -0
  238. package/lib/filter-parser.js.map +1 -0
  239. package/lib/index.d.ts +13 -6
  240. package/lib/index.js +27 -60
  241. package/lib/index.js.map +1 -1
  242. package/lib/magic-attribute-model.d.ts +7 -0
  243. package/lib/magic-attribute-model.js +77 -0
  244. package/lib/magic-attribute-model.js.map +1 -0
  245. package/lib/mock-database.d.ts +22 -0
  246. package/lib/mock-database.js +40 -0
  247. package/lib/mock-database.js.map +1 -0
  248. package/lib/model-hook.d.ts +12 -0
  249. package/lib/model-hook.js +68 -0
  250. package/lib/model-hook.js.map +1 -0
  251. package/lib/model.d.ts +11 -45
  252. package/lib/model.js +76 -452
  253. package/lib/model.js.map +1 -1
  254. package/lib/operators/array.d.ts +26 -0
  255. package/lib/operators/array.js +107 -0
  256. package/lib/operators/array.js.map +1 -0
  257. package/lib/operators/association.d.ts +10 -0
  258. package/lib/operators/association.js +16 -0
  259. package/lib/operators/association.js.map +1 -0
  260. package/lib/operators/date.d.ts +34 -0
  261. package/lib/operators/date.js +40 -0
  262. package/lib/operators/date.js.map +1 -0
  263. package/lib/operators/empty.d.ts +28 -0
  264. package/lib/operators/empty.js +82 -0
  265. package/lib/operators/empty.js.map +1 -0
  266. package/lib/operators/index.d.ts +2 -0
  267. package/lib/operators/index.js +4 -0
  268. package/lib/operators/index.js.map +1 -0
  269. package/lib/operators/ne.d.ts +10 -0
  270. package/lib/operators/ne.js +14 -0
  271. package/lib/operators/ne.js.map +1 -0
  272. package/lib/operators/string.d.ts +21 -0
  273. package/lib/operators/string.js +37 -0
  274. package/lib/operators/string.js.map +1 -0
  275. package/lib/operators/utils.d.ts +4 -0
  276. package/lib/operators/utils.js +16 -0
  277. package/lib/operators/utils.js.map +1 -0
  278. package/lib/options-parser.d.ts +31 -0
  279. package/lib/options-parser.js +232 -0
  280. package/lib/options-parser.js.map +1 -0
  281. package/lib/playground.d.ts +1 -0
  282. package/lib/playground.js +55 -0
  283. package/lib/playground.js.map +1 -0
  284. package/lib/relation-repository/belongs-to-many-repository.d.ts +36 -0
  285. package/lib/relation-repository/belongs-to-many-repository.js +206 -0
  286. package/lib/relation-repository/belongs-to-many-repository.js.map +1 -0
  287. package/lib/relation-repository/belongs-to-repository.d.ts +17 -0
  288. package/lib/relation-repository/belongs-to-repository.js +8 -0
  289. package/lib/relation-repository/belongs-to-repository.js.map +1 -0
  290. package/lib/relation-repository/hasmany-repository.d.ts +23 -0
  291. package/lib/relation-repository/hasmany-repository.js +129 -0
  292. package/lib/relation-repository/hasmany-repository.js.map +1 -0
  293. package/lib/relation-repository/hasone-repository.d.ts +17 -0
  294. package/lib/relation-repository/hasone-repository.js +8 -0
  295. package/lib/relation-repository/hasone-repository.js.map +1 -0
  296. package/lib/relation-repository/multiple-relation-repository.d.ts +23 -0
  297. package/lib/relation-repository/multiple-relation-repository.js +153 -0
  298. package/lib/relation-repository/multiple-relation-repository.js.map +1 -0
  299. package/lib/relation-repository/relation-repository.d.ts +32 -0
  300. package/lib/relation-repository/relation-repository.js +100 -0
  301. package/lib/relation-repository/relation-repository.js.map +1 -0
  302. package/lib/relation-repository/single-relation-repository.d.ts +23 -0
  303. package/lib/relation-repository/single-relation-repository.js +103 -0
  304. package/lib/relation-repository/single-relation-repository.js.map +1 -0
  305. package/lib/relation-repository/types.d.ts +7 -0
  306. package/lib/relation-repository/types.js +3 -0
  307. package/lib/relation-repository/types.js.map +1 -0
  308. package/lib/repository.d.ts +165 -0
  309. package/lib/repository.js +302 -0
  310. package/lib/repository.js.map +1 -0
  311. package/lib/transaction-decorator.d.ts +1 -0
  312. package/lib/transaction-decorator.js +70 -0
  313. package/lib/transaction-decorator.js.map +1 -0
  314. package/lib/update-associations.d.ts +60 -0
  315. package/lib/update-associations.js +374 -0
  316. package/lib/update-associations.js.map +1 -0
  317. package/lib/update-guard.d.ts +26 -0
  318. package/lib/update-guard.js +129 -0
  319. package/lib/update-guard.js.map +1 -0
  320. package/package.json +17 -5
  321. package/src/__tests__/collection-importer.test.ts +21 -0
  322. package/src/__tests__/collection.sortable.test.ts +65 -0
  323. package/src/__tests__/collection.test.ts +218 -0
  324. package/src/__tests__/database.import.test.ts +33 -0
  325. package/src/__tests__/database.test.ts +229 -0
  326. package/src/__tests__/field-options/hidden.test.ts +302 -0
  327. package/src/__tests__/field-options/sort-by.test.ts +220 -0
  328. package/src/__tests__/fields/belongs-to-field.test.ts +162 -0
  329. package/src/__tests__/fields/belongs-to-many-field.test.ts +61 -0
  330. package/src/__tests__/fields/context-field.test.ts +140 -0
  331. package/src/__tests__/fields/has-many-field.test.ts +152 -0
  332. package/src/__tests__/fields/has-one-field.test.ts +67 -0
  333. package/src/__tests__/fields/password-field.test.ts +30 -0
  334. package/src/__tests__/fields/sort-field.test.ts +133 -0
  335. package/src/__tests__/fields/string-field.test.ts +77 -0
  336. package/src/__tests__/filter-parser.test.ts +104 -0
  337. package/src/__tests__/fixtures/c0/a.ts +6 -0
  338. package/src/__tests__/fixtures/c1/b.ts +6 -0
  339. package/src/__tests__/fixtures/c2/a.ts +6 -0
  340. package/src/__tests__/fixtures/collections/delay-extend.ts +6 -0
  341. package/src/__tests__/fixtures/collections/delay-extend2.ts +6 -0
  342. package/src/__tests__/fixtures/collections/extend.ts +6 -0
  343. package/src/__tests__/fixtures/collections/extend2.ts +6 -0
  344. package/src/__tests__/fixtures/collections/posts.ts +4 -0
  345. package/src/__tests__/fixtures/collections/tags.js +4 -0
  346. package/src/__tests__/fixtures/collections/test.jpg +0 -0
  347. package/src/__tests__/fixtures/collections/user.json +9 -0
  348. package/src/__tests__/index.ts +1 -0
  349. package/src/__tests__/magic-attribute-model.test.ts +103 -0
  350. package/src/__tests__/model.test.ts +60 -0
  351. package/src/__tests__/operator/array-operator.test.ts +268 -0
  352. package/src/__tests__/operator/association-operator.test.ts +263 -0
  353. package/src/__tests__/operator/date-operator.test.ts +165 -0
  354. package/src/__tests__/operator/empty-operator.test.ts +77 -0
  355. package/src/__tests__/operator/ne.test.ts +33 -0
  356. package/src/__tests__/operator/string-operator.test.ts +62 -0
  357. package/src/__tests__/option-parser.test.ts +185 -0
  358. package/src/__tests__/relation-repository/belongs-to-many-repository.test.ts +697 -0
  359. package/src/__tests__/relation-repository/has-many-repository.test.ts +414 -0
  360. package/src/__tests__/relation-repository/hasone-repository.test.ts +77 -0
  361. package/src/__tests__/repository/count.test.ts +180 -0
  362. package/src/__tests__/repository/create.test.ts +163 -0
  363. package/src/__tests__/repository/destroy.test.ts +196 -0
  364. package/src/__tests__/repository/find.test.ts +247 -0
  365. package/src/__tests__/repository/update.test.ts +60 -0
  366. package/src/__tests__/repository.test.ts +438 -0
  367. package/src/__tests__/update-associations.test.ts +412 -0
  368. package/src/__tests__/update-guard.test.ts +376 -0
  369. package/src/collection-importer.ts +49 -0
  370. package/src/collection.ts +282 -0
  371. package/src/database.ts +340 -0
  372. package/src/fields/array-field.ts +35 -0
  373. package/src/fields/belongs-to-field.ts +76 -0
  374. package/src/fields/belongs-to-many-field.ts +77 -0
  375. package/src/fields/boolean-field.ts +12 -0
  376. package/src/fields/context-field.ts +45 -0
  377. package/src/fields/date-field.ts +12 -0
  378. package/src/fields/field.ts +105 -0
  379. package/src/fields/has-inverse-field.ts +5 -0
  380. package/src/fields/has-many-field.ts +143 -0
  381. package/src/fields/has-one-field.ts +136 -0
  382. package/src/fields/index.ts +72 -0
  383. package/src/fields/json-field.ts +25 -0
  384. package/src/fields/number-field.ts +52 -0
  385. package/src/fields/password-field.ts +72 -0
  386. package/src/fields/radio-field.ts +50 -0
  387. package/src/fields/relation-field.ts +37 -0
  388. package/src/fields/sort-field.ts +96 -0
  389. package/src/fields/string-field.ts +12 -0
  390. package/src/fields/text-field.ts +12 -0
  391. package/src/fields/time-field.ts +12 -0
  392. package/src/fields/uid-field.ts +24 -0
  393. package/src/fields/virtual-field.ts +12 -0
  394. package/src/filter-parser.ts +243 -0
  395. package/src/index.ts +16 -0
  396. package/src/magic-attribute-model.ts +62 -0
  397. package/src/mock-database.ts +42 -0
  398. package/src/model-hook.ts +69 -0
  399. package/src/model.ts +114 -0
  400. package/src/operators/array.ts +145 -0
  401. package/src/operators/association.ts +14 -0
  402. package/src/operators/date.ts +41 -0
  403. package/src/operators/empty.ts +75 -0
  404. package/src/operators/index.ts +8 -0
  405. package/src/operators/ne.ts +12 -0
  406. package/src/operators/string.ts +40 -0
  407. package/src/operators/utils.ts +13 -0
  408. package/src/options-parser.ts +285 -0
  409. package/src/playground.ts +52 -0
  410. package/src/relation-repository/belongs-to-many-repository.ts +240 -0
  411. package/src/relation-repository/belongs-to-repository.ts +23 -0
  412. package/src/relation-repository/hasmany-repository.ts +145 -0
  413. package/src/relation-repository/hasone-repository.ts +23 -0
  414. package/src/relation-repository/multiple-relation-repository.ts +198 -0
  415. package/src/relation-repository/relation-repository.ts +114 -0
  416. package/src/relation-repository/single-relation-repository.ts +99 -0
  417. package/src/relation-repository/types.ts +15 -0
  418. package/src/repository.ts +478 -0
  419. package/src/transaction-decorator.ts +58 -0
  420. package/src/update-associations.ts +478 -0
  421. package/src/update-guard.ts +167 -0
  422. package/tsconfig.build.json +9 -0
  423. package/tsconfig.json +5 -0
  424. package/examples/index.ts +0 -125
  425. package/examples/plugins/db-driven/index.ts +0 -25
  426. package/examples/plugins/db-driven/tables/fields.ts +0 -78
  427. package/examples/plugins/db-driven/tables/tables.ts +0 -53
  428. package/examples/tables/bar.js +0 -26
  429. package/examples/tables/comments.ts +0 -19
  430. package/examples/tables/foo.json +0 -3
  431. package/examples/tables/posts.ts +0 -28
  432. package/examples/tables/profiles.ts +0 -23
  433. package/examples/tables/tags.ts +0 -15
  434. package/examples/tables/users.ts +0 -34
  435. package/lib/database.d.ts.map +0 -1
  436. package/lib/fields/field-types.d.ts +0 -419
  437. package/lib/fields/field-types.d.ts.map +0 -1
  438. package/lib/fields/field-types.js +0 -1222
  439. package/lib/fields/field-types.js.map +0 -1
  440. package/lib/fields/index.d.ts.map +0 -1
  441. package/lib/fields/option-types.d.ts +0 -105
  442. package/lib/fields/option-types.d.ts.map +0 -1
  443. package/lib/fields/option-types.js +0 -18
  444. package/lib/fields/option-types.js.map +0 -1
  445. package/lib/index.d.ts.map +0 -1
  446. package/lib/model.d.ts.map +0 -1
  447. package/lib/op.d.ts +0 -45
  448. package/lib/op.d.ts.map +0 -1
  449. package/lib/op.js +0 -225
  450. package/lib/op.js.map +0 -1
  451. package/lib/table.d.ts +0 -56
  452. package/lib/table.d.ts.map +0 -1
  453. package/lib/table.js +0 -456
  454. package/lib/table.js.map +0 -1
  455. package/lib/utils.d.ts +0 -26
  456. package/lib/utils.d.ts.map +0 -1
  457. package/lib/utils.js +0 -438
  458. package/lib/utils.js.map +0 -1
package/lib/model.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["model.ts"],"names":[],"mappings":"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","file":"model.js","sourcesContent":["import {\n Model as SequelizeModel,\n Op,\n Sequelize,\n ProjectionAlias,\n Utils,\n SaveOptions,\n} from 'sequelize';\nimport Database from './database';\nimport {\n getDataTypeKey,\n HASONE,\n HASMANY,\n BELONGSTO,\n BELONGSTOMANY,\n} from './fields';\nimport { toInclude } from './utils';\n\nexport interface ApiJsonOptions {\n /**\n * 字段\n *\n * 数组式:\n * ['col', 'association.col1', 'association_count'],\n *\n * 白名单:\n * {\n * only: ['col1'],\n * appends: ['association_count'],\n * }\n *\n * 黑名单:\n * {\n * except: ['col1'],\n * appends: ['association_count'],\n * }\n */\n fields?:\n | string[]\n | {\n only?: string[];\n appends?: string[];\n }\n | {\n except?: string[];\n appends?: string[];\n };\n\n /**\n * 过滤\n *\n * 常规用法:\n * {\n * col1: {\n * $eq: 'val1'\n * },\n * }\n *\n * scope 的用法(如果 scope 与 col 同名,只会执行 scope):\n * {\n * scope1: value\n * }\n *\n * json 数据 & 关系数据,可以用点号:\n * {\n * 'association.col1': {\n * $eq: 'val1'\n * },\n * }\n *\n * meta 为 json 字段时\n * {\n * 'meta.key': {\n * $eq: 'val1'\n * },\n * }\n *\n * json 数据 & 关系数据的查询也可以不用点号:\n * {\n * association: {\n * col1: {\n * $eq: 'val1'\n * },\n * },\n * }\n */\n filter?: any;\n\n /**\n * 排序\n *\n * TODO\n *\n * ['col1', '-col2', 'association.col1', '-association.col2']\n */\n sort?: any;\n\n /**\n * 页码\n */\n page?: number;\n perPage?: number;\n\n context?: any;\n\n [key: string]: any;\n}\n\nexport interface WithCountAttributeOptions {\n /**\n * 关系名\n */\n association: string;\n\n /**\n * SourceModel 别名\n *\n * 在 include 里使用时,需要指定,一般与 include 的 association 同名\n *\n * include: {\n * association: 'user', // Post.belongsTo(User)\n * attributes: [\n * User.withCountAttribute({\n * association: 'posts',\n * sourceAlias: 'user', // 内嵌时,需要指定 source 别名\n * })\n * ]\n * }\n */\n sourceAlias?: string;\n\n where?: any;\n\n /**\n * 别名,默认为 association_count\n */\n alias?: string;\n\n [key: string]: any;\n}\n\nexport const DEFAULT_OFFSET = 0;\nexport const DEFAULT_LIMIT = 100;\nexport const MAX_LIMIT = 500;\n\nexport interface UpdateAssociationOptions extends SaveOptions {\n context?: any;\n}\n\n/**\n * Model 相关\n *\n * TODO: 自定义 model 时的提示问题\n */\n// @ts-ignore\nexport abstract class Model extends SequelizeModel {\n /**\n * 防止 ts 报错提示\n */\n [key: string]: any;\n\n /**\n * 当前 Model 的 database\n *\n * 与 Model.sequelize 对应,database 也用了 public static readonly\n */\n public static database: Database;\n\n /**\n * 供 model 实例访问的 database\n */\n get database(): Database {\n // @ts-ignore\n return this.constructor.database;\n }\n\n /**\n * sub query 关联数据的数量\n *\n * TODO: 关联字段暂不支持主键以外的字段\n *\n * @param options\n */\n static withCountAttribute(\n options?: string | WithCountAttributeOptions,\n ): string | ProjectionAlias {\n if (typeof options === 'string') {\n options = { association: options };\n }\n\n const {\n sourceAlias,\n association,\n where = {},\n alias,\n ...restOptions\n } = options;\n const associator = this.associations[association];\n const table = this.database.getTable(this.name);\n const field = table.getField(association);\n const { targetKey, otherKey, foreignKey, sourceKey } = field.options as any;\n\n if (associator.associationType === 'HasMany') {\n where[foreignKey as string] = {\n [Op.eq]: Sequelize.col(`${sourceAlias || this.name}.${sourceKey}`),\n };\n } else if (associator.associationType === 'BelongsToMany') {\n where[targetKey] = {\n [Op.in]: Sequelize.literal(\n `(${(associator as any).through.model.selectQuery({\n attributes: [otherKey],\n where: {\n [foreignKey]: {\n [Op.eq]: Sequelize.col(\n `${sourceAlias || this.name}.${sourceKey}`,\n ),\n },\n // @ts-ignore\n ...(associator.through.scope || {}),\n },\n })})`,\n ),\n };\n }\n\n let countLiteral = 'count(*)';\n\n if (this.database.sequelize.getDialect() === 'postgres') {\n countLiteral = 'cast(count(*) as integer)';\n }\n\n const attribute = [\n Sequelize.literal(\n // @ts-ignore\n `(${associator.target.selectQuery({\n ...restOptions,\n attributes: [[Sequelize.literal(countLiteral), 'count']],\n where: {\n // @ts-ignore\n ...where,\n ...((associator as any).scope || {}),\n },\n })})`,\n ),\n alias ||\n Utils.underscoredIf(`${association}Count`, this.options.underscored),\n ].filter(Boolean);\n\n return (attribute as unknown) as ProjectionAlias;\n }\n\n /**\n * 当前 Model 的 SQL\n *\n * @param options\n */\n static selectQuery(options = {}): string {\n // @ts-ignore\n return this.queryGenerator\n .selectQuery(this.getTableName(), options, this)\n .replace(/;$/, '');\n }\n\n static parseApiJson(options: ApiJsonOptions) {\n const { fields, filter, sort, context, page, perPage } = options;\n const data = toInclude(\n { fields, filter, sort },\n {\n model: this,\n associations: this.associations,\n dialect: this.sequelize.getDialect(),\n ctx: context,\n database: this.database,\n },\n );\n if (page || perPage) {\n data.limit =\n perPage === -1\n ? MAX_LIMIT\n : Math.min(perPage || DEFAULT_LIMIT, MAX_LIMIT);\n data.offset = data.limit * (page > 0 ? page - 1 : DEFAULT_OFFSET);\n }\n if (data.attributes && data.attributes.length === 0) {\n delete data.attributes;\n }\n return data;\n }\n\n getValuesByFieldNames(scope = []) {\n const table = this.database.getTable(this.constructor.name);\n const Model = table.getModel();\n const associations = table.getAssociations();\n const where = {};\n scope.forEach((col) => {\n const association = associations.get(col);\n const dataKey =\n association && association instanceof BELONGSTO\n ? association.options.foreignKey\n : col;\n if (!Model.rawAttributes[dataKey]) {\n return;\n }\n const value = this.getDataValue(dataKey);\n if (typeof value !== 'undefined') {\n where[dataKey] = value;\n }\n });\n return where;\n }\n\n async updateSingleAssociation(\n key: string,\n data: any,\n options: UpdateAssociationOptions = {},\n ) {\n const {\n fields,\n transaction = await this.sequelize.transaction(),\n ...opts\n } = options;\n Object.assign(opts, { transaction });\n\n const table = this.database.getTable(this.constructor.name);\n const association = table.getAssociations().get(key);\n const accessors = association.getAccessors();\n\n if (data == null) {\n await this[accessors.set](null, opts);\n return;\n }\n\n if (\n typeof data === 'number' ||\n typeof data === 'string' ||\n data instanceof SequelizeModel\n ) {\n await this[accessors.set](data, opts);\n } else if (typeof data === 'object') {\n const Target = association.getTargetModel();\n const targetAttribute =\n association instanceof BELONGSTO\n ? association.options.targetKey\n : association.options.sourceKey;\n if (data[targetAttribute]) {\n if (Object.keys(data).length > 0) {\n const target = await Target.findOne({\n where: {\n [targetAttribute]: data[targetAttribute],\n },\n transaction,\n });\n if (target) {\n await this[accessors.set](data[targetAttribute], opts);\n await target.update(data, opts);\n // @ts-ignore\n await target.updateAssociations(data, opts);\n } else {\n const t = await this[accessors.create](data, opts);\n await t.updateAssociations(data, opts);\n }\n }\n } else {\n const t = await this[accessors.create](data, opts);\n await t.updateAssociations(data, opts);\n }\n }\n if (!options.transaction) {\n await transaction.commit();\n }\n }\n\n async updateMultipleAssociation(\n associationName: string,\n data: any,\n options: UpdateAssociationOptions = {},\n ) {\n const items = Array.isArray(data) ? data : data == null ? [] : [data];\n\n const {\n fields,\n transaction = await this.sequelize.transaction(),\n ...opts\n } = options;\n Object.assign(opts, { transaction });\n\n const table = this.database.getTable(this.constructor.name);\n const association = table.getAssociations().get(associationName);\n const accessors = association.getAccessors();\n\n if (!items.length) {\n await this[accessors.set](null, opts);\n return;\n }\n\n const Target = association.getTargetModel();\n // 当前表关联 target 表的外键(大部分情况与 target 表主键相同,但可以设置为不同的,要考虑)\n const { targetKey = Target.primaryKeyAttribute } = association.options;\n // target 表的主键\n const targetPk = Target.primaryKeyAttribute;\n const targetKeyIsPk = targetKey === targetPk;\n // 准备设置的关联主键\n const toSetPks = new Set();\n const toSetUks = new Set();\n // 筛选后准备设置的关联主键\n const toSetItems = new Set();\n // 准备添加的关联对象\n const toUpsertObjects = [];\n\n // 遍历所有值成员准备数据\n items.forEach((item) => {\n if (item instanceof SequelizeModel) {\n if (targetKeyIsPk) {\n toSetPks.add(item.getDataValue(targetPk));\n } else {\n toSetUks.add(item.getDataValue(targetKey));\n }\n return;\n }\n if (typeof item === 'number' || typeof item === 'string') {\n let targetKeyType = getDataTypeKey(\n Target.rawAttributes[targetKey].type,\n ).toLocaleLowerCase();\n if (targetKeyType === 'integer') {\n targetKeyType = 'number';\n }\n // 如果传值类型与之前在 Model 上定义的 targetKey 不同,则报错。\n // 不应兼容定义的 targetKey 不是 primaryKey 却传了 primaryKey 的值的情况。\n if (typeof item !== targetKeyType) {\n throw new Error(\n `target key type [${typeof item}] does not match to [${targetKeyType}]`,\n );\n }\n if (targetKeyIsPk) {\n toSetPks.add(item);\n } else {\n toSetUks.add(item);\n }\n return;\n }\n if (typeof item === 'object') {\n toUpsertObjects.push(item);\n }\n });\n\n /* 仅传关联键处理开始 */\n // 查找已存在的数据\n const byPkExistItems = toSetPks.size\n ? await Target.findAll({\n ...opts,\n // @ts-ignore\n where: {\n [targetPk]: {\n [Op.in]: Array.from(toSetPks),\n },\n },\n attributes: [targetPk],\n })\n : [];\n byPkExistItems.forEach((item) => {\n toSetItems.add(item);\n });\n\n const byUkExistItems = toSetUks.size\n ? await Target.findAll({\n ...opts,\n // @ts-ignore\n where: {\n [targetKey]: {\n [Op.in]: Array.from(toSetUks),\n },\n },\n attributes: [targetPk, targetKey],\n })\n : [];\n byUkExistItems.forEach((item) => {\n toSetItems.add(item);\n });\n /* 仅传关联键处理结束 */\n\n const belongsToManyList = [];\n /* 值为对象处理开始 */\n for (const item of toUpsertObjects) {\n let target;\n if (typeof item[targetKey] === 'undefined') {\n target = await this[accessors.create](item, opts);\n } else {\n target = await Target.findOne({\n ...opts,\n where: { [targetKey]: item[targetKey] },\n });\n if (!target) {\n target = await this[accessors.create](item, opts);\n } else {\n await target.update(item, opts);\n }\n }\n // TODO(optimize): 此处添加的对象其实已经创建了关联,\n // 但考虑到单条 create 的 hook 要求带上关联键,且后面的 set,\n // 所以仍然交给 set 再调用关联一次。\n toSetItems.add(target);\n\n if (association instanceof BELONGSTOMANY) {\n belongsToManyList.push({\n item,\n target,\n });\n }\n\n await target.updateAssociations(item, opts);\n }\n /* 值为对象处理结束 */\n\n // 添加所有计算后的关联\n await this[accessors.set](Array.from(toSetItems), opts);\n\n // 后处理 belongsToMany 的更新内容\n if (belongsToManyList.length) {\n const ThroughModel = (association as BELONGSTOMANY).getThroughModel();\n const throughName = (association as BELONGSTOMANY).getThroughName();\n\n for (const { item, target } of belongsToManyList) {\n const throughValues = item[throughName];\n if (throughValues && typeof throughValues === 'object') {\n const { foreignKey, sourceKey, otherKey } = association.options;\n const through = await ThroughModel.findOne({\n where: {\n [foreignKey]: this.get(sourceKey),\n [otherKey]: target.get(targetKey),\n },\n transaction,\n });\n await through.update(throughValues, opts);\n // TODO:有 BUG,未知\n // await through.updateAssociations(throughValues, opts);\n }\n }\n }\n\n if (!options.transaction) {\n await transaction.commit();\n }\n }\n\n async updateAssociation(\n key: string,\n data: any,\n options: UpdateAssociationOptions = {},\n ) {\n const table = this.database.getTable(this.constructor.name);\n const association = table.getAssociations().get(key);\n switch (true) {\n case association instanceof BELONGSTO:\n case association instanceof HASONE:\n return this.updateSingleAssociation(key, data, options);\n case association instanceof HASMANY:\n case association instanceof BELONGSTOMANY:\n return this.updateMultipleAssociation(key, data, options);\n }\n }\n\n /**\n * 关联数据的更新\n *\n * @param data\n */\n async updateAssociations(data: any, options: UpdateAssociationOptions = {}) {\n const { transaction = await this.sequelize.transaction() } = options;\n // @ts-ignore 判断 Model.associations 更准确\n for (const key of Object.keys(this.constructor.associations)) {\n // 如果 key 不存在才跳过\n if (!Object.keys(data).includes(key)) {\n continue;\n }\n await this.updateAssociation(key, data[key], {\n ...options,\n transaction,\n });\n }\n\n await this.database.emitAsync('afterUpdateAssociations', this, {\n ...options,\n transaction,\n });\n\n if (!options.transaction) {\n await transaction.commit();\n }\n }\n}\n\n/**\n * ModelCtor 需要为当前 Model 的\n */\nexport type ModelCtor<M extends Model> = typeof Model & { new (): M } & {\n [key: string]: any;\n};\n\nexport default Model;\n"]}
1
+ {"version":3,"file":"model.js","sourceRoot":"","sources":["../src/model.ts"],"names":[],"mappings":"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","sourcesContent":["import { Model as SequelizeModel, ModelCtor } from 'sequelize';\nimport { Collection } from './collection';\nimport { Database } from './database';\nimport lodash from 'lodash';\nimport { Field } from './fields';\n\ninterface IModel {\n [key: string]: any;\n}\n\ninterface JSONTransformerOptions {\n model: ModelCtor<any>;\n collection: Collection;\n db: Database;\n key?: string;\n field?: Field;\n}\n\nexport class Model<TModelAttributes extends {} = any, TCreationAttributes extends {} = TModelAttributes>\n extends SequelizeModel<TModelAttributes, TCreationAttributes>\n implements IModel\n{\n public static database: Database;\n public static collection: Collection;\n\n public toJSON<T extends TModelAttributes>(): T {\n const handleObj = (obj, options: JSONTransformerOptions) => {\n const handles = [\n (data) => {\n if (data instanceof Model) {\n return data.toJSON();\n }\n\n return data;\n },\n this.hiddenObjKey,\n ];\n return handles.reduce((carry, fn) => fn.apply(this, [carry, options]), obj);\n };\n\n const handleArray = (arrayOfObj, options: JSONTransformerOptions) => {\n const handles = [this.sortAssociations];\n return handles.reduce((carry, fn) => fn.apply(this, [carry, options]), arrayOfObj || []);\n };\n\n const opts = {\n model: this.constructor as ModelCtor<any>,\n collection: (this.constructor as any).collection,\n db: (this.constructor as any).database as Database,\n };\n\n const traverseJSON = (data: T, options: JSONTransformerOptions): T => {\n const { model, db, collection } = options;\n // handle Object\n data = handleObj(data, options);\n\n const result = {};\n for (const key of Object.keys(data)) {\n // @ts-ignore\n if (model.hasAlias(key)) {\n const association = model.associations[key];\n const opts = {\n model: association.target,\n collection: db.getCollection(association.target.name),\n db,\n key,\n field: collection.getField(key),\n };\n\n if (['HasMany', 'BelongsToMany'].includes(association.associationType)) {\n result[key] = handleArray(data[key], opts).map((item) => traverseJSON(item, opts));\n } else {\n result[key] = data[key] ? traverseJSON(data[key], opts) : null;\n }\n } else {\n result[key] = data[key];\n }\n }\n\n return result as T;\n };\n\n return traverseJSON(super.toJSON(), opts);\n }\n\n private hiddenObjKey(obj, options: JSONTransformerOptions) {\n const hiddenFields = Array.from(options.collection.fields.values())\n .filter((field) => field.options.hidden)\n .map((field) => field.options.name);\n\n return lodash.omit(obj, hiddenFields);\n }\n\n private sortAssociations(data, { field }: JSONTransformerOptions): any {\n const sortBy = field.options.sortBy;\n return sortBy ? this.sortArray(data, sortBy) : data;\n }\n\n private sortArray(data, sortBy: string | string[]) {\n if (!lodash.isArray(sortBy)) {\n sortBy = [sortBy];\n }\n\n const orderItems = [];\n const orderDirections = [];\n\n sortBy.forEach((sortItem) => {\n orderDirections.push(sortItem.startsWith('-') ? 'desc' : 'asc');\n orderItems.push(sortItem.replace('-', ''));\n });\n\n return lodash.orderBy(data, orderItems, orderDirections);\n }\n}\n"]}
@@ -0,0 +1,26 @@
1
+ import { Op } from 'sequelize';
2
+ declare const _default: {
3
+ $match(value: any, ctx: any): import("sequelize/types/lib/utils").Literal | {
4
+ [Op.contained]: any;
5
+ [Op.contains]: any;
6
+ [Op.eq]?: undefined;
7
+ } | {
8
+ [Op.eq]: import("sequelize/types/lib/utils").Literal;
9
+ [Op.contained]?: undefined;
10
+ [Op.contains]?: undefined;
11
+ };
12
+ $notMatch(value: any, ctx: any): import("sequelize/types/lib/utils").Literal | {
13
+ [Op.ne]: import("sequelize/types/lib/utils").Literal;
14
+ };
15
+ $anyOf(value: any, ctx: any): import("sequelize/types/lib/utils").Literal;
16
+ $noneOf(value: any, ctx: any): {
17
+ [Op.or]: any[];
18
+ };
19
+ $arrayEmpty(value: any, ctx: any): {
20
+ [Op.and]: import("sequelize/types/lib/utils").Literal[];
21
+ };
22
+ $arrayNotEmpty(value: any, ctx: any): {
23
+ [Op.and]: import("sequelize/types/lib/utils").Literal[];
24
+ };
25
+ };
26
+ export default _default;
@@ -0,0 +1,107 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const sequelize_1 = require("sequelize");
4
+ const utils_1 = require("./utils");
5
+ const getFieldName = (ctx) => {
6
+ const fieldName = ctx.fieldName;
7
+ return fieldName;
8
+ };
9
+ const escape = (value, ctx) => {
10
+ const sequelize = ctx.db.sequelize;
11
+ return sequelize.escape(value);
12
+ };
13
+ const sqliteExistQuery = (value, ctx) => {
14
+ const fieldName = getFieldName(ctx);
15
+ const sqlArray = `(${value.map((v) => `'${v}'`).join(', ')})`;
16
+ const subQuery = `exists (select * from json_each(${fieldName}) where json_each.value in ${sqlArray})`;
17
+ return subQuery;
18
+ };
19
+ const emptyQuery = (ctx, operator) => {
20
+ const fieldName = getFieldName(ctx);
21
+ let funcName = 'json_array_length';
22
+ let ifNull = 'IFNULL';
23
+ if ((0, utils_1.isPg)(ctx)) {
24
+ funcName = 'jsonb_array_length';
25
+ ifNull = 'coalesce';
26
+ }
27
+ if ((0, utils_1.isMySQL)(ctx)) {
28
+ funcName = 'json_length';
29
+ }
30
+ return `(select ${ifNull}(${funcName}(${fieldName}), 0) ${operator} 0)`;
31
+ };
32
+ exports.default = {
33
+ $match(value, ctx) {
34
+ const fieldName = getFieldName(ctx);
35
+ if ((0, utils_1.isPg)(ctx)) {
36
+ return {
37
+ [sequelize_1.Op.contained]: value,
38
+ [sequelize_1.Op.contains]: value,
39
+ };
40
+ }
41
+ value = escape(JSON.stringify(value.sort()), ctx);
42
+ if ((0, utils_1.isMySQL)(ctx)) {
43
+ return sequelize_1.Sequelize.literal(`JSON_CONTAINS(${fieldName}, ${value}) AND JSON_CONTAINS(${value}, ${fieldName})`);
44
+ }
45
+ return {
46
+ [sequelize_1.Op.eq]: sequelize_1.Sequelize.literal(`json(${value})`),
47
+ };
48
+ },
49
+ $notMatch(value, ctx) {
50
+ const fieldName = getFieldName(ctx);
51
+ value = escape(JSON.stringify(value), ctx);
52
+ if ((0, utils_1.isPg)(ctx)) {
53
+ return sequelize_1.Sequelize.literal(`not (${fieldName} <@ ${value}::JSONB and ${fieldName} @> ${value}::JSONB)`);
54
+ }
55
+ if ((0, utils_1.isMySQL)(ctx)) {
56
+ return sequelize_1.Sequelize.literal(`not (JSON_CONTAINS(${fieldName}, ${value}) AND JSON_CONTAINS(${value}, ${fieldName}))`);
57
+ }
58
+ return {
59
+ [sequelize_1.Op.ne]: sequelize_1.Sequelize.literal(`json(${value})`),
60
+ };
61
+ },
62
+ $anyOf(value, ctx) {
63
+ const fieldName = getFieldName(ctx);
64
+ if ((0, utils_1.isPg)(ctx)) {
65
+ return sequelize_1.Sequelize.literal(`${fieldName} ?| ${escape(value.map((i) => `${i}`), ctx)}`);
66
+ }
67
+ if ((0, utils_1.isMySQL)(ctx)) {
68
+ value = escape(JSON.stringify(value), ctx);
69
+ return sequelize_1.Sequelize.literal(`JSON_OVERLAPS(${fieldName}, ${value})`);
70
+ }
71
+ const subQuery = sqliteExistQuery(value, ctx);
72
+ return sequelize_1.Sequelize.literal(subQuery);
73
+ },
74
+ $noneOf(value, ctx) {
75
+ let where;
76
+ if ((0, utils_1.isPg)(ctx)) {
77
+ const fieldName = getFieldName(ctx);
78
+ // pg single quote
79
+ where = sequelize_1.Sequelize.literal(`not (${fieldName} ?| ${escape(value.map((i) => `${i}`), ctx)})`);
80
+ }
81
+ else if ((0, utils_1.isMySQL)(ctx)) {
82
+ const fieldName = getFieldName(ctx);
83
+ value = escape(JSON.stringify(value), ctx);
84
+ where = sequelize_1.Sequelize.literal(`NOT JSON_OVERLAPS(${fieldName}, ${value})`);
85
+ }
86
+ else {
87
+ const subQuery = sqliteExistQuery(value, ctx);
88
+ where = sequelize_1.Sequelize.literal(`not ${subQuery}`);
89
+ }
90
+ return {
91
+ [sequelize_1.Op.or]: [where, { [sequelize_1.Op.is]: null }],
92
+ };
93
+ },
94
+ $arrayEmpty(value, ctx) {
95
+ const subQuery = emptyQuery(ctx, '=');
96
+ return {
97
+ [sequelize_1.Op.and]: [sequelize_1.Sequelize.literal(`${subQuery}`)],
98
+ };
99
+ },
100
+ $arrayNotEmpty(value, ctx) {
101
+ const subQuery = emptyQuery(ctx, '>');
102
+ return {
103
+ [sequelize_1.Op.and]: [sequelize_1.Sequelize.literal(`${subQuery}`)],
104
+ };
105
+ },
106
+ };
107
+ //# sourceMappingURL=array.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"array.js","sourceRoot":"","sources":["../../src/operators/array.ts"],"names":[],"mappings":"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","sourcesContent":["import { Op, Sequelize } from 'sequelize';\nimport { isPg, isMySQL } from './utils';\n\nconst getFieldName = (ctx) => {\n const fieldName = ctx.fieldName;\n return fieldName;\n};\n\nconst escape = (value, ctx) => {\n const sequelize: Sequelize = ctx.db.sequelize;\n return sequelize.escape(value);\n};\n\nconst sqliteExistQuery = (value, ctx) => {\n const fieldName = getFieldName(ctx);\n\n const sqlArray = `(${value.map((v) => `'${v}'`).join(', ')})`;\n\n const subQuery = `exists (select * from json_each(${fieldName}) where json_each.value in ${sqlArray})`;\n\n return subQuery;\n};\n\nconst emptyQuery = (ctx, operator: '=' | '>') => {\n const fieldName = getFieldName(ctx);\n\n let funcName = 'json_array_length';\n let ifNull = 'IFNULL';\n\n if (isPg(ctx)) {\n funcName = 'jsonb_array_length';\n ifNull = 'coalesce';\n }\n\n if (isMySQL(ctx)) {\n funcName = 'json_length';\n }\n\n return `(select ${ifNull}(${funcName}(${fieldName}), 0) ${operator} 0)`;\n};\n\nexport default {\n $match(value, ctx) {\n const fieldName = getFieldName(ctx);\n\n if (isPg(ctx)) {\n return {\n [Op.contained]: value,\n [Op.contains]: value,\n };\n }\n\n value = escape(JSON.stringify(value.sort()), ctx);\n\n if (isMySQL(ctx)) {\n return Sequelize.literal(`JSON_CONTAINS(${fieldName}, ${value}) AND JSON_CONTAINS(${value}, ${fieldName})`);\n }\n\n return {\n [Op.eq]: Sequelize.literal(`json(${value})`),\n };\n },\n\n $notMatch(value, ctx) {\n const fieldName = getFieldName(ctx);\n value = escape(JSON.stringify(value), ctx);\n\n if (isPg(ctx)) {\n return Sequelize.literal(`not (${fieldName} <@ ${value}::JSONB and ${fieldName} @> ${value}::JSONB)`);\n }\n\n if (isMySQL(ctx)) {\n return Sequelize.literal(`not (JSON_CONTAINS(${fieldName}, ${value}) AND JSON_CONTAINS(${value}, ${fieldName}))`);\n }\n return {\n [Op.ne]: Sequelize.literal(`json(${value})`),\n };\n },\n\n $anyOf(value, ctx) {\n const fieldName = getFieldName(ctx);\n\n if (isPg(ctx)) {\n return Sequelize.literal(\n `${fieldName} ?| ${escape(\n value.map((i) => `${i}`),\n ctx,\n )}`,\n );\n }\n\n if (isMySQL(ctx)) {\n value = escape(JSON.stringify(value), ctx);\n\n return Sequelize.literal(`JSON_OVERLAPS(${fieldName}, ${value})`);\n }\n\n const subQuery = sqliteExistQuery(value, ctx);\n\n return Sequelize.literal(subQuery);\n },\n\n $noneOf(value, ctx) {\n let where;\n\n if (isPg(ctx)) {\n const fieldName = getFieldName(ctx);\n // pg single quote\n where = Sequelize.literal(\n `not (${fieldName} ?| ${escape(\n value.map((i) => `${i}`),\n ctx,\n )})`,\n );\n } else if (isMySQL(ctx)) {\n const fieldName = getFieldName(ctx);\n value = escape(JSON.stringify(value), ctx);\n where = Sequelize.literal(`NOT JSON_OVERLAPS(${fieldName}, ${value})`);\n } else {\n const subQuery = sqliteExistQuery(value, ctx);\n\n where = Sequelize.literal(`not ${subQuery}`);\n }\n\n return {\n [Op.or]: [where, { [Op.is]: null }],\n };\n },\n\n $arrayEmpty(value, ctx) {\n const subQuery = emptyQuery(ctx, '=');\n\n return {\n [Op.and]: [Sequelize.literal(`${subQuery}`)],\n };\n },\n\n $arrayNotEmpty(value, ctx) {\n const subQuery = emptyQuery(ctx, '>');\n\n return {\n [Op.and]: [Sequelize.literal(`${subQuery}`)],\n };\n },\n};\n"]}
@@ -0,0 +1,10 @@
1
+ import { Op } from 'sequelize';
2
+ declare const _default: {
3
+ $exists(value: any, ctx: any): {
4
+ [Op.not]: any;
5
+ };
6
+ $notExists(value: any, ctx: any): {
7
+ [Op.is]: any;
8
+ };
9
+ };
10
+ export default _default;
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const sequelize_1 = require("sequelize");
4
+ exports.default = {
5
+ $exists(value, ctx) {
6
+ return {
7
+ [sequelize_1.Op.not]: null,
8
+ };
9
+ },
10
+ $notExists(value, ctx) {
11
+ return {
12
+ [sequelize_1.Op.is]: null,
13
+ };
14
+ },
15
+ };
16
+ //# sourceMappingURL=association.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"association.js","sourceRoot":"","sources":["../../src/operators/association.ts"],"names":[],"mappings":";;AAAA,yCAA0C;AAE1C,kBAAe;IACb,OAAO,CAAC,KAAK,EAAE,GAAG;QAChB,OAAO;YACL,CAAC,cAAE,CAAC,GAAG,CAAC,EAAE,IAAI;SACf,CAAC;IACJ,CAAC;IACD,UAAU,CAAC,KAAK,EAAE,GAAG;QACnB,OAAO;YACL,CAAC,cAAE,CAAC,EAAE,CAAC,EAAE,IAAI;SACd,CAAC;IACJ,CAAC;CACF,CAAC","sourcesContent":["import { Op, Sequelize } from 'sequelize';\n\nexport default {\n $exists(value, ctx) {\n return {\n [Op.not]: null,\n };\n },\n $notExists(value, ctx) {\n return {\n [Op.is]: null,\n };\n },\n};\n"]}
@@ -0,0 +1,34 @@
1
+ import { Op } from 'sequelize';
2
+ declare const _default: {
3
+ $dateOn(value: any): {
4
+ [Op.and]: ({
5
+ [Op.gte]: Date;
6
+ [Op.lt]?: undefined;
7
+ } | {
8
+ [Op.lt]: Date;
9
+ [Op.gte]?: undefined;
10
+ })[];
11
+ };
12
+ $dateNotOn(value: any): {
13
+ [Op.or]: ({
14
+ [Op.lt]: Date;
15
+ [Op.gte]?: undefined;
16
+ } | {
17
+ [Op.gte]: Date;
18
+ [Op.lt]?: undefined;
19
+ })[];
20
+ };
21
+ $dateBefore(value: any): {
22
+ [Op.lt]: Date;
23
+ };
24
+ $dateNotBefore(value: any): {
25
+ [Op.gte]: Date;
26
+ };
27
+ $dateAfter(value: any): {
28
+ [Op.gte]: Date;
29
+ };
30
+ $dateNotAfter(value: any): {
31
+ [Op.lt]: Date;
32
+ };
33
+ };
34
+ export default _default;
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const sequelize_1 = require("sequelize");
7
+ const moment_1 = __importDefault(require("moment"));
8
+ function stringToDate(value) {
9
+ return (0, moment_1.default)(value).toDate();
10
+ }
11
+ function getNextDay(value) {
12
+ return (0, moment_1.default)(value).add(1, 'd').toDate();
13
+ }
14
+ exports.default = {
15
+ $dateOn(value) {
16
+ return {
17
+ [sequelize_1.Op.and]: [{ [sequelize_1.Op.gte]: stringToDate(value) }, { [sequelize_1.Op.lt]: getNextDay(value) }],
18
+ };
19
+ },
20
+ $dateNotOn(value) {
21
+ return {
22
+ [sequelize_1.Op.or]: [{ [sequelize_1.Op.lt]: stringToDate(value) }, { [sequelize_1.Op.gte]: getNextDay(value) }],
23
+ };
24
+ },
25
+ $dateBefore(value) {
26
+ return { [sequelize_1.Op.lt]: stringToDate(value) };
27
+ },
28
+ $dateNotBefore(value) {
29
+ return {
30
+ [sequelize_1.Op.gte]: stringToDate(value),
31
+ };
32
+ },
33
+ $dateAfter(value) {
34
+ return { [sequelize_1.Op.gte]: getNextDay(value) };
35
+ },
36
+ $dateNotAfter(value) {
37
+ return { [sequelize_1.Op.lt]: getNextDay(value) };
38
+ },
39
+ };
40
+ //# sourceMappingURL=date.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"date.js","sourceRoot":"","sources":["../../src/operators/date.ts"],"names":[],"mappings":";;;;;AAAA,yCAA+B;AAC/B,oDAA6C;AAC7C,SAAS,YAAY,CAAC,KAAa;IACjC,OAAO,IAAA,gBAAM,EAAC,KAAK,CAAC,CAAC,MAAM,EAAE,CAAC;AAChC,CAAC;AAED,SAAS,UAAU,CAAC,KAAkB;IACpC,OAAO,IAAA,gBAAM,EAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC;AAC5C,CAAC;AAED,kBAAe;IACb,OAAO,CAAC,KAAK;QACX,OAAO;YACL,CAAC,cAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,cAAE,CAAC,GAAG,CAAC,EAAE,YAAY,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,cAAE,CAAC,EAAE,CAAC,EAAE,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;SAC9E,CAAC;IACJ,CAAC;IAED,UAAU,CAAC,KAAK;QACd,OAAO;YACL,CAAC,cAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,cAAE,CAAC,EAAE,CAAC,EAAE,YAAY,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,cAAE,CAAC,GAAG,CAAC,EAAE,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;SAC7E,CAAC;IACJ,CAAC;IAED,WAAW,CAAC,KAAK;QACf,OAAO,EAAE,CAAC,cAAE,CAAC,EAAE,CAAC,EAAE,YAAY,CAAC,KAAK,CAAC,EAAE,CAAC;IAC1C,CAAC;IAED,cAAc,CAAC,KAAK;QAClB,OAAO;YACL,CAAC,cAAE,CAAC,GAAG,CAAC,EAAE,YAAY,CAAC,KAAK,CAAC;SAC9B,CAAC;IACJ,CAAC;IAED,UAAU,CAAC,KAAK;QACd,OAAO,EAAE,CAAC,cAAE,CAAC,GAAG,CAAC,EAAE,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;IACzC,CAAC;IAED,aAAa,CAAC,KAAK;QACjB,OAAO,EAAE,CAAC,cAAE,CAAC,EAAE,CAAC,EAAE,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;IACxC,CAAC;CACF,CAAC","sourcesContent":["import { Op } from 'sequelize';\nimport moment, { MomentInput } from 'moment';\nfunction stringToDate(value: string): Date {\n return moment(value).toDate();\n}\n\nfunction getNextDay(value: MomentInput): Date {\n return moment(value).add(1, 'd').toDate();\n}\n\nexport default {\n $dateOn(value) {\n return {\n [Op.and]: [{ [Op.gte]: stringToDate(value) }, { [Op.lt]: getNextDay(value) }],\n };\n },\n\n $dateNotOn(value) {\n return {\n [Op.or]: [{ [Op.lt]: stringToDate(value) }, { [Op.gte]: getNextDay(value) }],\n };\n },\n\n $dateBefore(value) {\n return { [Op.lt]: stringToDate(value) };\n },\n\n $dateNotBefore(value) {\n return {\n [Op.gte]: stringToDate(value),\n };\n },\n\n $dateAfter(value) {\n return { [Op.gte]: getNextDay(value) };\n },\n\n $dateNotAfter(value) {\n return { [Op.lt]: getNextDay(value) };\n },\n};\n"]}
@@ -0,0 +1,28 @@
1
+ import { Op } from 'sequelize';
2
+ declare const _default: {
3
+ $empty(_: any, ctx: any): {
4
+ [Op.and]: import("sequelize/types/lib/utils").Literal[];
5
+ } | {
6
+ [Op.or]: {
7
+ [Op.is]: any;
8
+ [Op.eq]: string;
9
+ };
10
+ [Op.is]?: undefined;
11
+ } | {
12
+ [Op.is]: any;
13
+ [Op.or]?: undefined;
14
+ };
15
+ $notEmpty(_: any, ctx: any): {
16
+ [Op.and]: import("sequelize/types/lib/utils").Literal[];
17
+ } | {
18
+ [Op.and]: {
19
+ [Op.not]: any;
20
+ [Op.ne]: string;
21
+ };
22
+ [Op.not]?: undefined;
23
+ } | {
24
+ [Op.not]: any;
25
+ [Op.and]?: undefined;
26
+ };
27
+ };
28
+ export default _default;
@@ -0,0 +1,82 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
11
+ }) : function(o, v) {
12
+ o["default"] = v;
13
+ });
14
+ var __importStar = (this && this.__importStar) || function (mod) {
15
+ if (mod && mod.__esModule) return mod;
16
+ var result = {};
17
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
+ __setModuleDefault(result, mod);
19
+ return result;
20
+ };
21
+ var __importDefault = (this && this.__importDefault) || function (mod) {
22
+ return (mod && mod.__esModule) ? mod : { "default": mod };
23
+ };
24
+ Object.defineProperty(exports, "__esModule", { value: true });
25
+ const sequelize_1 = require("sequelize");
26
+ const fields_1 = require("../fields");
27
+ const array_1 = __importDefault(require("./array"));
28
+ const lodash_1 = __importStar(require("lodash"));
29
+ const findFilterFieldType = (ctx) => {
30
+ const db = ctx.db;
31
+ let path = ctx.path.split('.');
32
+ // remove operators
33
+ path.pop();
34
+ const fieldName = path.pop();
35
+ let model = ctx.model;
36
+ const associationPath = path;
37
+ for (const association of associationPath) {
38
+ if (lodash_1.default.isNumber((0, lodash_1.parseInt)(association)) || association.startsWith('$')) {
39
+ continue;
40
+ }
41
+ model = model.associations[association].target;
42
+ }
43
+ const collection = db.modelCollection.get(model);
44
+ return collection.getField(fieldName);
45
+ };
46
+ exports.default = {
47
+ $empty(_, ctx) {
48
+ const field = findFilterFieldType(ctx);
49
+ if (field instanceof fields_1.StringField) {
50
+ return {
51
+ [sequelize_1.Op.or]: {
52
+ [sequelize_1.Op.is]: null,
53
+ [sequelize_1.Op.eq]: '',
54
+ },
55
+ };
56
+ }
57
+ if (field instanceof fields_1.ArrayField) {
58
+ return array_1.default.$arrayEmpty(_, ctx);
59
+ }
60
+ return {
61
+ [sequelize_1.Op.is]: null,
62
+ };
63
+ },
64
+ $notEmpty(_, ctx) {
65
+ const field = findFilterFieldType(ctx);
66
+ if (field instanceof fields_1.StringField) {
67
+ return {
68
+ [sequelize_1.Op.and]: {
69
+ [sequelize_1.Op.not]: null,
70
+ [sequelize_1.Op.ne]: '',
71
+ },
72
+ };
73
+ }
74
+ if (field instanceof fields_1.ArrayField) {
75
+ return array_1.default.$arrayNotEmpty(_, ctx);
76
+ }
77
+ return {
78
+ [sequelize_1.Op.not]: null,
79
+ };
80
+ },
81
+ };
82
+ //# sourceMappingURL=empty.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"empty.js","sourceRoot":"","sources":["../../src/operators/empty.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA,yCAA0C;AAC1C,sCAAoD;AACpD,oDAAqC;AACrC,iDAA0C;AAE1C,MAAM,mBAAmB,GAAG,CAAC,GAAG,EAAE,EAAE;IAClC,MAAM,EAAE,GAAG,GAAG,CAAC,EAAE,CAAC;IAElB,IAAI,IAAI,GAAG,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAE/B,mBAAmB;IACnB,IAAI,CAAC,GAAG,EAAE,CAAC;IAEX,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IAE7B,IAAI,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC;IAEtB,MAAM,eAAe,GAAG,IAAI,CAAC;IAE7B,KAAK,MAAM,WAAW,IAAI,eAAe,EAAE;QACzC,IAAI,gBAAM,CAAC,QAAQ,CAAC,IAAA,iBAAQ,EAAC,WAAW,CAAC,CAAC,IAAI,WAAW,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;YACzE,SAAS;SACV;QAED,KAAK,GAAG,KAAK,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC;KAChD;IAED,MAAM,UAAU,GAAG,EAAE,CAAC,eAAe,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAEjD,OAAO,UAAU,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;AACxC,CAAC,CAAC;AAEF,kBAAe;IACb,MAAM,CAAC,CAAC,EAAE,GAAG;QACX,MAAM,KAAK,GAAG,mBAAmB,CAAC,GAAG,CAAC,CAAC;QAEvC,IAAI,KAAK,YAAY,oBAAW,EAAE;YAChC,OAAO;gBACL,CAAC,cAAE,CAAC,EAAE,CAAC,EAAE;oBACP,CAAC,cAAE,CAAC,EAAE,CAAC,EAAE,IAAI;oBACb,CAAC,cAAE,CAAC,EAAE,CAAC,EAAE,EAAE;iBACZ;aACF,CAAC;SACH;QAED,IAAI,KAAK,YAAY,mBAAU,EAAE;YAC/B,OAAO,eAAc,CAAC,WAAW,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;SAC3C;QAED,OAAO;YACL,CAAC,cAAE,CAAC,EAAE,CAAC,EAAE,IAAI;SACd,CAAC;IACJ,CAAC;IAED,SAAS,CAAC,CAAC,EAAE,GAAG;QACd,MAAM,KAAK,GAAG,mBAAmB,CAAC,GAAG,CAAC,CAAC;QAEvC,IAAI,KAAK,YAAY,oBAAW,EAAE;YAChC,OAAO;gBACL,CAAC,cAAE,CAAC,GAAG,CAAC,EAAE;oBACR,CAAC,cAAE,CAAC,GAAG,CAAC,EAAE,IAAI;oBACd,CAAC,cAAE,CAAC,EAAE,CAAC,EAAE,EAAE;iBACZ;aACF,CAAC;SACH;QAED,IAAI,KAAK,YAAY,mBAAU,EAAE;YAC/B,OAAO,eAAc,CAAC,cAAc,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;SAC9C;QAED,OAAO;YACL,CAAC,cAAE,CAAC,GAAG,CAAC,EAAE,IAAI;SACf,CAAC;IACJ,CAAC;CACF,CAAC","sourcesContent":["import { DataTypes, Op } from 'sequelize';\nimport { ArrayField, StringField } from '../fields';\nimport arrayOperators from './array';\nimport lodash, { parseInt } from 'lodash';\n\nconst findFilterFieldType = (ctx) => {\n const db = ctx.db;\n\n let path = ctx.path.split('.');\n\n // remove operators\n path.pop();\n\n const fieldName = path.pop();\n\n let model = ctx.model;\n\n const associationPath = path;\n\n for (const association of associationPath) {\n if (lodash.isNumber(parseInt(association)) || association.startsWith('$')) {\n continue;\n }\n\n model = model.associations[association].target;\n }\n\n const collection = db.modelCollection.get(model);\n\n return collection.getField(fieldName);\n};\n\nexport default {\n $empty(_, ctx) {\n const field = findFilterFieldType(ctx);\n\n if (field instanceof StringField) {\n return {\n [Op.or]: {\n [Op.is]: null,\n [Op.eq]: '',\n },\n };\n }\n\n if (field instanceof ArrayField) {\n return arrayOperators.$arrayEmpty(_, ctx);\n }\n\n return {\n [Op.is]: null,\n };\n },\n\n $notEmpty(_, ctx) {\n const field = findFilterFieldType(ctx);\n\n if (field instanceof StringField) {\n return {\n [Op.and]: {\n [Op.not]: null,\n [Op.ne]: '',\n },\n };\n }\n\n if (field instanceof ArrayField) {\n return arrayOperators.$arrayNotEmpty(_, ctx);\n }\n\n return {\n [Op.not]: null,\n };\n },\n};\n"]}
@@ -0,0 +1,2 @@
1
+ declare const _default: any;
2
+ export default _default;
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.default = Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({}, require('./association').default), require('./date').default), require('./array').default), require('./empty').default), require('./string').default), require('./ne').default);
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/operators/index.ts"],"names":[],"mappings":";;AAAA,0GACK,OAAO,CAAC,eAAe,CAAC,CAAC,OAAO,GAChC,OAAO,CAAC,QAAQ,CAAC,CAAC,OAAO,GACzB,OAAO,CAAC,SAAS,CAAC,CAAC,OAAO,GAC1B,OAAO,CAAC,SAAS,CAAC,CAAC,OAAO,GAC1B,OAAO,CAAC,UAAU,CAAC,CAAC,OAAO,GAC3B,OAAO,CAAC,MAAM,CAAC,CAAC,OAAO,EAC1B","sourcesContent":["export default {\n ...require('./association').default,\n ...require('./date').default,\n ...require('./array').default,\n ...require('./empty').default,\n ...require('./string').default,\n ...require('./ne').default,\n};\n"]}
@@ -0,0 +1,10 @@
1
+ import { Op } from 'sequelize';
2
+ declare const _default: {
3
+ $ne(val: any, ctx: any): {
4
+ [Op.or]: {
5
+ [Op.ne]: any;
6
+ [Op.is]: any;
7
+ };
8
+ };
9
+ };
10
+ export default _default;
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const sequelize_1 = require("sequelize");
4
+ exports.default = {
5
+ $ne(val, ctx) {
6
+ return {
7
+ [sequelize_1.Op.or]: {
8
+ [sequelize_1.Op.ne]: val,
9
+ [sequelize_1.Op.is]: null,
10
+ },
11
+ };
12
+ },
13
+ };
14
+ //# sourceMappingURL=ne.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ne.js","sourceRoot":"","sources":["../../src/operators/ne.ts"],"names":[],"mappings":";;AAAA,yCAA+B;AAE/B,kBAAe;IACb,GAAG,CAAC,GAAG,EAAE,GAAG;QACV,OAAO;YACL,CAAC,cAAE,CAAC,EAAE,CAAC,EAAE;gBACP,CAAC,cAAE,CAAC,EAAE,CAAC,EAAE,GAAG;gBACZ,CAAC,cAAE,CAAC,EAAE,CAAC,EAAE,IAAI;aACd;SACF,CAAC;IACJ,CAAC;CACF,CAAC","sourcesContent":["import { Op } from 'sequelize';\n\nexport default {\n $ne(val, ctx) {\n return {\n [Op.or]: {\n [Op.ne]: val,\n [Op.is]: null,\n },\n };\n },\n};\n"]}
@@ -0,0 +1,21 @@
1
+ declare const _default: {
2
+ $includes(value: any, ctx: any): {
3
+ [x: symbol]: string;
4
+ };
5
+ $notIncludes(value: any, ctx: any): {
6
+ [x: symbol]: string;
7
+ };
8
+ $startsWith(value: any, ctx: any): {
9
+ [x: symbol]: string;
10
+ };
11
+ $notStartsWith(value: any, ctx: any): {
12
+ [x: symbol]: string;
13
+ };
14
+ $endWith(value: any, ctx: any): {
15
+ [x: symbol]: string;
16
+ };
17
+ $notEndWith(value: any, ctx: any): {
18
+ [x: symbol]: string;
19
+ };
20
+ };
21
+ export default _default;
@@ -0,0 +1,37 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const utils_1 = require("./utils");
4
+ const sequelize_1 = require("sequelize");
5
+ exports.default = {
6
+ $includes(value, ctx) {
7
+ return {
8
+ [(0, utils_1.isPg)(ctx) ? sequelize_1.Op.iLike : sequelize_1.Op.like]: `%${value}%`,
9
+ };
10
+ },
11
+ $notIncludes(value, ctx) {
12
+ return {
13
+ [(0, utils_1.isPg)(ctx) ? sequelize_1.Op.notILike : sequelize_1.Op.notLike]: `%${value}%`,
14
+ };
15
+ },
16
+ $startsWith(value, ctx) {
17
+ return {
18
+ [(0, utils_1.isPg)(ctx) ? sequelize_1.Op.iLike : sequelize_1.Op.like]: `${value}%`,
19
+ };
20
+ },
21
+ $notStartsWith(value, ctx) {
22
+ return {
23
+ [(0, utils_1.isPg)(ctx) ? sequelize_1.Op.notILike : sequelize_1.Op.notLike]: `${value}%`,
24
+ };
25
+ },
26
+ $endWith(value, ctx) {
27
+ return {
28
+ [(0, utils_1.isPg)(ctx) ? sequelize_1.Op.iLike : sequelize_1.Op.like]: `%${value}`,
29
+ };
30
+ },
31
+ $notEndWith(value, ctx) {
32
+ return {
33
+ [(0, utils_1.isPg)(ctx) ? sequelize_1.Op.notILike : sequelize_1.Op.notLike]: `%${value}`,
34
+ };
35
+ },
36
+ };
37
+ //# sourceMappingURL=string.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"string.js","sourceRoot":"","sources":["../../src/operators/string.ts"],"names":[],"mappings":";;AAAA,mCAA+B;AAC/B,yCAA+B;AAE/B,kBAAe;IACb,SAAS,CAAC,KAAK,EAAE,GAAG;QAClB,OAAO;YACL,CAAC,IAAA,YAAI,EAAC,GAAG,CAAC,CAAC,CAAC,CAAC,cAAE,CAAC,KAAK,CAAC,CAAC,CAAC,cAAE,CAAC,IAAI,CAAC,EAAE,IAAI,KAAK,GAAG;SAC/C,CAAC;IACJ,CAAC;IAED,YAAY,CAAC,KAAK,EAAE,GAAG;QACrB,OAAO;YACL,CAAC,IAAA,YAAI,EAAC,GAAG,CAAC,CAAC,CAAC,CAAC,cAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,cAAE,CAAC,OAAO,CAAC,EAAE,IAAI,KAAK,GAAG;SACrD,CAAC;IACJ,CAAC;IAED,WAAW,CAAC,KAAK,EAAE,GAAG;QACpB,OAAO;YACL,CAAC,IAAA,YAAI,EAAC,GAAG,CAAC,CAAC,CAAC,CAAC,cAAE,CAAC,KAAK,CAAC,CAAC,CAAC,cAAE,CAAC,IAAI,CAAC,EAAE,GAAG,KAAK,GAAG;SAC9C,CAAC;IACJ,CAAC;IAED,cAAc,CAAC,KAAK,EAAE,GAAG;QACvB,OAAO;YACL,CAAC,IAAA,YAAI,EAAC,GAAG,CAAC,CAAC,CAAC,CAAC,cAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,cAAE,CAAC,OAAO,CAAC,EAAE,GAAG,KAAK,GAAG;SACpD,CAAC;IACJ,CAAC;IAED,QAAQ,CAAC,KAAK,EAAE,GAAG;QACjB,OAAO;YACL,CAAC,IAAA,YAAI,EAAC,GAAG,CAAC,CAAC,CAAC,CAAC,cAAE,CAAC,KAAK,CAAC,CAAC,CAAC,cAAE,CAAC,IAAI,CAAC,EAAE,IAAI,KAAK,EAAE;SAC9C,CAAC;IACJ,CAAC;IAED,WAAW,CAAC,KAAK,EAAE,GAAG;QACpB,OAAO;YACL,CAAC,IAAA,YAAI,EAAC,GAAG,CAAC,CAAC,CAAC,CAAC,cAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,cAAE,CAAC,OAAO,CAAC,EAAE,IAAI,KAAK,EAAE;SACpD,CAAC;IACJ,CAAC;CACF,CAAC","sourcesContent":["import { isPg } from './utils';\nimport { Op } from 'sequelize';\n\nexport default {\n $includes(value, ctx) {\n return {\n [isPg(ctx) ? Op.iLike : Op.like]: `%${value}%`,\n };\n },\n\n $notIncludes(value, ctx) {\n return {\n [isPg(ctx) ? Op.notILike : Op.notLike]: `%${value}%`,\n };\n },\n\n $startsWith(value, ctx) {\n return {\n [isPg(ctx) ? Op.iLike : Op.like]: `${value}%`,\n };\n },\n\n $notStartsWith(value, ctx) {\n return {\n [isPg(ctx) ? Op.notILike : Op.notLike]: `${value}%`,\n };\n },\n\n $endWith(value, ctx) {\n return {\n [isPg(ctx) ? Op.iLike : Op.like]: `%${value}`,\n };\n },\n\n $notEndWith(value, ctx) {\n return {\n [isPg(ctx) ? Op.notILike : Op.notLike]: `%${value}`,\n };\n },\n};\n"]}
@@ -0,0 +1,4 @@
1
+ declare const getDialect: (ctx: any) => any;
2
+ declare const isPg: (ctx: any) => boolean;
3
+ declare const isMySQL: (ctx: any) => boolean;
4
+ export { getDialect, isPg, isMySQL };
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isMySQL = exports.isPg = exports.getDialect = void 0;
4
+ const getDialect = (ctx) => {
5
+ return ctx.db.sequelize.getDialect();
6
+ };
7
+ exports.getDialect = getDialect;
8
+ const isPg = (ctx) => {
9
+ return getDialect(ctx) === 'postgres';
10
+ };
11
+ exports.isPg = isPg;
12
+ const isMySQL = (ctx) => {
13
+ return getDialect(ctx) === 'mysql';
14
+ };
15
+ exports.isMySQL = isMySQL;
16
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/operators/utils.ts"],"names":[],"mappings":";;;AAAA,MAAM,UAAU,GAAG,CAAC,GAAG,EAAE,EAAE;IACzB,OAAO,GAAG,CAAC,EAAE,CAAC,SAAS,CAAC,UAAU,EAAE,CAAC;AACvC,CAAC,CAAC;AAUO,gCAAU;AARnB,MAAM,IAAI,GAAG,CAAC,GAAG,EAAE,EAAE;IACnB,OAAO,UAAU,CAAC,GAAG,CAAC,KAAK,UAAU,CAAC;AACxC,CAAC,CAAC;AAMmB,oBAAI;AAJzB,MAAM,OAAO,GAAG,CAAC,GAAG,EAAE,EAAE;IACtB,OAAO,UAAU,CAAC,GAAG,CAAC,KAAK,OAAO,CAAC;AACrC,CAAC,CAAC;AAEyB,0BAAO","sourcesContent":["const getDialect = (ctx) => {\n return ctx.db.sequelize.getDialect();\n};\n\nconst isPg = (ctx) => {\n return getDialect(ctx) === 'postgres';\n};\n\nconst isMySQL = (ctx) => {\n return getDialect(ctx) === 'mysql';\n};\n\nexport { getDialect, isPg, isMySQL };\n"]}
@@ -0,0 +1,31 @@
1
+ import { ModelCtor } from 'sequelize';
2
+ import { Collection } from './collection';
3
+ import { Database } from './database';
4
+ import FilterParser from './filter-parser';
5
+ import { Appends, Except, FindOptions } from './repository';
6
+ interface OptionsParserContext {
7
+ collection: Collection;
8
+ targetKey?: string;
9
+ }
10
+ export declare class OptionsParser {
11
+ options: FindOptions;
12
+ database: Database;
13
+ collection: Collection;
14
+ model: ModelCtor<any>;
15
+ filterParser: FilterParser;
16
+ context: OptionsParserContext;
17
+ constructor(options: FindOptions, context: OptionsParserContext);
18
+ isAssociation(key: string): boolean;
19
+ isAssociationPath(path: string): boolean;
20
+ toSequelizeParams(): any;
21
+ /**
22
+ * parser sort options
23
+ * @param filterParams
24
+ * @protected
25
+ */
26
+ protected parseSort(filterParams: any): any;
27
+ protected parseFields(filterParams: any): any;
28
+ protected parseExcept(except: Except, filterParams: any): any;
29
+ protected parseAppends(appends: Appends, filterParams: any): any;
30
+ }
31
+ export {};