## Context While deploying the IS_NEW_RELATION_ENABLED (we don't compute relation based on relationMetadata anymore) to existing workspace, I've tested to run a sync-metadata post feature flag activation. This has raised two issues: - the workspaceMigration generator (which is over-complex and should be refactored later) for fieldMetadata of type RELATION was not handling settings update properly ; - we need to delete existing fieldMetadata corresponding to the UUID foreignKey as they are not needed anymore. This is handled as a 0.53 upgrade command as 0.53 will also come with the full removal of the old relation system --------- Co-authored-by: Etienne <45695613+etiennejouan@users.noreply.github.com> Co-authored-by: prastoin <paul@twenty.com>
63 lines
2.1 KiB
TypeScript
63 lines
2.1 KiB
TypeScript
import { FieldMetadataType } from 'twenty-shared/types';
|
|
import { RelationType } from 'typeorm/metadata/types/RelationTypes';
|
|
|
|
import { FieldMetadataInterface } from 'src/engine/metadata-modules/field-metadata/interfaces/field-metadata.interface';
|
|
|
|
import { ObjectMetadataMaps } from 'src/engine/metadata-modules/types/object-metadata-maps';
|
|
import { converRelationTypeToTypeORMRelationType } from 'src/engine/twenty-orm/utils/convert-relation-type-to-typeorm-relation-type.util';
|
|
|
|
interface RelationDetails {
|
|
relationType: RelationType;
|
|
target: string;
|
|
inverseSide: string;
|
|
joinColumn: { name: string } | undefined;
|
|
}
|
|
|
|
export async function determineSchemaRelationDetails(
|
|
fieldMetadata: FieldMetadataInterface<FieldMetadataType.RELATION>,
|
|
objectMetadataMaps: ObjectMetadataMaps,
|
|
): Promise<RelationDetails> {
|
|
if (!fieldMetadata.settings) {
|
|
throw new Error('Field metadata settings are missing');
|
|
}
|
|
|
|
const relationType = converRelationTypeToTypeORMRelationType(
|
|
fieldMetadata.settings.relationType,
|
|
);
|
|
|
|
if (!fieldMetadata.relationTargetObjectMetadataId) {
|
|
throw new Error('Relation target object metadata ID is missing');
|
|
}
|
|
|
|
const sourceObjectMetadata =
|
|
objectMetadataMaps.byId[fieldMetadata.objectMetadataId];
|
|
const targetObjectMetadata =
|
|
objectMetadataMaps.byId[fieldMetadata.relationTargetObjectMetadataId];
|
|
|
|
if (!sourceObjectMetadata || !targetObjectMetadata) {
|
|
throw new Error(`Object metadata not found for field ${fieldMetadata.id}`);
|
|
}
|
|
|
|
if (!fieldMetadata.relationTargetFieldMetadataId) {
|
|
throw new Error('Relation target field metadata ID is missing');
|
|
}
|
|
|
|
const targetFieldMetadata =
|
|
targetObjectMetadata.fieldsById[
|
|
fieldMetadata.relationTargetFieldMetadataId
|
|
];
|
|
|
|
if (!targetFieldMetadata) {
|
|
throw new Error('Target field metadata not found');
|
|
}
|
|
|
|
return {
|
|
relationType,
|
|
target: targetObjectMetadata.nameSingular,
|
|
inverseSide: targetFieldMetadata.name,
|
|
joinColumn: fieldMetadata.settings.joinColumnName
|
|
? { name: fieldMetadata.settings.joinColumnName }
|
|
: undefined,
|
|
};
|
|
}
|