59 lines
1.6 KiB
TypeScript
59 lines
1.6 KiB
TypeScript
import { rowEmission, tableEmission } from "./utils"
|
|
import mainEmitter from "./index"
|
|
import env from "../environment"
|
|
import { Table, Row } from "@budibase/types"
|
|
|
|
// max number of automations that can chain on top of each other
|
|
// TODO: in future make this configurable at the automation level
|
|
const MAX_AUTOMATION_CHAIN = env.SELF_HOSTED ? 5 : 0
|
|
|
|
/**
|
|
* Special emitter which takes the count of automation runs which have occurred and blocks an
|
|
* automation from running if it has reached the maximum number of chained automations runs.
|
|
* This essentially "fakes" the normal emitter to add some functionality in-between to stop automations
|
|
* from getting stuck endlessly chaining.
|
|
*/
|
|
class AutomationEmitter {
|
|
chainCount: number
|
|
metadata: { automationChainCount: number }
|
|
|
|
constructor(chainCount: number) {
|
|
this.chainCount = chainCount
|
|
this.metadata = {
|
|
automationChainCount: chainCount,
|
|
}
|
|
}
|
|
|
|
emitRow(eventName: string, appId: string, row: Row, table?: Table) {
|
|
// don't emit even if we've reached max automation chain
|
|
if (this.chainCount >= MAX_AUTOMATION_CHAIN) {
|
|
return
|
|
}
|
|
rowEmission({
|
|
emitter: mainEmitter,
|
|
eventName,
|
|
appId,
|
|
row,
|
|
table,
|
|
metadata: this.metadata,
|
|
})
|
|
}
|
|
|
|
emitTable(eventName: string, appId: string, table?: Table) {
|
|
// don't emit even if we've reached max automation chain
|
|
if (this.chainCount > MAX_AUTOMATION_CHAIN) {
|
|
return
|
|
}
|
|
|
|
tableEmission({
|
|
emitter: mainEmitter,
|
|
eventName,
|
|
appId,
|
|
table,
|
|
metadata: this.metadata,
|
|
})
|
|
}
|
|
}
|
|
|
|
export default AutomationEmitter
|