@forestadmin/datasource-sql 1.0.0-beta.3 → 1.0.0-beta.32
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.
- package/CHANGELOG.md +350 -0
- package/dist/datasource.d.ts +15 -1
- package/dist/datasource.js +135 -3
- package/dist/index.d.ts +2 -2
- package/dist/index.js +14 -2
- package/dist/utils/array-type-getter.d.ts +12 -0
- package/dist/utils/array-type-getter.js +67 -0
- package/dist/utils/default-value-parser.d.ts +11 -0
- package/dist/utils/default-value-parser.js +78 -0
- package/dist/utils/sql-type-converter.d.ts +14 -0
- package/dist/utils/sql-type-converter.js +104 -0
- package/package.json +4 -5
package/CHANGELOG.md
ADDED
|
@@ -0,0 +1,350 @@
|
|
|
1
|
+
# @forestadmin/datasource-sql [1.0.0-beta.32](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.31...@forestadmin/datasource-sql@1.0.0-beta.32) (2022-06-09)
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
### Dependencies
|
|
8
|
+
|
|
9
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.27
|
|
10
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.22
|
|
11
|
+
|
|
12
|
+
# @forestadmin/datasource-sql [1.0.0-beta.31](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.30...@forestadmin/datasource-sql@1.0.0-beta.31) (2022-06-01)
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
### Dependencies
|
|
19
|
+
|
|
20
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.26
|
|
21
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.21
|
|
22
|
+
|
|
23
|
+
# @forestadmin/datasource-sql [1.0.0-beta.30](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.29...@forestadmin/datasource-sql@1.0.0-beta.30) (2022-05-31)
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
### Dependencies
|
|
30
|
+
|
|
31
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.25
|
|
32
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.20
|
|
33
|
+
|
|
34
|
+
# @forestadmin/datasource-sql [1.0.0-beta.29](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.28...@forestadmin/datasource-sql@1.0.0-beta.29) (2022-05-25)
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
### Dependencies
|
|
41
|
+
|
|
42
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.24
|
|
43
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.19
|
|
44
|
+
|
|
45
|
+
# @forestadmin/datasource-sql [1.0.0-beta.28](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.27...@forestadmin/datasource-sql@1.0.0-beta.28) (2022-05-24)
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
|
|
51
|
+
### Dependencies
|
|
52
|
+
|
|
53
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.23
|
|
54
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.18
|
|
55
|
+
|
|
56
|
+
# @forestadmin/datasource-sql [1.0.0-beta.27](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.26...@forestadmin/datasource-sql@1.0.0-beta.27) (2022-05-24)
|
|
57
|
+
|
|
58
|
+
|
|
59
|
+
|
|
60
|
+
|
|
61
|
+
|
|
62
|
+
### Dependencies
|
|
63
|
+
|
|
64
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.22
|
|
65
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.17
|
|
66
|
+
|
|
67
|
+
# @forestadmin/datasource-sql [1.0.0-beta.26](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.25...@forestadmin/datasource-sql@1.0.0-beta.26) (2022-05-16)
|
|
68
|
+
|
|
69
|
+
|
|
70
|
+
|
|
71
|
+
|
|
72
|
+
|
|
73
|
+
### Dependencies
|
|
74
|
+
|
|
75
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.21
|
|
76
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.16
|
|
77
|
+
|
|
78
|
+
# @forestadmin/datasource-sql [1.0.0-beta.25](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.24...@forestadmin/datasource-sql@1.0.0-beta.25) (2022-05-12)
|
|
79
|
+
|
|
80
|
+
|
|
81
|
+
|
|
82
|
+
|
|
83
|
+
|
|
84
|
+
### Dependencies
|
|
85
|
+
|
|
86
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.20
|
|
87
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.15
|
|
88
|
+
|
|
89
|
+
# @forestadmin/datasource-sql [1.0.0-beta.24](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.23...@forestadmin/datasource-sql@1.0.0-beta.24) (2022-05-09)
|
|
90
|
+
|
|
91
|
+
|
|
92
|
+
### Bug Fixes
|
|
93
|
+
|
|
94
|
+
* **datasource sql:** throw an user friendly error when the provided connection uri is invalid ([#297](https://github.com/ForestAdmin/agent-nodejs/issues/297)) ([db1ac83](https://github.com/ForestAdmin/agent-nodejs/commit/db1ac83d3ef023c7875e4affbaecdc52de1e5fc3))
|
|
95
|
+
|
|
96
|
+
# @forestadmin/datasource-sql [1.0.0-beta.23](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.22...@forestadmin/datasource-sql@1.0.0-beta.23) (2022-05-09)
|
|
97
|
+
|
|
98
|
+
|
|
99
|
+
|
|
100
|
+
|
|
101
|
+
|
|
102
|
+
### Dependencies
|
|
103
|
+
|
|
104
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.19
|
|
105
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.14
|
|
106
|
+
|
|
107
|
+
# @forestadmin/datasource-sql [1.0.0-beta.22](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.21...@forestadmin/datasource-sql@1.0.0-beta.22) (2022-05-09)
|
|
108
|
+
|
|
109
|
+
|
|
110
|
+
|
|
111
|
+
|
|
112
|
+
|
|
113
|
+
### Dependencies
|
|
114
|
+
|
|
115
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.18
|
|
116
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.13
|
|
117
|
+
|
|
118
|
+
# @forestadmin/datasource-sql [1.0.0-beta.21](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.20...@forestadmin/datasource-sql@1.0.0-beta.21) (2022-05-09)
|
|
119
|
+
|
|
120
|
+
|
|
121
|
+
### Bug Fixes
|
|
122
|
+
|
|
123
|
+
* datasource naming consistency ([#292](https://github.com/ForestAdmin/agent-nodejs/issues/292)) ([ff50a1f](https://github.com/ForestAdmin/agent-nodejs/commit/ff50a1f02aa65b3d99824c2bc9fb19d729a4e465))
|
|
124
|
+
|
|
125
|
+
|
|
126
|
+
|
|
127
|
+
|
|
128
|
+
|
|
129
|
+
### Dependencies
|
|
130
|
+
|
|
131
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.17
|
|
132
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.12
|
|
133
|
+
|
|
134
|
+
# @forestadmin/datasource-sql [1.0.0-beta.20](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.19...@forestadmin/datasource-sql@1.0.0-beta.20) (2022-05-04)
|
|
135
|
+
|
|
136
|
+
|
|
137
|
+
|
|
138
|
+
|
|
139
|
+
|
|
140
|
+
### Dependencies
|
|
141
|
+
|
|
142
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.16
|
|
143
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.11
|
|
144
|
+
|
|
145
|
+
# @forestadmin/datasource-sql [1.0.0-beta.19](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.18...@forestadmin/datasource-sql@1.0.0-beta.19) (2022-04-29)
|
|
146
|
+
|
|
147
|
+
|
|
148
|
+
|
|
149
|
+
|
|
150
|
+
|
|
151
|
+
### Dependencies
|
|
152
|
+
|
|
153
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.15
|
|
154
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.10
|
|
155
|
+
|
|
156
|
+
# @forestadmin/datasource-sql [1.0.0-beta.18](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.17...@forestadmin/datasource-sql@1.0.0-beta.18) (2022-04-29)
|
|
157
|
+
|
|
158
|
+
|
|
159
|
+
|
|
160
|
+
|
|
161
|
+
|
|
162
|
+
### Dependencies
|
|
163
|
+
|
|
164
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.14
|
|
165
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.9
|
|
166
|
+
|
|
167
|
+
# @forestadmin/datasource-sql [1.0.0-beta.17](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.16...@forestadmin/datasource-sql@1.0.0-beta.17) (2022-04-28)
|
|
168
|
+
|
|
169
|
+
|
|
170
|
+
|
|
171
|
+
|
|
172
|
+
|
|
173
|
+
### Dependencies
|
|
174
|
+
|
|
175
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.13
|
|
176
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.8
|
|
177
|
+
|
|
178
|
+
# @forestadmin/datasource-sql [1.0.0-beta.16](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.15...@forestadmin/datasource-sql@1.0.0-beta.16) (2022-04-26)
|
|
179
|
+
|
|
180
|
+
|
|
181
|
+
|
|
182
|
+
|
|
183
|
+
|
|
184
|
+
### Dependencies
|
|
185
|
+
|
|
186
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.12
|
|
187
|
+
|
|
188
|
+
# @forestadmin/datasource-sql [1.0.0-beta.15](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.14...@forestadmin/datasource-sql@1.0.0-beta.15) (2022-04-26)
|
|
189
|
+
|
|
190
|
+
|
|
191
|
+
|
|
192
|
+
|
|
193
|
+
|
|
194
|
+
### Dependencies
|
|
195
|
+
|
|
196
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.11
|
|
197
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.7
|
|
198
|
+
|
|
199
|
+
# @forestadmin/datasource-sql [1.0.0-beta.14](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.13...@forestadmin/datasource-sql@1.0.0-beta.14) (2022-04-25)
|
|
200
|
+
|
|
201
|
+
|
|
202
|
+
|
|
203
|
+
|
|
204
|
+
|
|
205
|
+
### Dependencies
|
|
206
|
+
|
|
207
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.10
|
|
208
|
+
|
|
209
|
+
# @forestadmin/datasource-sql [1.0.0-beta.13](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.12...@forestadmin/datasource-sql@1.0.0-beta.13) (2022-04-25)
|
|
210
|
+
|
|
211
|
+
|
|
212
|
+
### Bug Fixes
|
|
213
|
+
|
|
214
|
+
* import packages from js ([#260](https://github.com/ForestAdmin/agent-nodejs/issues/260)) ([de00886](https://github.com/ForestAdmin/agent-nodejs/commit/de008862971ea5d3559e5a4c3136b0dd2161d760))
|
|
215
|
+
|
|
216
|
+
|
|
217
|
+
|
|
218
|
+
|
|
219
|
+
|
|
220
|
+
### Dependencies
|
|
221
|
+
|
|
222
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.9
|
|
223
|
+
|
|
224
|
+
# @forestadmin/datasource-sql [1.0.0-beta.12](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.11...@forestadmin/datasource-sql@1.0.0-beta.12) (2022-04-21)
|
|
225
|
+
|
|
226
|
+
|
|
227
|
+
### Features
|
|
228
|
+
|
|
229
|
+
* harmonize datasource creation and pass logger to it ([#257](https://github.com/ForestAdmin/agent-nodejs/issues/257)) ([82cb4ea](https://github.com/ForestAdmin/agent-nodejs/commit/82cb4ea37ac0a9fe83423d917226dfd8fad7d0a6))
|
|
230
|
+
|
|
231
|
+
|
|
232
|
+
|
|
233
|
+
|
|
234
|
+
|
|
235
|
+
### Dependencies
|
|
236
|
+
|
|
237
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.8
|
|
238
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.6
|
|
239
|
+
|
|
240
|
+
# @forestadmin/datasource-sql [1.0.0-beta.11](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.10...@forestadmin/datasource-sql@1.0.0-beta.11) (2022-04-21)
|
|
241
|
+
|
|
242
|
+
|
|
243
|
+
### Bug Fixes
|
|
244
|
+
|
|
245
|
+
* **datasource sql:** has one detection ([#254](https://github.com/ForestAdmin/agent-nodejs/issues/254)) ([68e68b3](https://github.com/ForestAdmin/agent-nodejs/commit/68e68b33063ba7bbfb9cfc747572f59953b64050))
|
|
246
|
+
|
|
247
|
+
# @forestadmin/datasource-sql [1.0.0-beta.10](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.9...@forestadmin/datasource-sql@1.0.0-beta.10) (2022-04-20)
|
|
248
|
+
|
|
249
|
+
|
|
250
|
+
### Features
|
|
251
|
+
|
|
252
|
+
* **datasource sql:** handle relations ([#224](https://github.com/ForestAdmin/agent-nodejs/issues/224)) ([275cf7e](https://github.com/ForestAdmin/agent-nodejs/commit/275cf7ed6835933fce418f92a6a4e2521a9721fe))
|
|
253
|
+
|
|
254
|
+
# @forestadmin/datasource-sql [1.0.0-beta.9](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.8...@forestadmin/datasource-sql@1.0.0-beta.9) (2022-04-20)
|
|
255
|
+
|
|
256
|
+
|
|
257
|
+
|
|
258
|
+
|
|
259
|
+
|
|
260
|
+
### Dependencies
|
|
261
|
+
|
|
262
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.7
|
|
263
|
+
|
|
264
|
+
# @forestadmin/datasource-sql [1.0.0-beta.8](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.7...@forestadmin/datasource-sql@1.0.0-beta.8) (2022-04-19)
|
|
265
|
+
|
|
266
|
+
|
|
267
|
+
|
|
268
|
+
|
|
269
|
+
|
|
270
|
+
### Dependencies
|
|
271
|
+
|
|
272
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.6
|
|
273
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.5
|
|
274
|
+
|
|
275
|
+
# @forestadmin/datasource-sql [1.0.0-beta.7](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.6...@forestadmin/datasource-sql@1.0.0-beta.7) (2022-04-19)
|
|
276
|
+
|
|
277
|
+
|
|
278
|
+
|
|
279
|
+
|
|
280
|
+
|
|
281
|
+
### Dependencies
|
|
282
|
+
|
|
283
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.5
|
|
284
|
+
|
|
285
|
+
# @forestadmin/datasource-sql [1.0.0-beta.6](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.5...@forestadmin/datasource-sql@1.0.0-beta.6) (2022-04-15)
|
|
286
|
+
|
|
287
|
+
|
|
288
|
+
### Features
|
|
289
|
+
|
|
290
|
+
* **datasource sql:** handle primitive fields and default values ([#215](https://github.com/ForestAdmin/agent-nodejs/issues/215)) ([59a56da](https://github.com/ForestAdmin/agent-nodejs/commit/59a56da2721f39d0487b14d72b11d71b38b83a1f))
|
|
291
|
+
|
|
292
|
+
# @forestadmin/datasource-sql [1.0.0-beta.5](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.4...@forestadmin/datasource-sql@1.0.0-beta.5) (2022-04-15)
|
|
293
|
+
|
|
294
|
+
|
|
295
|
+
|
|
296
|
+
|
|
297
|
+
|
|
298
|
+
### Dependencies
|
|
299
|
+
|
|
300
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.4
|
|
301
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.4
|
|
302
|
+
|
|
303
|
+
# @forestadmin/datasource-sql [1.0.0-beta.4](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.3...@forestadmin/datasource-sql@1.0.0-beta.4) (2022-04-15)
|
|
304
|
+
|
|
305
|
+
|
|
306
|
+
### Bug Fixes
|
|
307
|
+
|
|
308
|
+
* switched from qiwi to dhoulb version of msr ([020c3e0](https://github.com/ForestAdmin/agent-nodejs/commit/020c3e04c64164c3f26aae293989db7842f82e8c))
|
|
309
|
+
|
|
310
|
+
# @forestadmin/datasource-sql [1.0.0-beta.3](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.2...@forestadmin/datasource-sql@1.0.0-beta.3) (2022-04-15)
|
|
311
|
+
|
|
312
|
+
|
|
313
|
+
### Bug Fixes
|
|
314
|
+
|
|
315
|
+
* correct versions in package.json of all datasources ([540d395](https://github.com/ForestAdmin/agent-nodejs/commit/540d395bc5e42bdd7edb3dce5806ade8554f3d7a))
|
|
316
|
+
|
|
317
|
+
|
|
318
|
+
|
|
319
|
+
|
|
320
|
+
|
|
321
|
+
### Dependencies
|
|
322
|
+
|
|
323
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.3
|
|
324
|
+
|
|
325
|
+
# @forestadmin/datasource-sql [1.0.0-beta.2](https://github.com/ForestAdmin/agent-nodejs/compare/@forestadmin/datasource-sql@1.0.0-beta.1...@forestadmin/datasource-sql@1.0.0-beta.2) (2022-04-15)
|
|
326
|
+
|
|
327
|
+
|
|
328
|
+
|
|
329
|
+
|
|
330
|
+
|
|
331
|
+
### Dependencies
|
|
332
|
+
|
|
333
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.2
|
|
334
|
+
* **@forestadmin/datasource-toolkit:** upgraded to 1.0.0-beta.3
|
|
335
|
+
|
|
336
|
+
# @forestadmin/datasource-sql 1.0.0-beta.1 (2022-04-15)
|
|
337
|
+
|
|
338
|
+
|
|
339
|
+
### Bug Fixes
|
|
340
|
+
|
|
341
|
+
* enable npm, git and github distribution ([bd91825](https://github.com/ForestAdmin/agent-nodejs/commit/bd91825f4d185874a259da28b0f7a6c7f557196d))
|
|
342
|
+
* fix semantic release ([3a2fa73](https://github.com/ForestAdmin/agent-nodejs/commit/3a2fa738af84a50b9563db6ac039c922b77f55cc))
|
|
343
|
+
|
|
344
|
+
|
|
345
|
+
|
|
346
|
+
|
|
347
|
+
|
|
348
|
+
### Dependencies
|
|
349
|
+
|
|
350
|
+
* **@forestadmin/datasource-sequelize:** upgraded to 1.0.0-beta.1
|
package/dist/datasource.d.ts
CHANGED
|
@@ -1,5 +1,19 @@
|
|
|
1
|
+
import { Logger } from '@forestadmin/datasource-toolkit';
|
|
1
2
|
import { SequelizeDataSource } from '@forestadmin/datasource-sequelize';
|
|
2
3
|
export default class SqlDataSource extends SequelizeDataSource {
|
|
3
|
-
|
|
4
|
+
private readonly queryInterface;
|
|
5
|
+
private readonly defaultValueParser;
|
|
6
|
+
private readonly sqlTypeConverter;
|
|
7
|
+
protected logger: Logger;
|
|
8
|
+
constructor(connectionUri: string, logger?: Logger);
|
|
9
|
+
build(): Promise<void>;
|
|
10
|
+
private defineModels;
|
|
11
|
+
private defineRelations;
|
|
12
|
+
private hasTimestamps;
|
|
13
|
+
private removeTimeStampColumns;
|
|
14
|
+
private isParanoid;
|
|
15
|
+
private removeParanoidColumn;
|
|
16
|
+
private isJunctionTable;
|
|
17
|
+
private getUniqueFields;
|
|
4
18
|
}
|
|
5
19
|
//# sourceMappingURL=datasource.d.ts.map
|
package/dist/datasource.js
CHANGED
|
@@ -1,11 +1,143 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
2
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
6
|
const sequelize_1 = require("sequelize");
|
|
4
7
|
const datasource_sequelize_1 = require("@forestadmin/datasource-sequelize");
|
|
8
|
+
const default_value_parser_1 = __importDefault(require("./utils/default-value-parser"));
|
|
9
|
+
const sql_type_converter_1 = __importDefault(require("./utils/sql-type-converter"));
|
|
5
10
|
class SqlDataSource extends datasource_sequelize_1.SequelizeDataSource {
|
|
6
|
-
constructor(connectionUri) {
|
|
7
|
-
|
|
11
|
+
constructor(connectionUri, logger) {
|
|
12
|
+
const logging = (sql) => logger?.('Debug', sql.substring(sql.indexOf(':') + 2));
|
|
13
|
+
super(new sequelize_1.Sequelize(connectionUri, { logging }));
|
|
14
|
+
this.logger = logger;
|
|
15
|
+
this.queryInterface = this.sequelize.getQueryInterface();
|
|
16
|
+
this.defaultValueParser = new default_value_parser_1.default(this.sequelize.getDialect());
|
|
17
|
+
this.sqlTypeConverter = new sql_type_converter_1.default(this.sequelize);
|
|
18
|
+
}
|
|
19
|
+
async build() {
|
|
20
|
+
const tableNames = await this.queryInterface.showAllTables();
|
|
21
|
+
await this.defineModels(tableNames);
|
|
22
|
+
await this.defineRelations(tableNames);
|
|
23
|
+
this.createCollections(this.sequelize.models, this.logger);
|
|
24
|
+
}
|
|
25
|
+
async defineModels(tableNames) {
|
|
26
|
+
return Promise.all(tableNames.map(async (tableName) => {
|
|
27
|
+
const colmumnDescriptions = await this.queryInterface.describeTable(tableName);
|
|
28
|
+
const fieldDescriptions = await Promise.all(Object.entries(colmumnDescriptions).map(async ([columnName, colmumnDescription]) => {
|
|
29
|
+
try {
|
|
30
|
+
const type = await this.sqlTypeConverter.convert(tableName, columnName, colmumnDescription);
|
|
31
|
+
let defaultValue = this.defaultValueParser.parse(colmumnDescription.defaultValue, type);
|
|
32
|
+
if (colmumnDescription.primaryKey && defaultValue) {
|
|
33
|
+
defaultValue = null;
|
|
34
|
+
colmumnDescription.autoIncrement = true;
|
|
35
|
+
}
|
|
36
|
+
return [columnName, { ...colmumnDescription, type, defaultValue }];
|
|
37
|
+
}
|
|
38
|
+
catch (e) {
|
|
39
|
+
this.logger?.('Warn', `Skipping column ${tableName}.${columnName} (${e.message})`);
|
|
40
|
+
}
|
|
41
|
+
}));
|
|
42
|
+
let modelDefinition = Object.fromEntries(fieldDescriptions.filter(Boolean));
|
|
43
|
+
const columnNames = Object.keys(modelDefinition);
|
|
44
|
+
const hasTimestamps = this.hasTimestamps(columnNames);
|
|
45
|
+
const isParanoid = this.isParanoid(columnNames);
|
|
46
|
+
if (hasTimestamps) {
|
|
47
|
+
modelDefinition = this.removeTimeStampColumns(modelDefinition);
|
|
48
|
+
}
|
|
49
|
+
if (isParanoid) {
|
|
50
|
+
modelDefinition = this.removeParanoidColumn(modelDefinition);
|
|
51
|
+
}
|
|
52
|
+
this.sequelize.define(tableName, modelDefinition, {
|
|
53
|
+
tableName,
|
|
54
|
+
timestamps: hasTimestamps,
|
|
55
|
+
paranoid: isParanoid,
|
|
56
|
+
});
|
|
57
|
+
}));
|
|
58
|
+
}
|
|
59
|
+
async defineRelations(tableNames) {
|
|
60
|
+
return Promise.all(tableNames.map(async (tableName) => {
|
|
61
|
+
const foreignReferences = await this.queryInterface.getForeignKeyReferencesForTable(tableName);
|
|
62
|
+
const currentModel = this.sequelize.model(tableName);
|
|
63
|
+
if (this.isJunctionTable(currentModel.getAttributes())) {
|
|
64
|
+
const { referencedTableName: tableA, columnName: columnA, referencedColumnName: referencedColumnA, } = foreignReferences[0];
|
|
65
|
+
const { referencedTableName: tableB, columnName: columnB, referencedColumnName: referencedColumnB, } = foreignReferences[1];
|
|
66
|
+
const modelA = this.sequelize.model(tableA);
|
|
67
|
+
const modelB = this.sequelize.model(tableB);
|
|
68
|
+
modelA.belongsToMany(modelB, {
|
|
69
|
+
through: currentModel.name,
|
|
70
|
+
foreignKey: columnA,
|
|
71
|
+
otherKey: columnB,
|
|
72
|
+
});
|
|
73
|
+
modelB.belongsToMany(modelA, {
|
|
74
|
+
through: currentModel.name,
|
|
75
|
+
foreignKey: columnB,
|
|
76
|
+
otherKey: columnA,
|
|
77
|
+
});
|
|
78
|
+
currentModel.belongsTo(modelA, { foreignKey: columnA, targetKey: referencedColumnA });
|
|
79
|
+
currentModel.belongsTo(modelB, { foreignKey: columnB, targetKey: referencedColumnB });
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
const uniqueFields = await this.getUniqueFields(tableName);
|
|
83
|
+
foreignReferences.forEach(foreignReference => {
|
|
84
|
+
const { columnName, referencedTableName, referencedColumnName } = foreignReference;
|
|
85
|
+
const referencedModel = this.sequelize.model(referencedTableName);
|
|
86
|
+
currentModel.belongsTo(referencedModel, {
|
|
87
|
+
foreignKey: columnName,
|
|
88
|
+
targetKey: referencedColumnName,
|
|
89
|
+
});
|
|
90
|
+
if (uniqueFields.includes(columnName)) {
|
|
91
|
+
referencedModel.hasOne(currentModel, {
|
|
92
|
+
foreignKey: columnName,
|
|
93
|
+
sourceKey: referencedColumnName,
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
else {
|
|
97
|
+
referencedModel.hasMany(currentModel, {
|
|
98
|
+
foreignKey: columnName,
|
|
99
|
+
sourceKey: referencedColumnName,
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
}));
|
|
105
|
+
}
|
|
106
|
+
hasTimestamps(columnNames) {
|
|
107
|
+
const hasCreatedAt = columnNames.includes('createdAt');
|
|
108
|
+
const hasUpdatedAt = columnNames.includes('updatedAt');
|
|
109
|
+
return hasCreatedAt && hasUpdatedAt;
|
|
110
|
+
}
|
|
111
|
+
removeTimeStampColumns(modelDefinition) {
|
|
112
|
+
const copy = { ...modelDefinition };
|
|
113
|
+
delete copy.createdAt;
|
|
114
|
+
delete copy.updatedAt;
|
|
115
|
+
return copy;
|
|
116
|
+
}
|
|
117
|
+
isParanoid(columnNames) {
|
|
118
|
+
return columnNames.includes('deletedAt');
|
|
119
|
+
}
|
|
120
|
+
removeParanoidColumn(modelDefinition) {
|
|
121
|
+
const copy = { ...modelDefinition };
|
|
122
|
+
delete copy.deletedAt;
|
|
123
|
+
return copy;
|
|
124
|
+
}
|
|
125
|
+
isJunctionTable(modelAttributes) {
|
|
126
|
+
// remove autogenerated field to keep the belongsToMany behavior
|
|
127
|
+
const modelAttributesDefinition = Object.values(modelAttributes).filter(({ _autoGenerated }) => !_autoGenerated);
|
|
128
|
+
if (modelAttributesDefinition.length !== 2)
|
|
129
|
+
return false;
|
|
130
|
+
if (modelAttributesDefinition.some(({ primaryKey }) => !primaryKey))
|
|
131
|
+
return false;
|
|
132
|
+
return true;
|
|
133
|
+
}
|
|
134
|
+
async getUniqueFields(tableName) {
|
|
135
|
+
const tableIndex = await this.queryInterface.showIndex(tableName);
|
|
136
|
+
return tableIndex
|
|
137
|
+
.filter(({ primary, unique, fields }) => !primary && unique && fields.length === 1)
|
|
138
|
+
.map(({ fields }) => fields.map(({ attribute }) => attribute))
|
|
139
|
+
.flat();
|
|
8
140
|
}
|
|
9
141
|
}
|
|
10
142
|
exports.default = SqlDataSource;
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
143
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YXNvdXJjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9kYXRhc291cmNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEseUNBTW1CO0FBR25CLDRFQUF3RTtBQUV4RSx3RkFBOEQ7QUFDOUQsb0ZBQTBEO0FBRTFELE1BQXFCLGFBQWMsU0FBUSwwQ0FBbUI7SUFNNUQsWUFBWSxhQUFxQixFQUFFLE1BQWU7UUFDaEQsTUFBTSxPQUFPLEdBQUcsQ0FBQyxHQUFXLEVBQUUsRUFBRSxDQUFDLE1BQU0sRUFBRSxDQUFDLE9BQU8sRUFBRSxHQUFHLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN4RixLQUFLLENBQUMsSUFBSSxxQkFBUyxDQUFDLGFBQWEsRUFBRSxFQUFFLE9BQU8sRUFBRSxDQUFDLENBQUMsQ0FBQztRQUVqRCxJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNyQixJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztRQUN6RCxJQUFJLENBQUMsa0JBQWtCLEdBQUcsSUFBSSw4QkFBa0IsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFVBQVUsRUFBYSxDQUFDLENBQUM7UUFDekYsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksNEJBQWdCLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQy9ELENBQUM7SUFFRCxLQUFLLENBQUMsS0FBSztRQUNULE1BQU0sVUFBVSxHQUFHLE1BQU0sSUFBSSxDQUFDLGNBQWMsQ0FBQyxhQUFhLEVBQUUsQ0FBQztRQUU3RCxNQUFNLElBQUksQ0FBQyxZQUFZLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDcEMsTUFBTSxJQUFJLENBQUMsZUFBZSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBRXZDLElBQUksQ0FBQyxpQkFBaUIs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
|
package/dist/index.d.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import
|
|
2
|
-
export
|
|
1
|
+
import { DataSourceFactory } from '@forestadmin/datasource-toolkit';
|
|
2
|
+
export declare function createSqlDataSource(connectionUri: string): DataSourceFactory;
|
|
3
3
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.js
CHANGED
|
@@ -3,6 +3,18 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.createSqlDataSource = void 0;
|
|
6
7
|
const datasource_1 = __importDefault(require("./datasource"));
|
|
7
|
-
|
|
8
|
-
|
|
8
|
+
// eslint-disable-next-line import/prefer-default-export
|
|
9
|
+
function createSqlDataSource(connectionUri) {
|
|
10
|
+
if (!/.*:\/\//g.test(connectionUri))
|
|
11
|
+
throw new Error(`Connection Uri "${connectionUri}" provided to Sql data source is not valid.` +
|
|
12
|
+
' Should be <dialect>://<connection>.');
|
|
13
|
+
return async (logger) => {
|
|
14
|
+
const datasource = new datasource_1.default(connectionUri, logger);
|
|
15
|
+
await datasource.build();
|
|
16
|
+
return datasource;
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
exports.createSqlDataSource = createSqlDataSource;
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBRUEsOERBQXlDO0FBRXpDLHdEQUF3RDtBQUN4RCxTQUFnQixtQkFBbUIsQ0FBQyxhQUFxQjtJQUN2RCxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUM7UUFDakMsTUFBTSxJQUFJLEtBQUssQ0FDYixtQkFBbUIsYUFBYSw2Q0FBNkM7WUFDM0Usc0NBQXNDLENBQ3pDLENBQUM7SUFFSixPQUFPLEtBQUssRUFBRSxNQUFjLEVBQUUsRUFBRTtRQUM5QixNQUFNLFVBQVUsR0FBRyxJQUFJLG9CQUFhLENBQUMsYUFBYSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQzVELE1BQU0sVUFBVSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBRXpCLE9BQU8sVUFBVSxDQUFDO0lBQ3BCLENBQUMsQ0FBQztBQUNKLENBQUM7QUFiRCxrREFhQyJ9
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { Sequelize } from 'sequelize';
|
|
2
|
+
export default class ArrayTypeGetter {
|
|
3
|
+
private readonly sequelize;
|
|
4
|
+
private readonly fromArray;
|
|
5
|
+
private readonly query;
|
|
6
|
+
constructor(sequelize: Sequelize);
|
|
7
|
+
getType(tableName: string, columnName: string): Promise<{
|
|
8
|
+
type: string;
|
|
9
|
+
special: string[];
|
|
10
|
+
}>;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=array-type-getter.d.ts.map
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const sequelize_1 = require("sequelize");
|
|
4
|
+
class ArrayTypeGetter {
|
|
5
|
+
constructor(sequelize) {
|
|
6
|
+
this.query = `
|
|
7
|
+
SELECT
|
|
8
|
+
(
|
|
9
|
+
CASE
|
|
10
|
+
WHEN e.udt_name = 'hstore' THEN e.udt_name
|
|
11
|
+
ELSE e.data_type
|
|
12
|
+
END
|
|
13
|
+
) || (
|
|
14
|
+
CASE
|
|
15
|
+
WHEN e.character_maximum_length IS NOT NULL THEN '(' || e.character_maximum_length || ')'
|
|
16
|
+
ELSE ''
|
|
17
|
+
END
|
|
18
|
+
) as "type",
|
|
19
|
+
(
|
|
20
|
+
SELECT
|
|
21
|
+
array_agg(en.enumlabel)
|
|
22
|
+
FROM
|
|
23
|
+
pg_catalog.pg_type t
|
|
24
|
+
JOIN pg_catalog.pg_enum en ON t.oid = en.enumtypid
|
|
25
|
+
WHERE
|
|
26
|
+
t.typname = e.udt_name
|
|
27
|
+
) AS "special"
|
|
28
|
+
FROM
|
|
29
|
+
INFORMATION_SCHEMA.columns c
|
|
30
|
+
LEFT JOIN INFORMATION_SCHEMA.element_types e ON (
|
|
31
|
+
(
|
|
32
|
+
c.table_catalog,
|
|
33
|
+
c.table_schema,
|
|
34
|
+
c.table_name,
|
|
35
|
+
'TABLE',
|
|
36
|
+
c.dtd_identifier
|
|
37
|
+
) = (
|
|
38
|
+
e.object_catalog,
|
|
39
|
+
e.object_schema,
|
|
40
|
+
e.object_name,
|
|
41
|
+
e.object_type,
|
|
42
|
+
e.collection_type_identifier
|
|
43
|
+
)
|
|
44
|
+
)
|
|
45
|
+
WHERE
|
|
46
|
+
table_name = :tableName
|
|
47
|
+
AND c.column_name = :columnName
|
|
48
|
+
;
|
|
49
|
+
`;
|
|
50
|
+
this.sequelize = sequelize;
|
|
51
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
52
|
+
this.fromArray = this.sequelize.getQueryInterface().queryGenerator.fromArray;
|
|
53
|
+
}
|
|
54
|
+
async getType(tableName, columnName) {
|
|
55
|
+
const replacements = { tableName, columnName };
|
|
56
|
+
const [{ type, special }] = await this.sequelize.query(this.query, {
|
|
57
|
+
replacements,
|
|
58
|
+
type: sequelize_1.QueryTypes.SELECT,
|
|
59
|
+
});
|
|
60
|
+
return {
|
|
61
|
+
type: type.toUpperCase(),
|
|
62
|
+
special: special ? this.fromArray(special) : [],
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
exports.default = ArrayTypeGetter;
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJyYXktdHlwZS1nZXR0ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMvYXJyYXktdHlwZS1nZXR0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSx5Q0FBa0Q7QUFFbEQsTUFBcUIsZUFBZTtJQWdEbEMsWUFBWSxTQUFvQjtRQTdDZixVQUFLLEdBQUc7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0EyQ3hCLENBQUM7UUFHQSxJQUFJLENBQUMsU0FBUyxHQUFHLFNBQVMsQ0FBQztRQUMzQiw4REFBOEQ7UUFDOUQsSUFBSSxDQUFDLFNBQVMsR0FBSSxJQUFJLENBQUMsU0FBUyxDQUFDLGlCQUFpQixFQUFFLENBQUMsY0FBc0IsQ0FBQyxTQUFTLENBQUM7SUFDeEYsQ0FBQztJQUVELEtBQUssQ0FBQyxPQUFPLENBQ1gsU0FBaUIsRUFDakIsVUFBa0I7UUFFbEIsTUFBTSxZQUFZLEdBQUcsRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLENBQUM7UUFFL0MsTUFBTSxDQUFDLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxDQUFDLEdBQUcsTUFBTSxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFO1lBQ2pFLFlBQVk7WUFDWixJQUFJLEVBQUUsc0JBQVUsQ0FBQyxNQUFNO1NBQ3hCLENBQUMsQ0FBQztRQUVILE9BQU87WUFDTCxJQUFJLEVBQUUsSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUN4QixPQUFPLEVBQUUsT0FBTyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFO1NBQ2hELENBQUM7SUFDSixDQUFDO0NBQ0Y7QUF0RUQsa0NBc0VDIn0=
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { AbstractDataType, AbstractDataTypeConstructor, Dialect } from 'sequelize';
|
|
2
|
+
export default class DefaultValueParser {
|
|
3
|
+
private readonly dialect;
|
|
4
|
+
constructor(dialect: Dialect);
|
|
5
|
+
parse(expression: any, type: AbstractDataType | AbstractDataTypeConstructor): unknown;
|
|
6
|
+
private parseGeneric;
|
|
7
|
+
private sanitizeExpression;
|
|
8
|
+
private literalUnlessMatch;
|
|
9
|
+
private parseNumber;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=default-value-parser.d.ts.map
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const sequelize_1 = require("sequelize");
|
|
4
|
+
class DefaultValueParser {
|
|
5
|
+
constructor(dialect) {
|
|
6
|
+
this.dialect = dialect;
|
|
7
|
+
}
|
|
8
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
9
|
+
parse(expression, type) {
|
|
10
|
+
if (expression === null || expression === undefined)
|
|
11
|
+
return undefined;
|
|
12
|
+
if (typeof expression === 'string' && expression.startsWith('NULL'))
|
|
13
|
+
return null;
|
|
14
|
+
// FA backend not handle correctly
|
|
15
|
+
if (type instanceof sequelize_1.DataTypes.ARRAY) {
|
|
16
|
+
return undefined;
|
|
17
|
+
}
|
|
18
|
+
try {
|
|
19
|
+
const result = this.parseGeneric(expression, type);
|
|
20
|
+
return result !== undefined ? result : (0, sequelize_1.literal)(expression);
|
|
21
|
+
}
|
|
22
|
+
catch (e) {
|
|
23
|
+
return (0, sequelize_1.literal)(expression);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
parseGeneric(
|
|
27
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
28
|
+
expression, type) {
|
|
29
|
+
let sanitizedExpression = expression;
|
|
30
|
+
// sanitize string
|
|
31
|
+
if (typeof expression === 'string') {
|
|
32
|
+
sanitizedExpression = this.sanitizeExpression(expression);
|
|
33
|
+
}
|
|
34
|
+
if (type instanceof sequelize_1.DataTypes.ENUM) {
|
|
35
|
+
return sanitizedExpression;
|
|
36
|
+
}
|
|
37
|
+
switch (type) {
|
|
38
|
+
case sequelize_1.DataTypes.BOOLEAN:
|
|
39
|
+
return [true, 'true', 'TRUE', "b'1'", '1'].includes(sanitizedExpression);
|
|
40
|
+
case sequelize_1.DataTypes.NUMBER:
|
|
41
|
+
case sequelize_1.DataTypes.BIGINT:
|
|
42
|
+
case sequelize_1.DataTypes.FLOAT:
|
|
43
|
+
case sequelize_1.DataTypes.DOUBLE:
|
|
44
|
+
return this.parseNumber(sanitizedExpression);
|
|
45
|
+
case sequelize_1.DataTypes.DATE:
|
|
46
|
+
case sequelize_1.DataTypes.DATEONLY:
|
|
47
|
+
return this.literalUnlessMatch(/^(\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2})|(\d{4}-\d{2}-\d{2})|(\d{2}:\d{2}:\d{2})$/, sanitizedExpression);
|
|
48
|
+
case sequelize_1.DataTypes.STRING:
|
|
49
|
+
return sanitizedExpression;
|
|
50
|
+
case sequelize_1.DataTypes.JSON:
|
|
51
|
+
case sequelize_1.DataTypes.JSONB:
|
|
52
|
+
return JSON.parse(sanitizedExpression);
|
|
53
|
+
default:
|
|
54
|
+
return undefined;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
sanitizeExpression(expression) {
|
|
58
|
+
let sanitizedExpression = expression;
|
|
59
|
+
if (/^'.*'$/.test(sanitizedExpression)) {
|
|
60
|
+
sanitizedExpression = expression.substring(1, expression.length - 1);
|
|
61
|
+
}
|
|
62
|
+
if (this.dialect === 'mssql') {
|
|
63
|
+
while (/^\(.*\)$/.test(sanitizedExpression)) {
|
|
64
|
+
sanitizedExpression = sanitizedExpression.substring(1, sanitizedExpression.length - 1);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
return sanitizedExpression;
|
|
68
|
+
}
|
|
69
|
+
literalUnlessMatch(regexp, expression) {
|
|
70
|
+
return regexp.test(expression) ? expression : (0, sequelize_1.literal)(expression);
|
|
71
|
+
}
|
|
72
|
+
parseNumber(expression) {
|
|
73
|
+
const result = Number.parseFloat(expression);
|
|
74
|
+
return Number.isNaN(result) ? (0, sequelize_1.literal)(expression) : result;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
exports.default = DefaultValueParser;
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdC12YWx1ZS1wYXJzZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMvZGVmYXVsdC12YWx1ZS1wYXJzZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSx5Q0FNbUI7QUFFbkIsTUFBcUIsa0JBQWtCO0lBR3JDLFlBQVksT0FBZ0I7UUFDMUIsSUFBSSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7SUFDekIsQ0FBQztJQUVELDhEQUE4RDtJQUM5RCxLQUFLLENBQUMsVUFBZSxFQUFFLElBQW9EO1FBQ3pFLElBQUksVUFBVSxLQUFLLElBQUksSUFBSSxVQUFVLEtBQUssU0FBUztZQUFFLE9BQU8sU0FBUyxDQUFDO1FBRXRFLElBQUksT0FBTyxVQUFVLEtBQUssUUFBUSxJQUFJLFVBQVUsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDO1lBQUUsT0FBTyxJQUFJLENBQUM7UUFFakYsa0NBQWtDO1FBQ2xDLElBQUksSUFBSSxZQUFZLHFCQUFTLENBQUMsS0FBSyxFQUFFO1lBQ25DLE9BQU8sU0FBUyxDQUFDO1NBQ2xCO1FBRUQsSUFBSTtZQUNGLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsVUFBVSxFQUFFLElBQUksQ0FBQyxDQUFDO1lBRW5ELE9BQU8sTUFBTSxLQUFLLFNBQVMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxJQUFBLG1CQUFPLEVBQUMsVUFBVSxDQUFDLENBQUM7U0FDNUQ7UUFBQyxPQUFPLENBQUMsRUFBRTtZQUNWLE9BQU8sSUFBQSxtQkFBTyxFQUFDLFVBQVUsQ0FBQyxDQUFDO1NBQzVCO0lBQ0gsQ0FBQztJQUVPLFlBQVk7SUFDbEIsOERBQThEO0lBQzlELFVBQWUsRUFDZixJQUFvRDtRQUVwRCxJQUFJLG1CQUFtQixHQUFHLFVBQVUsQ0FBQztRQUVyQyxrQkFBa0I7UUFDbEIsSUFBSSxPQUFPLFVBQVUsS0FBSyxRQUFRLEVBQUU7WUFDbEMsbUJB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
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { AbstractDataType, AbstractDataTypeConstructor, ColumnDescription, Sequelize } from 'sequelize';
|
|
2
|
+
export default class SqlTypeConverter {
|
|
3
|
+
private readonly enumRegex;
|
|
4
|
+
private readonly arrayTypeGetter;
|
|
5
|
+
constructor(sequelize: Sequelize);
|
|
6
|
+
private typeMatch;
|
|
7
|
+
private typeStartsWith;
|
|
8
|
+
private typeContains;
|
|
9
|
+
private convertToEnum;
|
|
10
|
+
private getTypeForUserDefined;
|
|
11
|
+
private getTypeForArray;
|
|
12
|
+
convert(tableName: string, columnName: string, columnInfo: ColumnDescription): Promise<AbstractDataType | AbstractDataTypeConstructor>;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=sql-type-converter.d.ts.map
|
|
@@ -0,0 +1,104 @@
|
|
|
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 array_type_getter_1 = __importDefault(require("./array-type-getter"));
|
|
8
|
+
class SqlTypeConverter {
|
|
9
|
+
constructor(sequelize) {
|
|
10
|
+
this.enumRegex = /ENUM\((.*)\)/i;
|
|
11
|
+
this.arrayTypeGetter = new array_type_getter_1.default(sequelize);
|
|
12
|
+
}
|
|
13
|
+
typeMatch(type, value) {
|
|
14
|
+
return (type.match(value) || {}).input;
|
|
15
|
+
}
|
|
16
|
+
typeStartsWith(type, value) {
|
|
17
|
+
return this.typeMatch(type, new RegExp(`^${value}.*`, 'i'));
|
|
18
|
+
}
|
|
19
|
+
typeContains(type, value) {
|
|
20
|
+
return this.typeMatch(type, new RegExp(`${value}.*`, 'i'));
|
|
21
|
+
}
|
|
22
|
+
convertToEnum(type) {
|
|
23
|
+
const enumOptions = this.enumRegex.exec(type)?.[1];
|
|
24
|
+
return sequelize_1.DataTypes.ENUM(...enumOptions.replace(/'/g, '').split(','));
|
|
25
|
+
}
|
|
26
|
+
getTypeForUserDefined(columnInfo) {
|
|
27
|
+
const { special } = columnInfo;
|
|
28
|
+
if (special && special.length > 0) {
|
|
29
|
+
return sequelize_1.DataTypes.ENUM(...special);
|
|
30
|
+
}
|
|
31
|
+
// User-defined enum with no values will default to string
|
|
32
|
+
return sequelize_1.DataTypes.STRING;
|
|
33
|
+
}
|
|
34
|
+
async getTypeForArray(tableName, columnName) {
|
|
35
|
+
const { type, special } = await this.arrayTypeGetter.getType(tableName, columnName);
|
|
36
|
+
const arrayType = await this.convert(tableName, columnName, {
|
|
37
|
+
type,
|
|
38
|
+
special,
|
|
39
|
+
});
|
|
40
|
+
return sequelize_1.DataTypes.ARRAY(arrayType);
|
|
41
|
+
}
|
|
42
|
+
async convert(tableName, columnName, columnInfo) {
|
|
43
|
+
const { type } = columnInfo;
|
|
44
|
+
switch (type) {
|
|
45
|
+
case 'JSON':
|
|
46
|
+
return sequelize_1.DataTypes.JSON;
|
|
47
|
+
case 'TINYINT(1)': // MYSQL bool
|
|
48
|
+
case 'BIT': // NOTICE: MSSQL type.
|
|
49
|
+
case 'BOOLEAN':
|
|
50
|
+
return sequelize_1.DataTypes.BOOLEAN;
|
|
51
|
+
case 'CHARACTER VARYING':
|
|
52
|
+
case 'TEXT':
|
|
53
|
+
case 'NTEXT': // MSSQL type
|
|
54
|
+
case this.typeContains(type, 'TEXT'):
|
|
55
|
+
case this.typeContains(type, 'VARCHAR'):
|
|
56
|
+
case this.typeContains(type, 'CHAR'):
|
|
57
|
+
case 'NVARCHAR': // NOTICE: MSSQL type.
|
|
58
|
+
return sequelize_1.DataTypes.STRING;
|
|
59
|
+
case 'USER-DEFINED':
|
|
60
|
+
return this.getTypeForUserDefined(columnInfo);
|
|
61
|
+
case this.typeMatch(type, this.enumRegex):
|
|
62
|
+
return this.convertToEnum(type);
|
|
63
|
+
case 'UNIQUEIDENTIFIER':
|
|
64
|
+
case 'UUID':
|
|
65
|
+
return sequelize_1.DataTypes.UUID;
|
|
66
|
+
case 'JSONB':
|
|
67
|
+
return sequelize_1.DataTypes.JSONB;
|
|
68
|
+
case 'INTEGER':
|
|
69
|
+
case 'SERIAL':
|
|
70
|
+
case 'BIGSERIAL':
|
|
71
|
+
case this.typeStartsWith(type, 'INT'):
|
|
72
|
+
case this.typeStartsWith(type, 'SMALLINT'):
|
|
73
|
+
case this.typeStartsWith(type, 'TINYINT'):
|
|
74
|
+
case this.typeStartsWith(type, 'MEDIUMINT'):
|
|
75
|
+
return sequelize_1.DataTypes.NUMBER;
|
|
76
|
+
case this.typeStartsWith(type, 'BIGINT'):
|
|
77
|
+
return sequelize_1.DataTypes.BIGINT;
|
|
78
|
+
case this.typeContains(type, 'FLOAT'):
|
|
79
|
+
return sequelize_1.DataTypes.FLOAT;
|
|
80
|
+
case 'NUMERIC':
|
|
81
|
+
case 'REAL':
|
|
82
|
+
case 'DOUBLE':
|
|
83
|
+
case 'DOUBLE PRECISION':
|
|
84
|
+
case this.typeContains(type, 'DECIMAL'):
|
|
85
|
+
return sequelize_1.DataTypes.DOUBLE;
|
|
86
|
+
case 'DATE':
|
|
87
|
+
return sequelize_1.DataTypes.DATEONLY;
|
|
88
|
+
case this.typeStartsWith(type, 'DATETIME'):
|
|
89
|
+
case this.typeStartsWith(type, 'TIMESTAMP'):
|
|
90
|
+
return sequelize_1.DataTypes.DATE;
|
|
91
|
+
case 'TIME':
|
|
92
|
+
case 'TIME WITHOUT TIME ZONE':
|
|
93
|
+
return sequelize_1.DataTypes.TIME;
|
|
94
|
+
case 'ARRAY':
|
|
95
|
+
return this.getTypeForArray(tableName, columnName);
|
|
96
|
+
case 'INET':
|
|
97
|
+
return sequelize_1.DataTypes.INET;
|
|
98
|
+
default:
|
|
99
|
+
throw new Error(`Unsupported type: ${type}`);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
exports.default = SqlTypeConverter;
|
|
104
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3FsLXR5cGUtY29udmVydGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3V0aWxzL3NxbC10eXBlLWNvbnZlcnRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLHlDQU9tQjtBQUVuQiw0RUFBa0Q7QUFFbEQsTUFBcUIsZ0JBQWdCO0lBSW5DLFlBQVksU0FBb0I7UUFIZixjQUFTLEdBQUcsZUFBZSxDQUFDO1FBSTNDLElBQUksQ0FBQyxlQUFlLEdBQUcsSUFBSSwyQkFBZSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ3hELENBQUM7SUFFTyxTQUFTLENBQUMsSUFBWSxFQUFFLEtBQXNCO1FBQ3BELE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQztJQUN6QyxDQUFDO0lBRU8sY0FBYyxDQUFDLElBQVksRUFBRSxLQUFhO1FBQ2hELE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLEVBQUUsSUFBSSxNQUFNLENBQUMsSUFBSSxLQUFLLElBQUksRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFFTyxZQUFZLENBQUMsSUFBWSxFQUFFLEtBQWE7UUFDOUMsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxJQUFJLE1BQU0sQ0FBQyxHQUFHLEtBQUssSUFBSSxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFDN0QsQ0FBQztJQUVPLGFBQWEsQ0FBQyxJQUFZO1FBQ2hDLE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFFbkQsT0FBTyxxQkFBUyxDQUFDLElBQUksQ0FBQyxHQUFHLFdBQVcsQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxD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
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@forestadmin/datasource-sql",
|
|
3
|
-
"version": "1.0.0-beta.
|
|
3
|
+
"version": "1.0.0-beta.32",
|
|
4
4
|
"main": "dist/index.js",
|
|
5
5
|
"license": "GPL-3.0",
|
|
6
6
|
"publishConfig": {
|
|
@@ -12,8 +12,8 @@
|
|
|
12
12
|
"directory": "packages/datasource-sql"
|
|
13
13
|
},
|
|
14
14
|
"dependencies": {
|
|
15
|
-
"@forestadmin/datasource-sequelize": "1.0.0-beta.
|
|
16
|
-
"@forestadmin/datasource-toolkit": "1.0.0-beta.
|
|
15
|
+
"@forestadmin/datasource-sequelize": "1.0.0-beta.27",
|
|
16
|
+
"@forestadmin/datasource-toolkit": "1.0.0-beta.22",
|
|
17
17
|
"sequelize": "6.18.0"
|
|
18
18
|
},
|
|
19
19
|
"files": [
|
|
@@ -28,7 +28,6 @@
|
|
|
28
28
|
"test": "jest"
|
|
29
29
|
},
|
|
30
30
|
"devDependencies": {
|
|
31
|
-
"lodash": "^4.17.21"
|
|
32
|
-
"sequelize": "6.18.0"
|
|
31
|
+
"lodash": "^4.17.21"
|
|
33
32
|
}
|
|
34
33
|
}
|