mirror of
https://github.com/lingble/twenty.git
synced 2025-11-01 13:17:57 +00:00
6694 remove raw queries from connected account (#7101)
Closes #6694 --------- Co-authored-by: Charles Bochet <charles@twenty.com>
This commit is contained in:
@@ -24,11 +24,9 @@ import { UserModule } from 'src/engine/core-modules/user/user.module';
|
|||||||
import { Workspace } from 'src/engine/core-modules/workspace/workspace.entity';
|
import { Workspace } from 'src/engine/core-modules/workspace/workspace.entity';
|
||||||
import { WorkspaceModule } from 'src/engine/core-modules/workspace/workspace.module';
|
import { WorkspaceModule } from 'src/engine/core-modules/workspace/workspace.module';
|
||||||
import { DataSourceModule } from 'src/engine/metadata-modules/data-source/data-source.module';
|
import { DataSourceModule } from 'src/engine/metadata-modules/data-source/data-source.module';
|
||||||
import { ObjectMetadataRepositoryModule } from 'src/engine/object-metadata-repository/object-metadata-repository.module';
|
|
||||||
import { WorkspaceDataSourceModule } from 'src/engine/workspace-datasource/workspace-datasource.module';
|
import { WorkspaceDataSourceModule } from 'src/engine/workspace-datasource/workspace-datasource.module';
|
||||||
import { WorkspaceManagerModule } from 'src/engine/workspace-manager/workspace-manager.module';
|
import { WorkspaceManagerModule } from 'src/engine/workspace-manager/workspace-manager.module';
|
||||||
import { ConnectedAccountModule } from 'src/modules/connected-account/connected-account.module';
|
import { ConnectedAccountModule } from 'src/modules/connected-account/connected-account.module';
|
||||||
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
|
||||||
|
|
||||||
import { AuthResolver } from './auth.resolver';
|
import { AuthResolver } from './auth.resolver';
|
||||||
|
|
||||||
@@ -47,9 +45,6 @@ import { JwtAuthStrategy } from './strategies/jwt.auth.strategy';
|
|||||||
[Workspace, User, AppToken, FeatureFlagEntity],
|
[Workspace, User, AppToken, FeatureFlagEntity],
|
||||||
'core',
|
'core',
|
||||||
),
|
),
|
||||||
ObjectMetadataRepositoryModule.forFeature([
|
|
||||||
ConnectedAccountWorkspaceEntity,
|
|
||||||
]),
|
|
||||||
HttpModule,
|
HttpModule,
|
||||||
TokenModule,
|
TokenModule,
|
||||||
UserWorkspaceModule,
|
UserWorkspaceModule,
|
||||||
|
|||||||
@@ -7,7 +7,6 @@ import { EnvironmentService } from 'src/engine/core-modules/environment/environm
|
|||||||
import { InjectMessageQueue } from 'src/engine/core-modules/message-queue/decorators/message-queue.decorator';
|
import { InjectMessageQueue } from 'src/engine/core-modules/message-queue/decorators/message-queue.decorator';
|
||||||
import { MessageQueue } from 'src/engine/core-modules/message-queue/message-queue.constants';
|
import { MessageQueue } from 'src/engine/core-modules/message-queue/message-queue.constants';
|
||||||
import { MessageQueueService } from 'src/engine/core-modules/message-queue/services/message-queue.service';
|
import { MessageQueueService } from 'src/engine/core-modules/message-queue/services/message-queue.service';
|
||||||
import { InjectObjectMetadataRepository } from 'src/engine/object-metadata-repository/object-metadata-repository.decorator';
|
|
||||||
import { TwentyORMGlobalManager } from 'src/engine/twenty-orm/twenty-orm-global.manager';
|
import { TwentyORMGlobalManager } from 'src/engine/twenty-orm/twenty-orm-global.manager';
|
||||||
import {
|
import {
|
||||||
CalendarEventListFetchJob,
|
CalendarEventListFetchJob,
|
||||||
@@ -17,7 +16,6 @@ import {
|
|||||||
CalendarChannelVisibility,
|
CalendarChannelVisibility,
|
||||||
CalendarChannelWorkspaceEntity,
|
CalendarChannelWorkspaceEntity,
|
||||||
} from 'src/modules/calendar/common/standard-objects/calendar-channel.workspace-entity';
|
} from 'src/modules/calendar/common/standard-objects/calendar-channel.workspace-entity';
|
||||||
import { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
|
||||||
import { AccountsToReconnectService } from 'src/modules/connected-account/services/accounts-to-reconnect.service';
|
import { AccountsToReconnectService } from 'src/modules/connected-account/services/accounts-to-reconnect.service';
|
||||||
import {
|
import {
|
||||||
ConnectedAccountProvider,
|
ConnectedAccountProvider,
|
||||||
@@ -45,8 +43,6 @@ export class GoogleAPIsService {
|
|||||||
@InjectMessageQueue(MessageQueue.calendarQueue)
|
@InjectMessageQueue(MessageQueue.calendarQueue)
|
||||||
private readonly calendarQueueService: MessageQueueService,
|
private readonly calendarQueueService: MessageQueueService,
|
||||||
private readonly environmentService: EnvironmentService,
|
private readonly environmentService: EnvironmentService,
|
||||||
@InjectObjectMetadataRepository(ConnectedAccountWorkspaceEntity)
|
|
||||||
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
|
||||||
private readonly accountsToReconnectService: AccountsToReconnectService,
|
private readonly accountsToReconnectService: AccountsToReconnectService,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
@@ -71,14 +67,17 @@ export class GoogleAPIsService {
|
|||||||
'CALENDAR_PROVIDER_GOOGLE_ENABLED',
|
'CALENDAR_PROVIDER_GOOGLE_ENABLED',
|
||||||
);
|
);
|
||||||
|
|
||||||
const connectedAccounts =
|
const connectedAccountRepository =
|
||||||
await this.connectedAccountRepository.getAllByHandleAndWorkspaceMemberId(
|
await this.twentyORMGlobalManager.getRepositoryForWorkspace<ConnectedAccountWorkspaceEntity>(
|
||||||
handle,
|
|
||||||
workspaceMemberId,
|
|
||||||
workspaceId,
|
workspaceId,
|
||||||
|
'connectedAccount',
|
||||||
);
|
);
|
||||||
|
|
||||||
const existingAccountId = connectedAccounts?.[0]?.id;
|
const connectedAccount = await connectedAccountRepository.findOne({
|
||||||
|
where: { handle, accountOwnerId: workspaceMemberId },
|
||||||
|
});
|
||||||
|
|
||||||
|
const existingAccountId = connectedAccount?.id;
|
||||||
const newOrExistingConnectedAccountId = existingAccountId ?? v4();
|
const newOrExistingConnectedAccountId = existingAccountId ?? v4();
|
||||||
|
|
||||||
const calendarChannelRepository =
|
const calendarChannelRepository =
|
||||||
@@ -98,7 +97,7 @@ export class GoogleAPIsService {
|
|||||||
|
|
||||||
await workspaceDataSource.transaction(async (manager: EntityManager) => {
|
await workspaceDataSource.transaction(async (manager: EntityManager) => {
|
||||||
if (!existingAccountId) {
|
if (!existingAccountId) {
|
||||||
await this.connectedAccountRepository.create(
|
await connectedAccountRepository.save(
|
||||||
{
|
{
|
||||||
id: newOrExistingConnectedAccountId,
|
id: newOrExistingConnectedAccountId,
|
||||||
handle,
|
handle,
|
||||||
@@ -107,7 +106,7 @@ export class GoogleAPIsService {
|
|||||||
refreshToken: input.refreshToken,
|
refreshToken: input.refreshToken,
|
||||||
accountOwnerId: workspaceMemberId,
|
accountOwnerId: workspaceMemberId,
|
||||||
},
|
},
|
||||||
workspaceId,
|
{},
|
||||||
manager,
|
manager,
|
||||||
);
|
);
|
||||||
|
|
||||||
@@ -140,11 +139,14 @@ export class GoogleAPIsService {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
await this.connectedAccountRepository.updateAccessTokenAndRefreshToken(
|
await connectedAccountRepository.update(
|
||||||
input.accessToken,
|
{
|
||||||
input.refreshToken,
|
id: newOrExistingConnectedAccountId,
|
||||||
newOrExistingConnectedAccountId,
|
},
|
||||||
workspaceId,
|
{
|
||||||
|
accessToken: input.accessToken,
|
||||||
|
refreshToken: input.refreshToken,
|
||||||
|
},
|
||||||
manager,
|
manager,
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,4 @@
|
|||||||
import { BlocklistRepository } from 'src/modules/blocklist/repositories/blocklist.repository';
|
import { BlocklistRepository } from 'src/modules/blocklist/repositories/blocklist.repository';
|
||||||
import { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
|
||||||
import { AuditLogRepository } from 'src/modules/timeline/repositiories/audit-log.repository';
|
import { AuditLogRepository } from 'src/modules/timeline/repositiories/audit-log.repository';
|
||||||
import { TimelineActivityRepository } from 'src/modules/timeline/repositiories/timeline-activity.repository';
|
import { TimelineActivityRepository } from 'src/modules/timeline/repositiories/timeline-activity.repository';
|
||||||
import { WorkspaceMemberRepository } from 'src/modules/workspace-member/repositories/workspace-member.repository';
|
import { WorkspaceMemberRepository } from 'src/modules/workspace-member/repositories/workspace-member.repository';
|
||||||
@@ -7,7 +6,6 @@ import { WorkspaceMemberRepository } from 'src/modules/workspace-member/reposito
|
|||||||
export const metadataToRepositoryMapping = {
|
export const metadataToRepositoryMapping = {
|
||||||
AuditLogWorkspaceEntity: AuditLogRepository,
|
AuditLogWorkspaceEntity: AuditLogRepository,
|
||||||
BlocklistWorkspaceEntity: BlocklistRepository,
|
BlocklistWorkspaceEntity: BlocklistRepository,
|
||||||
ConnectedAccountWorkspaceEntity: ConnectedAccountRepository,
|
|
||||||
TimelineActivityWorkspaceEntity: TimelineActivityRepository,
|
TimelineActivityWorkspaceEntity: TimelineActivityRepository,
|
||||||
WorkspaceMemberWorkspaceEntity: WorkspaceMemberRepository,
|
WorkspaceMemberWorkspaceEntity: WorkspaceMemberRepository,
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -25,13 +25,11 @@ import { CalendarCommonModule } from 'src/modules/calendar/common/calendar-commo
|
|||||||
import { CalendarChannelSyncStatusService } from 'src/modules/calendar/common/services/calendar-channel-sync-status.service';
|
import { CalendarChannelSyncStatusService } from 'src/modules/calendar/common/services/calendar-channel-sync-status.service';
|
||||||
import { ConnectedAccountModule } from 'src/modules/connected-account/connected-account.module';
|
import { ConnectedAccountModule } from 'src/modules/connected-account/connected-account.module';
|
||||||
import { RefreshAccessTokenManagerModule } from 'src/modules/connected-account/refresh-access-token-manager/refresh-access-token-manager.module';
|
import { RefreshAccessTokenManagerModule } from 'src/modules/connected-account/refresh-access-token-manager/refresh-access-token-manager.module';
|
||||||
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
|
||||||
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
ObjectMetadataRepositoryModule.forFeature([
|
ObjectMetadataRepositoryModule.forFeature([
|
||||||
ConnectedAccountWorkspaceEntity,
|
|
||||||
BlocklistWorkspaceEntity,
|
BlocklistWorkspaceEntity,
|
||||||
WorkspaceMemberWorkspaceEntity,
|
WorkspaceMemberWorkspaceEntity,
|
||||||
]),
|
]),
|
||||||
|
|||||||
@@ -3,15 +3,12 @@ import { Scope } from '@nestjs/common';
|
|||||||
import { Process } from 'src/engine/core-modules/message-queue/decorators/process.decorator';
|
import { Process } from 'src/engine/core-modules/message-queue/decorators/process.decorator';
|
||||||
import { Processor } from 'src/engine/core-modules/message-queue/decorators/processor.decorator';
|
import { Processor } from 'src/engine/core-modules/message-queue/decorators/processor.decorator';
|
||||||
import { MessageQueue } from 'src/engine/core-modules/message-queue/message-queue.constants';
|
import { MessageQueue } from 'src/engine/core-modules/message-queue/message-queue.constants';
|
||||||
import { InjectObjectMetadataRepository } from 'src/engine/object-metadata-repository/object-metadata-repository.decorator';
|
|
||||||
import { TwentyORMManager } from 'src/engine/twenty-orm/twenty-orm.manager';
|
import { TwentyORMManager } from 'src/engine/twenty-orm/twenty-orm.manager';
|
||||||
import { CalendarEventsImportService } from 'src/modules/calendar/calendar-event-import-manager/services/calendar-events-import.service';
|
import { CalendarEventsImportService } from 'src/modules/calendar/calendar-event-import-manager/services/calendar-events-import.service';
|
||||||
import {
|
import {
|
||||||
CalendarChannelSyncStage,
|
CalendarChannelSyncStage,
|
||||||
CalendarChannelWorkspaceEntity,
|
CalendarChannelWorkspaceEntity,
|
||||||
} from 'src/modules/calendar/common/standard-objects/calendar-channel.workspace-entity';
|
} from 'src/modules/calendar/common/standard-objects/calendar-channel.workspace-entity';
|
||||||
import { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
|
||||||
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
|
||||||
import { isThrottled } from 'src/modules/connected-account/utils/is-throttled';
|
import { isThrottled } from 'src/modules/connected-account/utils/is-throttled';
|
||||||
|
|
||||||
export type CalendarEventsImportJobData = {
|
export type CalendarEventsImportJobData = {
|
||||||
@@ -27,8 +24,6 @@ export class CalendarEventListFetchJob {
|
|||||||
constructor(
|
constructor(
|
||||||
private readonly twentyORMManager: TwentyORMManager,
|
private readonly twentyORMManager: TwentyORMManager,
|
||||||
private readonly calendarEventsImportService: CalendarEventsImportService,
|
private readonly calendarEventsImportService: CalendarEventsImportService,
|
||||||
@InjectObjectMetadataRepository(ConnectedAccountWorkspaceEntity)
|
|
||||||
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
@Process(CalendarEventListFetchJob.name)
|
@Process(CalendarEventListFetchJob.name)
|
||||||
@@ -47,6 +42,7 @@ export class CalendarEventListFetchJob {
|
|||||||
id: calendarChannelId,
|
id: calendarChannelId,
|
||||||
isSyncEnabled: true,
|
isSyncEnabled: true,
|
||||||
},
|
},
|
||||||
|
relations: ['connectedAccount'],
|
||||||
});
|
});
|
||||||
|
|
||||||
if (!calendarChannel) {
|
if (!calendarChannel) {
|
||||||
@@ -62,12 +58,6 @@ export class CalendarEventListFetchJob {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const connectedAccount =
|
|
||||||
await this.connectedAccountRepository.getConnectedAccountOrThrow(
|
|
||||||
workspaceId,
|
|
||||||
calendarChannel.connectedAccountId,
|
|
||||||
);
|
|
||||||
|
|
||||||
switch (calendarChannel.syncStage) {
|
switch (calendarChannel.syncStage) {
|
||||||
case CalendarChannelSyncStage.FULL_CALENDAR_EVENT_LIST_FETCH_PENDING:
|
case CalendarChannelSyncStage.FULL_CALENDAR_EVENT_LIST_FETCH_PENDING:
|
||||||
await calendarChannelRepository.update(calendarChannelId, {
|
await calendarChannelRepository.update(calendarChannelId, {
|
||||||
@@ -77,7 +67,7 @@ export class CalendarEventListFetchJob {
|
|||||||
|
|
||||||
await this.calendarEventsImportService.processCalendarEventsImport(
|
await this.calendarEventsImportService.processCalendarEventsImport(
|
||||||
calendarChannel,
|
calendarChannel,
|
||||||
connectedAccount,
|
calendarChannel.connectedAccount,
|
||||||
workspaceId,
|
workspaceId,
|
||||||
);
|
);
|
||||||
break;
|
break;
|
||||||
@@ -85,7 +75,7 @@ export class CalendarEventListFetchJob {
|
|||||||
case CalendarChannelSyncStage.PARTIAL_CALENDAR_EVENT_LIST_FETCH_PENDING:
|
case CalendarChannelSyncStage.PARTIAL_CALENDAR_EVENT_LIST_FETCH_PENDING:
|
||||||
await this.calendarEventsImportService.processCalendarEventsImport(
|
await this.calendarEventsImportService.processCalendarEventsImport(
|
||||||
calendarChannel,
|
calendarChannel,
|
||||||
connectedAccount,
|
calendarChannel.connectedAccount,
|
||||||
workspaceId,
|
workspaceId,
|
||||||
);
|
);
|
||||||
break;
|
break;
|
||||||
|
|||||||
@@ -1,12 +1,12 @@
|
|||||||
import { ForbiddenException, Injectable } from '@nestjs/common';
|
import { ForbiddenException, Injectable } from '@nestjs/common';
|
||||||
|
|
||||||
import groupBy from 'lodash.groupby';
|
import groupBy from 'lodash.groupby';
|
||||||
|
import { Any } from 'typeorm';
|
||||||
|
|
||||||
import { InjectObjectMetadataRepository } from 'src/engine/object-metadata-repository/object-metadata-repository.decorator';
|
import { InjectObjectMetadataRepository } from 'src/engine/object-metadata-repository/object-metadata-repository.decorator';
|
||||||
import { TwentyORMManager } from 'src/engine/twenty-orm/twenty-orm.manager';
|
import { TwentyORMManager } from 'src/engine/twenty-orm/twenty-orm.manager';
|
||||||
import { CalendarChannelEventAssociationWorkspaceEntity } from 'src/modules/calendar/common/standard-objects/calendar-channel-event-association.workspace-entity';
|
import { CalendarChannelEventAssociationWorkspaceEntity } from 'src/modules/calendar/common/standard-objects/calendar-channel-event-association.workspace-entity';
|
||||||
import { CalendarChannelVisibility } from 'src/modules/calendar/common/standard-objects/calendar-channel.workspace-entity';
|
import { CalendarChannelVisibility } from 'src/modules/calendar/common/standard-objects/calendar-channel.workspace-entity';
|
||||||
import { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
|
||||||
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
import { WorkspaceMemberRepository } from 'src/modules/workspace-member/repositories/workspace-member.repository';
|
import { WorkspaceMemberRepository } from 'src/modules/workspace-member/repositories/workspace-member.repository';
|
||||||
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
@@ -15,8 +15,6 @@ import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/sta
|
|||||||
export class CanAccessCalendarEventService {
|
export class CanAccessCalendarEventService {
|
||||||
constructor(
|
constructor(
|
||||||
private readonly twentyORMManager: TwentyORMManager,
|
private readonly twentyORMManager: TwentyORMManager,
|
||||||
@InjectObjectMetadataRepository(ConnectedAccountWorkspaceEntity)
|
|
||||||
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
|
||||||
@InjectObjectMetadataRepository(WorkspaceMemberWorkspaceEntity)
|
@InjectObjectMetadataRepository(WorkspaceMemberWorkspaceEntity)
|
||||||
private readonly workspaceMemberService: WorkspaceMemberRepository,
|
private readonly workspaceMemberService: WorkspaceMemberRepository,
|
||||||
) {}
|
) {}
|
||||||
@@ -46,20 +44,20 @@ export class CanAccessCalendarEventService {
|
|||||||
const currentWorkspaceMember =
|
const currentWorkspaceMember =
|
||||||
await this.workspaceMemberService.getByIdOrFail(userId, workspaceId);
|
await this.workspaceMemberService.getByIdOrFail(userId, workspaceId);
|
||||||
|
|
||||||
const calendarChannelsConnectedAccounts =
|
const connectedAccountRepository =
|
||||||
await this.connectedAccountRepository.getByIds(
|
await this.twentyORMManager.getRepository<ConnectedAccountWorkspaceEntity>(
|
||||||
calendarChannels.map((channel) => channel.connectedAccountId),
|
'connectedAccount',
|
||||||
workspaceId,
|
|
||||||
);
|
);
|
||||||
|
|
||||||
const calendarChannelsWorkspaceMemberIds =
|
const connectedAccounts = await connectedAccountRepository.find({
|
||||||
calendarChannelsConnectedAccounts.map(
|
select: ['id'],
|
||||||
(connectedAccount) => connectedAccount.accountOwnerId,
|
where: {
|
||||||
);
|
calendarChannels: Any(calendarChannels.map((channel) => channel.id)),
|
||||||
|
accountOwnerId: currentWorkspaceMember.id,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
if (
|
if (connectedAccounts.length > 0) {
|
||||||
calendarChannelsWorkspaceMemberIds.includes(currentWorkspaceMember.id)
|
|
||||||
) {
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -4,15 +4,11 @@ import { ObjectMetadataRepositoryModule } from 'src/engine/object-metadata-repos
|
|||||||
import { CalendarEventFindManyPreQueryHook } from 'src/modules/calendar/common/query-hooks/calendar-event/calendar-event-find-many.pre-query.hook';
|
import { CalendarEventFindManyPreQueryHook } from 'src/modules/calendar/common/query-hooks/calendar-event/calendar-event-find-many.pre-query.hook';
|
||||||
import { CalendarEventFindOnePreQueryHook } from 'src/modules/calendar/common/query-hooks/calendar-event/calendar-event-find-one.pre-query-hook';
|
import { CalendarEventFindOnePreQueryHook } from 'src/modules/calendar/common/query-hooks/calendar-event/calendar-event-find-one.pre-query-hook';
|
||||||
import { CanAccessCalendarEventService } from 'src/modules/calendar/common/query-hooks/calendar-event/services/can-access-calendar-event.service';
|
import { CanAccessCalendarEventService } from 'src/modules/calendar/common/query-hooks/calendar-event/services/can-access-calendar-event.service';
|
||||||
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
|
||||||
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
ObjectMetadataRepositoryModule.forFeature([
|
ObjectMetadataRepositoryModule.forFeature([WorkspaceMemberWorkspaceEntity]),
|
||||||
ConnectedAccountWorkspaceEntity,
|
|
||||||
WorkspaceMemberWorkspaceEntity,
|
|
||||||
]),
|
|
||||||
],
|
],
|
||||||
providers: [
|
providers: [
|
||||||
CanAccessCalendarEventService,
|
CanAccessCalendarEventService,
|
||||||
|
|||||||
@@ -1,18 +1,11 @@
|
|||||||
import { Module } from '@nestjs/common';
|
import { Module } from '@nestjs/common';
|
||||||
|
|
||||||
import { ObjectMetadataRepositoryModule } from 'src/engine/object-metadata-repository/object-metadata-repository.module';
|
|
||||||
import { GoogleEmailAliasManagerService } from 'src/modules/connected-account/email-alias-manager/drivers/google/google-email-alias-manager.service';
|
import { GoogleEmailAliasManagerService } from 'src/modules/connected-account/email-alias-manager/drivers/google/google-email-alias-manager.service';
|
||||||
import { EmailAliasManagerService } from 'src/modules/connected-account/email-alias-manager/services/email-alias-manager.service';
|
import { EmailAliasManagerService } from 'src/modules/connected-account/email-alias-manager/services/email-alias-manager.service';
|
||||||
import { OAuth2ClientManagerModule } from 'src/modules/connected-account/oauth2-client-manager/oauth2-client-manager.module';
|
import { OAuth2ClientManagerModule } from 'src/modules/connected-account/oauth2-client-manager/oauth2-client-manager.module';
|
||||||
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [OAuth2ClientManagerModule],
|
||||||
ObjectMetadataRepositoryModule.forFeature([
|
|
||||||
ConnectedAccountWorkspaceEntity,
|
|
||||||
]),
|
|
||||||
OAuth2ClientManagerModule,
|
|
||||||
],
|
|
||||||
providers: [EmailAliasManagerService, GoogleEmailAliasManagerService],
|
providers: [EmailAliasManagerService, GoogleEmailAliasManagerService],
|
||||||
exports: [EmailAliasManagerService],
|
exports: [EmailAliasManagerService],
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -1,21 +1,18 @@
|
|||||||
import { Injectable } from '@nestjs/common';
|
import { Injectable } from '@nestjs/common';
|
||||||
|
|
||||||
import { InjectObjectMetadataRepository } from 'src/engine/object-metadata-repository/object-metadata-repository.decorator';
|
import { TwentyORMManager } from 'src/engine/twenty-orm/twenty-orm.manager';
|
||||||
import { GoogleEmailAliasManagerService } from 'src/modules/connected-account/email-alias-manager/drivers/google/google-email-alias-manager.service';
|
import { GoogleEmailAliasManagerService } from 'src/modules/connected-account/email-alias-manager/drivers/google/google-email-alias-manager.service';
|
||||||
import { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
|
||||||
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class EmailAliasManagerService {
|
export class EmailAliasManagerService {
|
||||||
constructor(
|
constructor(
|
||||||
@InjectObjectMetadataRepository(ConnectedAccountWorkspaceEntity)
|
|
||||||
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
|
||||||
private readonly googleEmailAliasManagerService: GoogleEmailAliasManagerService,
|
private readonly googleEmailAliasManagerService: GoogleEmailAliasManagerService,
|
||||||
|
private readonly twentyORMManager: TwentyORMManager,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
public async refreshHandleAliases(
|
public async refreshHandleAliases(
|
||||||
connectedAccount: ConnectedAccountWorkspaceEntity,
|
connectedAccount: ConnectedAccountWorkspaceEntity,
|
||||||
workspaceId: string,
|
|
||||||
) {
|
) {
|
||||||
let handleAliases: string[];
|
let handleAliases: string[];
|
||||||
|
|
||||||
@@ -32,10 +29,16 @@ export class EmailAliasManagerService {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
await this.connectedAccountRepository.updateHandleAliases(
|
const connectedAccountRepository =
|
||||||
handleAliases,
|
await this.twentyORMManager.getRepository<ConnectedAccountWorkspaceEntity>(
|
||||||
connectedAccount.id,
|
'connectedAccount',
|
||||||
workspaceId,
|
);
|
||||||
|
|
||||||
|
await connectedAccountRepository.update(
|
||||||
|
{ id: connectedAccount.id },
|
||||||
|
{
|
||||||
|
handleAliases: handleAliases.join(','), // TODO: modify handleAliases to be of fieldmetadatatype array
|
||||||
|
},
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,17 +1,10 @@
|
|||||||
import { Module } from '@nestjs/common';
|
import { Module } from '@nestjs/common';
|
||||||
|
|
||||||
import { ObjectMetadataRepositoryModule } from 'src/engine/object-metadata-repository/object-metadata-repository.module';
|
|
||||||
import { GoogleAPIRefreshAccessTokenService } from 'src/modules/connected-account/refresh-access-token-manager/drivers/google/services/google-api-refresh-access-token.service';
|
import { GoogleAPIRefreshAccessTokenService } from 'src/modules/connected-account/refresh-access-token-manager/drivers/google/services/google-api-refresh-access-token.service';
|
||||||
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
|
||||||
import { MessagingCommonModule } from 'src/modules/messaging/common/messaging-common.module';
|
import { MessagingCommonModule } from 'src/modules/messaging/common/messaging-common.module';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [MessagingCommonModule],
|
||||||
ObjectMetadataRepositoryModule.forFeature([
|
|
||||||
ConnectedAccountWorkspaceEntity,
|
|
||||||
]),
|
|
||||||
MessagingCommonModule,
|
|
||||||
],
|
|
||||||
providers: [GoogleAPIRefreshAccessTokenService],
|
providers: [GoogleAPIRefreshAccessTokenService],
|
||||||
exports: [GoogleAPIRefreshAccessTokenService],
|
exports: [GoogleAPIRefreshAccessTokenService],
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -1,20 +1,18 @@
|
|||||||
import { Injectable } from '@nestjs/common';
|
import { Injectable } from '@nestjs/common';
|
||||||
|
|
||||||
import { InjectObjectMetadataRepository } from 'src/engine/object-metadata-repository/object-metadata-repository.decorator';
|
import { TwentyORMManager } from 'src/engine/twenty-orm/twenty-orm.manager';
|
||||||
import { GoogleAPIRefreshAccessTokenService } from 'src/modules/connected-account/refresh-access-token-manager/drivers/google/services/google-api-refresh-access-token.service';
|
import { GoogleAPIRefreshAccessTokenService } from 'src/modules/connected-account/refresh-access-token-manager/drivers/google/services/google-api-refresh-access-token.service';
|
||||||
import {
|
import {
|
||||||
RefreshAccessTokenException,
|
RefreshAccessTokenException,
|
||||||
RefreshAccessTokenExceptionCode,
|
RefreshAccessTokenExceptionCode,
|
||||||
} from 'src/modules/connected-account/refresh-access-token-manager/exceptions/refresh-access-token.exception';
|
} from 'src/modules/connected-account/refresh-access-token-manager/exceptions/refresh-access-token.exception';
|
||||||
import { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
|
||||||
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class RefreshAccessTokenService {
|
export class RefreshAccessTokenService {
|
||||||
constructor(
|
constructor(
|
||||||
private readonly googleAPIRefreshAccessTokenService: GoogleAPIRefreshAccessTokenService,
|
private readonly googleAPIRefreshAccessTokenService: GoogleAPIRefreshAccessTokenService,
|
||||||
@InjectObjectMetadataRepository(ConnectedAccountWorkspaceEntity)
|
private readonly twentyORMManager: TwentyORMManager,
|
||||||
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
async refreshAndSaveAccessToken(
|
async refreshAndSaveAccessToken(
|
||||||
@@ -44,10 +42,16 @@ export class RefreshAccessTokenService {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
await this.connectedAccountRepository.updateAccessToken(
|
const connectedAccountRepository =
|
||||||
|
await this.twentyORMManager.getRepository<ConnectedAccountWorkspaceEntity>(
|
||||||
|
'connectedAccount',
|
||||||
|
);
|
||||||
|
|
||||||
|
await connectedAccountRepository.update(
|
||||||
|
{ id: connectedAccount.id },
|
||||||
|
{
|
||||||
accessToken,
|
accessToken,
|
||||||
connectedAccount.id,
|
},
|
||||||
workspaceId,
|
|
||||||
);
|
);
|
||||||
|
|
||||||
return accessToken;
|
return accessToken;
|
||||||
|
|||||||
@@ -1,240 +0,0 @@
|
|||||||
import { Injectable, NotFoundException } from '@nestjs/common';
|
|
||||||
|
|
||||||
import { EntityManager } from 'typeorm';
|
|
||||||
|
|
||||||
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
|
||||||
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
|
||||||
|
|
||||||
@Injectable()
|
|
||||||
export class ConnectedAccountRepository {
|
|
||||||
constructor(
|
|
||||||
private readonly workspaceDataSourceService: WorkspaceDataSourceService,
|
|
||||||
) {}
|
|
||||||
|
|
||||||
public async getAll(
|
|
||||||
workspaceId: string,
|
|
||||||
transactionManager?: EntityManager,
|
|
||||||
): Promise<ConnectedAccountWorkspaceEntity[]> {
|
|
||||||
const dataSourceSchema =
|
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
|
||||||
|
|
||||||
return await this.workspaceDataSourceService.executeRawQuery(
|
|
||||||
`SELECT * FROM ${dataSourceSchema}."connectedAccount" WHERE "provider" = 'google'`,
|
|
||||||
[],
|
|
||||||
workspaceId,
|
|
||||||
transactionManager,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async getByIds(
|
|
||||||
connectedAccountIds: string[],
|
|
||||||
workspaceId: string,
|
|
||||||
transactionManager?: EntityManager,
|
|
||||||
): Promise<ConnectedAccountWorkspaceEntity[]> {
|
|
||||||
const dataSourceSchema =
|
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
|
||||||
|
|
||||||
return await this.workspaceDataSourceService.executeRawQuery(
|
|
||||||
`SELECT * FROM ${dataSourceSchema}."connectedAccount" WHERE "id" = ANY($1)`,
|
|
||||||
[connectedAccountIds],
|
|
||||||
workspaceId,
|
|
||||||
transactionManager,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async getAllByWorkspaceMemberId(
|
|
||||||
workspaceMemberId: string,
|
|
||||||
workspaceId: string,
|
|
||||||
transactionManager?: EntityManager,
|
|
||||||
): Promise<ConnectedAccountWorkspaceEntity[] | undefined> {
|
|
||||||
const dataSourceSchema =
|
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
|
||||||
|
|
||||||
const connectedAccounts =
|
|
||||||
await this.workspaceDataSourceService.executeRawQuery(
|
|
||||||
`SELECT * FROM ${dataSourceSchema}."connectedAccount" WHERE "accountOwnerId" = $1`,
|
|
||||||
[workspaceMemberId],
|
|
||||||
workspaceId,
|
|
||||||
transactionManager,
|
|
||||||
);
|
|
||||||
|
|
||||||
return connectedAccounts;
|
|
||||||
}
|
|
||||||
|
|
||||||
public async getAllByHandleAndWorkspaceMemberId(
|
|
||||||
handle: string,
|
|
||||||
workspaceMemberId: string,
|
|
||||||
workspaceId: string,
|
|
||||||
transactionManager?: EntityManager,
|
|
||||||
): Promise<ConnectedAccountWorkspaceEntity[] | undefined> {
|
|
||||||
const dataSourceSchema =
|
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
|
||||||
|
|
||||||
const connectedAccounts =
|
|
||||||
await this.workspaceDataSourceService.executeRawQuery(
|
|
||||||
`SELECT * FROM ${dataSourceSchema}."connectedAccount" WHERE "handle" = $1 AND "accountOwnerId" = $2 LIMIT 1`,
|
|
||||||
[handle, workspaceMemberId],
|
|
||||||
workspaceId,
|
|
||||||
transactionManager,
|
|
||||||
);
|
|
||||||
|
|
||||||
return connectedAccounts;
|
|
||||||
}
|
|
||||||
|
|
||||||
public async create(
|
|
||||||
connectedAccount: Pick<
|
|
||||||
ConnectedAccountWorkspaceEntity,
|
|
||||||
| 'id'
|
|
||||||
| 'handle'
|
|
||||||
| 'provider'
|
|
||||||
| 'accessToken'
|
|
||||||
| 'refreshToken'
|
|
||||||
| 'accountOwnerId'
|
|
||||||
>,
|
|
||||||
workspaceId: string,
|
|
||||||
transactionManager?: EntityManager,
|
|
||||||
): Promise<ConnectedAccountWorkspaceEntity> {
|
|
||||||
const dataSourceSchema =
|
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
|
||||||
|
|
||||||
return await this.workspaceDataSourceService.executeRawQuery(
|
|
||||||
`INSERT INTO ${dataSourceSchema}."connectedAccount" ("id", "handle", "provider", "accessToken", "refreshToken", "accountOwnerId") VALUES ($1, $2, $3, $4, $5, $6)`,
|
|
||||||
[
|
|
||||||
connectedAccount.id,
|
|
||||||
connectedAccount.handle,
|
|
||||||
connectedAccount.provider,
|
|
||||||
connectedAccount.accessToken,
|
|
||||||
connectedAccount.refreshToken,
|
|
||||||
connectedAccount.accountOwnerId,
|
|
||||||
],
|
|
||||||
workspaceId,
|
|
||||||
transactionManager,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async updateAccessTokenAndRefreshToken(
|
|
||||||
accessToken: string,
|
|
||||||
refreshToken: string,
|
|
||||||
connectedAccountId: string,
|
|
||||||
workspaceId: string,
|
|
||||||
transactionManager?: EntityManager,
|
|
||||||
) {
|
|
||||||
const dataSourceSchema =
|
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
|
||||||
|
|
||||||
await this.workspaceDataSourceService.executeRawQuery(
|
|
||||||
`UPDATE ${dataSourceSchema}."connectedAccount" SET "accessToken" = $1, "refreshToken" = $2, "authFailedAt" = NULL WHERE "id" = $3`,
|
|
||||||
[accessToken, refreshToken, connectedAccountId],
|
|
||||||
workspaceId,
|
|
||||||
transactionManager,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async getById(
|
|
||||||
connectedAccountId: string,
|
|
||||||
workspaceId: string,
|
|
||||||
transactionManager?: EntityManager,
|
|
||||||
): Promise<ConnectedAccountWorkspaceEntity | undefined> {
|
|
||||||
const dataSourceSchema =
|
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
|
||||||
|
|
||||||
const connectedAccounts =
|
|
||||||
await this.workspaceDataSourceService.executeRawQuery(
|
|
||||||
`SELECT * FROM ${dataSourceSchema}."connectedAccount" WHERE "id" = $1 LIMIT 1`,
|
|
||||||
[connectedAccountId],
|
|
||||||
workspaceId,
|
|
||||||
transactionManager,
|
|
||||||
);
|
|
||||||
|
|
||||||
return connectedAccounts[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
public async getByIdOrFail(
|
|
||||||
connectedAccountId: string,
|
|
||||||
workspaceId: string,
|
|
||||||
transactionManager?: EntityManager,
|
|
||||||
): Promise<ConnectedAccountWorkspaceEntity> {
|
|
||||||
const connectedAccount = await this.getById(
|
|
||||||
connectedAccountId,
|
|
||||||
workspaceId,
|
|
||||||
transactionManager,
|
|
||||||
);
|
|
||||||
|
|
||||||
if (!connectedAccount) {
|
|
||||||
throw new NotFoundException(
|
|
||||||
`Connected account with id ${connectedAccountId} not found in workspace ${workspaceId}`,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
return connectedAccount;
|
|
||||||
}
|
|
||||||
|
|
||||||
public async updateAccessToken(
|
|
||||||
accessToken: string,
|
|
||||||
connectedAccountId: string,
|
|
||||||
workspaceId: string,
|
|
||||||
transactionManager?: EntityManager,
|
|
||||||
) {
|
|
||||||
const dataSourceSchema =
|
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
|
||||||
|
|
||||||
await this.workspaceDataSourceService.executeRawQuery(
|
|
||||||
`UPDATE ${dataSourceSchema}."connectedAccount" SET "accessToken" = $1, "authFailedAt" = NULL WHERE "id" = $2`,
|
|
||||||
[accessToken, connectedAccountId],
|
|
||||||
workspaceId,
|
|
||||||
transactionManager,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async updateAuthFailedAt(
|
|
||||||
connectedAccountId: string,
|
|
||||||
workspaceId: string,
|
|
||||||
transactionManager?: EntityManager,
|
|
||||||
) {
|
|
||||||
const dataSourceSchema =
|
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
|
||||||
|
|
||||||
await this.workspaceDataSourceService.executeRawQuery(
|
|
||||||
`UPDATE ${dataSourceSchema}."connectedAccount" SET "authFailedAt" = NOW() WHERE "id" = $1`,
|
|
||||||
[connectedAccountId],
|
|
||||||
workspaceId,
|
|
||||||
transactionManager,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async getConnectedAccountOrThrow(
|
|
||||||
workspaceId: string,
|
|
||||||
connectedAccountId: string,
|
|
||||||
): Promise<ConnectedAccountWorkspaceEntity> {
|
|
||||||
const connectedAccount = await this.getById(
|
|
||||||
connectedAccountId,
|
|
||||||
workspaceId,
|
|
||||||
);
|
|
||||||
|
|
||||||
if (!connectedAccount) {
|
|
||||||
throw new Error(
|
|
||||||
`Connected account ${connectedAccountId} not found in workspace ${workspaceId}`,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
return connectedAccount;
|
|
||||||
}
|
|
||||||
|
|
||||||
public async updateHandleAliases(
|
|
||||||
handleAliases: string[],
|
|
||||||
connectedAccountId: string,
|
|
||||||
workspaceId: string,
|
|
||||||
transactionManager?: EntityManager,
|
|
||||||
) {
|
|
||||||
const dataSourceSchema =
|
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
|
||||||
|
|
||||||
await this.workspaceDataSourceService.executeRawQuery(
|
|
||||||
`UPDATE ${dataSourceSchema}."connectedAccount" SET "handleAliases" = $1 WHERE "id" = $2`,
|
|
||||||
// TODO: modify handleAliases to be of fieldmetadatatype array
|
|
||||||
[handleAliases.join(','), connectedAccountId],
|
|
||||||
workspaceId,
|
|
||||||
transactionManager,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -5,17 +5,13 @@ import { Any } from 'typeorm';
|
|||||||
|
|
||||||
import { InjectObjectMetadataRepository } from 'src/engine/object-metadata-repository/object-metadata-repository.decorator';
|
import { InjectObjectMetadataRepository } from 'src/engine/object-metadata-repository/object-metadata-repository.decorator';
|
||||||
import { TwentyORMManager } from 'src/engine/twenty-orm/twenty-orm.manager';
|
import { TwentyORMManager } from 'src/engine/twenty-orm/twenty-orm.manager';
|
||||||
import { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
|
||||||
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
import { MessageChannelWorkspaceEntity } from 'src/modules/messaging/common/standard-objects/message-channel.workspace-entity';
|
import { MessageChannelWorkspaceEntity } from 'src/modules/messaging/common/standard-objects/message-channel.workspace-entity';
|
||||||
import { WorkspaceMemberRepository } from 'src/modules/workspace-member/repositories/workspace-member.repository';
|
import { WorkspaceMemberRepository } from 'src/modules/workspace-member/repositories/workspace-member.repository';
|
||||||
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
import { isDefined } from 'src/utils/is-defined';
|
|
||||||
|
|
||||||
export class CanAccessMessageThreadService {
|
export class CanAccessMessageThreadService {
|
||||||
constructor(
|
constructor(
|
||||||
@InjectObjectMetadataRepository(ConnectedAccountWorkspaceEntity)
|
|
||||||
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
|
||||||
@InjectObjectMetadataRepository(WorkspaceMemberWorkspaceEntity)
|
@InjectObjectMetadataRepository(WorkspaceMemberWorkspaceEntity)
|
||||||
private readonly workspaceMemberRepository: WorkspaceMemberRepository,
|
private readonly workspaceMemberRepository: WorkspaceMemberRepository,
|
||||||
private readonly twentyORMManager: TwentyORMManager,
|
private readonly twentyORMManager: TwentyORMManager,
|
||||||
@@ -31,6 +27,7 @@ export class CanAccessMessageThreadService {
|
|||||||
'messageChannel',
|
'messageChannel',
|
||||||
);
|
);
|
||||||
const messageChannels = await messageChannelRepository.find({
|
const messageChannels = await messageChannelRepository.find({
|
||||||
|
select: ['id', 'visibility'],
|
||||||
where: {
|
where: {
|
||||||
id: Any(
|
id: Any(
|
||||||
messageChannelMessageAssociations.map(
|
messageChannelMessageAssociations.map(
|
||||||
@@ -52,20 +49,20 @@ export class CanAccessMessageThreadService {
|
|||||||
const currentWorkspaceMember =
|
const currentWorkspaceMember =
|
||||||
await this.workspaceMemberRepository.getByIdOrFail(userId, workspaceId);
|
await this.workspaceMemberRepository.getByIdOrFail(userId, workspaceId);
|
||||||
|
|
||||||
const messageChannelsConnectedAccounts =
|
const connectedAccountRepository =
|
||||||
await this.connectedAccountRepository.getByIds(
|
await this.twentyORMManager.getRepository<ConnectedAccountWorkspaceEntity>(
|
||||||
messageChannels
|
'connectedAccount',
|
||||||
.map((channel) => channel.connectedAccountId)
|
|
||||||
.filter(isDefined),
|
|
||||||
workspaceId,
|
|
||||||
);
|
);
|
||||||
|
|
||||||
const messageChannelsWorkspaceMemberIds =
|
const connectedAccounts = await connectedAccountRepository.find({
|
||||||
messageChannelsConnectedAccounts.map(
|
select: ['id'],
|
||||||
(connectedAccount) => connectedAccount.accountOwnerId,
|
where: {
|
||||||
);
|
messageChannels: Any(messageChannels.map((channel) => channel.id)),
|
||||||
|
accountOwnerId: currentWorkspaceMember.id,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
if (messageChannelsWorkspaceMemberIds.includes(currentWorkspaceMember.id)) {
|
if (connectedAccounts.length > 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
import { Module } from '@nestjs/common';
|
import { Module } from '@nestjs/common';
|
||||||
|
|
||||||
import { ObjectMetadataRepositoryModule } from 'src/engine/object-metadata-repository/object-metadata-repository.module';
|
import { ObjectMetadataRepositoryModule } from 'src/engine/object-metadata-repository/object-metadata-repository.module';
|
||||||
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
|
||||||
import { CanAccessMessageThreadService } from 'src/modules/messaging/common/query-hooks/message/can-access-message-thread.service';
|
import { CanAccessMessageThreadService } from 'src/modules/messaging/common/query-hooks/message/can-access-message-thread.service';
|
||||||
import { MessageFindManyPreQueryHook } from 'src/modules/messaging/common/query-hooks/message/message-find-many.pre-query.hook';
|
import { MessageFindManyPreQueryHook } from 'src/modules/messaging/common/query-hooks/message/message-find-many.pre-query.hook';
|
||||||
import { MessageFindOnePreQueryHook } from 'src/modules/messaging/common/query-hooks/message/message-find-one.pre-query-hook';
|
import { MessageFindOnePreQueryHook } from 'src/modules/messaging/common/query-hooks/message/message-find-one.pre-query-hook';
|
||||||
@@ -9,10 +8,7 @@ import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/sta
|
|||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
ObjectMetadataRepositoryModule.forFeature([
|
ObjectMetadataRepositoryModule.forFeature([WorkspaceMemberWorkspaceEntity]),
|
||||||
ConnectedAccountWorkspaceEntity,
|
|
||||||
WorkspaceMemberWorkspaceEntity,
|
|
||||||
]),
|
|
||||||
],
|
],
|
||||||
providers: [
|
providers: [
|
||||||
CanAccessMessageThreadService,
|
CanAccessMessageThreadService,
|
||||||
|
|||||||
@@ -2,15 +2,14 @@ import { HttpModule } from '@nestjs/axios';
|
|||||||
import { Module } from '@nestjs/common';
|
import { Module } from '@nestjs/common';
|
||||||
import { TypeOrmModule } from '@nestjs/typeorm';
|
import { TypeOrmModule } from '@nestjs/typeorm';
|
||||||
|
|
||||||
|
import { EnvironmentModule } from 'src/engine/core-modules/environment/environment.module';
|
||||||
import { FeatureFlagEntity } from 'src/engine/core-modules/feature-flag/feature-flag.entity';
|
import { FeatureFlagEntity } from 'src/engine/core-modules/feature-flag/feature-flag.entity';
|
||||||
import { FeatureFlagModule } from 'src/engine/core-modules/feature-flag/feature-flag.module';
|
import { FeatureFlagModule } from 'src/engine/core-modules/feature-flag/feature-flag.module';
|
||||||
import { EnvironmentModule } from 'src/engine/core-modules/environment/environment.module';
|
|
||||||
import { ObjectMetadataRepositoryModule } from 'src/engine/object-metadata-repository/object-metadata-repository.module';
|
import { ObjectMetadataRepositoryModule } from 'src/engine/object-metadata-repository/object-metadata-repository.module';
|
||||||
import { WorkspaceDataSourceModule } from 'src/engine/workspace-datasource/workspace-datasource.module';
|
import { WorkspaceDataSourceModule } from 'src/engine/workspace-datasource/workspace-datasource.module';
|
||||||
import { BlocklistWorkspaceEntity } from 'src/modules/blocklist/standard-objects/blocklist.workspace-entity';
|
import { BlocklistWorkspaceEntity } from 'src/modules/blocklist/standard-objects/blocklist.workspace-entity';
|
||||||
import { EmailAliasManagerModule } from 'src/modules/connected-account/email-alias-manager/email-alias-manager.module';
|
import { EmailAliasManagerModule } from 'src/modules/connected-account/email-alias-manager/email-alias-manager.module';
|
||||||
import { OAuth2ClientManagerModule } from 'src/modules/connected-account/oauth2-client-manager/oauth2-client-manager.module';
|
import { OAuth2ClientManagerModule } from 'src/modules/connected-account/oauth2-client-manager/oauth2-client-manager.module';
|
||||||
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
|
||||||
import { MessagingCommonModule } from 'src/modules/messaging/common/messaging-common.module';
|
import { MessagingCommonModule } from 'src/modules/messaging/common/messaging-common.module';
|
||||||
import { GmailClientProvider } from 'src/modules/messaging/message-import-manager/drivers/gmail/providers/gmail-client.provider';
|
import { GmailClientProvider } from 'src/modules/messaging/message-import-manager/drivers/gmail/providers/gmail-client.provider';
|
||||||
import { GmailFetchByBatchService } from 'src/modules/messaging/message-import-manager/drivers/gmail/services/gmail-fetch-by-batch.service';
|
import { GmailFetchByBatchService } from 'src/modules/messaging/message-import-manager/drivers/gmail/services/gmail-fetch-by-batch.service';
|
||||||
@@ -26,10 +25,7 @@ import { MessageParticipantManagerModule } from 'src/modules/messaging/message-p
|
|||||||
baseURL: 'https://www.googleapis.com/batch/gmail/v1',
|
baseURL: 'https://www.googleapis.com/batch/gmail/v1',
|
||||||
}),
|
}),
|
||||||
EnvironmentModule,
|
EnvironmentModule,
|
||||||
ObjectMetadataRepositoryModule.forFeature([
|
ObjectMetadataRepositoryModule.forFeature([BlocklistWorkspaceEntity]),
|
||||||
ConnectedAccountWorkspaceEntity,
|
|
||||||
BlocklistWorkspaceEntity,
|
|
||||||
]),
|
|
||||||
MessagingCommonModule,
|
MessagingCommonModule,
|
||||||
TypeOrmModule.forFeature([FeatureFlagEntity], 'core'),
|
TypeOrmModule.forFeature([FeatureFlagEntity], 'core'),
|
||||||
OAuth2ClientManagerModule,
|
OAuth2ClientManagerModule,
|
||||||
|
|||||||
@@ -3,16 +3,12 @@ import { Logger, Scope } from '@nestjs/common';
|
|||||||
import { Process } from 'src/engine/core-modules/message-queue/decorators/process.decorator';
|
import { Process } from 'src/engine/core-modules/message-queue/decorators/process.decorator';
|
||||||
import { Processor } from 'src/engine/core-modules/message-queue/decorators/processor.decorator';
|
import { Processor } from 'src/engine/core-modules/message-queue/decorators/processor.decorator';
|
||||||
import { MessageQueue } from 'src/engine/core-modules/message-queue/message-queue.constants';
|
import { MessageQueue } from 'src/engine/core-modules/message-queue/message-queue.constants';
|
||||||
import { InjectObjectMetadataRepository } from 'src/engine/object-metadata-repository/object-metadata-repository.decorator';
|
|
||||||
import { TwentyORMManager } from 'src/engine/twenty-orm/twenty-orm.manager';
|
import { TwentyORMManager } from 'src/engine/twenty-orm/twenty-orm.manager';
|
||||||
import { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
|
||||||
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
|
||||||
import { isThrottled } from 'src/modules/connected-account/utils/is-throttled';
|
import { isThrottled } from 'src/modules/connected-account/utils/is-throttled';
|
||||||
import {
|
import {
|
||||||
MessageChannelSyncStage,
|
MessageChannelSyncStage,
|
||||||
MessageChannelWorkspaceEntity,
|
MessageChannelWorkspaceEntity,
|
||||||
} from 'src/modules/messaging/common/standard-objects/message-channel.workspace-entity';
|
} from 'src/modules/messaging/common/standard-objects/message-channel.workspace-entity';
|
||||||
import { MessageImportExceptionHandlerService } from 'src/modules/messaging/message-import-manager/services/message-import-exception-handler.service';
|
|
||||||
import { MessagingFullMessageListFetchService } from 'src/modules/messaging/message-import-manager/services/messaging-full-message-list-fetch.service';
|
import { MessagingFullMessageListFetchService } from 'src/modules/messaging/message-import-manager/services/messaging-full-message-list-fetch.service';
|
||||||
import { MessagingPartialMessageListFetchService } from 'src/modules/messaging/message-import-manager/services/messaging-partial-message-list-fetch.service';
|
import { MessagingPartialMessageListFetchService } from 'src/modules/messaging/message-import-manager/services/messaging-partial-message-list-fetch.service';
|
||||||
import { MessagingTelemetryService } from 'src/modules/messaging/monitoring/services/messaging-telemetry.service';
|
import { MessagingTelemetryService } from 'src/modules/messaging/monitoring/services/messaging-telemetry.service';
|
||||||
@@ -32,11 +28,8 @@ export class MessagingMessageListFetchJob {
|
|||||||
constructor(
|
constructor(
|
||||||
private readonly messagingFullMessageListFetchService: MessagingFullMessageListFetchService,
|
private readonly messagingFullMessageListFetchService: MessagingFullMessageListFetchService,
|
||||||
private readonly messagingPartialMessageListFetchService: MessagingPartialMessageListFetchService,
|
private readonly messagingPartialMessageListFetchService: MessagingPartialMessageListFetchService,
|
||||||
@InjectObjectMetadataRepository(ConnectedAccountWorkspaceEntity)
|
|
||||||
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
|
||||||
private readonly messagingTelemetryService: MessagingTelemetryService,
|
private readonly messagingTelemetryService: MessagingTelemetryService,
|
||||||
private readonly twentyORMManager: TwentyORMManager,
|
private readonly twentyORMManager: TwentyORMManager,
|
||||||
private readonly messageImportErrorHandlerService: MessageImportExceptionHandlerService,
|
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
@Process(MessagingMessageListFetchJob.name)
|
@Process(MessagingMessageListFetchJob.name)
|
||||||
@@ -60,6 +53,7 @@ export class MessagingMessageListFetchJob {
|
|||||||
where: {
|
where: {
|
||||||
id: messageChannelId,
|
id: messageChannelId,
|
||||||
},
|
},
|
||||||
|
relations: ['connectedAccount'],
|
||||||
});
|
});
|
||||||
|
|
||||||
if (!messageChannel) {
|
if (!messageChannel) {
|
||||||
@@ -72,16 +66,6 @@ export class MessagingMessageListFetchJob {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const connectedAccount =
|
|
||||||
await this.connectedAccountRepository.getByIdOrFail(
|
|
||||||
messageChannel.connectedAccountId,
|
|
||||||
workspaceId,
|
|
||||||
);
|
|
||||||
|
|
||||||
if (!messageChannel?.isSyncEnabled) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (
|
if (
|
||||||
isThrottled(
|
isThrottled(
|
||||||
messageChannel.syncStageStartedAt,
|
messageChannel.syncStageStartedAt,
|
||||||
@@ -100,20 +84,20 @@ export class MessagingMessageListFetchJob {
|
|||||||
await this.messagingTelemetryService.track({
|
await this.messagingTelemetryService.track({
|
||||||
eventName: 'partial_message_list_fetch.started',
|
eventName: 'partial_message_list_fetch.started',
|
||||||
workspaceId,
|
workspaceId,
|
||||||
connectedAccountId: connectedAccount.id,
|
connectedAccountId: messageChannel.connectedAccount.id,
|
||||||
messageChannelId: messageChannel.id,
|
messageChannelId: messageChannel.id,
|
||||||
});
|
});
|
||||||
|
|
||||||
await this.messagingPartialMessageListFetchService.processMessageListFetch(
|
await this.messagingPartialMessageListFetchService.processMessageListFetch(
|
||||||
messageChannel,
|
messageChannel,
|
||||||
connectedAccount,
|
messageChannel.connectedAccount,
|
||||||
workspaceId,
|
workspaceId,
|
||||||
);
|
);
|
||||||
|
|
||||||
await this.messagingTelemetryService.track({
|
await this.messagingTelemetryService.track({
|
||||||
eventName: 'partial_message_list_fetch.completed',
|
eventName: 'partial_message_list_fetch.completed',
|
||||||
workspaceId,
|
workspaceId,
|
||||||
connectedAccountId: connectedAccount.id,
|
connectedAccountId: messageChannel.connectedAccount.id,
|
||||||
messageChannelId: messageChannel.id,
|
messageChannelId: messageChannel.id,
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -121,26 +105,26 @@ export class MessagingMessageListFetchJob {
|
|||||||
|
|
||||||
case MessageChannelSyncStage.FULL_MESSAGE_LIST_FETCH_PENDING:
|
case MessageChannelSyncStage.FULL_MESSAGE_LIST_FETCH_PENDING:
|
||||||
this.logger.log(
|
this.logger.log(
|
||||||
`Fetching full message list for workspace ${workspaceId} and account ${connectedAccount.id}`,
|
`Fetching full message list for workspace ${workspaceId} and account ${messageChannel.connectedAccount.id}`,
|
||||||
);
|
);
|
||||||
|
|
||||||
await this.messagingTelemetryService.track({
|
await this.messagingTelemetryService.track({
|
||||||
eventName: 'full_message_list_fetch.started',
|
eventName: 'full_message_list_fetch.started',
|
||||||
workspaceId,
|
workspaceId,
|
||||||
connectedAccountId: connectedAccount.id,
|
connectedAccountId: messageChannel.connectedAccount.id,
|
||||||
messageChannelId: messageChannel.id,
|
messageChannelId: messageChannel.id,
|
||||||
});
|
});
|
||||||
|
|
||||||
await this.messagingFullMessageListFetchService.processMessageListFetch(
|
await this.messagingFullMessageListFetchService.processMessageListFetch(
|
||||||
messageChannel,
|
messageChannel,
|
||||||
connectedAccount,
|
messageChannel.connectedAccount,
|
||||||
workspaceId,
|
workspaceId,
|
||||||
);
|
);
|
||||||
|
|
||||||
await this.messagingTelemetryService.track({
|
await this.messagingTelemetryService.track({
|
||||||
eventName: 'full_message_list_fetch.completed',
|
eventName: 'full_message_list_fetch.completed',
|
||||||
workspaceId,
|
workspaceId,
|
||||||
connectedAccountId: connectedAccount.id,
|
connectedAccountId: messageChannel.connectedAccount.id,
|
||||||
messageChannelId: messageChannel.id,
|
messageChannelId: messageChannel.id,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -3,16 +3,12 @@ import { Scope } from '@nestjs/common';
|
|||||||
import { Process } from 'src/engine/core-modules/message-queue/decorators/process.decorator';
|
import { Process } from 'src/engine/core-modules/message-queue/decorators/process.decorator';
|
||||||
import { Processor } from 'src/engine/core-modules/message-queue/decorators/processor.decorator';
|
import { Processor } from 'src/engine/core-modules/message-queue/decorators/processor.decorator';
|
||||||
import { MessageQueue } from 'src/engine/core-modules/message-queue/message-queue.constants';
|
import { MessageQueue } from 'src/engine/core-modules/message-queue/message-queue.constants';
|
||||||
import { InjectObjectMetadataRepository } from 'src/engine/object-metadata-repository/object-metadata-repository.decorator';
|
|
||||||
import { TwentyORMManager } from 'src/engine/twenty-orm/twenty-orm.manager';
|
import { TwentyORMManager } from 'src/engine/twenty-orm/twenty-orm.manager';
|
||||||
import { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
|
||||||
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
|
||||||
import { isThrottled } from 'src/modules/connected-account/utils/is-throttled';
|
import { isThrottled } from 'src/modules/connected-account/utils/is-throttled';
|
||||||
import {
|
import {
|
||||||
MessageChannelSyncStage,
|
MessageChannelSyncStage,
|
||||||
MessageChannelWorkspaceEntity,
|
MessageChannelWorkspaceEntity,
|
||||||
} from 'src/modules/messaging/common/standard-objects/message-channel.workspace-entity';
|
} from 'src/modules/messaging/common/standard-objects/message-channel.workspace-entity';
|
||||||
import { MessageImportExceptionHandlerService } from 'src/modules/messaging/message-import-manager/services/message-import-exception-handler.service';
|
|
||||||
import { MessagingMessagesImportService } from 'src/modules/messaging/message-import-manager/services/messaging-messages-import.service';
|
import { MessagingMessagesImportService } from 'src/modules/messaging/message-import-manager/services/messaging-messages-import.service';
|
||||||
import { MessagingTelemetryService } from 'src/modules/messaging/monitoring/services/messaging-telemetry.service';
|
import { MessagingTelemetryService } from 'src/modules/messaging/monitoring/services/messaging-telemetry.service';
|
||||||
|
|
||||||
@@ -27,12 +23,9 @@ export type MessagingMessagesImportJobData = {
|
|||||||
})
|
})
|
||||||
export class MessagingMessagesImportJob {
|
export class MessagingMessagesImportJob {
|
||||||
constructor(
|
constructor(
|
||||||
@InjectObjectMetadataRepository(ConnectedAccountWorkspaceEntity)
|
|
||||||
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
|
||||||
private readonly messagingMessagesImportService: MessagingMessagesImportService,
|
private readonly messagingMessagesImportService: MessagingMessagesImportService,
|
||||||
private readonly messagingTelemetryService: MessagingTelemetryService,
|
private readonly messagingTelemetryService: MessagingTelemetryService,
|
||||||
private readonly twentyORMManager: TwentyORMManager,
|
private readonly twentyORMManager: TwentyORMManager,
|
||||||
private readonly messageImportErrorHandlerService: MessageImportExceptionHandlerService,
|
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
@Process(MessagingMessagesImportJob.name)
|
@Process(MessagingMessagesImportJob.name)
|
||||||
@@ -56,6 +49,7 @@ export class MessagingMessagesImportJob {
|
|||||||
where: {
|
where: {
|
||||||
id: messageChannelId,
|
id: messageChannelId,
|
||||||
},
|
},
|
||||||
|
relations: ['connectedAccount'],
|
||||||
});
|
});
|
||||||
|
|
||||||
if (!messageChannel) {
|
if (!messageChannel) {
|
||||||
@@ -68,12 +62,6 @@ export class MessagingMessagesImportJob {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const connectedAccount =
|
|
||||||
await this.connectedAccountRepository.getConnectedAccountOrThrow(
|
|
||||||
workspaceId,
|
|
||||||
messageChannel.connectedAccountId,
|
|
||||||
);
|
|
||||||
|
|
||||||
if (!messageChannel?.isSyncEnabled) {
|
if (!messageChannel?.isSyncEnabled) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -96,7 +84,7 @@ export class MessagingMessagesImportJob {
|
|||||||
|
|
||||||
await this.messagingMessagesImportService.processMessageBatchImport(
|
await this.messagingMessagesImportService.processMessageBatchImport(
|
||||||
messageChannel,
|
messageChannel,
|
||||||
connectedAccount,
|
messageChannel.connectedAccount,
|
||||||
workspaceId,
|
workspaceId,
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|||||||
@@ -110,7 +110,6 @@ export class MessagingMessagesImportService {
|
|||||||
|
|
||||||
await this.emailAliasManagerService.refreshHandleAliases(
|
await this.emailAliasManagerService.refreshHandleAliases(
|
||||||
connectedAccount,
|
connectedAccount,
|
||||||
workspaceId,
|
|
||||||
);
|
);
|
||||||
|
|
||||||
messageIdsToFetch = await this.cacheStorage.setPop(
|
messageIdsToFetch = await this.cacheStorage.setPop(
|
||||||
|
|||||||
@@ -6,9 +6,7 @@ import { Process } from 'src/engine/core-modules/message-queue/decorators/proces
|
|||||||
import { Processor } from 'src/engine/core-modules/message-queue/decorators/processor.decorator';
|
import { Processor } from 'src/engine/core-modules/message-queue/decorators/processor.decorator';
|
||||||
import { MessageQueue } from 'src/engine/core-modules/message-queue/message-queue.constants';
|
import { MessageQueue } from 'src/engine/core-modules/message-queue/message-queue.constants';
|
||||||
import { FieldActorSource } from 'src/engine/metadata-modules/field-metadata/composite-types/actor.composite-type';
|
import { FieldActorSource } from 'src/engine/metadata-modules/field-metadata/composite-types/actor.composite-type';
|
||||||
import { InjectObjectMetadataRepository } from 'src/engine/object-metadata-repository/object-metadata-repository.decorator';
|
|
||||||
import { TwentyORMManager } from 'src/engine/twenty-orm/twenty-orm.manager';
|
import { TwentyORMManager } from 'src/engine/twenty-orm/twenty-orm.manager';
|
||||||
import { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
|
||||||
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
import { CreateCompanyAndContactService } from 'src/modules/contact-creation-manager/services/create-company-and-contact.service';
|
import { CreateCompanyAndContactService } from 'src/modules/contact-creation-manager/services/create-company-and-contact.service';
|
||||||
import { MessageDirection } from 'src/modules/messaging/common/enums/message-direction.enum';
|
import { MessageDirection } from 'src/modules/messaging/common/enums/message-direction.enum';
|
||||||
@@ -30,8 +28,6 @@ export class MessagingCreateCompanyAndContactAfterSyncJob {
|
|||||||
);
|
);
|
||||||
constructor(
|
constructor(
|
||||||
private readonly createCompanyAndContactService: CreateCompanyAndContactService,
|
private readonly createCompanyAndContactService: CreateCompanyAndContactService,
|
||||||
@InjectObjectMetadataRepository(ConnectedAccountWorkspaceEntity)
|
|
||||||
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
|
||||||
private readonly twentyORMManager: TwentyORMManager,
|
private readonly twentyORMManager: TwentyORMManager,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
@@ -63,11 +59,17 @@ export class MessagingCreateCompanyAndContactAfterSyncJob {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const connectedAccount = await this.connectedAccountRepository.getById(
|
const connectedAccountRepository =
|
||||||
connectedAccountId,
|
await this.twentyORMManager.getRepository<ConnectedAccountWorkspaceEntity>(
|
||||||
workspaceId,
|
'connectedAccount',
|
||||||
);
|
);
|
||||||
|
|
||||||
|
const connectedAccount = await connectedAccountRepository.findOne({
|
||||||
|
where: {
|
||||||
|
id: connectedAccountId,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
if (!connectedAccount) {
|
if (!connectedAccount) {
|
||||||
throw new Error(
|
throw new Error(
|
||||||
`Connected account with id ${connectedAccountId} not found in workspace ${workspaceId}`,
|
`Connected account with id ${connectedAccountId} not found in workspace ${workspaceId}`,
|
||||||
|
|||||||
Reference in New Issue
Block a user