Files
n8n_Demo/n8n-n8n-1.109.2/packages/@n8n/db/src/entities/abstract-entity.ts
2025-09-08 04:48:28 +08:00

85 lines
2.0 KiB
TypeScript
Executable File

import { GlobalConfig } from '@n8n/config';
import { Container } from '@n8n/di';
import type { ColumnOptions } from '@n8n/typeorm';
import {
BeforeInsert,
BeforeUpdate,
Column,
CreateDateColumn,
PrimaryColumn,
UpdateDateColumn,
} from '@n8n/typeorm';
import type { Class } from 'n8n-core';
import { generateNanoId } from '../utils/generators';
export const { type: dbType } = Container.get(GlobalConfig).database;
const timestampSyntax = {
sqlite: "STRFTIME('%Y-%m-%d %H:%M:%f', 'NOW')",
postgresdb: 'CURRENT_TIMESTAMP(3)',
mysqldb: 'CURRENT_TIMESTAMP(3)',
mariadb: 'CURRENT_TIMESTAMP(3)',
}[dbType];
export const jsonColumnType = dbType === 'sqlite' ? 'simple-json' : 'json';
export const datetimeColumnType = dbType === 'postgresdb' ? 'timestamptz' : 'datetime';
export function JsonColumn(options?: Omit<ColumnOptions, 'type'>) {
return Column({
...options,
type: jsonColumnType,
});
}
export function DateTimeColumn(options?: Omit<ColumnOptions, 'type'>) {
return Column({
...options,
type: datetimeColumnType,
});
}
const tsColumnOptions: ColumnOptions = {
precision: 3,
default: () => timestampSyntax,
type: datetimeColumnType,
};
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function mixinStringId<T extends Class<{}, any[]>>(base: T) {
class Derived extends base {
@PrimaryColumn('varchar')
id: string;
@BeforeInsert()
generateId() {
if (!this.id) {
this.id = generateNanoId();
}
}
}
return Derived;
}
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function mixinTimestamps<T extends Class<{}, any[]>>(base: T) {
class Derived extends base {
@CreateDateColumn(tsColumnOptions)
createdAt: Date;
@UpdateDateColumn(tsColumnOptions)
updatedAt: Date;
@BeforeUpdate()
setUpdateDate(): void {
this.updatedAt = new Date();
}
}
return Derived;
}
class BaseEntity {}
export const WithStringId = mixinStringId(BaseEntity);
export const WithTimestamps = mixinTimestamps(BaseEntity);
export const WithTimestampsAndStringId = mixinStringId(WithTimestamps);