@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/db/state.js DELETED
@@ -1,674 +0,0 @@
1
- /**
2
- * State of Saltcorn
3
- * Keeps cache for main objects
4
- * @category saltcorn-data
5
- * @module db/state
6
- * @subcategory db
7
- */
8
- const { contract, is } = require("contractis");
9
- const {
10
- is_plugin_wrap,
11
- is_plugin,
12
- is_header,
13
- is_viewtemplate,
14
- is_plugin_type,
15
- is_plugin_layout,
16
- } = require("../contracts");
17
- const moment = require("moment");
18
-
19
- const db = require(".");
20
- const { migrate } = require("../migrate");
21
- const File = require("../models/file");
22
- const Trigger = require("../models/trigger");
23
- const View = require("../models/view");
24
- const {
25
- getAllTenants,
26
- createTenant,
27
- copy_tenant_template,
28
- } = require("../models/tenant");
29
- const {
30
- getAllConfigOrDefaults,
31
- setConfig,
32
- deleteConfig,
33
- configTypes,
34
- } = require("../models/config");
35
- const emergency_layout = require("@saltcorn/markup/emergency_layout");
36
- const { structuredClone, removeAllWhiteSpace } = require("../utils");
37
- const { I18n } = require("i18n");
38
- const path = require("path");
39
- const fs = require("fs");
40
-
41
- /**
42
- * @param {object} v
43
- * @returns {void}
44
- */
45
- const process_send = (v) => {
46
- if (process.send) process.send(v);
47
- };
48
-
49
- /**
50
- * State Class
51
- * @category saltcorn-data
52
- */
53
- class State {
54
- /**
55
- * State constructor
56
- * @param {string} tenant description
57
- */
58
- constructor(tenant) {
59
- this.tenant = tenant;
60
- this.views = [];
61
- this.triggers = [];
62
- this.virtual_triggers = [];
63
- this.viewtemplates = {};
64
- this.tables = [];
65
- this.types = {};
66
- this.stashed_fieldviews = {};
67
- this.files = {};
68
- this.pages = [];
69
- this.fields = [];
70
- this.configs = {};
71
- this.fileviews = {};
72
- this.actions = {};
73
- this.auth_methods = {};
74
- this.plugins = {};
75
- this.plugin_cfgs = {};
76
- this.plugin_locations = {};
77
- this.plugin_module_names = {};
78
- this.eventTypes = {};
79
- this.layouts = { emergency: { wrap: emergency_layout } };
80
- this.headers = [];
81
- this.function_context = { moment };
82
- this.functions = { moment };
83
- this.keyFieldviews = {};
84
- this.external_tables = {};
85
- this.verifier = null;
86
- this.i18n = new I18n({
87
- locales: [],
88
- directory: path.join(__dirname, "..", "app-locales"),
89
- });
90
- contract.class(this);
91
- }
92
-
93
- /**
94
- * Get Layout by user
95
- * Based on role of user
96
- * @param {object} user
97
- * @returns {object}
98
- */
99
- getLayout(user) {
100
- const role_id = user ? +user.role_id : 10;
101
- const layout_by_role = this.getConfig("layout_by_role");
102
- if (layout_by_role && layout_by_role[role_id]) {
103
- const chosen = this.layouts[layout_by_role[role_id]];
104
- if (chosen) return chosen;
105
- }
106
- const layoutvs = Object.values(this.layouts);
107
- return layoutvs[layoutvs.length - 1];
108
- }
109
-
110
- /**
111
- * Refresh State cache for all Saltcorn main objects
112
- * @param {boolean} noSignal
113
- * @returns {Promise<void>}
114
- */
115
- async refresh(noSignal) {
116
- await this.refresh_views(noSignal);
117
- await this.refresh_triggers(noSignal);
118
- await this.refresh_tables(noSignal);
119
- await this.refresh_files(noSignal);
120
- await this.refresh_pages(noSignal);
121
- await this.refresh_config(noSignal);
122
- }
123
-
124
- /**
125
- * Refresh config
126
- * @param {boolean} noSignal
127
- * @returns {Promise<void>}
128
- */
129
- async refresh_config(noSignal) {
130
- this.configs = await getAllConfigOrDefaults();
131
- this.getConfig("custom_events", []).forEach((cev) => {
132
- this.eventTypes[cev.name] = cev;
133
- });
134
- this.refresh_i18n();
135
- if (!noSignal)
136
- process_send({ refresh: "config", tenant: db.getTenantSchema() });
137
- }
138
-
139
- /**
140
- * @returns {Promise<void>}
141
- */
142
- async refresh_i18n() {
143
- const localeDir = path.join(__dirname, "..", "app-locales", this.tenant);
144
- try {
145
- //avoid race condition
146
- if (!fs.existsSync(localeDir)) await fs.promises.mkdir(localeDir);
147
- } catch {}
148
- const allStrings = this.getConfig("localizer_strings", {});
149
- for (const lang of Object.keys(this.getConfig("localizer_languages", {}))) {
150
- //write json file
151
- const strings = allStrings[lang];
152
- if (strings)
153
- await fs.promises.writeFile(
154
- path.join(localeDir, `${lang}.json`),
155
- JSON.stringify(strings, null, 2)
156
- );
157
- }
158
- this.i18n = new I18n({
159
- locales: Object.keys(this.getConfig("localizer_languages", {})),
160
- directory: localeDir,
161
- autoReload: false,
162
- updateFiles: false,
163
- syncFiles: false,
164
- });
165
- }
166
-
167
- /**
168
- * Refresh views
169
- * @param {boolean} noSignal
170
- * @returns {Promise<void>}
171
- */
172
- async refresh_views(noSignal) {
173
- this.views = await View.find();
174
- this.virtual_triggers = [];
175
- for (const view of this.views) {
176
- if (view.viewtemplateObj && view.viewtemplateObj.virtual_triggers) {
177
- const trs = await view.viewtemplateObj.virtual_triggers(
178
- view.table_id,
179
- view.name,
180
-
181
- view.configuration
182
- );
183
- this.virtual_triggers.push(...trs);
184
- }
185
- }
186
- if (!noSignal)
187
- process_send({ refresh: "views", tenant: db.getTenantSchema() });
188
- }
189
-
190
- /**
191
- * Refresh triggers
192
- * @param {boolean} noSignal
193
- * @returns {Promise<void>}
194
- */
195
- async refresh_triggers(noSignal) {
196
- this.triggers = await Trigger.findDB();
197
- if (!noSignal)
198
- process_send({ refresh: "triggers", tenant: db.getTenantSchema() });
199
- }
200
-
201
- /**
202
- * Refresh pages
203
- * @param {boolean} noSignal
204
- * @returns {Promise<void>}
205
- */
206
- async refresh_pages(noSignal) {
207
- const Page = require("../models/page");
208
- this.pages = await Page.find();
209
- if (!noSignal)
210
- process_send({ refresh: "pages", tenant: db.getTenantSchema() });
211
- }
212
-
213
- /**
214
- * Refresh files
215
- * @param {boolean} noSignal
216
- * @returns {Promise<void>}
217
- */
218
- // todo what will be if there are a lot of files? Yes, there are cache only ids of files.
219
- async refresh_files(noSignal) {
220
- const allfiles = await File.find();
221
- this.files = {};
222
- for (const f of allfiles) {
223
- this.files[f.id] = f;
224
- }
225
- if (!noSignal)
226
- process_send({ refresh: "files", tenant: db.getTenantSchema() });
227
- }
228
-
229
- /**
230
- * Refresh tables & fields
231
- * @param {boolean} noSignal
232
- * @returns {Promise<void>}
233
- */
234
- async refresh_tables(noSignal) {
235
- const allTables = await db.select(
236
- "_sc_tables",
237
- {},
238
- { orderBy: "name", nocase: true }
239
- );
240
- const allFields = await db.select(
241
- "_sc_fields",
242
- {},
243
- { orderBy: "name", nocase: true }
244
- );
245
- for (const table of allTables) {
246
- table.fields = allFields.filter((f) => f.table_id === table.id);
247
- table.fields.forEach((f) => {
248
- if (
249
- f.attributes &&
250
- f.attributes.localizes_field &&
251
- f.attributes.locale
252
- ) {
253
- const localized = table.fields.find(
254
- (lf) => lf.name === f.attributes.localizes_field
255
- );
256
- if (localized) {
257
- if (!localized.attributes) localized.attributes = {};
258
-
259
- if (!localized.attributes.localized_by)
260
- localized.attributes.localized_by = {};
261
-
262
- localized.attributes.localized_by[f.attributes.locale] = f.name;
263
- }
264
- }
265
- });
266
- }
267
- this.tables = allTables;
268
- if (!noSignal)
269
- process_send({ refresh: "tables", tenant: db.getTenantSchema() });
270
- }
271
-
272
- /**
273
- * Get config parameter by key
274
- * @param {string} key - key of config paramter
275
- * @param {string} [def] - default value
276
- * @returns {string}
277
- */
278
- getConfig(key, def) {
279
- const fixed = db.connectObj.fixed_configuration[key];
280
- if (typeof fixed !== "undefined") return fixed;
281
- if (db.connectObj.inherit_configuration.includes(key)) {
282
- if (typeof singleton.configs[key] !== "undefined")
283
- return singleton.configs[key].value;
284
- else return def || configTypes[key].default;
285
- }
286
- if (this.configs[key] && typeof this.configs[key].value !== "undefined")
287
- return this.configs[key].value;
288
- if (def) return def;
289
- else return configTypes[key] && configTypes[key].default;
290
- }
291
-
292
- /**
293
- * Get copy of config parameter
294
- * @param {sring} key - key of parameter
295
- * @param {string} [def] - default value
296
- * @returns {string}
297
- */
298
- getConfigCopy(key, def) {
299
- return structuredClone(this.getConfig(key, def));
300
- }
301
-
302
- /**
303
- *
304
- * Set value of config parameter
305
- * @param {string} key - key of parameter
306
- * @param {string} value - value of parameter
307
- * @returns {Promise<void>}
308
- */
309
- async setConfig(key, value) {
310
- if (
311
- !this.configs[key] ||
312
- typeof this.configs[key].value === "undefined" ||
313
- this.configs[key].value !== value
314
- ) {
315
- await setConfig(key, value);
316
- this.configs[key] = { value };
317
- if (key.startsWith("localizer_")) this.refresh_i18n();
318
- process_send({ refresh: "config", tenant: db.getTenantSchema() });
319
- }
320
- }
321
-
322
- /**
323
- * Delete config parameter by key
324
- * @param {string} key - key of parameter
325
- * @returns {Promise<void>}
326
- */
327
- async deleteConfig(...keys) {
328
- for (const key of keys) {
329
- await deleteConfig(key);
330
- delete this.configs[key];
331
- }
332
- process_send({ refresh: "config", tenant: db.getTenantSchema() });
333
- }
334
-
335
- /**
336
- * Register plugin
337
- * @param {string} name
338
- * @param {object} plugin
339
- * @param {*} cfg
340
- * @param {*} location
341
- * @param {string} modname
342
- * @returns {void}
343
- */
344
- registerPlugin(name, plugin, cfg, location, modname) {
345
- this.plugins[name] = plugin;
346
- this.plugin_cfgs[name] = cfg;
347
- this.plugin_locations[plugin.plugin_name || name] = location;
348
- if (modname) this.plugin_module_names[modname] = name;
349
-
350
- const withCfg = (key, def) =>
351
- plugin.configuration_workflow
352
- ? plugin[key]
353
- ? plugin[key](cfg || {})
354
- : def
355
- : plugin[key] || def;
356
-
357
- withCfg("types", []).forEach((t) => {
358
- this.addType(t);
359
- });
360
- withCfg("viewtemplates", []).forEach((vt) => {
361
- this.viewtemplates[vt.name] = vt;
362
- });
363
- Object.entries(withCfg("functions", {})).forEach(([k, v]) => {
364
- this.functions[k] = v;
365
- this.function_context[k] = typeof v === "function" ? v : v.run;
366
- });
367
- Object.entries(withCfg("fileviews", {})).forEach(([k, v]) => {
368
- this.fileviews[k] = v;
369
- });
370
- Object.entries(withCfg("actions", {})).forEach(([k, v]) => {
371
- this.actions[k] = v;
372
- });
373
- Object.entries(withCfg("eventTypes", {})).forEach(([k, v]) => {
374
- this.eventTypes[k] = v;
375
- });
376
- Object.entries(withCfg("authentication", {})).forEach(([k, v]) => {
377
- this.auth_methods[k] = v;
378
- });
379
- Object.entries(withCfg("external_tables", {})).forEach(([k, v]) => {
380
- if (!v.name) v.name = k;
381
- this.external_tables[k] = v;
382
- });
383
- Object.entries(withCfg("fieldviews", {})).forEach(([k, v]) => {
384
- if (v.type === "Key") {
385
- this.keyFieldviews[k] = v;
386
- return;
387
- }
388
- const type = this.types[v.type];
389
- if (type) {
390
- if (type.fieldviews) type.fieldviews[k] = v;
391
- else type.fieldviews = { [k]: v };
392
- } else {
393
- if (!this.stashed_fieldviews[v.type])
394
- this.stashed_fieldviews[v.type] = {};
395
- this.stashed_fieldviews[v.type][k] = v;
396
- }
397
- });
398
- const layout = withCfg("layout");
399
- if (layout) {
400
- this.layouts[name] = contract(is_plugin_layout, layout);
401
- }
402
- const verifier = withCfg("verifier_workflow");
403
- if (verifier) {
404
- this.verifier = verifier;
405
- }
406
- withCfg("headers", []).forEach((h) => {
407
- if (!this.headers.includes(h)) this.headers.push(h);
408
- });
409
- }
410
-
411
- /**
412
- * Get type names
413
- * @type {string[]}
414
- */
415
- get type_names() {
416
- return Object.keys(this.types);
417
- }
418
-
419
- /**
420
- * Add type
421
- * @param {object} t
422
- */
423
- addType(t) {
424
- this.types[t.name] = {
425
- ...t,
426
- fieldviews: {
427
- ...t.fieldviews,
428
- ...(this.stashed_fieldviews[t.name] || {}),
429
- },
430
- };
431
- }
432
-
433
- /**
434
- * Remove plugin
435
- * @param {string} name
436
- * @param {boolean} noSignal
437
- * @returns {Promise<void>}
438
- */
439
- async remove_plugin(name, noSignal) {
440
- delete this.plugins[name];
441
- await this.refresh_plugins();
442
- if (!noSignal)
443
- process_send({ removePlugin: name, tenant: db.getTenantSchema() });
444
- }
445
-
446
- /**
447
- * Reload plugins
448
- * @param {boolean} noSignal
449
- * @returns {Promise<void>}
450
- */
451
- async refresh_plugins(noSignal) {
452
- this.viewtemplates = {};
453
- this.types = {};
454
- this.stashed_fieldviews = {};
455
- this.fields = [];
456
- this.fileviews = {};
457
- this.actions = {};
458
- this.auth_methods = {};
459
- this.layouts = { emergency: { wrap: emergency_layout } };
460
- this.headers = [];
461
- this.function_context = { moment };
462
- this.functions = { moment };
463
- this.keyFieldviews = {};
464
- this.external_tables = {};
465
- this.eventTypes = {};
466
- this.verifier = null;
467
- Object.entries(this.plugins).forEach(([k, v]) => {
468
- this.registerPlugin(k, v, this.plugin_cfgs[k]);
469
- });
470
- await this.refresh(true);
471
- if (!noSignal)
472
- process_send({ refresh: "plugins", tenant: db.getTenantSchema() });
473
- }
474
-
475
- /**
476
- * @returns {string[]}
477
- */
478
- getStringsForI18n() {
479
- const strings = [];
480
- this.views.forEach((v) => strings.push(...v.getStringsForI18n()));
481
- this.pages.forEach((p) => strings.push(...p.getStringsForI18n()));
482
- const menu = this.getConfig("menu_items", []);
483
- strings.push(...menu.map(({ label }) => label));
484
- return Array.from(new Set(strings)).filter(
485
- (s) => s && removeAllWhiteSpace(s)
486
- );
487
- }
488
-
489
- /**
490
- *
491
- * @param {function} f
492
- */
493
- setRoomEmitter(f) {
494
- this.roomEmitter = f;
495
- }
496
-
497
- /**
498
- *
499
- * @param {*} args
500
- */
501
- emitRoom(...args) {
502
- if (this.roomEmitter) this.roomEmitter(...args);
503
- }
504
- }
505
-
506
- /**
507
- * State constract
508
- * @type {{variables: {headers: ((function(*=): *)|*), types: ((function(*=): *)|*), viewtemplates: ((function(*=): *)|*)}, methods: {addType: ((function(*=): *)|*), registerPlugin: ((function(*=): *)|*), type_names: ((function(*=): *)|*), refresh: ((function(*=): *)|*)}}}
509
- */
510
- State.contract = {
511
- variables: {
512
- headers: is.array(is_header),
513
- viewtemplates: is.objVals(is_viewtemplate),
514
- types: is.objVals(is_plugin_type),
515
- },
516
- methods: {
517
- addType: is.fun(is_plugin_type, is.eq(undefined)),
518
- registerPlugin: is.fun([is.str, is_plugin], is.eq(undefined)),
519
- refresh: is.fun([], is.promise(is.eq(undefined))),
520
- type_names: is.getter(is.array(is.str)),
521
- },
522
- };
523
-
524
- // the state is singleton
525
- const singleton = new State("public");
526
-
527
- // return current State object
528
-
529
- /**
530
- * @function
531
- * @returns {State}
532
- */
533
- const getState = contract(
534
- is.fun([], is.or(is.class("State"), is.eq(undefined))),
535
- () => {
536
- if (!db.is_it_multi_tenant()) return singleton;
537
-
538
- const ten = db.getTenantSchema();
539
- if (ten === db.connectObj.default_schema) return singleton;
540
- else return tenants[ten];
541
- }
542
- );
543
- // list of all tenants
544
- var tenants = { public: singleton };
545
- // list of tenants with other domains
546
- const otherdomaintenants = {};
547
-
548
- /**
549
- * Get other domain tenant
550
- * @param {string} hostname
551
- * @returns {object}
552
- */
553
- const get_other_domain_tenant = (hostname) => otherdomaintenants[hostname];
554
- /**
555
- * Get tenant
556
- * @param {string} ten
557
- * @returns {object}
558
- */
559
- const getTenant = (ten) => {
560
- //console.log({ ten, tenants });
561
- return tenants[ten];
562
- };
563
- /**
564
- * Remove protocol (http:// or https://) from domain url
565
- * @param {string} url
566
- * @returns {string}
567
- */
568
- const get_domain = (url) => {
569
- const noproto = url.replace("https://", "").replace("http://", "");
570
- return noproto.split("/")[0].split(":")[0];
571
- };
572
- /**
573
- * Set tenant base url???
574
- * From my point of view it just add tenant to list of otherdomaintenant
575
- * @param {object} tenant_subdomain
576
- * @param {string} [value] - new
577
- */
578
- const set_tenant_base_url = (tenant_subdomain, value) => {
579
- const root_domain = get_domain(singleton.configs.base_url.value);
580
- if (value) {
581
- const cfg_domain = get_domain(value);
582
- if (!cfg_domain.includes("." + root_domain))
583
- otherdomaintenants[cfg_domain] = tenant_subdomain;
584
- }
585
- };
586
- /**
587
- * Switch to multi_tenant
588
- * @param {object} plugin_loader
589
- * @param {boolean} disableMigrate - if true then dont migrate db
590
- * @returns {Promise<void>}
591
- */
592
- const init_multi_tenant = async (plugin_loader, disableMigrate) => {
593
- const tenantList = await getAllTenants();
594
- for (const domain of tenantList) {
595
- try {
596
- tenants[domain] = new State(domain);
597
- if (!disableMigrate)
598
- await db.runWithTenant(domain, () => migrate(domain, true));
599
- await db.runWithTenant(domain, plugin_loader);
600
- set_tenant_base_url(domain, tenants[domain].configs.base_url.value);
601
- } catch (err) {
602
- console.error(
603
- `init_multi_tenant error in domain ${domain}: `,
604
- err.message
605
- );
606
- }
607
- }
608
- };
609
- /**
610
- * Create tenant
611
- * @param {string} t
612
- * @param {object} plugin_loader
613
- * @param {string} newurl
614
- * @param {boolean} noSignalOrDB
615
- * @returns {Promise<void>}
616
- */
617
- const create_tenant = async (
618
- t,
619
- plugin_loader,
620
- newurl,
621
- noSignalOrDB,
622
- loadAndSaveNewPlugin
623
- ) => {
624
- if (!noSignalOrDB) await createTenant(t, newurl);
625
- tenants[t] = new State(t);
626
- await db.runWithTenant(t, plugin_loader);
627
- if (!noSignalOrDB) {
628
- const tenant_template = singleton.getConfig("tenant_template");
629
- if (tenant_template) {
630
- //create backup
631
- await copy_tenant_template({
632
- tenant_template,
633
- target: t,
634
- state: tenants[t],
635
- loadAndSaveNewPlugin,
636
- });
637
- }
638
- process_send({ createTenant: t });
639
- }
640
- };
641
- /**
642
- * Restart tenant
643
- * @param {object} plugin_loader
644
- * @returns {Promise<void>}
645
- */
646
- const restart_tenant = async (plugin_loader) => {
647
- const ten = db.getTenantSchema();
648
- tenants[ten] = new State(ten);
649
- await plugin_loader();
650
- };
651
-
652
- const process_init_time = new Date();
653
- /**
654
- * Get Process Init Time - moment when Saltcorn process was initiated
655
- * @returns {Date}
656
- */
657
- const get_process_init_time = () => process_init_time;
658
-
659
- const features = {
660
- serve_static_dependencies: true,
661
- deep_public_plugin_serve: true,
662
- };
663
-
664
- module.exports = {
665
- getState,
666
- getTenant,
667
- init_multi_tenant,
668
- create_tenant,
669
- restart_tenant,
670
- get_other_domain_tenant,
671
- set_tenant_base_url,
672
- get_process_init_time,
673
- features,
674
- };