@budibase/backend-core 3.2.26 → 3.2.27

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 (466) hide show
  1. package/dist/index.js +62 -23
  2. package/dist/index.js.map +4 -4
  3. package/dist/index.js.meta.json +1 -1
  4. package/dist/package.json +7 -7
  5. package/dist/plugins.js.map +2 -2
  6. package/dist/plugins.js.meta.json +1 -1
  7. package/dist/src/events/processors/types.d.ts +1 -1
  8. package/dist/src/events/publishers/index.d.ts +1 -0
  9. package/dist/src/events/publishers/rowAction.d.ts +6 -0
  10. package/dist/src/events/publishers/table.d.ts +2 -2
  11. package/dist/src/events/publishers/view.d.ts +17 -6
  12. package/dist/src/index.d.ts +11 -11
  13. package/dist/src/platform/platformDb.d.ts +1 -1
  14. package/dist/src/queue/queue.d.ts +1 -1
  15. package/dist/src/tenancy/db.d.ts +1 -1
  16. package/package.json +7 -7
  17. package/dist/jest.config.js +0 -25
  18. package/dist/jest.config.js.map +0 -1
  19. package/dist/src/accounts/accounts.js +0 -83
  20. package/dist/src/accounts/accounts.js.map +0 -1
  21. package/dist/src/accounts/api.js +0 -102
  22. package/dist/src/accounts/api.js.map +0 -1
  23. package/dist/src/accounts/index.js +0 -18
  24. package/dist/src/accounts/index.js.map +0 -1
  25. package/dist/src/auth/auth.js +0 -198
  26. package/dist/src/auth/auth.js.map +0 -1
  27. package/dist/src/auth/index.js +0 -18
  28. package/dist/src/auth/index.js.map +0 -1
  29. package/dist/src/blacklist/blacklist.js +0 -75
  30. package/dist/src/blacklist/blacklist.js.map +0 -1
  31. package/dist/src/blacklist/index.js +0 -18
  32. package/dist/src/blacklist/index.js.map +0 -1
  33. package/dist/src/cache/appMetadata.js +0 -96
  34. package/dist/src/cache/appMetadata.js.map +0 -1
  35. package/dist/src/cache/base/index.js +0 -189
  36. package/dist/src/cache/base/index.js.map +0 -1
  37. package/dist/src/cache/docWritethrough.js +0 -123
  38. package/dist/src/cache/docWritethrough.js.map +0 -1
  39. package/dist/src/cache/generic.js +0 -37
  40. package/dist/src/cache/generic.js.map +0 -1
  41. package/dist/src/cache/index.js +0 -48
  42. package/dist/src/cache/index.js.map +0 -1
  43. package/dist/src/cache/invite.js +0 -128
  44. package/dist/src/cache/invite.js.map +0 -1
  45. package/dist/src/cache/passwordReset.js +0 -92
  46. package/dist/src/cache/passwordReset.js.map +0 -1
  47. package/dist/src/cache/user.js +0 -183
  48. package/dist/src/cache/user.js.map +0 -1
  49. package/dist/src/cache/writethrough.js +0 -170
  50. package/dist/src/cache/writethrough.js.map +0 -1
  51. package/dist/src/configs/configs.js +0 -294
  52. package/dist/src/configs/configs.js.map +0 -1
  53. package/dist/src/configs/index.js +0 -18
  54. package/dist/src/configs/index.js.map +0 -1
  55. package/dist/src/constants/db.js +0 -75
  56. package/dist/src/constants/db.js.map +0 -1
  57. package/dist/src/constants/index.js +0 -19
  58. package/dist/src/constants/index.js.map +0 -1
  59. package/dist/src/constants/misc.js +0 -40
  60. package/dist/src/constants/misc.js.map +0 -1
  61. package/dist/src/context/Context.js +0 -14
  62. package/dist/src/context/Context.js.map +0 -1
  63. package/dist/src/context/identity.js +0 -81
  64. package/dist/src/context/identity.js.map +0 -1
  65. package/dist/src/context/index.js +0 -44
  66. package/dist/src/context/index.js.map +0 -1
  67. package/dist/src/context/mainContext.js +0 -446
  68. package/dist/src/context/mainContext.js.map +0 -1
  69. package/dist/src/context/types.js +0 -3
  70. package/dist/src/context/types.js.map +0 -1
  71. package/dist/src/db/Replication.js +0 -90
  72. package/dist/src/db/Replication.js.map +0 -1
  73. package/dist/src/db/couch/DatabaseImpl.js +0 -475
  74. package/dist/src/db/couch/DatabaseImpl.js.map +0 -1
  75. package/dist/src/db/couch/connections.js +0 -101
  76. package/dist/src/db/couch/connections.js.map +0 -1
  77. package/dist/src/db/couch/index.js +0 -26
  78. package/dist/src/db/couch/index.js.map +0 -1
  79. package/dist/src/db/couch/pouchDB.js +0 -108
  80. package/dist/src/db/couch/pouchDB.js.map +0 -1
  81. package/dist/src/db/couch/pouchDump.js +0 -2
  82. package/dist/src/db/couch/pouchDump.js.map +0 -1
  83. package/dist/src/db/couch/utils.js +0 -60
  84. package/dist/src/db/couch/utils.js.map +0 -1
  85. package/dist/src/db/db.js +0 -47
  86. package/dist/src/db/db.js.map +0 -1
  87. package/dist/src/db/errors.js +0 -21
  88. package/dist/src/db/errors.js.map +0 -1
  89. package/dist/src/db/index.js +0 -58
  90. package/dist/src/db/index.js.map +0 -1
  91. package/dist/src/db/instrumentation.js +0 -202
  92. package/dist/src/db/instrumentation.js.map +0 -1
  93. package/dist/src/db/lucene.js +0 -638
  94. package/dist/src/db/lucene.js.map +0 -1
  95. package/dist/src/db/searchIndexes/index.js +0 -18
  96. package/dist/src/db/searchIndexes/index.js.map +0 -1
  97. package/dist/src/db/searchIndexes/searchIndexes.js +0 -76
  98. package/dist/src/db/searchIndexes/searchIndexes.js.map +0 -1
  99. package/dist/src/db/utils.js +0 -212
  100. package/dist/src/db/utils.js.map +0 -1
  101. package/dist/src/db/views.js +0 -224
  102. package/dist/src/db/views.js.map +0 -1
  103. package/dist/src/docIds/conversions.js +0 -62
  104. package/dist/src/docIds/conversions.js.map +0 -1
  105. package/dist/src/docIds/ids.js +0 -125
  106. package/dist/src/docIds/ids.js.map +0 -1
  107. package/dist/src/docIds/index.js +0 -19
  108. package/dist/src/docIds/index.js.map +0 -1
  109. package/dist/src/docIds/newid.js +0 -8
  110. package/dist/src/docIds/newid.js.map +0 -1
  111. package/dist/src/docIds/params.js +0 -141
  112. package/dist/src/docIds/params.js.map +0 -1
  113. package/dist/src/docUpdates/index.js +0 -35
  114. package/dist/src/docUpdates/index.js.map +0 -1
  115. package/dist/src/environment.js +0 -182
  116. package/dist/src/environment.js.map +0 -1
  117. package/dist/src/errors/errors.js +0 -97
  118. package/dist/src/errors/errors.js.map +0 -1
  119. package/dist/src/errors/index.js +0 -18
  120. package/dist/src/errors/index.js.map +0 -1
  121. package/dist/src/events/analytics.js +0 -52
  122. package/dist/src/events/analytics.js.map +0 -1
  123. package/dist/src/events/asyncEvents/index.js +0 -19
  124. package/dist/src/events/asyncEvents/index.js.map +0 -1
  125. package/dist/src/events/asyncEvents/publisher.js +0 -26
  126. package/dist/src/events/asyncEvents/publisher.js.map +0 -1
  127. package/dist/src/events/asyncEvents/queue.js +0 -26
  128. package/dist/src/events/asyncEvents/queue.js.map +0 -1
  129. package/dist/src/events/backfill.js +0 -189
  130. package/dist/src/events/backfill.js.map +0 -1
  131. package/dist/src/events/documentId.js +0 -27
  132. package/dist/src/events/documentId.js.map +0 -1
  133. package/dist/src/events/events.js +0 -87
  134. package/dist/src/events/events.js.map +0 -1
  135. package/dist/src/events/identification.js +0 -299
  136. package/dist/src/events/identification.js.map +0 -1
  137. package/dist/src/events/index.js +0 -59
  138. package/dist/src/events/index.js.map +0 -1
  139. package/dist/src/events/processors/AnalyticsProcessor.js +0 -103
  140. package/dist/src/events/processors/AnalyticsProcessor.js.map +0 -1
  141. package/dist/src/events/processors/AuditLogsProcessor.js +0 -86
  142. package/dist/src/events/processors/AuditLogsProcessor.js.map +0 -1
  143. package/dist/src/events/processors/LoggingProcessor.js +0 -47
  144. package/dist/src/events/processors/LoggingProcessor.js.map +0 -1
  145. package/dist/src/events/processors/Processors.js +0 -52
  146. package/dist/src/events/processors/Processors.js.map +0 -1
  147. package/dist/src/events/processors/async/DocumentUpdateProcessor.js +0 -44
  148. package/dist/src/events/processors/async/DocumentUpdateProcessor.js.map +0 -1
  149. package/dist/src/events/processors/index.js +0 -23
  150. package/dist/src/events/processors/index.js.map +0 -1
  151. package/dist/src/events/processors/posthog/PosthogProcessor.js +0 -149
  152. package/dist/src/events/processors/posthog/PosthogProcessor.js.map +0 -1
  153. package/dist/src/events/processors/posthog/index.js +0 -8
  154. package/dist/src/events/processors/posthog/index.js.map +0 -1
  155. package/dist/src/events/processors/posthog/rateLimiting.js +0 -129
  156. package/dist/src/events/processors/posthog/rateLimiting.js.map +0 -1
  157. package/dist/src/events/processors/types.js +0 -3
  158. package/dist/src/events/processors/types.js.map +0 -1
  159. package/dist/src/events/publishers/account.js +0 -43
  160. package/dist/src/events/publishers/account.js.map +0 -1
  161. package/dist/src/events/publishers/ai.js +0 -30
  162. package/dist/src/events/publishers/ai.js.map +0 -1
  163. package/dist/src/events/publishers/app.js +0 -166
  164. package/dist/src/events/publishers/app.js.map +0 -1
  165. package/dist/src/events/publishers/auditLog.js +0 -34
  166. package/dist/src/events/publishers/auditLog.js.map +0 -1
  167. package/dist/src/events/publishers/auth.js +0 -80
  168. package/dist/src/events/publishers/auth.js.map +0 -1
  169. package/dist/src/events/publishers/automation.js +0 -117
  170. package/dist/src/events/publishers/automation.js.map +0 -1
  171. package/dist/src/events/publishers/backfill.js +0 -85
  172. package/dist/src/events/publishers/backfill.js.map +0 -1
  173. package/dist/src/events/publishers/backup.js +0 -41
  174. package/dist/src/events/publishers/backup.js.map +0 -1
  175. package/dist/src/events/publishers/datasource.js +0 -54
  176. package/dist/src/events/publishers/datasource.js.map +0 -1
  177. package/dist/src/events/publishers/email.js +0 -30
  178. package/dist/src/events/publishers/email.js.map +0 -1
  179. package/dist/src/events/publishers/environmentVariable.js +0 -44
  180. package/dist/src/events/publishers/environmentVariable.js.map +0 -1
  181. package/dist/src/events/publishers/group.js +0 -107
  182. package/dist/src/events/publishers/group.js.map +0 -1
  183. package/dist/src/events/publishers/index.js +0 -57
  184. package/dist/src/events/publishers/index.js.map +0 -1
  185. package/dist/src/events/publishers/installation.js +0 -52
  186. package/dist/src/events/publishers/installation.js.map +0 -1
  187. package/dist/src/events/publishers/layout.js +0 -34
  188. package/dist/src/events/publishers/layout.js.map +0 -1
  189. package/dist/src/events/publishers/license.js +0 -77
  190. package/dist/src/events/publishers/license.js.map +0 -1
  191. package/dist/src/events/publishers/org.js +0 -52
  192. package/dist/src/events/publishers/org.js.map +0 -1
  193. package/dist/src/events/publishers/plugin.js +0 -55
  194. package/dist/src/events/publishers/plugin.js.map +0 -1
  195. package/dist/src/events/publishers/query.js +0 -74
  196. package/dist/src/events/publishers/query.js.map +0 -1
  197. package/dist/src/events/publishers/role.js +0 -69
  198. package/dist/src/events/publishers/role.js.map +0 -1
  199. package/dist/src/events/publishers/rows.js +0 -32
  200. package/dist/src/events/publishers/rows.js.map +0 -1
  201. package/dist/src/events/publishers/screen.js +0 -46
  202. package/dist/src/events/publishers/screen.js.map +0 -1
  203. package/dist/src/events/publishers/serve.js +0 -47
  204. package/dist/src/events/publishers/serve.js.map +0 -1
  205. package/dist/src/events/publishers/table.js +0 -77
  206. package/dist/src/events/publishers/table.js.map +0 -1
  207. package/dist/src/events/publishers/user.js +0 -201
  208. package/dist/src/events/publishers/user.js.map +0 -1
  209. package/dist/src/events/publishers/view.js +0 -111
  210. package/dist/src/events/publishers/view.js.map +0 -1
  211. package/dist/src/features/features.js +0 -271
  212. package/dist/src/features/features.js.map +0 -1
  213. package/dist/src/features/index.js +0 -42
  214. package/dist/src/features/index.js.map +0 -1
  215. package/dist/src/features/tests/utils.js +0 -56
  216. package/dist/src/features/tests/utils.js.map +0 -1
  217. package/dist/src/helpers.js +0 -13
  218. package/dist/src/helpers.js.map +0 -1
  219. package/dist/src/index.js +0 -99
  220. package/dist/src/index.js.map +0 -1
  221. package/dist/src/installation.js +0 -159
  222. package/dist/src/installation.js.map +0 -1
  223. package/dist/src/logging/alerts.js +0 -23
  224. package/dist/src/logging/alerts.js.map +0 -1
  225. package/dist/src/logging/correlation/correlation.js +0 -18
  226. package/dist/src/logging/correlation/correlation.js.map +0 -1
  227. package/dist/src/logging/correlation/index.js +0 -18
  228. package/dist/src/logging/correlation/index.js.map +0 -1
  229. package/dist/src/logging/correlation/middleware.js +0 -17
  230. package/dist/src/logging/correlation/middleware.js.map +0 -1
  231. package/dist/src/logging/index.js +0 -45
  232. package/dist/src/logging/index.js.map +0 -1
  233. package/dist/src/logging/pino/logger.js +0 -234
  234. package/dist/src/logging/pino/logger.js.map +0 -1
  235. package/dist/src/logging/pino/middleware.js +0 -46
  236. package/dist/src/logging/pino/middleware.js.map +0 -1
  237. package/dist/src/logging/system.js +0 -110
  238. package/dist/src/logging/system.js.map +0 -1
  239. package/dist/src/middleware/adminOnly.js +0 -19
  240. package/dist/src/middleware/adminOnly.js.map +0 -1
  241. package/dist/src/middleware/auditLog.js +0 -18
  242. package/dist/src/middleware/auditLog.js.map +0 -1
  243. package/dist/src/middleware/authenticated.js +0 -254
  244. package/dist/src/middleware/authenticated.js.map +0 -1
  245. package/dist/src/middleware/builderOnly.js +0 -33
  246. package/dist/src/middleware/builderOnly.js.map +0 -1
  247. package/dist/src/middleware/builderOrAdmin.js +0 -33
  248. package/dist/src/middleware/builderOrAdmin.js.map +0 -1
  249. package/dist/src/middleware/contentSecurityPolicy.js +0 -124
  250. package/dist/src/middleware/contentSecurityPolicy.js.map +0 -1
  251. package/dist/src/middleware/csrf.js +0 -81
  252. package/dist/src/middleware/csrf.js.map +0 -1
  253. package/dist/src/middleware/errorHandling.js +0 -88
  254. package/dist/src/middleware/errorHandling.js.map +0 -1
  255. package/dist/src/middleware/index.js +0 -79
  256. package/dist/src/middleware/index.js.map +0 -1
  257. package/dist/src/middleware/internalApi.js +0 -30
  258. package/dist/src/middleware/internalApi.js.map +0 -1
  259. package/dist/src/middleware/ip.js +0 -23
  260. package/dist/src/middleware/ip.js.map +0 -1
  261. package/dist/src/middleware/joi-validator.js +0 -53
  262. package/dist/src/middleware/joi-validator.js.map +0 -1
  263. package/dist/src/middleware/matchers.js +0 -36
  264. package/dist/src/middleware/matchers.js.map +0 -1
  265. package/dist/src/middleware/passport/datasource/google.js +0 -107
  266. package/dist/src/middleware/passport/datasource/google.js.map +0 -1
  267. package/dist/src/middleware/passport/local.js +0 -91
  268. package/dist/src/middleware/passport/local.js.map +0 -1
  269. package/dist/src/middleware/passport/sso/google.js +0 -98
  270. package/dist/src/middleware/passport/sso/google.js.map +0 -1
  271. package/dist/src/middleware/passport/sso/oidc.js +0 -158
  272. package/dist/src/middleware/passport/sso/oidc.js.map +0 -1
  273. package/dist/src/middleware/passport/sso/sso.js +0 -150
  274. package/dist/src/middleware/passport/sso/sso.js.map +0 -1
  275. package/dist/src/middleware/passport/utils.js +0 -75
  276. package/dist/src/middleware/passport/utils.js.map +0 -1
  277. package/dist/src/middleware/querystringToBody.js +0 -29
  278. package/dist/src/middleware/querystringToBody.js.map +0 -1
  279. package/dist/src/middleware/tenancy.js +0 -37
  280. package/dist/src/middleware/tenancy.js.map +0 -1
  281. package/dist/src/migrations/definitions.js +0 -39
  282. package/dist/src/migrations/definitions.js.map +0 -1
  283. package/dist/src/migrations/index.js +0 -19
  284. package/dist/src/migrations/index.js.map +0 -1
  285. package/dist/src/migrations/migrations.js +0 -203
  286. package/dist/src/migrations/migrations.js.map +0 -1
  287. package/dist/src/objectStore/buckets/app.js +0 -95
  288. package/dist/src/objectStore/buckets/app.js.map +0 -1
  289. package/dist/src/objectStore/buckets/global.js +0 -68
  290. package/dist/src/objectStore/buckets/global.js.map +0 -1
  291. package/dist/src/objectStore/buckets/index.js +0 -20
  292. package/dist/src/objectStore/buckets/index.js.map +0 -1
  293. package/dist/src/objectStore/buckets/plugins.js +0 -104
  294. package/dist/src/objectStore/buckets/plugins.js.map +0 -1
  295. package/dist/src/objectStore/cloudfront.js +0 -73
  296. package/dist/src/objectStore/cloudfront.js.map +0 -1
  297. package/dist/src/objectStore/index.js +0 -20
  298. package/dist/src/objectStore/index.js.map +0 -1
  299. package/dist/src/objectStore/objectStore.js +0 -509
  300. package/dist/src/objectStore/objectStore.js.map +0 -1
  301. package/dist/src/objectStore/utils.js +0 -148
  302. package/dist/src/objectStore/utils.js.map +0 -1
  303. package/dist/src/platform/index.js +0 -43
  304. package/dist/src/platform/index.js.map +0 -1
  305. package/dist/src/platform/platformDb.js +0 -9
  306. package/dist/src/platform/platformDb.js.map +0 -1
  307. package/dist/src/platform/tenants.js +0 -149
  308. package/dist/src/platform/tenants.js.map +0 -1
  309. package/dist/src/platform/users.js +0 -118
  310. package/dist/src/platform/users.js.map +0 -1
  311. package/dist/src/plugin/index.js +0 -18
  312. package/dist/src/plugin/index.js.map +0 -1
  313. package/dist/src/plugin/utils.js +0 -158
  314. package/dist/src/plugin/utils.js.map +0 -1
  315. package/dist/src/queue/constants.js +0 -13
  316. package/dist/src/queue/constants.js.map +0 -1
  317. package/dist/src/queue/inMemoryQueue.js +0 -192
  318. package/dist/src/queue/inMemoryQueue.js.map +0 -1
  319. package/dist/src/queue/index.js +0 -19
  320. package/dist/src/queue/index.js.map +0 -1
  321. package/dist/src/queue/listeners.js +0 -199
  322. package/dist/src/queue/listeners.js.map +0 -1
  323. package/dist/src/queue/queue.js +0 -124
  324. package/dist/src/queue/queue.js.map +0 -1
  325. package/dist/src/redis/index.js +0 -47
  326. package/dist/src/redis/index.js.map +0 -1
  327. package/dist/src/redis/init.js +0 -184
  328. package/dist/src/redis/init.js.map +0 -1
  329. package/dist/src/redis/redis.js +0 -396
  330. package/dist/src/redis/redis.js.map +0 -1
  331. package/dist/src/redis/redlockImpl.js +0 -181
  332. package/dist/src/redis/redlockImpl.js.map +0 -1
  333. package/dist/src/redis/utils.js +0 -131
  334. package/dist/src/redis/utils.js.map +0 -1
  335. package/dist/src/security/auth.js +0 -26
  336. package/dist/src/security/auth.js.map +0 -1
  337. package/dist/src/security/encryption.js +0 -169
  338. package/dist/src/security/encryption.js.map +0 -1
  339. package/dist/src/security/index.js +0 -18
  340. package/dist/src/security/index.js.map +0 -1
  341. package/dist/src/security/permissions.js +0 -147
  342. package/dist/src/security/permissions.js.map +0 -1
  343. package/dist/src/security/roles.js +0 -566
  344. package/dist/src/security/roles.js.map +0 -1
  345. package/dist/src/security/secrets.js +0 -53
  346. package/dist/src/security/secrets.js.map +0 -1
  347. package/dist/src/security/sessions.js +0 -156
  348. package/dist/src/security/sessions.js.map +0 -1
  349. package/dist/src/sql/designDoc.js +0 -19
  350. package/dist/src/sql/designDoc.js.map +0 -1
  351. package/dist/src/sql/index.js +0 -47
  352. package/dist/src/sql/index.js.map +0 -1
  353. package/dist/src/sql/sql.js +0 -1536
  354. package/dist/src/sql/sql.js.map +0 -1
  355. package/dist/src/sql/sqlTable.js +0 -256
  356. package/dist/src/sql/sqlTable.js.map +0 -1
  357. package/dist/src/sql/utils.js +0 -179
  358. package/dist/src/sql/utils.js.map +0 -1
  359. package/dist/src/tenancy/db.js +0 -9
  360. package/dist/src/tenancy/db.js.map +0 -1
  361. package/dist/src/tenancy/index.js +0 -19
  362. package/dist/src/tenancy/index.js.map +0 -1
  363. package/dist/src/tenancy/tenancy.js +0 -125
  364. package/dist/src/tenancy/tenancy.js.map +0 -1
  365. package/dist/src/timers/index.js +0 -18
  366. package/dist/src/timers/index.js.map +0 -1
  367. package/dist/src/timers/timers.js +0 -25
  368. package/dist/src/timers/timers.js.map +0 -1
  369. package/dist/src/users/db.js +0 -489
  370. package/dist/src/users/db.js.map +0 -1
  371. package/dist/src/users/events.js +0 -179
  372. package/dist/src/users/events.js.map +0 -1
  373. package/dist/src/users/index.js +0 -23
  374. package/dist/src/users/index.js.map +0 -1
  375. package/dist/src/users/lookup.js +0 -126
  376. package/dist/src/users/lookup.js.map +0 -1
  377. package/dist/src/users/users.js +0 -376
  378. package/dist/src/users/users.js.map +0 -1
  379. package/dist/src/users/utils.js +0 -127
  380. package/dist/src/users/utils.js.map +0 -1
  381. package/dist/src/utils/Duration.js +0 -54
  382. package/dist/src/utils/Duration.js.map +0 -1
  383. package/dist/src/utils/hashing.js +0 -46
  384. package/dist/src/utils/hashing.js.map +0 -1
  385. package/dist/src/utils/index.js +0 -21
  386. package/dist/src/utils/index.js.map +0 -1
  387. package/dist/src/utils/stringUtils.js +0 -8
  388. package/dist/src/utils/stringUtils.js.map +0 -1
  389. package/dist/src/utils/utils.js +0 -267
  390. package/dist/src/utils/utils.js.map +0 -1
  391. package/dist/tests/core/logging.js +0 -33
  392. package/dist/tests/core/logging.js.map +0 -1
  393. package/dist/tests/core/utilities/index.js +0 -48
  394. package/dist/tests/core/utilities/index.js.map +0 -1
  395. package/dist/tests/core/utilities/jestUtils.js +0 -21
  396. package/dist/tests/core/utilities/jestUtils.js.map +0 -1
  397. package/dist/tests/core/utilities/mocks/alerts.js +0 -40
  398. package/dist/tests/core/utilities/mocks/alerts.js.map +0 -1
  399. package/dist/tests/core/utilities/mocks/date.js +0 -6
  400. package/dist/tests/core/utilities/mocks/date.js.map +0 -1
  401. package/dist/tests/core/utilities/mocks/events.js +0 -154
  402. package/dist/tests/core/utilities/mocks/events.js.map +0 -1
  403. package/dist/tests/core/utilities/mocks/index.js +0 -47
  404. package/dist/tests/core/utilities/mocks/index.js.map +0 -1
  405. package/dist/tests/core/utilities/mocks/licenses.js +0 -109
  406. package/dist/tests/core/utilities/mocks/licenses.js.map +0 -1
  407. package/dist/tests/core/utilities/queue.js +0 -21
  408. package/dist/tests/core/utilities/queue.js.map +0 -1
  409. package/dist/tests/core/utilities/structures/Chance.js +0 -21
  410. package/dist/tests/core/utilities/structures/Chance.js.map +0 -1
  411. package/dist/tests/core/utilities/structures/accounts.js +0 -43
  412. package/dist/tests/core/utilities/structures/accounts.js.map +0 -1
  413. package/dist/tests/core/utilities/structures/apps.js +0 -23
  414. package/dist/tests/core/utilities/structures/apps.js.map +0 -1
  415. package/dist/tests/core/utilities/structures/common.js +0 -11
  416. package/dist/tests/core/utilities/structures/common.js.map +0 -1
  417. package/dist/tests/core/utilities/structures/db.js +0 -15
  418. package/dist/tests/core/utilities/structures/db.js.map +0 -1
  419. package/dist/tests/core/utilities/structures/documents/index.js +0 -18
  420. package/dist/tests/core/utilities/structures/documents/index.js.map +0 -1
  421. package/dist/tests/core/utilities/structures/documents/platform/index.js +0 -38
  422. package/dist/tests/core/utilities/structures/documents/platform/index.js.map +0 -1
  423. package/dist/tests/core/utilities/structures/documents/platform/installation.js +0 -47
  424. package/dist/tests/core/utilities/structures/documents/platform/installation.js.map +0 -1
  425. package/dist/tests/core/utilities/structures/generator.js +0 -9
  426. package/dist/tests/core/utilities/structures/generator.js.map +0 -1
  427. package/dist/tests/core/utilities/structures/index.js +0 -56
  428. package/dist/tests/core/utilities/structures/index.js.map +0 -1
  429. package/dist/tests/core/utilities/structures/koa.js +0 -10
  430. package/dist/tests/core/utilities/structures/koa.js.map +0 -1
  431. package/dist/tests/core/utilities/structures/licenses.js +0 -157
  432. package/dist/tests/core/utilities/structures/licenses.js.map +0 -1
  433. package/dist/tests/core/utilities/structures/plugins.js +0 -22
  434. package/dist/tests/core/utilities/structures/plugins.js.map +0 -1
  435. package/dist/tests/core/utilities/structures/quotas.js +0 -73
  436. package/dist/tests/core/utilities/structures/quotas.js.map +0 -1
  437. package/dist/tests/core/utilities/structures/scim.js +0 -62
  438. package/dist/tests/core/utilities/structures/scim.js.map +0 -1
  439. package/dist/tests/core/utilities/structures/sso.js +0 -140
  440. package/dist/tests/core/utilities/structures/sso.js.map +0 -1
  441. package/dist/tests/core/utilities/structures/tenants.js +0 -8
  442. package/dist/tests/core/utilities/structures/tenants.js.map +0 -1
  443. package/dist/tests/core/utilities/structures/userGroups.js +0 -12
  444. package/dist/tests/core/utilities/structures/userGroups.js.map +0 -1
  445. package/dist/tests/core/utilities/structures/users.js +0 -53
  446. package/dist/tests/core/utilities/structures/users.js.map +0 -1
  447. package/dist/tests/core/utilities/testContainerUtils.js +0 -161
  448. package/dist/tests/core/utilities/testContainerUtils.js.map +0 -1
  449. package/dist/tests/core/utilities/utils/index.js +0 -39
  450. package/dist/tests/core/utilities/utils/index.js.map +0 -1
  451. package/dist/tests/core/utilities/utils/queue.js +0 -37
  452. package/dist/tests/core/utilities/utils/queue.js.map +0 -1
  453. package/dist/tests/core/utilities/utils/time.js +0 -7
  454. package/dist/tests/core/utilities/utils/time.js.map +0 -1
  455. package/dist/tests/extra/DBTestConfiguration.js +0 -65
  456. package/dist/tests/extra/DBTestConfiguration.js.map +0 -1
  457. package/dist/tests/extra/index.js +0 -43
  458. package/dist/tests/extra/index.js.map +0 -1
  459. package/dist/tests/extra/testEnv.js +0 -136
  460. package/dist/tests/extra/testEnv.js.map +0 -1
  461. package/dist/tests/index.js +0 -19
  462. package/dist/tests/index.js.map +0 -1
  463. package/dist/tests/jestEnv.js +0 -12
  464. package/dist/tests/jestEnv.js.map +0 -1
  465. package/dist/tests/jestSetup.js +0 -33
  466. package/dist/tests/jestSetup.js.map +0 -1
@@ -1,110 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- var __importDefault = (this && this.__importDefault) || function (mod) {
36
- return (mod && mod.__esModule) ? mod : { "default": mod };
37
- };
38
- Object.defineProperty(exports, "__esModule", { value: true });
39
- exports.getSingleFileMaxSizeInfo = getSingleFileMaxSizeInfo;
40
- exports.localFileDestination = localFileDestination;
41
- exports.getLogReadStream = getLogReadStream;
42
- const fs_1 = __importDefault(require("fs"));
43
- const path_1 = __importDefault(require("path"));
44
- const rfs = __importStar(require("rotating-file-stream"));
45
- const environment_1 = __importDefault(require("../environment"));
46
- const objectStore_1 = require("../objectStore");
47
- const logsFileName = `budibase.log`;
48
- const budibaseLogsHistoryFileName = "budibase-logs-history.txt";
49
- const logsPath = path_1.default.join((0, objectStore_1.budibaseTempDir)(), "systemlogs");
50
- function getFullPath(fileName) {
51
- return path_1.default.join(logsPath, fileName);
52
- }
53
- function getSingleFileMaxSizeInfo(totalMaxSize) {
54
- const regex = /(\d+)([A-Za-z])/;
55
- const match = totalMaxSize === null || totalMaxSize === void 0 ? void 0 : totalMaxSize.match(regex);
56
- if (!match) {
57
- console.warn(`totalMaxSize does not have a valid value`, {
58
- totalMaxSize,
59
- });
60
- return undefined;
61
- }
62
- const size = +match[1];
63
- const unit = match[2];
64
- if (size === 1) {
65
- switch (unit) {
66
- case "B":
67
- return { size: `${size}B`, totalHistoryFiles: 1 };
68
- case "K":
69
- return { size: `${(size * 1000) / 2}B`, totalHistoryFiles: 1 };
70
- case "M":
71
- return { size: `${(size * 1000) / 2}K`, totalHistoryFiles: 1 };
72
- case "G":
73
- return { size: `${(size * 1000) / 2}M`, totalHistoryFiles: 1 };
74
- default:
75
- return undefined;
76
- }
77
- }
78
- if (size % 2 === 0) {
79
- return { size: `${size / 2}${unit}`, totalHistoryFiles: 1 };
80
- }
81
- return { size: `1${unit}`, totalHistoryFiles: size - 1 };
82
- }
83
- function localFileDestination() {
84
- const fileInfo = getSingleFileMaxSizeInfo(environment_1.default.ROLLING_LOG_MAX_SIZE);
85
- const outFile = rfs.createStream(logsFileName, {
86
- // As we have a rolling size, we want to half the max size
87
- size: fileInfo === null || fileInfo === void 0 ? void 0 : fileInfo.size,
88
- path: logsPath,
89
- maxFiles: (fileInfo === null || fileInfo === void 0 ? void 0 : fileInfo.totalHistoryFiles) || 1,
90
- immutable: true,
91
- history: budibaseLogsHistoryFileName,
92
- initialRotation: false,
93
- });
94
- return outFile;
95
- }
96
- function getLogReadStream() {
97
- const streams = [];
98
- const historyFile = getFullPath(budibaseLogsHistoryFileName);
99
- if (fs_1.default.existsSync(historyFile)) {
100
- const fileContent = fs_1.default.readFileSync(historyFile, "utf-8");
101
- const historyFiles = fileContent.split("\n");
102
- for (const historyFile of historyFiles.filter(x => x)) {
103
- streams.push(fs_1.default.readFileSync(historyFile));
104
- }
105
- }
106
- streams.push(fs_1.default.readFileSync(getFullPath(logsFileName)));
107
- const combinedContent = Buffer.concat(streams);
108
- return combinedContent;
109
- }
110
- //# sourceMappingURL=system.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"system.js","sourceRoot":"","sources":["../../../src/logging/system.ts"],"names":[],"mappings":"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"}
@@ -1,19 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- const users_1 = require("../users");
13
- exports.default = (ctx, next) => __awaiter(void 0, void 0, void 0, function* () {
14
- if (!ctx.internal && !(0, users_1.isAdmin)(ctx.user)) {
15
- ctx.throw(403, "Admin user only endpoint.");
16
- }
17
- return next();
18
- });
19
- //# sourceMappingURL=adminOnly.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"adminOnly.js","sourceRoot":"","sources":["../../../src/middleware/adminOnly.ts"],"names":[],"mappings":";;;;;;;;;;;AACA,oCAAkC;AAElC,kBAAe,CAAO,GAAY,EAAE,IAAS,EAAE,EAAE;IAC/C,IAAI,CAAC,GAAG,CAAC,QAAQ,IAAI,CAAC,IAAA,eAAO,EAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;QACxC,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,2BAA2B,CAAC,CAAA;IAC7C,CAAC;IACD,OAAO,IAAI,EAAE,CAAA;AACf,CAAC,CAAA,CAAA"}
@@ -1,18 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- // this middleware exists purely to be overridden by middlewares supplied by the @budibase/pro library
13
- const middleware = ((ctx, next) => __awaiter(void 0, void 0, void 0, function* () {
14
- // Placeholder for audit log middleware
15
- return next();
16
- }));
17
- exports.default = middleware;
18
- //# sourceMappingURL=auditLog.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"auditLog.js","sourceRoot":"","sources":["../../../src/middleware/auditLog.ts"],"names":[],"mappings":";;;;;;;;;;;AAGA,sGAAsG;AACtG,MAAM,UAAU,GAAG,CAAC,CAAO,GAAQ,EAAE,IAAU,EAAE,EAAE;IACjD,uCAAuC;IACvC,OAAO,IAAI,EAAE,CAAA;AACf,CAAC,CAAA,CAAe,CAAA;AAEhB,kBAAe,UAAU,CAAA"}
@@ -1,254 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
36
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
37
- return new (P || (P = Promise))(function (resolve, reject) {
38
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
39
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
40
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
41
- step((generator = generator.apply(thisArg, _arguments || [])).next());
42
- });
43
- };
44
- var __importDefault = (this && this.__importDefault) || function (mod) {
45
- return (mod && mod.__esModule) ? mod : { "default": mod };
46
- };
47
- Object.defineProperty(exports, "__esModule", { value: true });
48
- exports.default = default_1;
49
- const constants_1 = require("../constants");
50
- const utils_1 = require("../utils");
51
- const user_1 = require("../cache/user");
52
- const sessions_1 = require("../security/sessions");
53
- const matchers_1 = require("./matchers");
54
- const db_1 = require("../db");
55
- const context_1 = require("../context");
56
- const encryption_1 = require("../security/encryption");
57
- const identity = __importStar(require("../context/identity"));
58
- const environment_1 = __importDefault(require("../environment"));
59
- const types_1 = require("@budibase/types");
60
- const errors_1 = require("../errors");
61
- const dd_trace_1 = __importDefault(require("dd-trace"));
62
- const ONE_MINUTE = environment_1.default.SESSION_UPDATE_PERIOD
63
- ? parseInt(environment_1.default.SESSION_UPDATE_PERIOD)
64
- : 60 * 1000;
65
- function timeMinusOneMinute() {
66
- return new Date(Date.now() - ONE_MINUTE).toISOString();
67
- }
68
- function finalise(ctx, opts = {}) {
69
- ctx.publicEndpoint = opts.publicEndpoint || false;
70
- ctx.isAuthenticated = opts.authenticated || false;
71
- ctx.loginMethod = opts.loginMethod;
72
- ctx.user = opts.user;
73
- ctx.internal = opts.internal || false;
74
- ctx.version = opts.version;
75
- }
76
- function checkApiKey(apiKey, populateUser) {
77
- return __awaiter(this, void 0, void 0, function* () {
78
- // check both the primary and the fallback internal api keys
79
- // this allows for rotation
80
- if ((0, utils_1.isValidInternalAPIKey)(apiKey)) {
81
- return { valid: true, user: undefined };
82
- }
83
- const decrypted = (0, encryption_1.decrypt)(apiKey);
84
- const tenantId = decrypted.split(db_1.SEPARATOR)[0];
85
- return (0, context_1.doInTenant)(tenantId, () => __awaiter(this, void 0, void 0, function* () {
86
- let userId;
87
- try {
88
- const db = (0, context_1.getGlobalDB)();
89
- // api key is encrypted in the database
90
- userId = (yield (0, db_1.queryGlobalView)(db_1.ViewName.BY_API_KEY, {
91
- key: apiKey,
92
- }, db));
93
- }
94
- catch (err) {
95
- userId = undefined;
96
- }
97
- if (userId) {
98
- return {
99
- valid: true,
100
- user: yield (0, user_1.getUser)({
101
- userId,
102
- tenantId,
103
- populateUser,
104
- }),
105
- };
106
- }
107
- else {
108
- throw new errors_1.InvalidAPIKeyError();
109
- }
110
- }));
111
- });
112
- }
113
- function getHeader(ctx, header) {
114
- const contents = ctx.request.headers[header];
115
- if (Array.isArray(contents)) {
116
- throw new Error("Unexpected header format");
117
- }
118
- return contents;
119
- }
120
- /**
121
- * This middleware is tenancy aware, so that it does not depend on other middlewares being used.
122
- * The tenancy modules should not be used here and it should be assumed that the tenancy context
123
- * has not yet been populated.
124
- */
125
- function default_1(noAuthPatterns = [], opts = {
126
- publicAllowed: false,
127
- }) {
128
- const noAuthOptions = noAuthPatterns ? (0, matchers_1.buildMatcherRegex)(noAuthPatterns) : [];
129
- return ((ctx, next) => __awaiter(this, void 0, void 0, function* () {
130
- let publicEndpoint = false;
131
- const version = getHeader(ctx, constants_1.Header.API_VER);
132
- // the path is not authenticated
133
- const found = (0, matchers_1.matches)(ctx, noAuthOptions);
134
- if (found) {
135
- publicEndpoint = true;
136
- }
137
- try {
138
- // check the actual user is authenticated first, try header or cookie
139
- let headerToken = getHeader(ctx, constants_1.Header.TOKEN);
140
- const authCookie = (0, utils_1.getCookie)(ctx, constants_1.Cookie.Auth) ||
141
- (0, utils_1.openJwt)(headerToken);
142
- let apiKey = getHeader(ctx, constants_1.Header.API_KEY);
143
- if (!apiKey && ctx.request.headers[constants_1.Header.AUTHORIZATION]) {
144
- apiKey = ctx.request.headers[constants_1.Header.AUTHORIZATION].split(" ")[1];
145
- }
146
- const tenantId = getHeader(ctx, constants_1.Header.TENANT_ID);
147
- let authenticated = false, user = undefined, internal = false, loginMethod = undefined;
148
- if (authCookie && !apiKey) {
149
- const sessionId = authCookie.sessionId;
150
- const userId = authCookie.userId;
151
- let session;
152
- try {
153
- // getting session handles error checking (if session exists etc)
154
- session = yield (0, sessions_1.getSession)(userId, sessionId);
155
- if (opts && opts.populateUser) {
156
- user = yield (0, user_1.getUser)({
157
- userId,
158
- tenantId: session.tenantId,
159
- email: session.email,
160
- populateUser: opts.populateUser(ctx),
161
- });
162
- }
163
- else {
164
- user = yield (0, user_1.getUser)({
165
- userId,
166
- tenantId: session.tenantId,
167
- email: session.email,
168
- });
169
- }
170
- // @ts-ignore
171
- user.csrfToken = session.csrfToken;
172
- loginMethod = types_1.LoginMethod.COOKIE;
173
- if ((session === null || session === void 0 ? void 0 : session.lastAccessedAt) < timeMinusOneMinute()) {
174
- // make sure we denote that the session is still in use
175
- yield (0, sessions_1.updateSessionTTL)(session);
176
- }
177
- authenticated = true;
178
- }
179
- catch (err) {
180
- authenticated = false;
181
- console.error(`Auth Error: ${err.message}`);
182
- // remove the cookie as the user does not exist anymore
183
- (0, utils_1.clearCookie)(ctx, constants_1.Cookie.Auth);
184
- }
185
- }
186
- // this is an internal request, no user made it
187
- if (!authenticated && apiKey) {
188
- const populateUser = opts.populateUser ? opts.populateUser(ctx) : null;
189
- const { valid, user: foundUser } = yield checkApiKey(apiKey, populateUser);
190
- if (valid) {
191
- authenticated = true;
192
- loginMethod = types_1.LoginMethod.API_KEY;
193
- user = foundUser;
194
- internal = !foundUser;
195
- }
196
- }
197
- if (!user && tenantId) {
198
- user = { tenantId };
199
- }
200
- else if (user && "password" in user) {
201
- delete user.password;
202
- }
203
- // be explicit
204
- if (!authenticated) {
205
- authenticated = false;
206
- }
207
- const isUser = (user) => {
208
- return user && user.email;
209
- };
210
- if (isUser(user)) {
211
- dd_trace_1.default.setUser({
212
- id: user._id,
213
- tenantId: user.tenantId,
214
- budibaseAccess: user.budibaseAccess,
215
- status: user.status,
216
- });
217
- }
218
- // isAuthenticated is a function, so use a variable to be able to check authed state
219
- finalise(ctx, {
220
- authenticated,
221
- user,
222
- internal,
223
- version,
224
- publicEndpoint,
225
- loginMethod,
226
- });
227
- if (isUser(user)) {
228
- return identity.doInUserContext(user, ctx, next);
229
- }
230
- else {
231
- return next();
232
- }
233
- }
234
- catch (err) {
235
- console.error(`Auth Error: ${err.message}`);
236
- // invalid token, clear the cookie
237
- if ((err === null || err === void 0 ? void 0 : err.name) === "JsonWebTokenError") {
238
- (0, utils_1.clearCookie)(ctx, constants_1.Cookie.Auth);
239
- }
240
- else if ((err === null || err === void 0 ? void 0 : err.code) === errors_1.ErrorCode.INVALID_API_KEY) {
241
- ctx.throw(403, err.message);
242
- }
243
- // allow configuring for public access
244
- if ((opts && opts.publicAllowed) || publicEndpoint) {
245
- finalise(ctx, { authenticated: false, version, publicEndpoint });
246
- return next();
247
- }
248
- else {
249
- ctx.throw(err.status || 403, err);
250
- }
251
- }
252
- }));
253
- }
254
- //# sourceMappingURL=authenticated.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"authenticated.js","sourceRoot":"","sources":["../../../src/middleware/authenticated.ts"],"names":[],"mappings":"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"}
@@ -1,33 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- var __importDefault = (this && this.__importDefault) || function (mod) {
12
- return (mod && mod.__esModule) ? mod : { "default": mod };
13
- };
14
- Object.defineProperty(exports, "__esModule", { value: true });
15
- const users_1 = require("../users");
16
- const context_1 = require("../context");
17
- const environment_1 = __importDefault(require("../environment"));
18
- exports.default = (ctx, next) => __awaiter(void 0, void 0, void 0, function* () {
19
- const appId = (0, context_1.getAppId)();
20
- const builderFn = environment_1.default.isWorker() || !appId
21
- ? users_1.hasBuilderPermissions
22
- : environment_1.default.isApps()
23
- ? users_1.isBuilder
24
- : undefined;
25
- if (!builderFn) {
26
- throw new Error("Service name unknown - middleware inactive.");
27
- }
28
- if (!ctx.internal && !builderFn(ctx.user, appId)) {
29
- ctx.throw(403, "Builder user only endpoint.");
30
- }
31
- return next();
32
- });
33
- //# sourceMappingURL=builderOnly.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"builderOnly.js","sourceRoot":"","sources":["../../../src/middleware/builderOnly.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AACA,oCAA2D;AAC3D,wCAAqC;AACrC,iEAAgC;AAEhC,kBAAe,CAAO,GAAY,EAAE,IAAS,EAAE,EAAE;IAC/C,MAAM,KAAK,GAAG,IAAA,kBAAQ,GAAE,CAAA;IACxB,MAAM,SAAS,GACb,qBAAG,CAAC,QAAQ,EAAE,IAAI,CAAC,KAAK;QACtB,CAAC,CAAC,6BAAqB;QACvB,CAAC,CAAC,qBAAG,CAAC,MAAM,EAAE;YACd,CAAC,CAAC,iBAAS;YACX,CAAC,CAAC,SAAS,CAAA;IACf,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAA;IAChE,CAAC;IACD,IAAI,CAAC,GAAG,CAAC,QAAQ,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,CAAC;QACjD,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,6BAA6B,CAAC,CAAA;IAC/C,CAAC;IACD,OAAO,IAAI,EAAE,CAAA;AACf,CAAC,CAAA,CAAA"}
@@ -1,33 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- var __importDefault = (this && this.__importDefault) || function (mod) {
12
- return (mod && mod.__esModule) ? mod : { "default": mod };
13
- };
14
- Object.defineProperty(exports, "__esModule", { value: true });
15
- const users_1 = require("../users");
16
- const context_1 = require("../context");
17
- const environment_1 = __importDefault(require("../environment"));
18
- exports.default = (ctx, next) => __awaiter(void 0, void 0, void 0, function* () {
19
- const appId = (0, context_1.getAppId)();
20
- const builderFn = environment_1.default.isWorker() || !appId
21
- ? users_1.hasBuilderPermissions
22
- : environment_1.default.isApps()
23
- ? users_1.isBuilder
24
- : undefined;
25
- if (!builderFn) {
26
- throw new Error("Service name unknown - middleware inactive.");
27
- }
28
- if (!ctx.internal && !builderFn(ctx.user, appId) && !(0, users_1.isAdmin)(ctx.user)) {
29
- ctx.throw(403, "Admin/Builder user only endpoint.");
30
- }
31
- return next();
32
- });
33
- //# sourceMappingURL=builderOrAdmin.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"builderOrAdmin.js","sourceRoot":"","sources":["../../../src/middleware/builderOrAdmin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AACA,oCAAoE;AACpE,wCAAqC;AACrC,iEAAgC;AAEhC,kBAAe,CAAO,GAAY,EAAE,IAAS,EAAE,EAAE;IAC/C,MAAM,KAAK,GAAG,IAAA,kBAAQ,GAAE,CAAA;IACxB,MAAM,SAAS,GACb,qBAAG,CAAC,QAAQ,EAAE,IAAI,CAAC,KAAK;QACtB,CAAC,CAAC,6BAAqB;QACvB,CAAC,CAAC,qBAAG,CAAC,MAAM,EAAE;YACd,CAAC,CAAC,iBAAS;YACX,CAAC,CAAC,SAAS,CAAA;IACf,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAA;IAChE,CAAC;IACD,IAAI,CAAC,GAAG,CAAC,QAAQ,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,IAAA,eAAO,EAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;QACvE,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,mCAAmC,CAAC,CAAA;IACrD,CAAC;IACD,OAAO,IAAI,EAAE,CAAA;AACf,CAAC,CAAA,CAAA"}
@@ -1,124 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- var __importDefault = (this && this.__importDefault) || function (mod) {
12
- return (mod && mod.__esModule) ? mod : { "default": mod };
13
- };
14
- Object.defineProperty(exports, "__esModule", { value: true });
15
- exports.contentSecurityPolicy = contentSecurityPolicy;
16
- const crypto_1 = __importDefault(require("crypto"));
17
- const CSP_DIRECTIVES = {
18
- "default-src": ["'self'"],
19
- "script-src": [
20
- "'self'",
21
- "'unsafe-eval'",
22
- "https://*.budibase.net",
23
- "https://cdn.budi.live",
24
- "https://js.intercomcdn.com",
25
- "https://widget.intercom.io",
26
- "https://d2l5prqdbvm3op.cloudfront.net",
27
- "https://us-assets.i.posthog.com",
28
- ],
29
- "style-src": [
30
- "'self'",
31
- "'unsafe-inline'",
32
- "https://cdn.jsdelivr.net",
33
- "https://fonts.googleapis.com",
34
- "https://rsms.me",
35
- "https://maxcdn.bootstrapcdn.com",
36
- ],
37
- "object-src": ["'none'"],
38
- "base-uri": ["'self'"],
39
- "connect-src": [
40
- "'self'",
41
- "https://*.budibase.app",
42
- "https://*.budibaseqa.app",
43
- "https://*.budibase.net",
44
- "https://api-iam.intercom.io",
45
- "https://api-ping.intercom.io",
46
- "https://app.posthog.com",
47
- "https://us.i.posthog.com",
48
- "wss://nexus-websocket-a.intercom.io",
49
- "wss://nexus-websocket-b.intercom.io",
50
- "https://nexus-websocket-a.intercom.io",
51
- "https://nexus-websocket-b.intercom.io",
52
- "https://uploads.intercomcdn.com",
53
- "https://uploads.intercomusercontent.com",
54
- "https://*.amazonaws.com",
55
- "https://*.s3.amazonaws.com",
56
- "https://*.s3.us-east-2.amazonaws.com",
57
- "https://*.s3.us-east-1.amazonaws.com",
58
- "https://*.s3.us-west-1.amazonaws.com",
59
- "https://*.s3.us-west-2.amazonaws.com",
60
- "https://*.s3.af-south-1.amazonaws.com",
61
- "https://*.s3.ap-east-1.amazonaws.com",
62
- "https://*.s3.ap-south-1.amazonaws.com",
63
- "https://*.s3.ap-northeast-2.amazonaws.com",
64
- "https://*.s3.ap-southeast-1.amazonaws.com",
65
- "https://*.s3.ap-southeast-2.amazonaws.com",
66
- "https://*.s3.ap-northeast-1.amazonaws.com",
67
- "https://*.s3.ca-central-1.amazonaws.com",
68
- "https://*.s3.cn-north-1.amazonaws.com",
69
- "https://*.s3.cn-northwest-1.amazonaws.com",
70
- "https://*.s3.eu-central-1.amazonaws.com",
71
- "https://*.s3.eu-west-1.amazonaws.com",
72
- "https://*.s3.eu-west-2.amazonaws.com",
73
- "https://*.s3.eu-south-1.amazonaws.com",
74
- "https://*.s3.eu-west-3.amazonaws.com",
75
- "https://*.s3.eu-north-1.amazonaws.com",
76
- "https://*.s3.sa-east-1.amazonaws.com",
77
- "https://*.s3.me-south-1.amazonaws.com",
78
- "https://*.s3.us-gov-east-1.amazonaws.com",
79
- "https://*.s3.us-gov-west-1.amazonaws.com",
80
- "https://api.github.com",
81
- ],
82
- "font-src": [
83
- "'self'",
84
- "data:",
85
- "https://cdn.jsdelivr.net",
86
- "https://fonts.gstatic.com",
87
- "https://rsms.me",
88
- "https://maxcdn.bootstrapcdn.com",
89
- "https://js.intercomcdn.com",
90
- "https://fonts.intercomcdn.com",
91
- ],
92
- "frame-src": ["'self'", "https:"],
93
- "img-src": ["http:", "https:", "data:", "blob:"],
94
- "manifest-src": ["'self'"],
95
- "media-src": [
96
- "'self'",
97
- "https://js.intercomcdn.com",
98
- "https://cdn.budi.live",
99
- ],
100
- "worker-src": ["blob:"],
101
- };
102
- function contentSecurityPolicy(ctx, next) {
103
- return __awaiter(this, void 0, void 0, function* () {
104
- try {
105
- const nonce = crypto_1.default.randomBytes(16).toString("base64");
106
- const directives = Object.assign({}, CSP_DIRECTIVES);
107
- directives["script-src"] = [
108
- ...CSP_DIRECTIVES["script-src"],
109
- `'nonce-${nonce}'`,
110
- ];
111
- ctx.state.nonce = nonce;
112
- const cspHeader = Object.entries(directives)
113
- .map(([key, sources]) => `${key} ${sources.join(" ")}`)
114
- .join("; ");
115
- ctx.set("Content-Security-Policy", cspHeader);
116
- yield next();
117
- }
118
- catch (err) {
119
- console.error(`Error occurred in Content-Security-Policy middleware: ${err}`);
120
- }
121
- });
122
- }
123
- exports.default = contentSecurityPolicy;
124
- //# sourceMappingURL=contentSecurityPolicy.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"contentSecurityPolicy.js","sourceRoot":"","sources":["../../../src/middleware/contentSecurityPolicy.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAwFA,sDAsBC;AA9GD,oDAA2B;AAE3B,MAAM,cAAc,GAAG;IACrB,aAAa,EAAE,CAAC,QAAQ,CAAC;IACzB,YAAY,EAAE;QACZ,QAAQ;QACR,eAAe;QACf,wBAAwB;QACxB,uBAAuB;QACvB,4BAA4B;QAC5B,4BAA4B;QAC5B,uCAAuC;QACvC,iCAAiC;KAClC;IACD,WAAW,EAAE;QACX,QAAQ;QACR,iBAAiB;QACjB,0BAA0B;QAC1B,8BAA8B;QAC9B,iBAAiB;QACjB,iCAAiC;KAClC;IACD,YAAY,EAAE,CAAC,QAAQ,CAAC;IACxB,UAAU,EAAE,CAAC,QAAQ,CAAC;IACtB,aAAa,EAAE;QACb,QAAQ;QACR,wBAAwB;QACxB,0BAA0B;QAC1B,wBAAwB;QACxB,6BAA6B;QAC7B,8BAA8B;QAC9B,yBAAyB;QACzB,0BAA0B;QAC1B,qCAAqC;QACrC,qCAAqC;QACrC,uCAAuC;QACvC,uCAAuC;QACvC,iCAAiC;QACjC,yCAAyC;QACzC,yBAAyB;QACzB,4BAA4B;QAC5B,sCAAsC;QACtC,sCAAsC;QACtC,sCAAsC;QACtC,sCAAsC;QACtC,uCAAuC;QACvC,sCAAsC;QACtC,uCAAuC;QACvC,2CAA2C;QAC3C,2CAA2C;QAC3C,2CAA2C;QAC3C,2CAA2C;QAC3C,yCAAyC;QACzC,uCAAuC;QACvC,2CAA2C;QAC3C,yCAAyC;QACzC,sCAAsC;QACtC,sCAAsC;QACtC,uCAAuC;QACvC,sCAAsC;QACtC,uCAAuC;QACvC,sCAAsC;QACtC,uCAAuC;QACvC,0CAA0C;QAC1C,0CAA0C;QAC1C,wBAAwB;KACzB;IACD,UAAU,EAAE;QACV,QAAQ;QACR,OAAO;QACP,0BAA0B;QAC1B,2BAA2B;QAC3B,iBAAiB;QACjB,iCAAiC;QACjC,4BAA4B;QAC5B,+BAA+B;KAChC;IACD,WAAW,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IACjC,SAAS,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,OAAO,CAAC;IAChD,cAAc,EAAE,CAAC,QAAQ,CAAC;IAC1B,WAAW,EAAE;QACX,QAAQ;QACR,4BAA4B;QAC5B,uBAAuB;KACxB;IACD,YAAY,EAAE,CAAC,OAAO,CAAC;CACxB,CAAA;AAED,SAAsB,qBAAqB,CAAC,GAAQ,EAAE,IAAS;;QAC7D,IAAI,CAAC;YACH,MAAM,KAAK,GAAG,gBAAM,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAA;YAEvD,MAAM,UAAU,qBAAQ,cAAc,CAAE,CAAA;YACxC,UAAU,CAAC,YAAY,CAAC,GAAG;gBACzB,GAAG,cAAc,CAAC,YAAY,CAAC;gBAC/B,UAAU,KAAK,GAAG;aACnB,CAAA;YAED,GAAG,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAA;YAEvB,MAAM,SAAS,GAAG,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC;iBACzC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,OAAO,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;iBACtD,IAAI,CAAC,IAAI,CAAC,CAAA;YACb,GAAG,CAAC,GAAG,CAAC,yBAAyB,EAAE,SAAS,CAAC,CAAA;YAC7C,MAAM,IAAI,EAAE,CAAA;QACd,CAAC;QAAC,OAAO,GAAQ,EAAE,CAAC;YAClB,OAAO,CAAC,KAAK,CACX,yDAAyD,GAAG,EAAE,CAC/D,CAAA;QACH,CAAC;IACH,CAAC;CAAA;AAED,kBAAe,qBAAqB,CAAA"}