In this PR: ## Improve recompute metadata cache performance. We are aiming for ~100ms Deleting relationMetadata table and FKs pointing on it Fetching indexMetadata and indexFieldMetadata in a separate query as typeorm is suboptimizing ## Remove caching lock As recomputing the metadata cache is lighter, we try to stop preventing multiple concurrent computations. This also simplifies interfaces ## Introduce self recovery mecanisms to recompute cache automatically if corrupted Aka getFreshObjectMetadataMaps ## custom object resolver performance improvement: 1sec to 200ms Double check queries and indexes used while creating a custom object Remove the queries to db to use the cached objectMetadataMap ## reduce objectMetadataMaps to 500kb <img width="222" alt="image" src="https://github.com/user-attachments/assets/2370dc80-49b6-4b63-8d5e-30c5ebdaa062" /> We used to stored 3 fieldMetadataMaps (byId, byName, byJoinColumnName). While this is great for devXP, this is not great for performances. Using the same mecanisme as for objectMetadataMap: we only keep byIdMap and introduce two otherMaps to idByName, idByJoinColumnName to make the bridge ## Add dataloader on IndexMetadata (aka indexMetadataList in the API) ## Improve field resolver performances too ## Deprecate ClientConfig
36 lines
1.3 KiB
TypeScript
36 lines
1.3 KiB
TypeScript
import {
|
|
ObjectMetadataException,
|
|
ObjectMetadataExceptionCode,
|
|
} from 'src/engine/metadata-modules/object-metadata/object-metadata.exception';
|
|
import { ObjectMetadataMaps } from 'src/engine/metadata-modules/types/object-metadata-maps';
|
|
|
|
type ValidateNoOtherObjectWithSameNameExistsOrThrowsParams = {
|
|
objectMetadataNameSingular: string;
|
|
objectMetadataNamePlural: string;
|
|
existingObjectMetadataId?: string;
|
|
objectMetadataMaps: ObjectMetadataMaps;
|
|
};
|
|
|
|
export const validatesNoOtherObjectWithSameNameExistsOrThrows = ({
|
|
objectMetadataNameSingular,
|
|
objectMetadataNamePlural,
|
|
existingObjectMetadataId,
|
|
objectMetadataMaps,
|
|
}: ValidateNoOtherObjectWithSameNameExistsOrThrowsParams) => {
|
|
const objectAlreadyExists = Object.values(objectMetadataMaps.byId).find(
|
|
(objectMetadata) =>
|
|
(objectMetadata.nameSingular === objectMetadataNameSingular ||
|
|
objectMetadata.namePlural === objectMetadataNamePlural ||
|
|
objectMetadata.nameSingular === objectMetadataNamePlural ||
|
|
objectMetadata.namePlural === objectMetadataNameSingular) &&
|
|
objectMetadata.id !== existingObjectMetadataId,
|
|
);
|
|
|
|
if (objectAlreadyExists) {
|
|
throw new ObjectMetadataException(
|
|
'Object already exists',
|
|
ObjectMetadataExceptionCode.OBJECT_ALREADY_EXISTS,
|
|
);
|
|
}
|
|
};
|