2024-07-17 15:53:01 +00:00
|
|
|
import {
|
2025-01-17 13:49:02 +00:00
|
|
|
Check,
|
2024-07-17 15:53:01 +00:00
|
|
|
Column,
|
|
|
|
|
CreateDateColumn,
|
2025-06-03 13:28:43 +00:00
|
|
|
DeleteDateColumn,
|
2024-07-17 15:53:01 +00:00
|
|
|
Entity,
|
2025-06-03 13:28:43 +00:00
|
|
|
Index,
|
2024-07-17 15:53:01 +00:00
|
|
|
PrimaryGeneratedColumn,
|
|
|
|
|
UpdateDateColumn,
|
2025-08-28 12:47:48 +00:00
|
|
|
OneToMany,
|
2024-07-17 15:53:01 +00:00
|
|
|
} from 'typeorm';
|
|
|
|
|
|
2025-02-27 09:39:48 +00:00
|
|
|
import { InputSchema } from 'src/modules/workflow/workflow-builder/workflow-schema/types/input-schema.type';
|
2025-08-28 12:47:48 +00:00
|
|
|
import { CronTrigger } from 'src/engine/metadata-modules/trigger/entities/cron-trigger.entity';
|
2025-08-29 06:11:35 +00:00
|
|
|
import { DatabaseEventTrigger } from 'src/engine/metadata-modules/trigger/entities/database-event-trigger.entity';
|
2024-11-05 13:57:06 +00:00
|
|
|
|
2025-01-17 13:49:02 +00:00
|
|
|
const DEFAULT_SERVERLESS_TIMEOUT_SECONDS = 300; // 5 minutes
|
|
|
|
|
|
2024-07-29 11:03:09 +00:00
|
|
|
export enum ServerlessFunctionRuntime {
|
|
|
|
|
NODE18 = 'nodejs18.x',
|
2025-06-06 16:35:30 +00:00
|
|
|
NODE22 = 'nodejs22.x',
|
2024-07-29 11:03:09 +00:00
|
|
|
}
|
|
|
|
|
|
2024-07-17 15:53:01 +00:00
|
|
|
@Entity('serverlessFunction')
|
2025-06-03 13:28:43 +00:00
|
|
|
@Index('IDX_SERVERLESS_FUNCTION_ID_DELETED_AT', ['id', 'deletedAt'])
|
2024-07-17 15:53:01 +00:00
|
|
|
export class ServerlessFunctionEntity {
|
|
|
|
|
@PrimaryGeneratedColumn('uuid')
|
|
|
|
|
id: string;
|
|
|
|
|
|
|
|
|
|
@Column({ nullable: false })
|
|
|
|
|
name: string;
|
|
|
|
|
|
2024-07-29 11:03:09 +00:00
|
|
|
@Column({ nullable: true })
|
|
|
|
|
description: string;
|
|
|
|
|
|
2024-08-23 10:06:03 +00:00
|
|
|
@Column({ nullable: true })
|
|
|
|
|
latestVersion: string;
|
2024-07-17 15:53:01 +00:00
|
|
|
|
2024-10-22 12:51:03 +00:00
|
|
|
@Column({ nullable: false, type: 'jsonb', default: [] })
|
|
|
|
|
publishedVersions: string[];
|
|
|
|
|
|
2024-11-05 13:57:06 +00:00
|
|
|
@Column({ nullable: true, type: 'jsonb' })
|
2024-11-08 16:15:27 +00:00
|
|
|
latestVersionInputSchema: InputSchema;
|
2024-11-05 13:57:06 +00:00
|
|
|
|
2025-06-06 16:35:30 +00:00
|
|
|
@Column({ nullable: false, default: ServerlessFunctionRuntime.NODE22 })
|
2024-07-29 11:03:09 +00:00
|
|
|
runtime: ServerlessFunctionRuntime;
|
|
|
|
|
|
2025-01-17 13:49:02 +00:00
|
|
|
@Column({ nullable: false, default: DEFAULT_SERVERLESS_TIMEOUT_SECONDS })
|
|
|
|
|
@Check(`"timeoutSeconds" >= 1 AND "timeoutSeconds" <= 900`)
|
|
|
|
|
timeoutSeconds: number;
|
|
|
|
|
|
2024-09-02 13:25:20 +00:00
|
|
|
@Column({ nullable: true })
|
|
|
|
|
layerVersion: number;
|
|
|
|
|
|
2024-07-17 15:53:01 +00:00
|
|
|
@Column({ nullable: false, type: 'uuid' })
|
|
|
|
|
workspaceId: string;
|
|
|
|
|
|
2025-08-28 12:47:48 +00:00
|
|
|
@OneToMany(
|
|
|
|
|
() => CronTrigger,
|
|
|
|
|
(cronTrigger) => cronTrigger.serverlessFunction,
|
|
|
|
|
{
|
|
|
|
|
cascade: true,
|
|
|
|
|
},
|
|
|
|
|
)
|
|
|
|
|
cronTriggers: CronTrigger[];
|
|
|
|
|
|
2025-08-29 06:11:35 +00:00
|
|
|
@OneToMany(
|
|
|
|
|
() => DatabaseEventTrigger,
|
|
|
|
|
(databaseEventTrigger) => databaseEventTrigger.serverlessFunction,
|
|
|
|
|
{
|
|
|
|
|
cascade: true,
|
|
|
|
|
},
|
|
|
|
|
)
|
|
|
|
|
databaseEventTriggers: DatabaseEventTrigger[];
|
|
|
|
|
|
2024-07-17 15:53:01 +00:00
|
|
|
@CreateDateColumn({ type: 'timestamptz' })
|
|
|
|
|
createdAt: Date;
|
|
|
|
|
|
|
|
|
|
@UpdateDateColumn({ type: 'timestamptz' })
|
|
|
|
|
updatedAt: Date;
|
2025-06-03 13:28:43 +00:00
|
|
|
|
|
|
|
|
@DeleteDateColumn({ type: 'timestamptz' })
|
|
|
|
|
deletedAt?: Date;
|
2024-07-17 15:53:01 +00:00
|
|
|
}
|