Was looking into the Twenty ORM files and caught a camelCase typo which is `workspaceEntityOrobjectMetadataName` to `workspaceEntityOrObjectMetadataName` in two files 1. twenty-orm.manager.ts 2. twenty-orm-global.manager.ts Co-authored-by: Raphaël Bosi <71827178+bosiraphael@users.noreply.github.com>
86 lines
2.6 KiB
TypeScript
86 lines
2.6 KiB
TypeScript
import { Injectable, Type } from '@nestjs/common';
|
|
|
|
import { ObjectLiteral } from 'typeorm';
|
|
|
|
import { WorkspaceDatasourceFactory } from 'src/engine/twenty-orm/factories/workspace-datasource.factory';
|
|
import { WorkspaceRepository } from 'src/engine/twenty-orm/repository/workspace.repository';
|
|
import { convertClassNameToObjectMetadataName } from 'src/engine/workspace-manager/workspace-sync-metadata/utils/convert-class-to-object-metadata-name.util';
|
|
|
|
@Injectable()
|
|
export class TwentyORMGlobalManager {
|
|
constructor(
|
|
private readonly workspaceDataSourceFactory: WorkspaceDatasourceFactory,
|
|
) {}
|
|
|
|
async getRepositoryForWorkspace<T extends ObjectLiteral>(
|
|
workspaceId: string,
|
|
workspaceEntity: Type<T>,
|
|
options?: {
|
|
shouldBypassPermissionChecks?: boolean;
|
|
shouldFailIfMetadataNotFound?: boolean;
|
|
},
|
|
): Promise<WorkspaceRepository<T>>;
|
|
|
|
async getRepositoryForWorkspace<T extends ObjectLiteral>(
|
|
workspaceId: string,
|
|
objectMetadataName: string,
|
|
options?: {
|
|
shouldBypassPermissionChecks?: boolean;
|
|
shouldFailIfMetadataNotFound?: boolean;
|
|
},
|
|
): Promise<WorkspaceRepository<T>>;
|
|
|
|
async getRepositoryForWorkspace<T extends ObjectLiteral>(
|
|
workspaceId: string,
|
|
workspaceEntityOrObjectMetadataName: Type<T> | string,
|
|
options: {
|
|
shouldBypassPermissionChecks?: boolean;
|
|
shouldFailIfMetadataNotFound?: boolean;
|
|
} = {
|
|
shouldBypassPermissionChecks: false,
|
|
shouldFailIfMetadataNotFound: true,
|
|
},
|
|
): Promise<WorkspaceRepository<T>> {
|
|
let objectMetadataName: string;
|
|
|
|
if (typeof workspaceEntityOrObjectMetadataName === 'string') {
|
|
objectMetadataName = workspaceEntityOrObjectMetadataName;
|
|
} else {
|
|
objectMetadataName = convertClassNameToObjectMetadataName(
|
|
workspaceEntityOrObjectMetadataName.name,
|
|
);
|
|
}
|
|
|
|
const workspaceDataSource = await this.workspaceDataSourceFactory.create(
|
|
workspaceId,
|
|
null,
|
|
options.shouldFailIfMetadataNotFound,
|
|
);
|
|
|
|
const repository = workspaceDataSource.getRepository<T>(
|
|
objectMetadataName,
|
|
options.shouldBypassPermissionChecks,
|
|
);
|
|
|
|
return repository;
|
|
}
|
|
|
|
async getDataSourceForWorkspace({
|
|
workspaceId,
|
|
shouldFailIfMetadataNotFound = true,
|
|
}: {
|
|
workspaceId: string;
|
|
shouldFailIfMetadataNotFound?: boolean;
|
|
}) {
|
|
return await this.workspaceDataSourceFactory.create(
|
|
workspaceId,
|
|
null,
|
|
shouldFailIfMetadataNotFound,
|
|
);
|
|
}
|
|
|
|
async destroyDataSourceForWorkspace(workspaceId: string) {
|
|
await this.workspaceDataSourceFactory.destroy(workspaceId);
|
|
}
|
|
}
|