Move automation creation to sdk
This commit is contained in:
parent
68dea69cc1
commit
373aeac00f
|
@ -1,9 +1,5 @@
|
||||||
import * as triggers from "../../automations/triggers"
|
import * as triggers from "../../automations/triggers"
|
||||||
import {
|
import { getAutomationParams, DocumentType } from "../../db/utils"
|
||||||
getAutomationParams,
|
|
||||||
generateAutomationID,
|
|
||||||
DocumentType,
|
|
||||||
} from "../../db/utils"
|
|
||||||
import {
|
import {
|
||||||
checkForWebhooks,
|
checkForWebhooks,
|
||||||
updateTestHistory,
|
updateTestHistory,
|
||||||
|
@ -76,7 +72,6 @@ function cleanAutomationInputs(automation: Automation) {
|
||||||
export async function create(
|
export async function create(
|
||||||
ctx: UserCtx<Automation, { message: string; automation: Automation }>
|
ctx: UserCtx<Automation, { message: string; automation: Automation }>
|
||||||
) {
|
) {
|
||||||
const db = context.getAppDB()
|
|
||||||
let automation = ctx.request.body
|
let automation = ctx.request.body
|
||||||
automation.appId = ctx.appId
|
automation.appId = ctx.appId
|
||||||
|
|
||||||
|
@ -86,30 +81,12 @@ export async function create(
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// Respect existing IDs if recreating a deleted automation
|
const response = await sdk.automations.create(automation)
|
||||||
if (!automation._id) {
|
|
||||||
automation._id = generateAutomationID()
|
|
||||||
}
|
|
||||||
|
|
||||||
automation.type = "automation"
|
|
||||||
automation = cleanAutomationInputs(automation)
|
|
||||||
automation = await checkForWebhooks({
|
|
||||||
newAuto: automation,
|
|
||||||
})
|
|
||||||
const response = await db.put(automation)
|
|
||||||
await events.automation.created(automation)
|
|
||||||
for (let step of automation.definition.steps) {
|
|
||||||
await events.automation.stepCreated(automation, step)
|
|
||||||
}
|
|
||||||
automation._rev = response.rev
|
|
||||||
|
|
||||||
ctx.status = 200
|
ctx.status = 200
|
||||||
ctx.body = {
|
ctx.body = {
|
||||||
message: "Automation created successfully",
|
message: "Automation created successfully",
|
||||||
automation: {
|
automation: response,
|
||||||
...automation,
|
|
||||||
...response,
|
|
||||||
},
|
|
||||||
}
|
}
|
||||||
builderSocket?.emitAutomationUpdate(ctx, automation)
|
builderSocket?.emitAutomationUpdate(ctx, automation)
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,57 @@
|
||||||
|
import { context, events } from "@budibase/backend-core"
|
||||||
|
import { Automation } from "@budibase/types"
|
||||||
|
import { checkForWebhooks } from "src/automations/utils"
|
||||||
|
import { generateAutomationID } from "src/db/utils"
|
||||||
|
|
||||||
|
function getDb() {
|
||||||
|
return context.getAppDB()
|
||||||
|
}
|
||||||
|
|
||||||
|
function cleanAutomationInputs(automation: Automation) {
|
||||||
|
if (automation == null) {
|
||||||
|
return automation
|
||||||
|
}
|
||||||
|
let steps = automation.definition.steps
|
||||||
|
let trigger = automation.definition.trigger
|
||||||
|
let allSteps = [...steps, trigger]
|
||||||
|
// live is not a property used anymore
|
||||||
|
if (automation.live != null) {
|
||||||
|
delete automation.live
|
||||||
|
}
|
||||||
|
for (let step of allSteps) {
|
||||||
|
if (step == null) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
for (let inputName of Object.keys(step.inputs)) {
|
||||||
|
if (!step.inputs[inputName] || step.inputs[inputName] === "") {
|
||||||
|
delete step.inputs[inputName]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return automation
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function create(automation: Automation) {
|
||||||
|
automation = { ...automation }
|
||||||
|
const db = getDb()
|
||||||
|
|
||||||
|
// Respect existing IDs if recreating a deleted automation
|
||||||
|
if (!automation._id) {
|
||||||
|
automation._id = generateAutomationID()
|
||||||
|
}
|
||||||
|
|
||||||
|
automation.type = "automation"
|
||||||
|
automation = cleanAutomationInputs(automation)
|
||||||
|
automation = await checkForWebhooks({
|
||||||
|
newAuto: automation,
|
||||||
|
})
|
||||||
|
const response = await db.put(automation)
|
||||||
|
await events.automation.created(automation)
|
||||||
|
for (let step of automation.definition.steps) {
|
||||||
|
await events.automation.stepCreated(automation, step)
|
||||||
|
}
|
||||||
|
automation._rev = response.rev
|
||||||
|
automation._id = response.id
|
||||||
|
|
||||||
|
return automation
|
||||||
|
}
|
|
@ -1,7 +1,9 @@
|
||||||
|
import * as crud from "./crud"
|
||||||
import * as webhook from "./webhook"
|
import * as webhook from "./webhook"
|
||||||
import * as utils from "./utils"
|
import * as utils from "./utils"
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
|
...crud,
|
||||||
webhook,
|
webhook,
|
||||||
utils,
|
utils,
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue