@saltcorn/data 0.6.2-beta.0 → 0.6.2-beta.4

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 (555) hide show
  1. package/dist/base-plugin/actions.d.ts +141 -0
  2. package/dist/base-plugin/actions.d.ts.map +1 -0
  3. package/dist/base-plugin/actions.js +551 -0
  4. package/dist/base-plugin/actions.js.map +1 -0
  5. package/dist/base-plugin/base.test.d.ts +2 -0
  6. package/dist/base-plugin/base.test.d.ts.map +1 -0
  7. package/dist/base-plugin/base.test.js +15 -0
  8. package/dist/base-plugin/base.test.js.map +1 -0
  9. package/dist/base-plugin/fieldviews.d.ts +25 -0
  10. package/dist/base-plugin/fieldviews.d.ts.map +1 -0
  11. package/dist/base-plugin/fieldviews.js +159 -0
  12. package/dist/base-plugin/fieldviews.js.map +1 -0
  13. package/dist/base-plugin/fileviews.d.ts +52 -0
  14. package/dist/base-plugin/fileviews.d.ts.map +1 -0
  15. package/dist/base-plugin/fileviews.js +59 -0
  16. package/dist/base-plugin/fileviews.js.map +1 -0
  17. package/dist/base-plugin/index.d.ts +524 -0
  18. package/dist/base-plugin/index.d.ts.map +1 -0
  19. package/{base-plugin → dist/base-plugin}/index.js +22 -24
  20. package/dist/base-plugin/index.js.map +1 -0
  21. package/dist/base-plugin/types.d.ts +383 -0
  22. package/dist/base-plugin/types.d.ts.map +1 -0
  23. package/dist/base-plugin/types.js +1080 -0
  24. package/dist/base-plugin/types.js.map +1 -0
  25. package/dist/base-plugin/viewtemplates/edit.d.ts +116 -0
  26. package/dist/base-plugin/viewtemplates/edit.d.ts.map +1 -0
  27. package/dist/base-plugin/viewtemplates/edit.js +561 -0
  28. package/dist/base-plugin/viewtemplates/edit.js.map +1 -0
  29. package/dist/base-plugin/viewtemplates/feed.d.ts +73 -0
  30. package/dist/base-plugin/viewtemplates/feed.d.ts.map +1 -0
  31. package/dist/base-plugin/viewtemplates/feed.js +348 -0
  32. package/dist/base-plugin/viewtemplates/feed.js.map +1 -0
  33. package/dist/base-plugin/viewtemplates/filter.d.ts +46 -0
  34. package/dist/base-plugin/viewtemplates/filter.d.ts.map +1 -0
  35. package/dist/base-plugin/viewtemplates/filter.js +267 -0
  36. package/dist/base-plugin/viewtemplates/filter.js.map +1 -0
  37. package/dist/base-plugin/viewtemplates/list.d.ts +99 -0
  38. package/dist/base-plugin/viewtemplates/list.d.ts.map +1 -0
  39. package/dist/base-plugin/viewtemplates/list.js +471 -0
  40. package/dist/base-plugin/viewtemplates/list.js.map +1 -0
  41. package/dist/base-plugin/viewtemplates/listshowlist.d.ts +41 -0
  42. package/dist/base-plugin/viewtemplates/listshowlist.d.ts.map +1 -0
  43. package/dist/base-plugin/viewtemplates/listshowlist.js +248 -0
  44. package/dist/base-plugin/viewtemplates/listshowlist.js.map +1 -0
  45. package/dist/base-plugin/viewtemplates/room.d.ts +140 -0
  46. package/dist/base-plugin/viewtemplates/room.d.ts.map +1 -0
  47. package/dist/base-plugin/viewtemplates/room.js +469 -0
  48. package/dist/base-plugin/viewtemplates/room.js.map +1 -0
  49. package/dist/base-plugin/viewtemplates/show.d.ts +101 -0
  50. package/dist/base-plugin/viewtemplates/show.d.ts.map +1 -0
  51. package/dist/base-plugin/viewtemplates/show.js +562 -0
  52. package/dist/base-plugin/viewtemplates/show.js.map +1 -0
  53. package/dist/base-plugin/viewtemplates/viewable_fields.d.ts +108 -0
  54. package/dist/base-plugin/viewtemplates/viewable_fields.d.ts.map +1 -0
  55. package/dist/base-plugin/viewtemplates/viewable_fields.js +563 -0
  56. package/dist/base-plugin/viewtemplates/viewable_fields.js.map +1 -0
  57. package/dist/contracts.d.ts +49 -0
  58. package/dist/contracts.d.ts.map +1 -0
  59. package/dist/contracts.js +212 -0
  60. package/dist/contracts.js.map +1 -0
  61. package/dist/coverage/lcov-report/block-navigation.d.ts +2 -0
  62. package/dist/coverage/lcov-report/block-navigation.d.ts.map +1 -0
  63. package/dist/coverage/lcov-report/block-navigation.js +66 -0
  64. package/dist/coverage/lcov-report/block-navigation.js.map +1 -0
  65. package/dist/coverage/lcov-report/prettify.d.ts +1 -0
  66. package/dist/coverage/lcov-report/prettify.d.ts.map +1 -0
  67. package/dist/coverage/lcov-report/prettify.js +478 -0
  68. package/dist/coverage/lcov-report/prettify.js.map +1 -0
  69. package/dist/coverage/lcov-report/sorter.d.ts +2 -0
  70. package/dist/coverage/lcov-report/sorter.d.ts.map +1 -0
  71. package/dist/coverage/lcov-report/sorter.js +141 -0
  72. package/dist/coverage/lcov-report/sorter.js.map +1 -0
  73. package/dist/db/connect.d.ts +40 -0
  74. package/dist/db/connect.d.ts.map +1 -0
  75. package/dist/db/connect.js +150 -0
  76. package/dist/db/connect.js.map +1 -0
  77. package/dist/db/db.test.d.ts +2 -0
  78. package/dist/db/db.test.d.ts.map +1 -0
  79. package/dist/db/db.test.js +28 -0
  80. package/dist/db/db.test.js.map +1 -0
  81. package/dist/db/fixtures.d.ts +8 -0
  82. package/dist/db/fixtures.d.ts.map +1 -0
  83. package/dist/db/fixtures.js +300 -0
  84. package/dist/db/fixtures.js.map +1 -0
  85. package/dist/db/index.d.ts +3 -0
  86. package/dist/db/index.d.ts.map +1 -0
  87. package/dist/db/index.js +41 -0
  88. package/dist/db/index.js.map +1 -0
  89. package/dist/db/reset_schema.d.ts +13 -0
  90. package/dist/db/reset_schema.d.ts.map +1 -0
  91. package/{db → dist/db}/reset_schema.js +45 -55
  92. package/dist/db/reset_schema.js.map +1 -0
  93. package/dist/db/state.d.ts +56 -0
  94. package/dist/db/state.d.ts.map +1 -0
  95. package/dist/db/state.js +608 -0
  96. package/dist/db/state.js.map +1 -0
  97. package/dist/index.d.ts +2 -0
  98. package/dist/index.d.ts.map +1 -0
  99. package/{index.js → dist/index.js} +2 -1
  100. package/dist/index.js.map +1 -0
  101. package/dist/migrate.d.ts +12 -0
  102. package/dist/migrate.d.ts.map +1 -0
  103. package/dist/migrate.js +94 -0
  104. package/dist/migrate.js.map +1 -0
  105. package/dist/migrations/202005141503.d.ts +2 -0
  106. package/dist/migrations/202005141503.d.ts.map +1 -0
  107. package/{migrations → dist/migrations}/202005141503.js +2 -1
  108. package/dist/migrations/202005141503.js.map +1 -0
  109. package/dist/migrations/202005241712.d.ts +2 -0
  110. package/dist/migrations/202005241712.d.ts.map +1 -0
  111. package/{migrations → dist/migrations}/202005241712.js +2 -1
  112. package/dist/migrations/202005241712.js.map +1 -0
  113. package/dist/migrations/202005251037.d.ts +2 -0
  114. package/dist/migrations/202005251037.d.ts.map +1 -0
  115. package/{migrations → dist/migrations}/202005251037.js +2 -1
  116. package/dist/migrations/202005251037.js.map +1 -0
  117. package/dist/migrations/202005282134.d.ts +2 -0
  118. package/dist/migrations/202005282134.d.ts.map +1 -0
  119. package/{migrations → dist/migrations}/202005282134.js +2 -1
  120. package/dist/migrations/202005282134.js.map +1 -0
  121. package/dist/migrations/202006022156.d.ts +2 -0
  122. package/dist/migrations/202006022156.d.ts.map +1 -0
  123. package/{migrations → dist/migrations}/202006022156.js +2 -1
  124. package/dist/migrations/202006022156.js.map +1 -0
  125. package/dist/migrations/202006051507.d.ts +2 -0
  126. package/dist/migrations/202006051507.d.ts.map +1 -0
  127. package/{migrations → dist/migrations}/202006051507.js +2 -1
  128. package/dist/migrations/202006051507.js.map +1 -0
  129. package/dist/migrations/202006240906.d.ts +2 -0
  130. package/dist/migrations/202006240906.d.ts.map +1 -0
  131. package/{migrations → dist/migrations}/202006240906.js +2 -1
  132. package/dist/migrations/202006240906.js.map +1 -0
  133. package/dist/migrations/202007091707.d.ts +2 -0
  134. package/dist/migrations/202007091707.d.ts.map +1 -0
  135. package/{migrations → dist/migrations}/202007091707.js +2 -1
  136. package/dist/migrations/202007091707.js.map +1 -0
  137. package/dist/migrations/202007202144.d.ts +2 -0
  138. package/dist/migrations/202007202144.d.ts.map +1 -0
  139. package/{migrations → dist/migrations}/202007202144.js +2 -1
  140. package/dist/migrations/202007202144.js.map +1 -0
  141. package/dist/migrations/202008031500.d.ts +2 -0
  142. package/dist/migrations/202008031500.d.ts.map +1 -0
  143. package/dist/migrations/202008031500.js +4 -0
  144. package/dist/migrations/202008031500.js.map +1 -0
  145. package/dist/migrations/202008051415.d.ts +2 -0
  146. package/dist/migrations/202008051415.d.ts.map +1 -0
  147. package/{migrations → dist/migrations}/202008051415.js +2 -1
  148. package/dist/migrations/202008051415.js.map +1 -0
  149. package/dist/migrations/202008121149.d.ts +3 -0
  150. package/dist/migrations/202008121149.d.ts.map +1 -0
  151. package/{migrations → dist/migrations}/202008121149.js +2 -2
  152. package/dist/migrations/202008121149.js.map +1 -0
  153. package/dist/migrations/202009112140.d.ts +3 -0
  154. package/dist/migrations/202009112140.d.ts.map +1 -0
  155. package/{migrations → dist/migrations}/202009112140.js +2 -2
  156. package/dist/migrations/202009112140.js.map +1 -0
  157. package/dist/migrations/202009181655.d.ts +2 -0
  158. package/dist/migrations/202009181655.d.ts.map +1 -0
  159. package/dist/migrations/202009181655.js +7 -0
  160. package/dist/migrations/202009181655.js.map +1 -0
  161. package/dist/migrations/202009221105.d.ts +2 -0
  162. package/dist/migrations/202009221105.d.ts.map +1 -0
  163. package/dist/migrations/202009221105.js +4 -0
  164. package/dist/migrations/202009221105.js.map +1 -0
  165. package/dist/migrations/202009231331.d.ts +2 -0
  166. package/dist/migrations/202009231331.d.ts.map +1 -0
  167. package/{migrations → dist/migrations}/202009231331.js +2 -1
  168. package/dist/migrations/202009231331.js.map +1 -0
  169. package/dist/migrations/202009301531.d.ts +2 -0
  170. package/dist/migrations/202009301531.d.ts.map +1 -0
  171. package/dist/migrations/202009301531.js +8 -0
  172. package/dist/migrations/202009301531.js.map +1 -0
  173. package/dist/migrations/202010231444.d.ts +2 -0
  174. package/dist/migrations/202010231444.d.ts.map +1 -0
  175. package/dist/migrations/202010231444.js +4 -0
  176. package/dist/migrations/202010231444.js.map +1 -0
  177. package/dist/migrations/202010251412.d.ts +2 -0
  178. package/dist/migrations/202010251412.d.ts.map +1 -0
  179. package/dist/migrations/202010251412.js +10 -0
  180. package/dist/migrations/202010251412.js.map +1 -0
  181. package/dist/migrations/202011021749.d.ts +2 -0
  182. package/dist/migrations/202011021749.d.ts.map +1 -0
  183. package/{migrations → dist/migrations}/202011021749.js +2 -1
  184. package/dist/migrations/202011021749.js.map +1 -0
  185. package/dist/migrations/202011051353.d.ts +2 -0
  186. package/dist/migrations/202011051353.d.ts.map +1 -0
  187. package/{migrations → dist/migrations}/202011051353.js +2 -1
  188. package/dist/migrations/202011051353.js.map +1 -0
  189. package/dist/migrations/202011111127.d.ts +2 -0
  190. package/dist/migrations/202011111127.d.ts.map +1 -0
  191. package/{migrations → dist/migrations}/202011111127.js +2 -1
  192. package/dist/migrations/202011111127.js.map +1 -0
  193. package/dist/migrations/202012011203.d.ts +2 -0
  194. package/dist/migrations/202012011203.d.ts.map +1 -0
  195. package/{migrations → dist/migrations}/202012011203.js +2 -1
  196. package/dist/migrations/202012011203.js.map +1 -0
  197. package/dist/migrations/202012100841.d.ts +2 -0
  198. package/dist/migrations/202012100841.d.ts.map +1 -0
  199. package/{migrations → dist/migrations}/202012100841.js +2 -1
  200. package/dist/migrations/202012100841.js.map +1 -0
  201. package/dist/migrations/202012281835.d.ts +2 -0
  202. package/dist/migrations/202012281835.d.ts.map +1 -0
  203. package/{migrations → dist/migrations}/202012281835.js +2 -1
  204. package/dist/migrations/202012281835.js.map +1 -0
  205. package/dist/migrations/202101061051.d.ts +2 -0
  206. package/dist/migrations/202101061051.d.ts.map +1 -0
  207. package/{migrations → dist/migrations}/202101061051.js +2 -1
  208. package/dist/migrations/202101061051.js.map +1 -0
  209. package/dist/migrations/202101141128.d.ts +2 -0
  210. package/dist/migrations/202101141128.d.ts.map +1 -0
  211. package/dist/migrations/202101141128.js +4 -0
  212. package/dist/migrations/202101141128.js.map +1 -0
  213. package/dist/migrations/202102091312.d.ts +3 -0
  214. package/dist/migrations/202102091312.d.ts.map +1 -0
  215. package/dist/migrations/202102091312.js +19 -0
  216. package/dist/migrations/202102091312.js.map +1 -0
  217. package/dist/migrations/202102101624.d.ts +2 -0
  218. package/dist/migrations/202102101624.d.ts.map +1 -0
  219. package/dist/migrations/202102101624.js +7 -0
  220. package/dist/migrations/202102101624.js.map +1 -0
  221. package/dist/migrations/202102172148.d.ts +2 -0
  222. package/dist/migrations/202102172148.d.ts.map +1 -0
  223. package/{migrations → dist/migrations}/202102172148.js +2 -2
  224. package/dist/migrations/202102172148.js.map +1 -0
  225. package/dist/migrations/202102261650.d.ts +2 -0
  226. package/dist/migrations/202102261650.d.ts.map +1 -0
  227. package/dist/migrations/202102261650.js +7 -0
  228. package/dist/migrations/202102261650.js.map +1 -0
  229. package/dist/migrations/202106102347.d.ts +2 -0
  230. package/dist/migrations/202106102347.d.ts.map +1 -0
  231. package/{migrations → dist/migrations}/202106102347.js +2 -3
  232. package/dist/migrations/202106102347.js.map +1 -0
  233. package/dist/migrations/202106112120.d.ts +2 -0
  234. package/dist/migrations/202106112120.d.ts.map +1 -0
  235. package/{migrations → dist/migrations}/202106112120.js +2 -3
  236. package/dist/migrations/202106112120.js.map +1 -0
  237. package/dist/migrations/202106120012.d.ts +2 -0
  238. package/dist/migrations/202106120012.d.ts.map +1 -0
  239. package/{migrations → dist/migrations}/202106120012.js +2 -3
  240. package/dist/migrations/202106120012.js.map +1 -0
  241. package/dist/migrations/202106120220.d.ts +2 -0
  242. package/dist/migrations/202106120220.d.ts.map +1 -0
  243. package/{migrations → dist/migrations}/202106120220.js +2 -4
  244. package/dist/migrations/202106120220.js.map +1 -0
  245. package/dist/migrations/202106121701.d.ts +2 -0
  246. package/dist/migrations/202106121701.d.ts.map +1 -0
  247. package/{migrations → dist/migrations}/202106121701.js +2 -3
  248. package/dist/migrations/202106121701.js.map +1 -0
  249. package/dist/migrations/202106121703.d.ts +3 -0
  250. package/dist/migrations/202106121703.d.ts.map +1 -0
  251. package/{migrations → dist/migrations}/202106121703.js +2 -3
  252. package/dist/migrations/202106121703.js.map +1 -0
  253. package/dist/migrations/202106251126.d.ts +2 -0
  254. package/dist/migrations/202106251126.d.ts.map +1 -0
  255. package/dist/migrations/202106251126.js +6 -0
  256. package/dist/migrations/202106251126.js.map +1 -0
  257. package/dist/migrations/202107281619.d.ts +2 -0
  258. package/dist/migrations/202107281619.d.ts.map +1 -0
  259. package/{migrations → dist/migrations}/202107281619.js +2 -1
  260. package/dist/migrations/202107281619.js.map +1 -0
  261. package/dist/migrations/202107302158.d.ts +3 -0
  262. package/dist/migrations/202107302158.d.ts.map +1 -0
  263. package/{migrations → dist/migrations}/202107302158.js +2 -3
  264. package/dist/migrations/202107302158.js.map +1 -0
  265. package/dist/migrations/202108022257.d.ts +2 -0
  266. package/dist/migrations/202108022257.d.ts.map +1 -0
  267. package/{migrations → dist/migrations}/202108022257.js +3 -4
  268. package/dist/migrations/202108022257.js.map +1 -0
  269. package/dist/migrations/202109201624.d.ts +2 -0
  270. package/dist/migrations/202109201624.d.ts.map +1 -0
  271. package/{migrations → dist/migrations}/202109201624.js +2 -1
  272. package/dist/migrations/202109201624.js.map +1 -0
  273. package/dist/migrations/202109301031.d.ts +3 -0
  274. package/dist/migrations/202109301031.d.ts.map +1 -0
  275. package/{migrations → dist/migrations}/202109301031.js +2 -2
  276. package/dist/migrations/202109301031.js.map +1 -0
  277. package/dist/migrations/202111290253.d.ts +3 -0
  278. package/dist/migrations/202111290253.d.ts.map +1 -0
  279. package/dist/migrations/202111290253.js +5 -0
  280. package/dist/migrations/202111290253.js.map +1 -0
  281. package/dist/models/backup.d.ts +22 -0
  282. package/dist/models/backup.d.ts.map +1 -0
  283. package/{models → dist/models}/backup.js +95 -192
  284. package/dist/models/backup.js.map +1 -0
  285. package/dist/models/config.d.ts +180 -0
  286. package/dist/models/config.d.ts.map +1 -0
  287. package/dist/models/config.js +758 -0
  288. package/dist/models/config.js.map +1 -0
  289. package/dist/models/crash.d.ts +74 -0
  290. package/dist/models/crash.d.ts.map +1 -0
  291. package/dist/models/crash.js +118 -0
  292. package/dist/models/crash.js.map +1 -0
  293. package/dist/models/discovery.d.ts +28 -0
  294. package/dist/models/discovery.d.ts.map +1 -0
  295. package/dist/models/discovery.js +163 -0
  296. package/dist/models/discovery.js.map +1 -0
  297. package/dist/models/email.d.ts +16 -0
  298. package/dist/models/email.d.ts.map +1 -0
  299. package/dist/models/email.js +90 -0
  300. package/dist/models/email.js.map +1 -0
  301. package/dist/models/eventlog.d.ts +77 -0
  302. package/dist/models/eventlog.d.ts.map +1 -0
  303. package/dist/models/eventlog.js +132 -0
  304. package/dist/models/eventlog.js.map +1 -0
  305. package/dist/models/expression.d.ts +54 -0
  306. package/dist/models/expression.d.ts.map +1 -0
  307. package/dist/models/expression.js +274 -0
  308. package/dist/models/expression.js.map +1 -0
  309. package/dist/models/field.d.ts +217 -0
  310. package/dist/models/field.d.ts.map +1 -0
  311. package/dist/models/field.js +619 -0
  312. package/dist/models/field.js.map +1 -0
  313. package/dist/models/fieldrepeat.d.ts +49 -0
  314. package/dist/models/fieldrepeat.d.ts.map +1 -0
  315. package/dist/models/fieldrepeat.js +88 -0
  316. package/dist/models/fieldrepeat.js.map +1 -0
  317. package/dist/models/file.d.ts +122 -0
  318. package/dist/models/file.d.ts.map +1 -0
  319. package/dist/models/file.js +224 -0
  320. package/dist/models/file.js.map +1 -0
  321. package/dist/models/form.d.ts +82 -0
  322. package/dist/models/form.d.ts.map +1 -0
  323. package/dist/models/form.js +163 -0
  324. package/dist/models/form.js.map +1 -0
  325. package/dist/models/index.d.ts +1 -0
  326. package/dist/models/index.d.ts.map +1 -0
  327. package/{models → dist/models}/index.js +42 -42
  328. package/dist/models/index.js.map +1 -0
  329. package/dist/models/layout.d.ts +34 -0
  330. package/dist/models/layout.d.ts.map +1 -0
  331. package/dist/models/layout.js +153 -0
  332. package/dist/models/layout.js.map +1 -0
  333. package/dist/models/library.d.ts +50 -0
  334. package/dist/models/library.d.ts.map +1 -0
  335. package/dist/models/library.js +129 -0
  336. package/dist/models/library.js.map +1 -0
  337. package/dist/models/pack.d.ts +89 -0
  338. package/dist/models/pack.d.ts.map +1 -0
  339. package/dist/models/pack.js +390 -0
  340. package/dist/models/pack.js.map +1 -0
  341. package/dist/models/page.d.ts +101 -0
  342. package/dist/models/page.d.ts.map +1 -0
  343. package/dist/models/page.js +223 -0
  344. package/dist/models/page.js.map +1 -0
  345. package/dist/models/plugin.d.ts +100 -0
  346. package/dist/models/plugin.d.ts.map +1 -0
  347. package/dist/models/plugin.js +204 -0
  348. package/dist/models/plugin.js.map +1 -0
  349. package/dist/models/random.d.ts +24 -0
  350. package/dist/models/random.d.ts.map +1 -0
  351. package/dist/models/random.js +186 -0
  352. package/dist/models/random.js.map +1 -0
  353. package/dist/models/role.d.ts +42 -0
  354. package/dist/models/role.d.ts.map +1 -0
  355. package/dist/models/role.js +64 -0
  356. package/dist/models/role.js.map +1 -0
  357. package/dist/models/scheduler.d.ts +18 -0
  358. package/dist/models/scheduler.d.ts.map +1 -0
  359. package/dist/models/scheduler.js +159 -0
  360. package/dist/models/scheduler.js.map +1 -0
  361. package/dist/models/table.d.ts +326 -0
  362. package/dist/models/table.d.ts.map +1 -0
  363. package/dist/models/table.js +1006 -0
  364. package/dist/models/table.js.map +1 -0
  365. package/dist/models/table_constraints.d.ts +69 -0
  366. package/dist/models/table_constraints.d.ts.map +1 -0
  367. package/dist/models/table_constraints.js +118 -0
  368. package/dist/models/table_constraints.js.map +1 -0
  369. package/dist/models/tenant.d.ts +55 -0
  370. package/dist/models/tenant.d.ts.map +1 -0
  371. package/{models → dist/models}/tenant.js +40 -63
  372. package/dist/models/tenant.js.map +1 -0
  373. package/dist/models/trigger.d.ts +133 -0
  374. package/dist/models/trigger.d.ts.map +1 -0
  375. package/dist/models/trigger.js +292 -0
  376. package/dist/models/trigger.js.map +1 -0
  377. package/dist/models/user.d.ts +235 -0
  378. package/dist/models/user.d.ts.map +1 -0
  379. package/dist/models/user.js +434 -0
  380. package/dist/models/user.js.map +1 -0
  381. package/dist/models/view.d.ts +204 -0
  382. package/dist/models/view.d.ts.map +1 -0
  383. package/dist/models/view.js +497 -0
  384. package/dist/models/view.js.map +1 -0
  385. package/dist/models/workflow.d.ts +48 -0
  386. package/dist/models/workflow.d.ts.map +1 -0
  387. package/dist/models/workflow.js +190 -0
  388. package/dist/models/workflow.js.map +1 -0
  389. package/dist/plugin-helper.d.ts +145 -0
  390. package/dist/plugin-helper.d.ts.map +1 -0
  391. package/dist/plugin-helper.js +1158 -0
  392. package/dist/plugin-helper.js.map +1 -0
  393. package/dist/plugin-testing.d.ts +3 -0
  394. package/dist/plugin-testing.d.ts.map +1 -0
  395. package/dist/plugin-testing.js +120 -0
  396. package/dist/plugin-testing.js.map +1 -0
  397. package/dist/tests/actions.test.d.ts +2 -0
  398. package/dist/tests/actions.test.d.ts.map +1 -0
  399. package/dist/tests/actions.test.js +205 -0
  400. package/dist/tests/actions.test.js.map +1 -0
  401. package/dist/tests/auxtest.test.d.ts +2 -0
  402. package/dist/tests/auxtest.test.d.ts.map +1 -0
  403. package/dist/tests/auxtest.test.js +48 -0
  404. package/dist/tests/auxtest.test.js.map +1 -0
  405. package/dist/tests/backup.test.d.ts +2 -0
  406. package/dist/tests/backup.test.d.ts.map +1 -0
  407. package/dist/tests/backup.test.js +88 -0
  408. package/dist/tests/backup.test.js.map +1 -0
  409. package/dist/tests/calc.test.d.ts +2 -0
  410. package/dist/tests/calc.test.d.ts.map +1 -0
  411. package/dist/tests/calc.test.js +231 -0
  412. package/dist/tests/calc.test.js.map +1 -0
  413. package/dist/tests/config.test.d.ts +2 -0
  414. package/dist/tests/config.test.d.ts.map +1 -0
  415. package/dist/tests/config.test.js +83 -0
  416. package/dist/tests/config.test.js.map +1 -0
  417. package/dist/tests/discover.test.d.ts +2 -0
  418. package/dist/tests/discover.test.d.ts.map +1 -0
  419. package/dist/tests/discover.test.js +106 -0
  420. package/dist/tests/discover.test.js.map +1 -0
  421. package/dist/tests/exact_views.test.d.ts +2 -0
  422. package/dist/tests/exact_views.test.d.ts.map +1 -0
  423. package/dist/tests/exact_views.test.js +511 -0
  424. package/dist/tests/exact_views.test.js.map +1 -0
  425. package/dist/tests/field.test.d.ts +2 -0
  426. package/dist/tests/field.test.d.ts.map +1 -0
  427. package/dist/tests/field.test.js +237 -0
  428. package/dist/tests/field.test.js.map +1 -0
  429. package/dist/tests/form.test.d.ts +2 -0
  430. package/dist/tests/form.test.d.ts.map +1 -0
  431. package/dist/tests/form.test.js +191 -0
  432. package/dist/tests/form.test.js.map +1 -0
  433. package/dist/tests/mocks.d.ts +111 -0
  434. package/dist/tests/mocks.d.ts.map +1 -0
  435. package/dist/tests/mocks.js +165 -0
  436. package/dist/tests/mocks.js.map +1 -0
  437. package/dist/tests/models.test.d.ts +2 -0
  438. package/dist/tests/models.test.d.ts.map +1 -0
  439. package/dist/tests/models.test.js +210 -0
  440. package/dist/tests/models.test.js.map +1 -0
  441. package/dist/tests/pack.test.d.ts +2 -0
  442. package/dist/tests/pack.test.d.ts.map +1 -0
  443. package/dist/tests/pack.test.js +331 -0
  444. package/dist/tests/pack.test.js.map +1 -0
  445. package/dist/tests/plugin.test.d.ts +2 -0
  446. package/dist/tests/plugin.test.d.ts.map +1 -0
  447. package/dist/tests/plugin.test.js +53 -0
  448. package/dist/tests/plugin.test.js.map +1 -0
  449. package/dist/tests/random.test.d.ts +2 -0
  450. package/dist/tests/random.test.d.ts.map +1 -0
  451. package/dist/tests/random.test.js +138 -0
  452. package/dist/tests/random.test.js.map +1 -0
  453. package/dist/tests/table.test.d.ts +2 -0
  454. package/dist/tests/table.test.d.ts.map +1 -0
  455. package/dist/tests/table.test.js +1048 -0
  456. package/dist/tests/table.test.js.map +1 -0
  457. package/dist/tests/tenant.test.d.ts +2 -0
  458. package/dist/tests/tenant.test.d.ts.map +1 -0
  459. package/dist/tests/tenant.test.js +45 -0
  460. package/dist/tests/tenant.test.js.map +1 -0
  461. package/dist/tests/user.test.d.ts +2 -0
  462. package/dist/tests/user.test.d.ts.map +1 -0
  463. package/dist/tests/user.test.js +190 -0
  464. package/dist/tests/user.test.js.map +1 -0
  465. package/dist/tests/view.test.d.ts +2 -0
  466. package/dist/tests/view.test.d.ts.map +1 -0
  467. package/dist/tests/view.test.js +238 -0
  468. package/dist/tests/view.test.js.map +1 -0
  469. package/dist/tests/workflow.test.d.ts +2 -0
  470. package/dist/tests/workflow.test.d.ts.map +1 -0
  471. package/dist/tests/workflow.test.js +115 -0
  472. package/dist/tests/workflow.test.js.map +1 -0
  473. package/dist/tsconfig.ref.tsbuildinfo +1 -0
  474. package/dist/utils.d.ts +26 -0
  475. package/dist/utils.d.ts.map +1 -0
  476. package/dist/utils.js +124 -0
  477. package/dist/utils.js.map +1 -0
  478. package/package.json +32 -8
  479. package/base-plugin/actions.js +0 -629
  480. package/base-plugin/base.test.js +0 -15
  481. package/base-plugin/fieldviews.js +0 -197
  482. package/base-plugin/fileviews.js +0 -65
  483. package/base-plugin/types.js +0 -1154
  484. package/base-plugin/viewtemplates/edit.js +0 -669
  485. package/base-plugin/viewtemplates/feed.js +0 -434
  486. package/base-plugin/viewtemplates/filter.js +0 -358
  487. package/base-plugin/viewtemplates/list.js +0 -575
  488. package/base-plugin/viewtemplates/listshowlist.js +0 -292
  489. package/base-plugin/viewtemplates/room.js +0 -652
  490. package/base-plugin/viewtemplates/show.js +0 -689
  491. package/base-plugin/viewtemplates/viewable_fields.js +0 -713
  492. package/contracts.js +0 -311
  493. package/db/connect.js +0 -151
  494. package/db/db.test.js +0 -33
  495. package/db/fixtures.js +0 -303
  496. package/db/index.js +0 -63
  497. package/db/state.js +0 -674
  498. package/migrate.js +0 -99
  499. package/migrations/202008031500.js +0 -4
  500. package/migrations/202009181655.js +0 -6
  501. package/migrations/202009221105.js +0 -4
  502. package/migrations/202009301531.js +0 -7
  503. package/migrations/202010231444.js +0 -4
  504. package/migrations/202010251412.js +0 -9
  505. package/migrations/202101141128.js +0 -4
  506. package/migrations/202102091312.js +0 -19
  507. package/migrations/202102101624.js +0 -5
  508. package/migrations/202102261650.js +0 -6
  509. package/migrations/202106251126.js +0 -5
  510. package/models/config.js +0 -680
  511. package/models/crash.js +0 -126
  512. package/models/discovery.js +0 -195
  513. package/models/email.js +0 -92
  514. package/models/eventlog.js +0 -146
  515. package/models/expression.js +0 -276
  516. package/models/field.js +0 -746
  517. package/models/fieldrepeat.js +0 -96
  518. package/models/file.js +0 -234
  519. package/models/form.js +0 -169
  520. package/models/layout.js +0 -146
  521. package/models/library.js +0 -135
  522. package/models/pack.js +0 -466
  523. package/models/page.js +0 -255
  524. package/models/plugin.js +0 -219
  525. package/models/random.js +0 -206
  526. package/models/role.js +0 -94
  527. package/models/scheduler.js +0 -163
  528. package/models/table.js +0 -1211
  529. package/models/table_constraints.js +0 -133
  530. package/models/trigger.js +0 -327
  531. package/models/user.js +0 -503
  532. package/models/view.js +0 -622
  533. package/models/workflow.js +0 -205
  534. package/plugin-helper.js +0 -1311
  535. package/plugin-testing.js +0 -124
  536. package/tests/actions.test.js +0 -232
  537. package/tests/auxtest.test.js +0 -52
  538. package/tests/backup.test.js +0 -92
  539. package/tests/calc.test.js +0 -243
  540. package/tests/config.test.js +0 -91
  541. package/tests/discover.test.js +0 -114
  542. package/tests/exact_views.test.js +0 -526
  543. package/tests/field.test.js +0 -253
  544. package/tests/form.test.js +0 -198
  545. package/tests/mocks.js +0 -173
  546. package/tests/models.test.js +0 -221
  547. package/tests/pack.test.js +0 -350
  548. package/tests/plugin.test.js +0 -59
  549. package/tests/random.test.js +0 -154
  550. package/tests/table.test.js +0 -1091
  551. package/tests/tenant.test.js +0 -56
  552. package/tests/user.test.js +0 -196
  553. package/tests/view.test.js +0 -251
  554. package/tests/workflow.test.js +0 -119
  555. package/utils.js +0 -137
package/plugin-testing.js DELETED
@@ -1,124 +0,0 @@
1
- /**
2
- * @category saltcorn-data
3
- * @module plugin-testing
4
- */
5
- const { contract, is, auto_test } = require("contractis");
6
- const { is_plugin_wrap, is_plugin } = require("./contracts");
7
- const { getState } = require("./db/state");
8
- const { renderForm } = require("@saltcorn/markup");
9
- const { mockReqRes } = require("./tests/mocks");
10
- const Field = require("./models/field");
11
-
12
- const auto_test_wrap = (wrap) => {
13
- auto_test(contract(is_plugin_wrap, wrap, { n: 5 }));
14
- };
15
-
16
- const generate_attributes = (typeattrs, validate, table_id) => {
17
- var res = {};
18
- const attrs = Field.getTypeAttributes(typeattrs, table_id);
19
- (attrs || []).forEach((a) => {
20
- if (a.type && (a.required || is.bool.generate())) {
21
- const contract = a.type.contract || getState().types[a.type].contract;
22
- const gen = contract({}).generate;
23
- if (gen) res[a.name] = gen();
24
- }
25
- });
26
- if (validate && !validate(res))
27
- return generate_attributes(attrs, validate, table_id);
28
- else return res;
29
- };
30
-
31
- const auto_test_type = (t) => {
32
- const fvs = t.fieldviews || {};
33
-
34
- //run edit field views without a value
35
- Object.values(fvs).forEach((fv) => {
36
- if (fv.isEdit) {
37
- const attr = generate_attributes(t.attributes, t.validate_attributes);
38
- is.str(fv.run("foo", undefined, attr, "myclass", true, { name: "foo" }));
39
- is.str(fv.run("foo", undefined, attr, "myclass", false, { name: "foo" }));
40
- }
41
- });
42
- //find examples, run all fieldview on each example
43
-
44
- const has_contract = t.contract && t.contract.generate;
45
- const numex = has_contract ? 20 : 200;
46
- for (let index = 0; index < numex; index++) {
47
- const x = has_contract ? t.contract.generate() : t.read(is.any.generate());
48
-
49
- const attribs = generate_attributes(t.attributes, t.validate_attributes);
50
- if (has_contract || (typeof x !== "undefined" && x !== null))
51
- if ((t.validate && t.validate(attribs)(x)) || !t.validate) {
52
- Object.values(fvs).forEach((fv) => {
53
- if (fv.isEdit) {
54
- is.str(fv.run("foo", x, attribs, "myclass", true, { name: "foo" }));
55
- is.str(
56
- fv.run("foo", x, attribs, "myclass", false, { name: "foo" })
57
- );
58
- } else {
59
- is.str(fv.run(x));
60
- }
61
- });
62
- if (t.readFromFormRecord) t.readFromFormRecord({ akey: x }, "akey");
63
- }
64
- }
65
- if (t.readFromFormRecord) {
66
- t.readFromFormRecord({}, "akey");
67
- }
68
- //todo: try creating a table with this type
69
- };
70
- const auto_test_workflow = async (wf, initialCtx) => {
71
- const step = async (wf, ctx) => {
72
- is.obj(ctx);
73
- const res = await wf.run(ctx);
74
-
75
- if (res.renderForm) {
76
- is.str(renderForm(res.renderForm, ""));
77
-
78
- const vs = await res.renderForm.generate();
79
- return await step(wf, vs);
80
- } else return res;
81
- };
82
- return await step(wf, initialCtx);
83
- };
84
-
85
- const auto_test_viewtemplate = async (vt) => {
86
- if (vt.noAutoTest) return;
87
- const wf = vt.configuration_workflow({ __: (s) => s });
88
- is.class("Workflow")(wf);
89
- for (let index = 0; index < 10; index++) {
90
- var cfg;
91
- if (vt.initial_config && Math.round() > 0.5)
92
- cfg = await vt.initial_config({ table_id: 2 });
93
- else
94
- cfg = await auto_test_workflow(wf, {
95
- table_id: 2,
96
- viewname: "newview",
97
- });
98
- const sfs = vt.get_state_fields
99
- ? await vt.get_state_fields(1, "newview", cfg)
100
- : [];
101
- const res = await vt.run(2, "newview", cfg, {}, mockReqRes);
102
- is.or(is.str, is.array(is.str))(res);
103
- if (sfs.some((sf) => sf.name === "id")) {
104
- const resid = await vt.run(2, "newview", cfg, { id: 1 }, mockReqRes);
105
- is.or(is.str, is.array(is.str))(resid);
106
- }
107
- }
108
- };
109
-
110
- const auto_test_plugin = async (plugin) => {
111
- is_plugin(plugin);
112
- getState().registerPlugin("test_plugin", plugin);
113
- if (plugin.layout) {
114
- auto_test_wrap(plugin.layout.wrap);
115
- }
116
- if (plugin.types) {
117
- plugin.types.forEach(auto_test_type);
118
- }
119
- for (const vt of plugin.viewtemplates || []) await auto_test_viewtemplate(vt);
120
-
121
- //is each header reachable
122
- };
123
-
124
- module.exports = { auto_test_plugin, generate_attributes };
@@ -1,232 +0,0 @@
1
- const Table = require("../models/table");
2
- //const Field = require("../models/field");
3
- const Trigger = require("../models/trigger");
4
- const runScheduler = require("../models/scheduler");
5
- const db = require("../db");
6
- const { getState } = require("../db/state");
7
- const {
8
- plugin_with_routes,
9
- getActionCounter,
10
- resetActionCounter,
11
- sleep,
12
- } = require("./mocks");
13
- const EventLog = require("../models/eventlog");
14
-
15
- afterAll(db.close);
16
-
17
- beforeAll(async () => {
18
- await require("../db/reset_schema")();
19
- await require("../db/fixtures")();
20
- });
21
-
22
- jest.setTimeout(10000);
23
-
24
- describe("Action", () => {
25
- it("should add insert trigger", async () => {
26
- getState().registerPlugin("mock_plugin", plugin_with_routes);
27
- resetActionCounter();
28
- expect(getActionCounter()).toBe(0);
29
-
30
- const table = await Table.findOne({ name: "patients" });
31
-
32
- const trigger = await Trigger.create({
33
- action: "incrementCounter",
34
- table_id: table.id,
35
- when_trigger: "Insert",
36
- });
37
- expect(getActionCounter()).toBe(0);
38
- await table.insertRow({ name: "Don Fabrizio" });
39
- await sleep(10);
40
- expect(getActionCounter()).toBe(1);
41
- const trigger1 = await Trigger.findOne({ id: trigger.id });
42
- expect(!!trigger1).toBe(true);
43
- expect(trigger1.id).toBe(trigger.id);
44
- });
45
- it("should add update trigger", async () => {
46
- expect(getActionCounter()).toBe(1);
47
-
48
- const table = await Table.findOne({ name: "patients" });
49
-
50
- await Trigger.create({
51
- action: "setCounter",
52
- table_id: table.id,
53
- when_trigger: "Update",
54
- configuration: { number: 17 },
55
- });
56
- expect(getActionCounter()).toBe(1);
57
- const don = await table.getRow({ name: "Don Fabrizio" });
58
- await table.updateRow({ name: "Don Fabrizio II" }, don.id);
59
- expect(getActionCounter()).toBe(17);
60
- });
61
- it("should add update trigger", async () => {
62
- expect(getActionCounter()).toBe(17);
63
-
64
- const table = await Table.findOne({ name: "patients" });
65
-
66
- await Trigger.create({
67
- action: "setCounter",
68
- table_id: table.id,
69
- when_trigger: "Delete",
70
- configuration: { number: 37 },
71
- });
72
- expect(getActionCounter()).toBe(17);
73
- await table.deleteRows({ name: "Don Fabrizio" });
74
- expect(getActionCounter()).toBe(17);
75
-
76
- await table.deleteRows({ name: "Don Fabrizio II" });
77
- expect(getActionCounter()).toBe(37);
78
- });
79
- it("should run js code", async () => {
80
- const table = await Table.findOne({ name: "books" });
81
-
82
- await Trigger.create({
83
- action: "run_js_code",
84
- table_id: table.id,
85
- when_trigger: "Insert",
86
- configuration: {
87
- code: `
88
- const table = await Table.findOne({ name: "patients" });
89
- await table.insertRow({ name: "TriggeredInsert" });
90
- `,
91
- },
92
- });
93
- await table.insertRow({ author: "Giuseppe Tomasi", pages: 209 });
94
- const patients = await Table.findOne({ name: "patients" });
95
- await sleep(10);
96
- const rows = await patients.getRows({ name: "TriggeredInsert" });
97
-
98
- expect(rows.length).toBe(1);
99
- });
100
- it("should run webhook", async () => {
101
- const table = await Table.findOne({ name: "books" });
102
-
103
- await Trigger.create({
104
- action: "webhook",
105
- table_id: table.id,
106
- when_trigger: "Update",
107
- configuration: {
108
- // from https://requestbin.com/
109
- // to inspect https://pipedream.com/sources/dc_jku44wk
110
- url: "https://b6af540a71dce96ec130de5a0c47ada6.m.pipedream.net",
111
- },
112
- });
113
- const row = await table.getRow({ author: "Giuseppe Tomasi" });
114
- await table.updateRow({ pages: 210 }, row.id);
115
- });
116
-
117
- it("should list triggers", async () => {
118
- //const table = await Table.findOne({ name: "books" });
119
-
120
- const triggers = await Trigger.findAllWithTableName();
121
- expect(triggers.length).toBe(5);
122
- expect(
123
- triggers.find(
124
- (tr) => tr.table_name === "books" && tr.when_trigger === "Update"
125
- ).action
126
- ).toBe("webhook");
127
- });
128
- it("should get triggers", async () => {
129
- const table = await Table.findOne({ name: "books" });
130
- const trigger = await Trigger.findOne({
131
- table_id: table.id,
132
- when_trigger: "Update",
133
- });
134
- expect(trigger.action).toBe("webhook");
135
- await Trigger.update(trigger.id, { when_trigger: "Insert" });
136
- const ins_trigger = Trigger.find({
137
- table_id: table.id,
138
- when_trigger: "Insert",
139
- });
140
- expect(ins_trigger.length).toBe(2);
141
- await trigger.delete();
142
- const ins_trigger1 = Trigger.find({
143
- table_id: table.id,
144
- when_trigger: "Insert",
145
- });
146
- expect(ins_trigger1.length).toBe(1);
147
- });
148
- it("should run webhook on insert", async () => {
149
- const table = await Table.findOne({ name: "books" });
150
-
151
- await Trigger.create({
152
- action: "webhook",
153
- table_id: table.id,
154
- when_trigger: "Insert",
155
- configuration: {
156
- // from https://requestbin.com/
157
- // to inspect https://pipedream.com/sources/dc_jku44wk
158
- url: "https://b6af540a71dce96ec130de5a0c47ada6.m.pipedream.net",
159
- body: "",
160
- },
161
- });
162
- await table.insertRow({ author: "NK Jemisin", pages: 901 });
163
- });
164
- });
165
-
166
- describe("Events", () => {
167
- it("should add custom event", async () => {
168
- await getState().setConfig("custom_events", [
169
- {
170
- name: "FooHappened",
171
- hasChannel: false,
172
- },
173
- {
174
- name: "BarWasHere",
175
- hasChannel: true,
176
- },
177
- ]);
178
- await getState().setConfig("event_log_settings", {
179
- FooHappened: true,
180
- BarWasHere: true,
181
- BarWasHere_channel: "Baz",
182
- });
183
- await getState().refresh_config();
184
- });
185
- it("should emit custom event", async () => {
186
- await Trigger.emitEvent("FooHappened");
187
- const evs = await EventLog.find({ event_type: "FooHappened" });
188
- expect(evs.length).toBe(0);
189
- await sleep(100);
190
- const evs1 = await EventLog.find({ event_type: "FooHappened" });
191
- expect(evs1.length).toBe(1);
192
- });
193
- it("should find with user", async () => {
194
- const ev = await EventLog.findOne({ event_type: "FooHappened" });
195
- const evlog_w_user = await EventLog.findOneWithUser(ev.id);
196
- expect(evlog_w_user.event_type).toBe("FooHappened");
197
- });
198
- it("should emit custom event with channel", async () => {
199
- await Trigger.emitEvent("BarWasHere");
200
- await Trigger.emitEvent("BarWasHere", "Zap");
201
- await Trigger.emitEvent("BarWasHere", "Baz");
202
- const evs = await EventLog.find({ event_type: "BarWasHere" });
203
- expect(evs.length).toBe(0);
204
- await sleep(100);
205
- const evs1 = await EventLog.find({ event_type: "BarWasHere" });
206
- expect(evs1.length).toBe(1);
207
- });
208
- });
209
-
210
- describe("Scheduler", () => {
211
- it("should run and tick", async () => {
212
- getState().registerPlugin("mock_plugin", plugin_with_routes);
213
- resetActionCounter();
214
- expect(getActionCounter()).toBe(0);
215
-
216
- await Trigger.create({
217
- action: "incrementCounter",
218
- when_trigger: "Often",
219
- });
220
- let stopSched = false;
221
- runScheduler({
222
- stop_when: () => stopSched,
223
- tickSeconds: 1,
224
- });
225
- await sleep(500);
226
- expect(getActionCounter()).toBe(1);
227
- await sleep(1200);
228
- expect(getActionCounter() > 1).toBe(true);
229
- stopSched = true;
230
- await sleep(1200);
231
- });
232
- });
@@ -1,52 +0,0 @@
1
- const View = require("../models/view");
2
- const db = require("../db/index.js");
3
- const Table = require("../models/table");
4
-
5
- const { get_parent_views, get_child_views } = require("../plugin-helper");
6
- const { getState } = require("../db/state");
7
- const { satisfies } = require("../utils");
8
-
9
- getState().registerPlugin("base", require("../base-plugin"));
10
- beforeAll(async () => {
11
- await require("../db/reset_schema")();
12
- await require("../db/fixtures")();
13
- });
14
-
15
- afterAll(db.close);
16
-
17
- describe("plugin helper", () => {
18
- it("get parent views", async () => {
19
- const patients = await Table.findOne({ name: "patients" });
20
- const x = await get_parent_views(patients, "foobar");
21
- expect(x[0].views.map((v) => v.name)).toStrictEqual([
22
- "authoredit",
23
- "authorshow",
24
- ]);
25
- });
26
- it("get child views", async () => {
27
- const books = await Table.findOne({ name: "books" });
28
- const x = await get_child_views(books, "foobar");
29
- expect(x[1].views.map((v) => v.name)).toStrictEqual(["patientlist"]);
30
- });
31
- });
32
-
33
- describe("satisfies", () => {
34
- it("works", async () => {
35
- expect(satisfies({ x: 5 })({ x: 5 })).toBe(true);
36
- expect(satisfies({ x: 5 })({ x: 5, y: 7 })).toBe(true);
37
- expect(satisfies({ x: 5 })({ x: 6 })).toBe(false);
38
- expect(satisfies({ x: 5 })({ y: 6 })).toBe(false);
39
- expect(satisfies({})({ y: 6 })).toBe(true);
40
- expect(satisfies()({ y: 6 })).toBe(true);
41
- expect(satisfies({ x: { or: [5, 6] } })({ x: 5 })).toBe(true);
42
- expect(satisfies({ x: { or: [5, 6] } })({ x: 8 })).toBe(false);
43
- expect(satisfies({ x: { or: [5, 6] } })({ y: 8 })).toBe(false);
44
- expect(satisfies({ x: { in: [5, 6] } })({ x: 5 })).toBe(true);
45
- expect(satisfies({ x: { in: [5, 6] } })({ x: 8 })).toBe(false);
46
- expect(satisfies({ x: { in: [5, 6] } })({ y: 8 })).toBe(false);
47
-
48
- expect(satisfies({ x: 5, y: 7 })({ x: 5, y: 7 })).toBe(true);
49
- expect(satisfies({ x: 5, y: 8 })({ x: 5, y: 7 })).toBe(false);
50
- expect(satisfies({ x: 4, y: 8 })({ x: 5, y: 7 })).toBe(false);
51
- });
52
- });
@@ -1,92 +0,0 @@
1
- const db = require("../db");
2
- const { getState } = require("../db/state");
3
- getState().registerPlugin("base", require("../base-plugin"));
4
- const { create_backup, restore } = require("../models/backup");
5
- const reset = require("../db/reset_schema");
6
- const fs = require("fs").promises;
7
- const Table = require("../models/table");
8
- const View = require("../models/view");
9
- const User = require("../models/user");
10
- const { setConfig, getConfig } = require("../models/config");
11
- const Trigger = require("../models/trigger");
12
- const Library = require("../models/library");
13
- const Role = require("../models/role");
14
- afterAll(db.close);
15
-
16
- beforeAll(async () => {
17
- await require("../db/reset_schema")();
18
- await require("../db/fixtures")();
19
- });
20
-
21
- describe("Backup and restore", () => {
22
- it("should create and restore backup", async () => {
23
- await setConfig("site_name", "backups rule!");
24
- const sn1 = await getConfig("site_name");
25
- expect(sn1).toBe("backups rule!");
26
- await Role.create({ role: "paid", id: 6 });
27
- await Table.create("myblanktable", { min_role_read: 6 });
28
- await Trigger.create({
29
- name: "footrig",
30
- table_id: 1,
31
- when_trigger: "Insert",
32
- action: "run_js_code",
33
- configuration: { code: "console.log('new user')" },
34
- });
35
- await Trigger.create({
36
- name: "hourtrig",
37
- when_trigger: "Hourly",
38
- action: "run_js_code",
39
- configuration: { code: "console.log('cuckoo')" },
40
- });
41
- await Library.create({
42
- name: "foo",
43
- icon: "fa-bar",
44
- layout: { baz: "bar" },
45
- });
46
-
47
- const fnm = await create_backup();
48
- const t1 = await Table.findOne({ name: "books" });
49
- const t1c = await t1.countRows();
50
- const v1 = await View.find();
51
- expect(!!t1).toBe(true);
52
-
53
- await reset();
54
- const admu = await User.create({
55
- email: "admin@foo.com",
56
- password: "AhGGr6rhu45",
57
- role_id: 1,
58
- });
59
- expect(typeof admu.password).toBe("string");
60
-
61
- const t2 = await Table.findOne({ name: "books" });
62
- expect(t2).toBe(null);
63
- const sn0 = await getConfig("site_name");
64
- expect(sn0).toBe("Saltcorn");
65
- const restore_res = await restore(fnm, (p) => {});
66
- await fs.unlink(fnm);
67
- expect(restore_res).toBe(undefined);
68
- const t3 = await Table.findOne({ name: "books" });
69
- expect(!!t3).toBe(true);
70
- const t5 = await Table.findOne({ name: "myblanktable" });
71
- expect(!!t5).toBe(true);
72
- expect(t5.min_role_read).toBe(6);
73
- const t3c = await t3.countRows();
74
- expect(t1c).toBe(t3c);
75
- const v2 = await View.find();
76
- expect(v1.length).toBe(v2.length);
77
- const sn = await getConfig("site_name");
78
- expect(sn).toBe("backups rule!");
79
- await t3.insertRow({ author: "Marcus Rediker", pages: 224 });
80
- const staff = await User.findOne({ email: "staff@foo.com" });
81
- expect(!!staff).toBe(true);
82
- expect(typeof staff.password).toBe("string");
83
- const trig = await Trigger.findOne({ name: "footrig" });
84
- expect(!!trig).toBe(true);
85
- const htrig = await Trigger.findOne({ name: "hourtrig" });
86
- expect(!!htrig).toBe(true);
87
- const lib = await Library.findOne({ name: "foo" });
88
- expect(!!lib).toBe(true);
89
-
90
- expect(staff.checkPassword("ghrarhr54hg")).toBe(true);
91
- });
92
- });