@budibase/server 2.6.19-alpha.1 → 2.6.19-alpha.11

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 (347) hide show
  1. package/.dockerignore +7 -6
  2. package/Dockerfile +16 -8
  3. package/builder/assets/{index.b9eeb2a8.js → index.7a65d631.js} +357 -349
  4. package/builder/assets/{index.07382a47.css → index.ec1c6a1a.css} +2 -2
  5. package/builder/index.html +2 -2
  6. package/client/manifest.json +5229 -0
  7. package/dist/automation.js +32190 -0
  8. package/dist/automation.js.map +7 -0
  9. package/dist/index.js +44363 -13
  10. package/dist/index.js.map +7 -0
  11. package/dist/query.js +24307 -0
  12. package/dist/query.js.map +7 -0
  13. package/jest.config.ts +3 -0
  14. package/nodemon.json +1 -1
  15. package/package.json +29 -13
  16. package/pm2.config.js +1 -1
  17. package/scripts/build.js +48 -0
  18. package/src/api/controllers/datasource.ts +16 -0
  19. package/src/api/controllers/static/index.ts +3 -3
  20. package/src/api/controllers/table/internal.ts +2 -6
  21. package/src/api/controllers/table/utils.ts +32 -1
  22. package/src/api/routes/datasource.ts +5 -0
  23. package/src/api/routes/static.ts +3 -1
  24. package/src/api/routes/tests/datasource.spec.ts +1 -1
  25. package/src/automations/actions.ts +5 -0
  26. package/src/automations/steps/openai.ts +105 -0
  27. package/src/automations/tests/openai.spec.ts +86 -0
  28. package/src/constants/index.ts +17 -16
  29. package/src/db/inMemoryView.ts +3 -1
  30. package/src/environment.ts +2 -0
  31. package/src/integration-test/postgres.spec.ts +47 -4
  32. package/src/integrations/base/sqlTable.ts +0 -1
  33. package/src/integrations/googlesheets.ts +11 -3
  34. package/src/integrations/microsoftSqlServer.ts +18 -2
  35. package/src/integrations/mysql.ts +27 -11
  36. package/src/integrations/oracle.ts +11 -1
  37. package/src/integrations/postgres.ts +27 -10
  38. package/src/integrations/tests/googlesheets.spec.ts +41 -9
  39. package/src/utilities/fileSystem/app.ts +1 -1
  40. package/src/utilities/fileSystem/clientLibrary.ts +8 -3
  41. package/src/utilities/fileSystem/filesystem.ts +3 -1
  42. package/tsconfig.build.json +9 -1
  43. package/tsconfig.json +1 -14
  44. package/dist/api/controllers/analytics.js +0 -46
  45. package/dist/api/controllers/apikeys.js +0 -72
  46. package/dist/api/controllers/application.js +0 -574
  47. package/dist/api/controllers/auth.js +0 -80
  48. package/dist/api/controllers/automation.js +0 -303
  49. package/dist/api/controllers/backup.js +0 -37
  50. package/dist/api/controllers/component.js +0 -59
  51. package/dist/api/controllers/datasource.js +0 -337
  52. package/dist/api/controllers/deploy/Deployment.js +0 -53
  53. package/dist/api/controllers/deploy/index.js +0 -198
  54. package/dist/api/controllers/dev.js +0 -146
  55. package/dist/api/controllers/integration.js +0 -28
  56. package/dist/api/controllers/layout.js +0 -49
  57. package/dist/api/controllers/metadata.js +0 -63
  58. package/dist/api/controllers/migrations.js +0 -29
  59. package/dist/api/controllers/ops.js +0 -40
  60. package/dist/api/controllers/permission.js +0 -162
  61. package/dist/api/controllers/plugin/file.js +0 -24
  62. package/dist/api/controllers/plugin/github.js +0 -69
  63. package/dist/api/controllers/plugin/index.js +0 -112
  64. package/dist/api/controllers/plugin/npm.js +0 -58
  65. package/dist/api/controllers/plugin/uploaders.js +0 -11
  66. package/dist/api/controllers/plugin/url.js +0 -24
  67. package/dist/api/controllers/plugin/utils.js +0 -27
  68. package/dist/api/controllers/public/applications.js +0 -146
  69. package/dist/api/controllers/public/mapping/applications.js +0 -29
  70. package/dist/api/controllers/public/mapping/index.js +0 -11
  71. package/dist/api/controllers/public/mapping/queries.js +0 -36
  72. package/dist/api/controllers/public/mapping/rows.js +0 -24
  73. package/dist/api/controllers/public/mapping/tables.js +0 -23
  74. package/dist/api/controllers/public/mapping/types.js +0 -2
  75. package/dist/api/controllers/public/mapping/users.js +0 -29
  76. package/dist/api/controllers/public/metrics.js +0 -113
  77. package/dist/api/controllers/public/queries.js +0 -58
  78. package/dist/api/controllers/public/rows.js +0 -120
  79. package/dist/api/controllers/public/tables.js +0 -95
  80. package/dist/api/controllers/public/users.js +0 -93
  81. package/dist/api/controllers/public/utils.js +0 -56
  82. package/dist/api/controllers/query/import/index.js +0 -87
  83. package/dist/api/controllers/query/import/sources/base/index.js +0 -75
  84. package/dist/api/controllers/query/import/sources/base/openapi.js +0 -42
  85. package/dist/api/controllers/query/import/sources/curl.js +0 -99
  86. package/dist/api/controllers/query/import/sources/openapi2.js +0 -145
  87. package/dist/api/controllers/query/import/sources/openapi3.js +0 -177
  88. package/dist/api/controllers/query/import/sources/tests/openapi2/data/crud/crud.json +0 -253
  89. package/dist/api/controllers/query/import/sources/tests/openapi2/data/petstore/petstore.json +0 -1054
  90. package/dist/api/controllers/query/import/sources/tests/openapi3/data/crud/crud.json +0 -253
  91. package/dist/api/controllers/query/import/sources/tests/openapi3/data/petstore/petstore.json +0 -1225
  92. package/dist/api/controllers/query/index.js +0 -299
  93. package/dist/api/controllers/query/validation.js +0 -53
  94. package/dist/api/controllers/role.js +0 -109
  95. package/dist/api/controllers/routing.js +0 -105
  96. package/dist/api/controllers/row/ExternalRequest.js +0 -683
  97. package/dist/api/controllers/row/external.js +0 -339
  98. package/dist/api/controllers/row/index.js +0 -203
  99. package/dist/api/controllers/row/internal.js +0 -509
  100. package/dist/api/controllers/row/internalSearch.js +0 -28
  101. package/dist/api/controllers/row/staticFormula.js +0 -165
  102. package/dist/api/controllers/row/utils.js +0 -183
  103. package/dist/api/controllers/screen.js +0 -110
  104. package/dist/api/controllers/script.js +0 -30
  105. package/dist/api/controllers/static/index.js +0 -268
  106. package/dist/api/controllers/table/bulkFormula.js +0 -173
  107. package/dist/api/controllers/table/external.js +0 -279
  108. package/dist/api/controllers/table/index.js +0 -179
  109. package/dist/api/controllers/table/internal.js +0 -197
  110. package/dist/api/controllers/table/utils.js +0 -379
  111. package/dist/api/controllers/templates.js +0 -56
  112. package/dist/api/controllers/user.js +0 -124
  113. package/dist/api/controllers/view/exporters.js +0 -46
  114. package/dist/api/controllers/view/index.js +0 -193
  115. package/dist/api/controllers/view/utils.js +0 -177
  116. package/dist/api/controllers/view/viewBuilder.js +0 -158
  117. package/dist/api/controllers/webhook.js +0 -134
  118. package/dist/api/index.js +0 -55
  119. package/dist/api/routes/analytics.js +0 -34
  120. package/dist/api/routes/apikeys.js +0 -37
  121. package/dist/api/routes/application.js +0 -48
  122. package/dist/api/routes/auth.js +0 -33
  123. package/dist/api/routes/automation.js +0 -50
  124. package/dist/api/routes/backup.js +0 -35
  125. package/dist/api/routes/component.js +0 -35
  126. package/dist/api/routes/datasource.js +0 -44
  127. package/dist/api/routes/deploy.js +0 -37
  128. package/dist/api/routes/dev.js +0 -49
  129. package/dist/api/routes/index.js +0 -75
  130. package/dist/api/routes/integration.js +0 -37
  131. package/dist/api/routes/layout.js +0 -37
  132. package/dist/api/routes/metadata.js +0 -40
  133. package/dist/api/routes/migrations.js +0 -36
  134. package/dist/api/routes/ops.js +0 -52
  135. package/dist/api/routes/permission.js +0 -44
  136. package/dist/api/routes/plugin.js +0 -39
  137. package/dist/api/routes/public/applications.js +0 -174
  138. package/dist/api/routes/public/index.js +0 -140
  139. package/dist/api/routes/public/metrics.js +0 -30
  140. package/dist/api/routes/public/middleware/mapper.js +0 -97
  141. package/dist/api/routes/public/queries.js +0 -72
  142. package/dist/api/routes/public/rows.js +0 -158
  143. package/dist/api/routes/public/tables.js +0 -152
  144. package/dist/api/routes/public/users.js +0 -135
  145. package/dist/api/routes/public/utils/Endpoint.js +0 -36
  146. package/dist/api/routes/query.js +0 -47
  147. package/dist/api/routes/role.js +0 -40
  148. package/dist/api/routes/routing.js +0 -39
  149. package/dist/api/routes/row.js +0 -239
  150. package/dist/api/routes/screen.js +0 -39
  151. package/dist/api/routes/script.js +0 -35
  152. package/dist/api/routes/static.js +0 -80
  153. package/dist/api/routes/table.js +0 -163
  154. package/dist/api/routes/templates.js +0 -37
  155. package/dist/api/routes/user.js +0 -43
  156. package/dist/api/routes/utils/validators.js +0 -238
  157. package/dist/api/routes/view.js +0 -42
  158. package/dist/api/routes/webhook.js +0 -43
  159. package/dist/app.js +0 -132
  160. package/dist/automations/actions.js +0 -137
  161. package/dist/automations/automationUtils.js +0 -173
  162. package/dist/automations/bullboard.js +0 -71
  163. package/dist/automations/index.js +0 -43
  164. package/dist/automations/logging/index.js +0 -53
  165. package/dist/automations/steps/bash.js +0 -111
  166. package/dist/automations/steps/createRow.js +0 -108
  167. package/dist/automations/steps/delay.js +0 -53
  168. package/dist/automations/steps/deleteRow.js +0 -96
  169. package/dist/automations/steps/discord.js +0 -116
  170. package/dist/automations/steps/executeQuery.js +0 -134
  171. package/dist/automations/steps/executeScript.js +0 -106
  172. package/dist/automations/steps/filter.js +0 -112
  173. package/dist/automations/steps/loop.js +0 -54
  174. package/dist/automations/steps/make.js +0 -134
  175. package/dist/automations/steps/outgoingWebhook.js +0 -166
  176. package/dist/automations/steps/queryRows.js +0 -216
  177. package/dist/automations/steps/sendSmtpEmail.js +0 -115
  178. package/dist/automations/steps/serverLog.js +0 -65
  179. package/dist/automations/steps/slack.js +0 -98
  180. package/dist/automations/steps/updateRow.js +0 -144
  181. package/dist/automations/steps/utils.js +0 -56
  182. package/dist/automations/steps/zapier.js +0 -130
  183. package/dist/automations/triggerInfo/app.js +0 -36
  184. package/dist/automations/triggerInfo/cron.js +0 -35
  185. package/dist/automations/triggerInfo/index.js +0 -40
  186. package/dist/automations/triggerInfo/rowDeleted.js +0 -36
  187. package/dist/automations/triggerInfo/rowSaved.js +0 -44
  188. package/dist/automations/triggerInfo/rowUpdated.js +0 -44
  189. package/dist/automations/triggerInfo/webhook.js +0 -40
  190. package/dist/automations/triggers.js +0 -181
  191. package/dist/automations/utils.js +0 -275
  192. package/dist/constants/definitions.js +0 -2
  193. package/dist/constants/index.js +0 -181
  194. package/dist/constants/layouts.js +0 -148
  195. package/dist/constants/screens.js +0 -51
  196. package/dist/db/defaultData/datasource_bb_default.js +0 -574
  197. package/dist/db/defaultData/employeeImport.js +0 -155
  198. package/dist/db/defaultData/expensesImport.js +0 -117
  199. package/dist/db/defaultData/inventoryImport.js +0 -109
  200. package/dist/db/defaultData/jobsImport.js +0 -152
  201. package/dist/db/dynamoClient.js +0 -124
  202. package/dist/db/inMemoryView.js +0 -62
  203. package/dist/db/index.js +0 -43
  204. package/dist/db/linkedRows/LinkController.js +0 -392
  205. package/dist/db/linkedRows/LinkDocument.js +0 -33
  206. package/dist/db/linkedRows/index.js +0 -206
  207. package/dist/db/linkedRows/linkUtils.js +0 -131
  208. package/dist/db/newid.js +0 -7
  209. package/dist/db/utils.js +0 -248
  210. package/dist/db/views/staticViews.js +0 -144
  211. package/dist/ddApm.js +0 -11
  212. package/dist/definitions/automations.js +0 -8
  213. package/dist/definitions/common.js +0 -2
  214. package/dist/definitions/datasource.js +0 -7
  215. package/dist/definitions/openapi.js +0 -6
  216. package/dist/environment.js +0 -109
  217. package/dist/events/AutomationEmitter.js +0 -53
  218. package/dist/events/BudibaseEmitter.js +0 -25
  219. package/dist/events/docUpdates/index.js +0 -17
  220. package/dist/events/docUpdates/processors.js +0 -18
  221. package/dist/events/docUpdates/syncUsers.js +0 -49
  222. package/dist/events/index.js +0 -11
  223. package/dist/events/utils.js +0 -43
  224. package/dist/integrations/airtable.js +0 -173
  225. package/dist/integrations/arangodb.js +0 -119
  226. package/dist/integrations/base/query.js +0 -32
  227. package/dist/integrations/base/sql.js +0 -600
  228. package/dist/integrations/base/sqlTable.js +0 -167
  229. package/dist/integrations/base/types.js +0 -2
  230. package/dist/integrations/couchdb.js +0 -140
  231. package/dist/integrations/dynamodb.js +0 -210
  232. package/dist/integrations/elasticsearch.js +0 -201
  233. package/dist/integrations/firebase.js +0 -189
  234. package/dist/integrations/googlesheets.js +0 -484
  235. package/dist/integrations/index.js +0 -138
  236. package/dist/integrations/microsoftSqlServer.js +0 -289
  237. package/dist/integrations/mongodb.js +0 -630
  238. package/dist/integrations/mysql.js +0 -272
  239. package/dist/integrations/oracle.js +0 -404
  240. package/dist/integrations/postgres.js +0 -319
  241. package/dist/integrations/queries/sql.js +0 -84
  242. package/dist/integrations/redis.js +0 -187
  243. package/dist/integrations/rest.js +0 -400
  244. package/dist/integrations/s3.js +0 -256
  245. package/dist/integrations/snowflake.js +0 -114
  246. package/dist/integrations/utils.js +0 -295
  247. package/dist/middleware/appInfo.js +0 -22
  248. package/dist/middleware/authorized.js +0 -112
  249. package/dist/middleware/builder.js +0 -93
  250. package/dist/middleware/currentapp.js +0 -103
  251. package/dist/middleware/joi-validator.js +0 -43
  252. package/dist/middleware/publicApi.js +0 -25
  253. package/dist/middleware/resourceId.js +0 -59
  254. package/dist/middleware/selfhost.js +0 -24
  255. package/dist/middleware/utils.js +0 -8
  256. package/dist/migrations/functions/appUrls.js +0 -42
  257. package/dist/migrations/functions/backfill/app/automations.js +0 -31
  258. package/dist/migrations/functions/backfill/app/datasources.js +0 -28
  259. package/dist/migrations/functions/backfill/app/layouts.js +0 -33
  260. package/dist/migrations/functions/backfill/app/queries.js +0 -49
  261. package/dist/migrations/functions/backfill/app/roles.js +0 -28
  262. package/dist/migrations/functions/backfill/app/screens.js +0 -28
  263. package/dist/migrations/functions/backfill/app/tables.js +0 -37
  264. package/dist/migrations/functions/backfill/app.js +0 -176
  265. package/dist/migrations/functions/backfill/global/configs.js +0 -67
  266. package/dist/migrations/functions/backfill/global/quotas.js +0 -60
  267. package/dist/migrations/functions/backfill/global/users.js +0 -50
  268. package/dist/migrations/functions/backfill/global.js +0 -205
  269. package/dist/migrations/functions/backfill/index.js +0 -32
  270. package/dist/migrations/functions/backfill/installation.js +0 -80
  271. package/dist/migrations/functions/syncQuotas.js +0 -52
  272. package/dist/migrations/functions/tableSettings.js +0 -130
  273. package/dist/migrations/functions/usageQuotas/index.js +0 -16
  274. package/dist/migrations/functions/usageQuotas/syncApps.js +0 -24
  275. package/dist/migrations/functions/usageQuotas/syncPlugins.js +0 -23
  276. package/dist/migrations/functions/usageQuotas/syncRows.js +0 -33
  277. package/dist/migrations/functions/usageQuotas/syncUsers.js +0 -21
  278. package/dist/migrations/functions/userEmailViewCasing.js +0 -24
  279. package/dist/migrations/index.js +0 -111
  280. package/dist/migrations/tests/helpers.js +0 -72
  281. package/dist/migrations/tests/structures.js +0 -37
  282. package/dist/sdk/app/applications/index.js +0 -28
  283. package/dist/sdk/app/applications/sync.js +0 -164
  284. package/dist/sdk/app/applications/utils.js +0 -21
  285. package/dist/sdk/app/automations/index.js +0 -29
  286. package/dist/sdk/app/automations/webhook.js +0 -54
  287. package/dist/sdk/app/backups/constants.js +0 -6
  288. package/dist/sdk/app/backups/exports.js +0 -160
  289. package/dist/sdk/app/backups/imports.js +0 -170
  290. package/dist/sdk/app/backups/index.js +0 -29
  291. package/dist/sdk/app/backups/statistics.js +0 -73
  292. package/dist/sdk/app/datasources/datasources.js +0 -173
  293. package/dist/sdk/app/datasources/index.js +0 -27
  294. package/dist/sdk/app/queries/index.js +0 -27
  295. package/dist/sdk/app/queries/queries.js +0 -60
  296. package/dist/sdk/app/rows/attachments.js +0 -61
  297. package/dist/sdk/app/rows/index.js +0 -28
  298. package/dist/sdk/app/rows/rows.js +0 -30
  299. package/dist/sdk/app/tables/index.js +0 -65
  300. package/dist/sdk/index.js +0 -27
  301. package/dist/sdk/plugins/index.js +0 -27
  302. package/dist/sdk/plugins/plugins.js +0 -53
  303. package/dist/sdk/users/index.js +0 -27
  304. package/dist/sdk/users/utils.js +0 -87
  305. package/dist/sdk/utils/index.js +0 -29
  306. package/dist/startup.js +0 -158
  307. package/dist/threads/automation.js +0 -450
  308. package/dist/threads/definitions.js +0 -2
  309. package/dist/threads/index.js +0 -140
  310. package/dist/threads/query.js +0 -265
  311. package/dist/threads/utils.js +0 -120
  312. package/dist/tsconfig.build.tsbuildinfo +0 -1
  313. package/dist/utilities/appDirectoryTemplate/package.json +0 -10
  314. package/dist/utilities/budibaseDir.js +0 -5
  315. package/dist/utilities/centralPath.js +0 -27
  316. package/dist/utilities/csv.js +0 -33
  317. package/dist/utilities/fileSystem/app.js +0 -88
  318. package/dist/utilities/fileSystem/clientLibrary.js +0 -138
  319. package/dist/utilities/fileSystem/filesystem.js +0 -180
  320. package/dist/utilities/fileSystem/index.js +0 -21
  321. package/dist/utilities/fileSystem/plugin.js +0 -76
  322. package/dist/utilities/fileSystem/processor.js +0 -34
  323. package/dist/utilities/fileSystem/template.js +0 -47
  324. package/dist/utilities/global.js +0 -149
  325. package/dist/utilities/index.js +0 -143
  326. package/dist/utilities/redis.js +0 -117
  327. package/dist/utilities/retry.js +0 -30
  328. package/dist/utilities/routing/index.js +0 -39
  329. package/dist/utilities/rowProcessor/index.js +0 -282
  330. package/dist/utilities/rowProcessor/map.js +0 -116
  331. package/dist/utilities/rowProcessor/utils.js +0 -87
  332. package/dist/utilities/schema.js +0 -112
  333. package/dist/utilities/scriptRunner.js +0 -26
  334. package/dist/utilities/security.js +0 -57
  335. package/dist/utilities/statusCodes.js +0 -9
  336. package/dist/utilities/usageQuota/rows.js +0 -88
  337. package/dist/utilities/usageQuota/usageQuoteReset.js +0 -16
  338. package/dist/utilities/users.js +0 -57
  339. package/dist/utilities/workerRequests.js +0 -171
  340. package/dist/watch.js +0 -53
  341. package/dist/websockets/client.js +0 -14
  342. package/dist/websockets/grid.js +0 -60
  343. package/dist/websockets/index.js +0 -17
  344. package/dist/websockets/websocket.js +0 -78
  345. /package/dist/{api/controllers/static/templates/BudibaseApp.svelte → BudibaseApp-Y5NZEDTC.svelte} +0 -0
  346. /package/dist/{api/controllers/static/templates/app.hbs → app.hbs} +0 -0
  347. /package/dist/{api/controllers/static/templates/preview.hbs → preview.hbs} +0 -0
@@ -1,134 +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.run = exports.definition = void 0;
16
- const node_fetch_1 = __importDefault(require("node-fetch"));
17
- const utils_1 = require("./utils");
18
- const types_1 = require("@budibase/types");
19
- exports.definition = {
20
- name: "Make Integration",
21
- stepTitle: "Make",
22
- tagline: "Trigger a Make scenario",
23
- description: "Performs a webhook call to Make and gets the response (if configured)",
24
- icon: "ri-shut-down-line",
25
- stepId: types_1.AutomationActionStepId.integromat,
26
- type: types_1.AutomationStepType.ACTION,
27
- internal: false,
28
- inputs: {},
29
- schema: {
30
- inputs: {
31
- properties: {
32
- url: {
33
- type: types_1.AutomationIOType.STRING,
34
- title: "Webhook URL",
35
- },
36
- body: {
37
- type: types_1.AutomationIOType.JSON,
38
- title: "Payload",
39
- },
40
- value1: {
41
- type: types_1.AutomationIOType.STRING,
42
- title: "Input Value 1",
43
- },
44
- value2: {
45
- type: types_1.AutomationIOType.STRING,
46
- title: "Input Value 2",
47
- },
48
- value3: {
49
- type: types_1.AutomationIOType.STRING,
50
- title: "Input Value 3",
51
- },
52
- value4: {
53
- type: types_1.AutomationIOType.STRING,
54
- title: "Input Value 4",
55
- },
56
- value5: {
57
- type: types_1.AutomationIOType.STRING,
58
- title: "Input Value 5",
59
- },
60
- },
61
- required: ["url", "value1", "value2", "value3", "value4", "value5"],
62
- },
63
- outputs: {
64
- properties: {
65
- success: {
66
- type: types_1.AutomationIOType.BOOLEAN,
67
- description: "Whether call was successful",
68
- },
69
- httpStatus: {
70
- type: types_1.AutomationIOType.NUMBER,
71
- description: "The HTTP status code returned",
72
- },
73
- response: {
74
- type: types_1.AutomationIOType.OBJECT,
75
- description: "The webhook response - this can have properties",
76
- },
77
- },
78
- required: ["success", "response"],
79
- },
80
- },
81
- };
82
- function run({ inputs }) {
83
- var _a;
84
- return __awaiter(this, void 0, void 0, function* () {
85
- //TODO - Remove deprecated values 1,2,3,4,5 after November 2023
86
- const { url, value1, value2, value3, value4, value5, body } = inputs;
87
- let payload = {};
88
- try {
89
- payload = (body === null || body === void 0 ? void 0 : body.value) ? JSON.parse(body === null || body === void 0 ? void 0 : body.value) : {};
90
- }
91
- catch (err) {
92
- return {
93
- httpStatus: 400,
94
- response: "Invalid payload JSON",
95
- success: false,
96
- };
97
- }
98
- if (!((_a = url === null || url === void 0 ? void 0 : url.trim()) === null || _a === void 0 ? void 0 : _a.length)) {
99
- return {
100
- httpStatus: 400,
101
- response: "Missing Webhook URL",
102
- success: false,
103
- };
104
- }
105
- let response;
106
- try {
107
- response = yield (0, node_fetch_1.default)(url, {
108
- method: "post",
109
- body: JSON.stringify(Object.assign({ value1,
110
- value2,
111
- value3,
112
- value4,
113
- value5 }, payload)),
114
- headers: {
115
- "Content-Type": "application/json",
116
- },
117
- });
118
- }
119
- catch (err) {
120
- return {
121
- httpStatus: 400,
122
- response: err.message,
123
- success: false,
124
- };
125
- }
126
- const { status, message } = yield (0, utils_1.getFetchResponse)(response);
127
- return {
128
- httpStatus: status,
129
- success: status === 200,
130
- response: message,
131
- };
132
- });
133
- }
134
- exports.run = run;
@@ -1,166 +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 (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
26
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
27
- return new (P || (P = Promise))(function (resolve, reject) {
28
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
29
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
30
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
31
- step((generator = generator.apply(thisArg, _arguments || [])).next());
32
- });
33
- };
34
- var __importDefault = (this && this.__importDefault) || function (mod) {
35
- return (mod && mod.__esModule) ? mod : { "default": mod };
36
- };
37
- Object.defineProperty(exports, "__esModule", { value: true });
38
- exports.run = exports.definition = void 0;
39
- const node_fetch_1 = __importDefault(require("node-fetch"));
40
- const utils_1 = require("./utils");
41
- const automationUtils = __importStar(require("../automationUtils"));
42
- const types_1 = require("@budibase/types");
43
- var RequestType;
44
- (function (RequestType) {
45
- RequestType["POST"] = "POST";
46
- RequestType["GET"] = "GET";
47
- RequestType["PUT"] = "PUT";
48
- RequestType["DELETE"] = "DELETE";
49
- RequestType["PATCH"] = "PATCH";
50
- })(RequestType || (RequestType = {}));
51
- const BODY_REQUESTS = [RequestType.POST, RequestType.PUT, RequestType.PATCH];
52
- /**
53
- * NOTE: this functionality is deprecated - it no longer should be used.
54
- */
55
- exports.definition = {
56
- deprecated: true,
57
- name: "Outgoing webhook",
58
- tagline: "Send a {{inputs.requestMethod}} request",
59
- icon: "Send",
60
- description: "Send a request of specified method to a URL",
61
- type: types_1.AutomationStepType.ACTION,
62
- internal: true,
63
- stepId: types_1.AutomationActionStepId.OUTGOING_WEBHOOK,
64
- inputs: {
65
- requestMethod: "POST",
66
- url: "http://",
67
- requestBody: "{}",
68
- headers: "{}",
69
- },
70
- schema: {
71
- inputs: {
72
- properties: {
73
- requestMethod: {
74
- type: types_1.AutomationIOType.STRING,
75
- enum: Object.values(RequestType),
76
- title: "Request method",
77
- },
78
- url: {
79
- type: types_1.AutomationIOType.STRING,
80
- title: "URL",
81
- },
82
- requestBody: {
83
- type: types_1.AutomationIOType.STRING,
84
- title: "JSON Body",
85
- customType: types_1.AutomationCustomIOType.WIDE,
86
- },
87
- headers: {
88
- type: types_1.AutomationIOType.STRING,
89
- title: "Headers",
90
- customType: types_1.AutomationCustomIOType.WIDE,
91
- },
92
- },
93
- required: ["requestMethod", "url"],
94
- },
95
- outputs: {
96
- properties: {
97
- response: {
98
- type: types_1.AutomationIOType.OBJECT,
99
- description: "The response from the webhook",
100
- },
101
- httpStatus: {
102
- type: types_1.AutomationIOType.NUMBER,
103
- description: "The HTTP status code returned",
104
- },
105
- success: {
106
- type: types_1.AutomationIOType.BOOLEAN,
107
- description: "Whether the action was successful",
108
- },
109
- },
110
- required: ["response", "success"],
111
- },
112
- },
113
- };
114
- function run({ inputs }) {
115
- return __awaiter(this, void 0, void 0, function* () {
116
- let { requestMethod, url, requestBody, headers } = inputs;
117
- if (!url.startsWith("http")) {
118
- url = `http://${url}`;
119
- }
120
- const request = {
121
- method: requestMethod,
122
- };
123
- if (headers) {
124
- try {
125
- const customHeaders = typeof headers === "string" ? JSON.parse(headers) : headers;
126
- request.headers = Object.assign(Object.assign({}, request.headers), customHeaders);
127
- }
128
- catch (err) {
129
- return {
130
- success: false,
131
- response: "Unable to process headers, must be a JSON object.",
132
- };
133
- }
134
- }
135
- if (requestBody &&
136
- requestBody.length !== 0 &&
137
- BODY_REQUESTS.indexOf(requestMethod) !== -1) {
138
- request.body =
139
- typeof requestBody === "string"
140
- ? requestBody
141
- : JSON.stringify(requestBody);
142
- request.headers = Object.assign(Object.assign({}, request.headers), { "Content-Type": "application/json" });
143
- }
144
- try {
145
- // do a quick JSON parse if there is a body, to generate an error if its invalid
146
- if (request.body) {
147
- JSON.parse(request.body);
148
- }
149
- const response = yield (0, node_fetch_1.default)(url, request);
150
- const { status, message } = yield (0, utils_1.getFetchResponse)(response);
151
- return {
152
- httpStatus: status,
153
- response: message,
154
- success: status >= 200 && status <= 206,
155
- };
156
- }
157
- catch (err) {
158
- /* istanbul ignore next */
159
- return {
160
- success: false,
161
- response: automationUtils.getError(err),
162
- };
163
- }
164
- });
165
- }
166
- exports.run = run;
@@ -1,216 +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 (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
26
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
27
- return new (P || (P = Promise))(function (resolve, reject) {
28
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
29
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
30
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
31
- step((generator = generator.apply(thisArg, _arguments || [])).next());
32
- });
33
- };
34
- Object.defineProperty(exports, "__esModule", { value: true });
35
- exports.run = exports.definition = void 0;
36
- const rowController = __importStar(require("../../api/controllers/row"));
37
- const tableController = __importStar(require("../../api/controllers/table"));
38
- const constants_1 = require("../../constants");
39
- const utils_1 = require("./utils");
40
- const automationUtils = __importStar(require("../automationUtils"));
41
- const types_1 = require("@budibase/types");
42
- var SortOrder;
43
- (function (SortOrder) {
44
- SortOrder["ASCENDING"] = "ascending";
45
- SortOrder["DESCENDING"] = "descending";
46
- })(SortOrder || (SortOrder = {}));
47
- const SortOrderPretty = {
48
- [SortOrder.ASCENDING]: "Ascending",
49
- [SortOrder.DESCENDING]: "Descending",
50
- };
51
- var EmptyFilterOption;
52
- (function (EmptyFilterOption) {
53
- EmptyFilterOption["RETURN_ALL"] = "all";
54
- EmptyFilterOption["RETURN_NONE"] = "none";
55
- })(EmptyFilterOption || (EmptyFilterOption = {}));
56
- const EmptyFilterOptionPretty = {
57
- [EmptyFilterOption.RETURN_ALL]: "Return all table rows",
58
- [EmptyFilterOption.RETURN_NONE]: "Return no rows",
59
- };
60
- exports.definition = {
61
- description: "Query rows from the database",
62
- icon: "Search",
63
- name: "Query rows",
64
- tagline: "Query rows from {{inputs.enriched.table.name}} table",
65
- type: types_1.AutomationStepType.ACTION,
66
- stepId: types_1.AutomationActionStepId.QUERY_ROWS,
67
- internal: true,
68
- inputs: {},
69
- schema: {
70
- inputs: {
71
- properties: {
72
- tableId: {
73
- type: types_1.AutomationIOType.STRING,
74
- customType: types_1.AutomationCustomIOType.TABLE,
75
- title: "Table",
76
- },
77
- filters: {
78
- type: types_1.AutomationIOType.OBJECT,
79
- customType: types_1.AutomationCustomIOType.FILTERS,
80
- title: "Filtering",
81
- },
82
- sortColumn: {
83
- type: types_1.AutomationIOType.STRING,
84
- title: "Sort Column",
85
- customType: types_1.AutomationCustomIOType.COLUMN,
86
- },
87
- sortOrder: {
88
- type: types_1.AutomationIOType.STRING,
89
- title: "Sort Order",
90
- enum: Object.values(SortOrder),
91
- pretty: Object.values(SortOrderPretty),
92
- },
93
- limit: {
94
- type: types_1.AutomationIOType.NUMBER,
95
- title: "Limit",
96
- customType: types_1.AutomationCustomIOType.QUERY_LIMIT,
97
- },
98
- onEmptyFilter: {
99
- pretty: Object.values(EmptyFilterOptionPretty),
100
- enum: Object.values(EmptyFilterOption),
101
- type: types_1.AutomationIOType.STRING,
102
- title: "When Filter Empty",
103
- },
104
- },
105
- required: ["tableId"],
106
- },
107
- outputs: {
108
- properties: {
109
- rows: {
110
- type: types_1.AutomationIOType.ARRAY,
111
- customType: types_1.AutomationCustomIOType.ROWS,
112
- description: "The rows that were found",
113
- },
114
- success: {
115
- type: types_1.AutomationIOType.BOOLEAN,
116
- description: "Whether the query was successful",
117
- },
118
- },
119
- required: ["rows", "success"],
120
- },
121
- },
122
- };
123
- function getTable(appId, tableId) {
124
- return __awaiter(this, void 0, void 0, function* () {
125
- const ctx = (0, utils_1.buildCtx)(appId, null, {
126
- params: {
127
- tableId,
128
- },
129
- });
130
- yield tableController.find(ctx);
131
- return ctx.body;
132
- });
133
- }
134
- function typeCoercion(filters, table) {
135
- if (!filters || !table) {
136
- return filters;
137
- }
138
- for (let key of Object.keys(filters)) {
139
- // @ts-ignore
140
- const searchParam = filters[key];
141
- if (typeof searchParam === "object") {
142
- for (let [property, value] of Object.entries(searchParam)) {
143
- const column = table.schema[property];
144
- // convert string inputs
145
- if (!column || typeof value !== "string") {
146
- continue;
147
- }
148
- if (column.type === constants_1.FieldTypes.NUMBER) {
149
- searchParam[property] = parseFloat(value);
150
- }
151
- }
152
- }
153
- }
154
- return filters;
155
- }
156
- function hasNullFilters(filters) {
157
- return (filters.length === 0 ||
158
- filters.some(filter => filter.value === null || filter.value === ""));
159
- }
160
- function run({ inputs, appId }) {
161
- return __awaiter(this, void 0, void 0, function* () {
162
- const { tableId, filters, sortColumn, sortOrder, limit } = inputs;
163
- if (!tableId) {
164
- return {
165
- success: false,
166
- response: {
167
- message: "You must select a table to query.",
168
- },
169
- };
170
- }
171
- const table = yield getTable(appId, tableId);
172
- let sortType = constants_1.FieldTypes.STRING;
173
- if (table && table.schema && table.schema[sortColumn] && sortColumn) {
174
- const fieldType = table.schema[sortColumn].type;
175
- sortType =
176
- fieldType === constants_1.FieldTypes.NUMBER ? constants_1.FieldTypes.NUMBER : constants_1.FieldTypes.STRING;
177
- }
178
- const ctx = (0, utils_1.buildCtx)(appId, null, {
179
- params: {
180
- tableId,
181
- },
182
- body: {
183
- sortType,
184
- limit,
185
- sort: sortColumn,
186
- query: typeCoercion(filters || {}, table),
187
- // default to ascending, like data tab
188
- sortOrder: sortOrder || SortOrder.ASCENDING,
189
- },
190
- version: "1",
191
- });
192
- try {
193
- let rows;
194
- if (inputs.onEmptyFilter === EmptyFilterOption.RETURN_NONE &&
195
- inputs["filters-def"] &&
196
- hasNullFilters(inputs["filters-def"])) {
197
- rows = [];
198
- }
199
- else {
200
- yield rowController.search(ctx);
201
- rows = ctx.body ? ctx.body.rows : [];
202
- }
203
- return {
204
- rows,
205
- success: ctx.status === 200,
206
- };
207
- }
208
- catch (err) {
209
- return {
210
- success: false,
211
- response: automationUtils.getError(err),
212
- };
213
- }
214
- });
215
- }
216
- exports.run = run;
@@ -1,115 +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 (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
26
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
27
- return new (P || (P = Promise))(function (resolve, reject) {
28
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
29
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
30
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
31
- step((generator = generator.apply(thisArg, _arguments || [])).next());
32
- });
33
- };
34
- Object.defineProperty(exports, "__esModule", { value: true });
35
- exports.run = exports.definition = void 0;
36
- const workerRequests_1 = require("../../utilities/workerRequests");
37
- const automationUtils = __importStar(require("../automationUtils"));
38
- const types_1 = require("@budibase/types");
39
- exports.definition = {
40
- description: "Send an email using SMTP",
41
- tagline: "Send SMTP email to {{inputs.to}}",
42
- icon: "Email",
43
- name: "Send Email (SMTP)",
44
- type: types_1.AutomationStepType.ACTION,
45
- internal: true,
46
- stepId: types_1.AutomationActionStepId.SEND_EMAIL_SMTP,
47
- inputs: {},
48
- schema: {
49
- inputs: {
50
- properties: {
51
- to: {
52
- type: types_1.AutomationIOType.STRING,
53
- title: "Send To",
54
- },
55
- from: {
56
- type: types_1.AutomationIOType.STRING,
57
- title: "Send From",
58
- },
59
- cc: {
60
- type: types_1.AutomationIOType.STRING,
61
- title: "CC",
62
- },
63
- bcc: {
64
- type: types_1.AutomationIOType.STRING,
65
- title: "BCC",
66
- },
67
- subject: {
68
- type: types_1.AutomationIOType.STRING,
69
- title: "Email Subject",
70
- },
71
- contents: {
72
- type: types_1.AutomationIOType.STRING,
73
- title: "HTML Contents",
74
- },
75
- },
76
- required: ["to", "from", "subject", "contents"],
77
- },
78
- outputs: {
79
- properties: {
80
- success: {
81
- type: types_1.AutomationIOType.BOOLEAN,
82
- description: "Whether the email was sent",
83
- },
84
- response: {
85
- type: types_1.AutomationIOType.OBJECT,
86
- description: "A response from the email client, this may be an error",
87
- },
88
- },
89
- required: ["success"],
90
- },
91
- },
92
- };
93
- function run({ inputs }) {
94
- return __awaiter(this, void 0, void 0, function* () {
95
- let { to, from, subject, contents, cc, bcc } = inputs;
96
- if (!contents) {
97
- contents = "<h1>No content</h1>";
98
- }
99
- to = to || undefined;
100
- try {
101
- let response = yield (0, workerRequests_1.sendSmtpEmail)(to, from, subject, contents, cc, bcc, true);
102
- return {
103
- success: true,
104
- response,
105
- };
106
- }
107
- catch (err) {
108
- return {
109
- success: false,
110
- response: automationUtils.getError(err),
111
- };
112
- }
113
- });
114
- }
115
- exports.run = run;
@@ -1,65 +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
- exports.run = exports.definition = void 0;
13
- const types_1 = require("@budibase/types");
14
- /**
15
- * Note, there is some functionality in this that is not currently exposed as it
16
- * is complex and maybe better to be opinionated here.
17
- * GET/DELETE requests cannot handle body elements so they will not be sent if configured.
18
- */
19
- exports.definition = {
20
- name: "Backend log",
21
- tagline: "Console log a value in the backend",
22
- icon: "Monitoring",
23
- description: "Logs the given text to the server (using console.log)",
24
- type: types_1.AutomationStepType.ACTION,
25
- internal: true,
26
- stepId: types_1.AutomationActionStepId.SERVER_LOG,
27
- inputs: {
28
- text: "",
29
- },
30
- schema: {
31
- inputs: {
32
- properties: {
33
- text: {
34
- type: types_1.AutomationIOType.STRING,
35
- title: "Log",
36
- },
37
- },
38
- required: ["text"],
39
- },
40
- outputs: {
41
- properties: {
42
- success: {
43
- type: types_1.AutomationIOType.BOOLEAN,
44
- description: "Whether the action was successful",
45
- },
46
- message: {
47
- type: types_1.AutomationIOType.STRING,
48
- description: "What was output",
49
- },
50
- },
51
- required: ["success", "message"],
52
- },
53
- },
54
- };
55
- function run({ inputs, appId }) {
56
- return __awaiter(this, void 0, void 0, function* () {
57
- const message = `App ${appId} - ${inputs.text}`;
58
- console.log(message);
59
- return {
60
- success: true,
61
- message,
62
- };
63
- });
64
- }
65
- exports.run = run;