* Convert metadata tables to camelcase * refactor folder structure * rename datasourcemetadata * regenerate metadata schema * rename dataSourceMetadata to dataSource
58 lines
1.2 KiB
TypeScript
58 lines
1.2 KiB
TypeScript
import { ObjectType, ID, Field, HideField } from '@nestjs/graphql';
|
|
|
|
import { CreateDateColumn, UpdateDateColumn } from 'typeorm';
|
|
import {
|
|
Authorize,
|
|
IDField,
|
|
QueryOptions,
|
|
Relation,
|
|
} from '@ptc-org/nestjs-query-graphql';
|
|
|
|
import { ObjectMetadataDTO } from 'src/metadata/object-metadata/dtos/object-metadata.dto';
|
|
import { RelationMetadataType } from 'src/metadata/relation-metadata/relation-metadata.entity';
|
|
|
|
@ObjectType('relation')
|
|
@Authorize({
|
|
authorize: (context: any) => ({
|
|
workspaceId: { eq: context?.req?.user?.workspace?.id },
|
|
}),
|
|
})
|
|
@QueryOptions({
|
|
defaultResultSize: 10,
|
|
disableFilter: true,
|
|
disableSort: true,
|
|
maxResultsSize: 1000,
|
|
})
|
|
@Relation('fromObjectMetadata', () => ObjectMetadataDTO)
|
|
@Relation('toObjectMetadata', () => ObjectMetadataDTO)
|
|
export class RelationMetadataDTO {
|
|
@IDField(() => ID)
|
|
id: string;
|
|
|
|
@Field()
|
|
relationType: RelationMetadataType;
|
|
|
|
@Field()
|
|
fromObjectMetadataId: string;
|
|
|
|
@Field()
|
|
toObjectMetadataId: string;
|
|
|
|
@Field()
|
|
fromFieldMetadataId: string;
|
|
|
|
@Field()
|
|
toFieldMetadataId: string;
|
|
|
|
@HideField()
|
|
workspaceId: string;
|
|
|
|
@Field()
|
|
@CreateDateColumn()
|
|
createdAt: Date;
|
|
|
|
@Field()
|
|
@UpdateDateColumn()
|
|
updatedAt: Date;
|
|
}
|