* wip: refacto and start creating custom resolver * feat: findMany & findUnique of a custom entity * feat: wip pagination * feat: initial metadata migration * feat: universal findAll with pagination * fix: clean small stuff in pagination * fix: test * fix: miss file * feat: rename custom into universal * feat: create metadata schema in default database * Multi-tenant db schemas POC fix tests and use query builders remove synchronize restore updatedAt remove unnecessary import use queryRunner fix camelcase add migrations for standard objects Multi-tenant db schemas POC fix tests and use query builders remove synchronize restore updatedAt remove unnecessary import use queryRunner fix camelcase add migrations for standard objects poc: conditional schema at runtime wip: try to create resolver in Nest.JS context fix * feat: wip add pg_graphql * feat: setup pg_graphql during database init * wip: dynamic resolver * poc: dynamic resolver and query using pg_graphql * feat: pg_graphql use ARG in Dockerfile * feat: clean findMany & findOne dynamic resolver * feat: get correct schema based on access token * fix: remove old file * fix: tests * fix: better comment * fix: e2e test not working, error format change due to yoga * remove typeorm entity generation + fix jwt + fix search_path + remove anon * fix conflict --------- Co-authored-by: Charles Bochet <charles@twenty.com> Co-authored-by: corentin <corentin@twenty.com>
52 lines
1.2 KiB
TypeScript
52 lines
1.2 KiB
TypeScript
import {
|
|
Column,
|
|
CreateDateColumn,
|
|
Entity,
|
|
JoinColumn,
|
|
ManyToOne,
|
|
PrimaryGeneratedColumn,
|
|
UpdateDateColumn,
|
|
} from 'typeorm';
|
|
|
|
import { ObjectMetadata } from 'src/tenant/metadata/object-metadata/object-metadata.entity';
|
|
|
|
@Entity('field_metadata')
|
|
export class FieldMetadata {
|
|
@PrimaryGeneratedColumn('uuid')
|
|
id: string;
|
|
|
|
@Column({ nullable: false, name: 'object_id' })
|
|
objectId: string;
|
|
|
|
@Column({ nullable: false })
|
|
type: string;
|
|
|
|
@Column({ nullable: false, name: 'display_name' })
|
|
displayName: string;
|
|
|
|
@Column({ nullable: false, name: 'target_column_name' })
|
|
targetColumnName: string;
|
|
|
|
@Column('text', { nullable: true, array: true })
|
|
enums: string[];
|
|
|
|
@Column({ default: false, name: 'is_custom' })
|
|
isCustom: boolean;
|
|
|
|
@Column({ nullable: true, default: true, name: 'is_nullable' })
|
|
isNullable: boolean;
|
|
|
|
@Column({ nullable: false, name: 'workspace_id' })
|
|
workspaceId: string;
|
|
|
|
@ManyToOne(() => ObjectMetadata, (object) => object.fields)
|
|
@JoinColumn({ name: 'object_id' })
|
|
object: ObjectMetadata;
|
|
|
|
@CreateDateColumn({ name: 'created_at' })
|
|
createdAt: Date;
|
|
|
|
@UpdateDateColumn({ name: 'updated_at' })
|
|
updatedAt: Date;
|
|
}
|