[backend] rename repository services and replace repository modules by dynamicModule (#4536)
* rename database services to repository * refactor more repositories * more refactoring * followup * remove unused imports * fix * fix * Fix calendar listener being called when flag is off * remove folders
This commit is contained in:
@ -0,0 +1,33 @@
|
||||
import { CalendarChannelEventAssociationRepository } from 'src/modules/calendar/repositories/calendar-channel-event-association.repository';
|
||||
import { CalendarChannelRepository } from 'src/modules/calendar/repositories/calendar-channel.repository';
|
||||
import { CalendarEventAttendeeRepository } from 'src/modules/calendar/repositories/calendar-event-attendee.repository';
|
||||
import { CalendarEventRepository } from 'src/modules/calendar/repositories/calendar-event.repository';
|
||||
import { CompanyRepository } from 'src/modules/company/repositories/company.repository';
|
||||
import { BlocklistRepository } from 'src/modules/connected-account/repositories/blocklist.repository';
|
||||
import { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
||||
import { MessageChannelMessageAssociationRepository } from 'src/modules/messaging/repositories/message-channel-message-association.repository';
|
||||
import { MessageChannelRepository } from 'src/modules/messaging/repositories/message-channel.repository';
|
||||
import { MessageParticipantRepository } from 'src/modules/messaging/repositories/message-participant.repository';
|
||||
import { MessageThreadRepository } from 'src/modules/messaging/repositories/message-thread.repository';
|
||||
import { MessageRepository } from 'src/modules/messaging/repositories/message.repository';
|
||||
import { PersonRepository } from 'src/modules/person/repositories/person.repository';
|
||||
import { WorkspaceMemberRepository } from 'src/modules/workspace-member/repositories/workspace-member.repository';
|
||||
|
||||
export const metadataToRepositoryMapping = {
|
||||
BlocklistObjectMetadata: BlocklistRepository,
|
||||
CalendarChannelEventAssociationObjectMetadata:
|
||||
CalendarChannelEventAssociationRepository,
|
||||
CalendarChannelObjectMetadata: CalendarChannelRepository,
|
||||
CalendarEventAttendeeObjectMetadata: CalendarEventAttendeeRepository,
|
||||
CalendarEventObjectMetadata: CalendarEventRepository,
|
||||
CompanyObjectMetadata: CompanyRepository,
|
||||
ConnectedAccountObjectMetadata: ConnectedAccountRepository,
|
||||
MessageChannelMessageAssociationObjectMetadata:
|
||||
MessageChannelMessageAssociationRepository,
|
||||
MessageChannelObjectMetadata: MessageChannelRepository,
|
||||
MessageObjectMetadata: MessageRepository,
|
||||
MessageParticipantObjectMetadata: MessageParticipantRepository,
|
||||
MessageThreadObjectMetadata: MessageThreadRepository,
|
||||
PersonObjectMetadata: PersonRepository,
|
||||
WorkspaceMemberObjectMetadata: WorkspaceMemberRepository,
|
||||
};
|
||||
@ -0,0 +1,12 @@
|
||||
import { Inject } from '@nestjs/common';
|
||||
|
||||
import { convertClassNameToObjectMetadataName } from 'src/engine/workspace-manager/workspace-sync-metadata/utils/convert-class-to-object-metadata-name.util';
|
||||
import { capitalize } from 'src/utils/capitalize';
|
||||
|
||||
export const InjectObjectMetadataRepository = (objectMetadata: any) => {
|
||||
const token = `${capitalize(
|
||||
convertClassNameToObjectMetadataName(objectMetadata.name),
|
||||
)}Repository`;
|
||||
|
||||
return Inject(token);
|
||||
};
|
||||
@ -0,0 +1,40 @@
|
||||
import { Global, Module, DynamicModule, Provider } from '@nestjs/common';
|
||||
|
||||
import { metadataToRepositoryMapping } from 'src/engine/object-metadata-repository/metadata-to-repository.mapping';
|
||||
import { WorkspaceDataSourceModule } from 'src/engine/workspace-datasource/workspace-datasource.module';
|
||||
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
||||
import { convertClassNameToObjectMetadataName } from 'src/engine/workspace-manager/workspace-sync-metadata/utils/convert-class-to-object-metadata-name.util';
|
||||
import { capitalize } from 'src/utils/capitalize';
|
||||
|
||||
@Global()
|
||||
@Module({})
|
||||
export class ObjectMetadataRepositoryModule {
|
||||
static forFeature(objectMetadatas): DynamicModule {
|
||||
const providers: Provider[] = objectMetadatas.map((objectMetadata) => {
|
||||
const repositoryClass = metadataToRepositoryMapping[objectMetadata.name];
|
||||
|
||||
if (!repositoryClass) {
|
||||
throw new Error(`No repository found for ${objectMetadata.name}`);
|
||||
}
|
||||
|
||||
return {
|
||||
provide: `${capitalize(
|
||||
convertClassNameToObjectMetadataName(objectMetadata.name),
|
||||
)}Repository`,
|
||||
useFactory: (
|
||||
workspaceDataSourceService: WorkspaceDataSourceService,
|
||||
) => {
|
||||
return new repositoryClass(workspaceDataSourceService);
|
||||
},
|
||||
inject: [WorkspaceDataSourceService],
|
||||
};
|
||||
});
|
||||
|
||||
return {
|
||||
module: ObjectMetadataRepositoryModule,
|
||||
imports: [WorkspaceDataSourceModule],
|
||||
providers: [...providers],
|
||||
exports: providers,
|
||||
};
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user