fix: multiple twenty orm issues & show an example of use (#5439)
This PR is fixing some issues and adding enhancement in TwentyORM: - [x] Composite fields in nested relations are not formatted properly - [x] Passing operators like `Any` in `where` condition is breaking the query - [x] Ability to auto load workspace-entities based on a regex path I've also introduced an example of use for `CalendarEventService`: https://github.com/twentyhq/twenty/pull/5439/files#diff-3a7dffc0dea57345d10e70c648e911f98fe237248bcea124dafa9c8deb1db748R15
This commit is contained in:
@ -2,7 +2,7 @@ import { EntityManager } from 'typeorm';
|
|||||||
|
|
||||||
import { DEV_SEED_PERSON_IDS } from 'src/database/typeorm-seeds/workspace/people';
|
import { DEV_SEED_PERSON_IDS } from 'src/database/typeorm-seeds/workspace/people';
|
||||||
import { DEV_SEED_WORKSPACE_MEMBER_IDS } from 'src/database/typeorm-seeds/workspace/workspace-members';
|
import { DEV_SEED_WORKSPACE_MEMBER_IDS } from 'src/database/typeorm-seeds/workspace/workspace-members';
|
||||||
import { CalendarEventParticipantResponseStatus } from 'src/modules/calendar/standard-objects/calendar-event-participant.object-metadata';
|
import { CalendarEventParticipantResponseStatus } from 'src/modules/calendar/standard-objects/calendar-event-participant.workspace-entity';
|
||||||
|
|
||||||
const tableName = 'calendarEventParticipant';
|
const tableName = 'calendarEventParticipant';
|
||||||
|
|
||||||
|
|||||||
@ -9,7 +9,7 @@ import { RecordPositionListener } from 'src/engine/api/graphql/workspace-query-r
|
|||||||
import { AuthModule } from 'src/engine/core-modules/auth/auth.module';
|
import { AuthModule } from 'src/engine/core-modules/auth/auth.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 { Workspace } from 'src/engine/core-modules/workspace/workspace.entity';
|
import { Workspace } from 'src/engine/core-modules/workspace/workspace.entity';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
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 { TelemetryListener } from 'src/engine/api/graphql/workspace-query-runner/listeners/telemetry.listener';
|
import { TelemetryListener } from 'src/engine/api/graphql/workspace-query-runner/listeners/telemetry.listener';
|
||||||
import { AnalyticsModule } from 'src/engine/core-modules/analytics/analytics.module';
|
import { AnalyticsModule } from 'src/engine/core-modules/analytics/analytics.module';
|
||||||
@ -25,7 +25,7 @@ import { EntityEventsToDbListener } from './listeners/entity-events-to-db.listen
|
|||||||
WorkspaceDataSourceModule,
|
WorkspaceDataSourceModule,
|
||||||
WorkspacePreQueryHookModule,
|
WorkspacePreQueryHookModule,
|
||||||
TypeOrmModule.forFeature([Workspace, FeatureFlagEntity], 'core'),
|
TypeOrmModule.forFeature([Workspace, FeatureFlagEntity], 'core'),
|
||||||
ObjectMetadataRepositoryModule.forFeature([WorkspaceMemberObjectMetadata]),
|
ObjectMetadataRepositoryModule.forFeature([WorkspaceMemberWorkspaceEntity]),
|
||||||
AnalyticsModule,
|
AnalyticsModule,
|
||||||
],
|
],
|
||||||
providers: [
|
providers: [
|
||||||
|
|||||||
@ -24,9 +24,9 @@ import { FileUploadModule } from 'src/engine/core-modules/file/file-upload/file-
|
|||||||
import { MicrosoftAuthController } from 'src/engine/core-modules/auth/controllers/microsoft-auth.controller';
|
import { MicrosoftAuthController } from 'src/engine/core-modules/auth/controllers/microsoft-auth.controller';
|
||||||
import { AppTokenService } from 'src/engine/core-modules/app-token/services/app-token.service';
|
import { AppTokenService } from 'src/engine/core-modules/app-token/services/app-token.service';
|
||||||
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 { ConnectedAccountObjectMetadata } from 'src/modules/connected-account/standard-objects/connected-account.object-metadata';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
import { MessageChannelObjectMetadata } from 'src/modules/messaging/standard-objects/message-channel.object-metadata';
|
import { MessageChannelWorkspaceEntity } from 'src/modules/messaging/standard-objects/message-channel.workspace-entity';
|
||||||
import { CalendarChannelObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel.object-metadata';
|
import { CalendarChannelWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel.workspace-entity';
|
||||||
|
|
||||||
import { AuthResolver } from './auth.resolver';
|
import { AuthResolver } from './auth.resolver';
|
||||||
|
|
||||||
@ -57,9 +57,9 @@ const jwtModule = JwtModule.registerAsync({
|
|||||||
'core',
|
'core',
|
||||||
),
|
),
|
||||||
ObjectMetadataRepositoryModule.forFeature([
|
ObjectMetadataRepositoryModule.forFeature([
|
||||||
ConnectedAccountObjectMetadata,
|
ConnectedAccountWorkspaceEntity,
|
||||||
MessageChannelObjectMetadata,
|
MessageChannelWorkspaceEntity,
|
||||||
CalendarChannelObjectMetadata,
|
CalendarChannelWorkspaceEntity,
|
||||||
]),
|
]),
|
||||||
HttpModule,
|
HttpModule,
|
||||||
UserWorkspaceModule,
|
UserWorkspaceModule,
|
||||||
|
|||||||
@ -17,20 +17,20 @@ import {
|
|||||||
} from 'src/modules/calendar/jobs/google-calendar-sync.job';
|
} from 'src/modules/calendar/jobs/google-calendar-sync.job';
|
||||||
import { CalendarChannelRepository } from 'src/modules/calendar/repositories/calendar-channel.repository';
|
import { CalendarChannelRepository } from 'src/modules/calendar/repositories/calendar-channel.repository';
|
||||||
import {
|
import {
|
||||||
CalendarChannelObjectMetadata,
|
CalendarChannelWorkspaceEntity,
|
||||||
CalendarChannelVisibility,
|
CalendarChannelVisibility,
|
||||||
} from 'src/modules/calendar/standard-objects/calendar-channel.object-metadata';
|
} from 'src/modules/calendar/standard-objects/calendar-channel.workspace-entity';
|
||||||
import { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
import { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
||||||
import {
|
import {
|
||||||
ConnectedAccountObjectMetadata,
|
ConnectedAccountWorkspaceEntity,
|
||||||
ConnectedAccountProvider,
|
ConnectedAccountProvider,
|
||||||
} from 'src/modules/connected-account/standard-objects/connected-account.object-metadata';
|
} from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
import { MessageChannelRepository } from 'src/modules/messaging/repositories/message-channel.repository';
|
import { MessageChannelRepository } from 'src/modules/messaging/repositories/message-channel.repository';
|
||||||
import {
|
import {
|
||||||
MessageChannelObjectMetadata,
|
MessageChannelWorkspaceEntity,
|
||||||
MessageChannelType,
|
MessageChannelType,
|
||||||
MessageChannelVisibility,
|
MessageChannelVisibility,
|
||||||
} from 'src/modules/messaging/standard-objects/message-channel.object-metadata';
|
} from 'src/modules/messaging/standard-objects/message-channel.workspace-entity';
|
||||||
import {
|
import {
|
||||||
GmailFullSyncJobData,
|
GmailFullSyncJobData,
|
||||||
GmailFullSyncJob,
|
GmailFullSyncJob,
|
||||||
@ -48,11 +48,11 @@ export class GoogleAPIsService {
|
|||||||
private readonly environmentService: EnvironmentService,
|
private readonly environmentService: EnvironmentService,
|
||||||
@InjectRepository(FeatureFlagEntity, 'core')
|
@InjectRepository(FeatureFlagEntity, 'core')
|
||||||
private readonly featureFlagRepository: Repository<FeatureFlagEntity>,
|
private readonly featureFlagRepository: Repository<FeatureFlagEntity>,
|
||||||
@InjectObjectMetadataRepository(ConnectedAccountObjectMetadata)
|
@InjectObjectMetadataRepository(ConnectedAccountWorkspaceEntity)
|
||||||
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
||||||
@InjectObjectMetadataRepository(MessageChannelObjectMetadata)
|
@InjectObjectMetadataRepository(MessageChannelWorkspaceEntity)
|
||||||
private readonly messageChannelRepository: MessageChannelRepository,
|
private readonly messageChannelRepository: MessageChannelRepository,
|
||||||
@InjectObjectMetadataRepository(CalendarChannelObjectMetadata)
|
@InjectObjectMetadataRepository(CalendarChannelWorkspaceEntity)
|
||||||
private readonly calendarChannelRepository: CalendarChannelRepository,
|
private readonly calendarChannelRepository: CalendarChannelRepository,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
|
|||||||
@ -4,7 +4,7 @@ import { OnEvent } from '@nestjs/event-emitter';
|
|||||||
import { MessageQueue } from 'src/engine/integrations/message-queue/message-queue.constants';
|
import { MessageQueue } from 'src/engine/integrations/message-queue/message-queue.constants';
|
||||||
import { MessageQueueService } from 'src/engine/integrations/message-queue/services/message-queue.service';
|
import { MessageQueueService } from 'src/engine/integrations/message-queue/services/message-queue.service';
|
||||||
import { ObjectRecordCreateEvent } from 'src/engine/integrations/event-emitter/types/object-record-create.event';
|
import { ObjectRecordCreateEvent } from 'src/engine/integrations/event-emitter/types/object-record-create.event';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
import {
|
import {
|
||||||
UpdateSubscriptionJob,
|
UpdateSubscriptionJob,
|
||||||
UpdateSubscriptionJobData,
|
UpdateSubscriptionJobData,
|
||||||
@ -22,7 +22,7 @@ export class BillingWorkspaceMemberListener {
|
|||||||
@OnEvent('workspaceMember.created')
|
@OnEvent('workspaceMember.created')
|
||||||
@OnEvent('workspaceMember.deleted')
|
@OnEvent('workspaceMember.deleted')
|
||||||
async handleCreateOrDeleteEvent(
|
async handleCreateOrDeleteEvent(
|
||||||
payload: ObjectRecordCreateEvent<WorkspaceMemberObjectMetadata>,
|
payload: ObjectRecordCreateEvent<WorkspaceMemberWorkspaceEntity>,
|
||||||
) {
|
) {
|
||||||
if (!this.environmentService.get('IS_BILLING_ENABLED')) {
|
if (!this.environmentService.get('IS_BILLING_ENABLED')) {
|
||||||
return;
|
return;
|
||||||
|
|||||||
@ -1,12 +1,20 @@
|
|||||||
import { Module } from '@nestjs/common';
|
import { Module } from '@nestjs/common';
|
||||||
|
|
||||||
import { WorkspaceDataSourceModule } from 'src/engine/workspace-datasource/workspace-datasource.module';
|
|
||||||
import { UserModule } from 'src/engine/core-modules/user/user.module';
|
import { UserModule } from 'src/engine/core-modules/user/user.module';
|
||||||
import { TimelineCalendarEventResolver } from 'src/engine/core-modules/calendar/timeline-calendar-event.resolver';
|
import { TimelineCalendarEventResolver } from 'src/engine/core-modules/calendar/timeline-calendar-event.resolver';
|
||||||
import { TimelineCalendarEventService } from 'src/engine/core-modules/calendar/timeline-calendar-event.service';
|
import { TimelineCalendarEventService } from 'src/engine/core-modules/calendar/timeline-calendar-event.service';
|
||||||
|
import { TwentyORMModule } from 'src/engine/twenty-orm/twenty-orm.module';
|
||||||
|
import { CalendarEventWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event.workspace-entity';
|
||||||
|
import { PersonWorkspaceEntity } from 'src/modules/person/standard-objects/person.workspace-entity';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [WorkspaceDataSourceModule, UserModule],
|
imports: [
|
||||||
|
TwentyORMModule.forFeature([
|
||||||
|
CalendarEventWorkspaceEntity,
|
||||||
|
PersonWorkspaceEntity,
|
||||||
|
]),
|
||||||
|
UserModule,
|
||||||
|
],
|
||||||
exports: [],
|
exports: [],
|
||||||
providers: [TimelineCalendarEventResolver, TimelineCalendarEventService],
|
providers: [TimelineCalendarEventResolver, TimelineCalendarEventService],
|
||||||
})
|
})
|
||||||
|
|||||||
@ -5,14 +5,11 @@ import { Max } from 'class-validator';
|
|||||||
|
|
||||||
import { User } from 'src/engine/core-modules/user/user.entity';
|
import { User } from 'src/engine/core-modules/user/user.entity';
|
||||||
import { AuthUser } from 'src/engine/decorators/auth/auth-user.decorator';
|
import { AuthUser } from 'src/engine/decorators/auth/auth-user.decorator';
|
||||||
import { AuthWorkspace } from 'src/engine/decorators/auth/auth-workspace.decorator';
|
|
||||||
import { JwtAuthGuard } from 'src/engine/guards/jwt.auth.guard';
|
import { JwtAuthGuard } from 'src/engine/guards/jwt.auth.guard';
|
||||||
import { TIMELINE_CALENDAR_EVENTS_MAX_PAGE_SIZE } from 'src/engine/core-modules/calendar/constants/calendar.constants';
|
import { TIMELINE_CALENDAR_EVENTS_MAX_PAGE_SIZE } from 'src/engine/core-modules/calendar/constants/calendar.constants';
|
||||||
import { TimelineCalendarEventsWithTotal } from 'src/engine/core-modules/calendar/dtos/timeline-calendar-events-with-total.dto';
|
import { TimelineCalendarEventsWithTotal } from 'src/engine/core-modules/calendar/dtos/timeline-calendar-events-with-total.dto';
|
||||||
import { TimelineCalendarEventService } from 'src/engine/core-modules/calendar/timeline-calendar-event.service';
|
import { TimelineCalendarEventService } from 'src/engine/core-modules/calendar/timeline-calendar-event.service';
|
||||||
import { UserService } from 'src/engine/core-modules/user/services/user.service';
|
import { UserService } from 'src/engine/core-modules/user/services/user.service';
|
||||||
import { Workspace } from 'src/engine/core-modules/workspace/workspace.entity';
|
|
||||||
import { NotFoundError } from 'src/engine/utils/graphql-errors.util';
|
|
||||||
import { UUIDScalarType } from 'src/engine/api/graphql/workspace-schema-builder/graphql-types/scalars';
|
import { UUIDScalarType } from 'src/engine/api/graphql/workspace-schema-builder/graphql-types/scalars';
|
||||||
|
|
||||||
@ArgsType()
|
@ArgsType()
|
||||||
@ -51,21 +48,12 @@ export class TimelineCalendarEventResolver {
|
|||||||
|
|
||||||
@Query(() => TimelineCalendarEventsWithTotal)
|
@Query(() => TimelineCalendarEventsWithTotal)
|
||||||
async getTimelineCalendarEventsFromPersonId(
|
async getTimelineCalendarEventsFromPersonId(
|
||||||
@AuthWorkspace() { id: workspaceId }: Workspace,
|
|
||||||
@AuthUser() user: User,
|
@AuthUser() user: User,
|
||||||
@Args()
|
@Args()
|
||||||
{ personId, page, pageSize }: GetTimelineCalendarEventsFromPersonIdArgs,
|
{ personId, page, pageSize }: GetTimelineCalendarEventsFromPersonIdArgs,
|
||||||
) {
|
) {
|
||||||
const workspaceMember = await this.userService.loadWorkspaceMember(user);
|
|
||||||
|
|
||||||
if (!workspaceMember) {
|
|
||||||
throw new NotFoundError('Workspace member not found');
|
|
||||||
}
|
|
||||||
|
|
||||||
const timelineCalendarEvents =
|
const timelineCalendarEvents =
|
||||||
await this.timelineCalendarEventService.getCalendarEventsFromPersonIds(
|
await this.timelineCalendarEventService.getCalendarEventsFromPersonIds(
|
||||||
workspaceMember.id,
|
|
||||||
workspaceId,
|
|
||||||
[personId],
|
[personId],
|
||||||
page,
|
page,
|
||||||
pageSize,
|
pageSize,
|
||||||
@ -76,21 +64,12 @@ export class TimelineCalendarEventResolver {
|
|||||||
|
|
||||||
@Query(() => TimelineCalendarEventsWithTotal)
|
@Query(() => TimelineCalendarEventsWithTotal)
|
||||||
async getTimelineCalendarEventsFromCompanyId(
|
async getTimelineCalendarEventsFromCompanyId(
|
||||||
@AuthWorkspace() { id: workspaceId }: Workspace,
|
|
||||||
@AuthUser() user: User,
|
@AuthUser() user: User,
|
||||||
@Args()
|
@Args()
|
||||||
{ companyId, page, pageSize }: GetTimelineCalendarEventsFromCompanyIdArgs,
|
{ companyId, page, pageSize }: GetTimelineCalendarEventsFromCompanyIdArgs,
|
||||||
) {
|
) {
|
||||||
const workspaceMember = await this.userService.loadWorkspaceMember(user);
|
|
||||||
|
|
||||||
if (!workspaceMember) {
|
|
||||||
throw new NotFoundError('Workspace member not found');
|
|
||||||
}
|
|
||||||
|
|
||||||
const timelineCalendarEvents =
|
const timelineCalendarEvents =
|
||||||
await this.timelineCalendarEventService.getCalendarEventsFromCompanyId(
|
await this.timelineCalendarEventService.getCalendarEventsFromCompanyId(
|
||||||
workspaceMember.id,
|
|
||||||
workspaceId,
|
|
||||||
companyId,
|
companyId,
|
||||||
page,
|
page,
|
||||||
pageSize,
|
pageSize,
|
||||||
|
|||||||
@ -1,272 +1,159 @@
|
|||||||
import { Injectable } from '@nestjs/common';
|
import { Injectable } from '@nestjs/common';
|
||||||
|
|
||||||
import groupBy from 'lodash.groupby';
|
import { Any } from 'typeorm';
|
||||||
|
import omit from 'lodash.omit';
|
||||||
|
|
||||||
import { TIMELINE_CALENDAR_EVENTS_DEFAULT_PAGE_SIZE } from 'src/engine/core-modules/calendar/constants/calendar.constants';
|
import { TIMELINE_CALENDAR_EVENTS_DEFAULT_PAGE_SIZE } from 'src/engine/core-modules/calendar/constants/calendar.constants';
|
||||||
import { TimelineCalendarEventParticipant } from 'src/engine/core-modules/calendar/dtos/timeline-calendar-event-participant.dto';
|
import { TimelineCalendarEventVisibility } from 'src/engine/core-modules/calendar/dtos/timeline-calendar-event.dto';
|
||||||
import {
|
|
||||||
TimelineCalendarEvent,
|
|
||||||
TimelineCalendarEventVisibility,
|
|
||||||
} from 'src/engine/core-modules/calendar/dtos/timeline-calendar-event.dto';
|
|
||||||
import { TimelineCalendarEventsWithTotal } from 'src/engine/core-modules/calendar/dtos/timeline-calendar-events-with-total.dto';
|
import { TimelineCalendarEventsWithTotal } from 'src/engine/core-modules/calendar/dtos/timeline-calendar-events-with-total.dto';
|
||||||
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
import { InjectWorkspaceRepository } from 'src/engine/twenty-orm/decorators/inject-workspace-repository.decorator';
|
||||||
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
import { WorkspaceRepository } from 'src/engine/twenty-orm/repository/workspace.repository';
|
||||||
import { CalendarEventParticipantObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event-participant.object-metadata';
|
import { CalendarEventWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event.workspace-entity';
|
||||||
|
import { PersonWorkspaceEntity } from 'src/modules/person/standard-objects/person.workspace-entity';
|
||||||
|
|
||||||
type TimelineCalendarEventParticipantWithPersonInformation =
|
|
||||||
ObjectRecord<CalendarEventParticipantObjectMetadata> & {
|
|
||||||
personFirstName: string;
|
|
||||||
personLastName: string;
|
|
||||||
personAvatarUrl: string;
|
|
||||||
workspaceMemberFirstName: string;
|
|
||||||
workspaceMemberLastName: string;
|
|
||||||
workspaceMemberAvatarUrl: string;
|
|
||||||
};
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class TimelineCalendarEventService {
|
export class TimelineCalendarEventService {
|
||||||
constructor(
|
constructor(
|
||||||
private readonly workspaceDataSourceService: WorkspaceDataSourceService,
|
@InjectWorkspaceRepository(CalendarEventWorkspaceEntity)
|
||||||
|
private readonly calendarEventRepository: WorkspaceRepository<CalendarEventWorkspaceEntity>,
|
||||||
|
@InjectWorkspaceRepository(PersonWorkspaceEntity)
|
||||||
|
private readonly personRepository: WorkspaceRepository<PersonWorkspaceEntity>,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
|
// TODO: Align return type with the entities to avoid mapping
|
||||||
async getCalendarEventsFromPersonIds(
|
async getCalendarEventsFromPersonIds(
|
||||||
workspaceMemberId: string,
|
|
||||||
workspaceId: string,
|
|
||||||
personIds: string[],
|
personIds: string[],
|
||||||
page = 1,
|
page = 1,
|
||||||
pageSize: number = TIMELINE_CALENDAR_EVENTS_DEFAULT_PAGE_SIZE,
|
pageSize: number = TIMELINE_CALENDAR_EVENTS_DEFAULT_PAGE_SIZE,
|
||||||
): Promise<TimelineCalendarEventsWithTotal> {
|
): Promise<TimelineCalendarEventsWithTotal> {
|
||||||
const offset = (page - 1) * pageSize;
|
const offset = (page - 1) * pageSize;
|
||||||
|
|
||||||
const dataSourceSchema =
|
const calendarEventIds = await this.calendarEventRepository.find({
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
where: {
|
||||||
|
calendarEventParticipants: {
|
||||||
|
person: {
|
||||||
|
id: Any(personIds),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
select: {
|
||||||
|
id: true,
|
||||||
|
startsAt: true,
|
||||||
|
},
|
||||||
|
skip: offset,
|
||||||
|
take: pageSize,
|
||||||
|
order: {
|
||||||
|
startsAt: 'DESC',
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
const calendarEvents: Omit<TimelineCalendarEvent, 'participants'>[] =
|
const ids = calendarEventIds.map(({ id }) => id);
|
||||||
await this.workspaceDataSourceService.executeRawQuery(
|
|
||||||
`SELECT
|
|
||||||
"calendarEvent".*
|
|
||||||
FROM
|
|
||||||
${dataSourceSchema}."calendarEvent" "calendarEvent"
|
|
||||||
LEFT JOIN
|
|
||||||
${dataSourceSchema}."calendarEventParticipant" "calendarEventParticipant" ON "calendarEvent".id = "calendarEventParticipant"."calendarEventId"
|
|
||||||
LEFT JOIN
|
|
||||||
${dataSourceSchema}."person" "person" ON "calendarEventParticipant"."personId" = "person".id
|
|
||||||
WHERE
|
|
||||||
"calendarEventParticipant"."personId" = ANY($1)
|
|
||||||
GROUP BY
|
|
||||||
"calendarEvent".id
|
|
||||||
ORDER BY
|
|
||||||
"calendarEvent"."startsAt" DESC
|
|
||||||
LIMIT $2
|
|
||||||
OFFSET $3`,
|
|
||||||
[personIds, pageSize, offset],
|
|
||||||
workspaceId,
|
|
||||||
);
|
|
||||||
|
|
||||||
if (!calendarEvents) {
|
if (ids.length <= 0) {
|
||||||
return {
|
return {
|
||||||
totalNumberOfCalendarEvents: 0,
|
totalNumberOfCalendarEvents: 0,
|
||||||
timelineCalendarEvents: [],
|
timelineCalendarEvents: [],
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
const calendarEventParticipants: TimelineCalendarEventParticipantWithPersonInformation[] =
|
// We've split the query into two parts, because we want to fetch all the participants without any filtering
|
||||||
await this.workspaceDataSourceService.executeRawQuery(
|
const [events, total] = await this.calendarEventRepository.findAndCount({
|
||||||
`SELECT
|
where: {
|
||||||
"calendarEventParticipant".*,
|
id: Any(ids),
|
||||||
"person"."nameFirstName" as "personFirstName",
|
},
|
||||||
"person"."nameLastName" as "personLastName",
|
relations: {
|
||||||
"person"."avatarUrl" as "personAvatarUrl",
|
calendarEventParticipants: {
|
||||||
"workspaceMember"."nameFirstName" as "workspaceMemberFirstName",
|
person: true,
|
||||||
"workspaceMember"."nameLastName" as "workspaceMemberLastName",
|
workspaceMember: true,
|
||||||
"workspaceMember"."avatarUrl" as "workspaceMemberAvatarUrl"
|
},
|
||||||
FROM
|
calendarChannelEventAssociations: {
|
||||||
${dataSourceSchema}."calendarEventParticipant" "calendarEventParticipant"
|
calendarChannel: true,
|
||||||
LEFT JOIN
|
},
|
||||||
${dataSourceSchema}."person" "person" ON "calendarEventParticipant"."personId" = "person".id
|
},
|
||||||
LEFT JOIN
|
});
|
||||||
${dataSourceSchema}."workspaceMember" "workspaceMember" ON "calendarEventParticipant"."workspaceMemberId" = "workspaceMember".id
|
|
||||||
WHERE
|
|
||||||
"calendarEventParticipant"."calendarEventId" = ANY($1)`,
|
|
||||||
[calendarEvents.map((event) => event.id)],
|
|
||||||
workspaceId,
|
|
||||||
);
|
|
||||||
|
|
||||||
const formattedCalendarEventParticipants: TimelineCalendarEventParticipant[] =
|
// Keep events in the same order as they ids were returned
|
||||||
calendarEventParticipants.map((participant) => {
|
const orderedEvents = events.sort(
|
||||||
const firstName =
|
(a, b) => ids.indexOf(a.id) - ids.indexOf(b.id),
|
||||||
participant.personFirstName ||
|
);
|
||||||
participant.workspaceMemberFirstName ||
|
|
||||||
'';
|
|
||||||
|
|
||||||
const lastName =
|
const timelineCalendarEvents = orderedEvents.map((event) => {
|
||||||
participant.personLastName ||
|
const participants = event.calendarEventParticipants.map(
|
||||||
participant.workspaceMemberLastName ||
|
(participant) => ({
|
||||||
'';
|
calendarEventId: event.id,
|
||||||
|
personId: participant.person?.id,
|
||||||
const displayName =
|
workspaceMemberId: participant.workspaceMember?.id,
|
||||||
firstName || participant.displayName || participant.handle;
|
firstName:
|
||||||
|
participant.person?.name.firstName ||
|
||||||
const avatarUrl =
|
participant.workspaceMember?.name.firstName ||
|
||||||
participant.personAvatarUrl ||
|
'',
|
||||||
participant.workspaceMemberAvatarUrl ||
|
lastName:
|
||||||
'';
|
participant.person?.name.lastName ||
|
||||||
|
participant.workspaceMember?.name.lastName ||
|
||||||
return {
|
'',
|
||||||
calendarEventId: participant.calendarEventId,
|
displayName:
|
||||||
personId: participant.personId,
|
participant.person?.name.firstName ||
|
||||||
workspaceMemberId: participant.workspaceMemberId,
|
participant.person?.name.lastName ||
|
||||||
firstName,
|
participant.workspaceMember?.name.firstName ||
|
||||||
lastName,
|
participant.workspaceMember?.name.lastName ||
|
||||||
displayName,
|
'',
|
||||||
avatarUrl,
|
avatarUrl:
|
||||||
|
participant.person?.avatarUrl ||
|
||||||
|
participant.workspaceMember?.avatarUrl ||
|
||||||
|
'',
|
||||||
handle: participant.handle,
|
handle: participant.handle,
|
||||||
};
|
}),
|
||||||
});
|
|
||||||
|
|
||||||
const calendarEventParticipantsByEventId: {
|
|
||||||
[calendarEventId: string]: TimelineCalendarEventParticipant[];
|
|
||||||
} = groupBy(formattedCalendarEventParticipants, 'calendarEventId');
|
|
||||||
|
|
||||||
const totalNumberOfCalendarEvents: { count: number }[] =
|
|
||||||
await this.workspaceDataSourceService.executeRawQuery(
|
|
||||||
`
|
|
||||||
SELECT
|
|
||||||
COUNT(DISTINCT "calendarEventId")
|
|
||||||
FROM
|
|
||||||
${dataSourceSchema}."calendarEventParticipant" "calendarEventParticipant"
|
|
||||||
WHERE
|
|
||||||
"calendarEventParticipant"."personId" = ANY($1)
|
|
||||||
`,
|
|
||||||
[personIds],
|
|
||||||
workspaceId,
|
|
||||||
);
|
);
|
||||||
|
const visibility = event.calendarChannelEventAssociations.some(
|
||||||
const timelineCalendarEvents = calendarEvents.map((event) => {
|
(association) => association.calendarChannel.visibility === 'METADATA',
|
||||||
const participants = calendarEventParticipantsByEventId[event.id] || [];
|
)
|
||||||
|
? TimelineCalendarEventVisibility.METADATA
|
||||||
|
: TimelineCalendarEventVisibility.SHARE_EVERYTHING;
|
||||||
|
|
||||||
return {
|
return {
|
||||||
...event,
|
...omit(event, [
|
||||||
|
'calendarEventParticipants',
|
||||||
|
'calendarChannelEventAssociations',
|
||||||
|
]),
|
||||||
|
startsAt: event.startsAt as unknown as Date,
|
||||||
|
endsAt: event.endsAt as unknown as Date,
|
||||||
participants,
|
participants,
|
||||||
|
visibility,
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
const calendarEventIdsWithWorkspaceMemberInParticipants =
|
|
||||||
await this.workspaceDataSourceService.executeRawQuery(
|
|
||||||
`
|
|
||||||
SELECT
|
|
||||||
"calendarEventId"
|
|
||||||
FROM
|
|
||||||
${dataSourceSchema}."calendarEventParticipant" "calendarEventParticipant"
|
|
||||||
WHERE
|
|
||||||
"calendarEventParticipant"."workspaceMemberId" = $1
|
|
||||||
`,
|
|
||||||
[workspaceMemberId],
|
|
||||||
workspaceId,
|
|
||||||
);
|
|
||||||
|
|
||||||
const calendarEventIdsWithWorkspaceMemberInParticipantsFormatted =
|
|
||||||
calendarEventIdsWithWorkspaceMemberInParticipants.map(
|
|
||||||
(event: { calendarEventId: string }) => event.calendarEventId,
|
|
||||||
);
|
|
||||||
|
|
||||||
const calendarEventIdsToFetchVisibilityFor = timelineCalendarEvents
|
|
||||||
.filter(
|
|
||||||
(event) =>
|
|
||||||
!calendarEventIdsWithWorkspaceMemberInParticipantsFormatted.includes(
|
|
||||||
event.id,
|
|
||||||
),
|
|
||||||
)
|
|
||||||
.map((event) => event.id);
|
|
||||||
|
|
||||||
const calendarEventIdsForWhichVisibilityIsMetadata:
|
|
||||||
| {
|
|
||||||
id: string;
|
|
||||||
}[]
|
|
||||||
| undefined = await this.workspaceDataSourceService.executeRawQuery(
|
|
||||||
`
|
|
||||||
SELECT
|
|
||||||
"calendarChannelEventAssociation"."calendarEventId" AS "id"
|
|
||||||
FROM
|
|
||||||
${dataSourceSchema}."calendarChannel" "calendarChannel"
|
|
||||||
LEFT JOIN
|
|
||||||
${dataSourceSchema}."calendarChannelEventAssociation" "calendarChannelEventAssociation" ON "calendarChannel".id = "calendarChannelEventAssociation"."calendarChannelId"
|
|
||||||
WHERE
|
|
||||||
"calendarChannelEventAssociation"."calendarEventId" = ANY($1)
|
|
||||||
AND
|
|
||||||
"calendarChannel"."visibility" = 'METADATA'
|
|
||||||
`,
|
|
||||||
[calendarEventIdsToFetchVisibilityFor],
|
|
||||||
workspaceId,
|
|
||||||
);
|
|
||||||
|
|
||||||
if (!calendarEventIdsForWhichVisibilityIsMetadata) {
|
|
||||||
throw new Error('Failed to fetch calendar event visibility');
|
|
||||||
}
|
|
||||||
|
|
||||||
const calendarEventIdsForWhichVisibilityIsMetadataMap = new Map(
|
|
||||||
calendarEventIdsForWhichVisibilityIsMetadata.map((event) => [
|
|
||||||
event.id,
|
|
||||||
TimelineCalendarEventVisibility.METADATA,
|
|
||||||
]),
|
|
||||||
);
|
|
||||||
|
|
||||||
timelineCalendarEvents.forEach((event) => {
|
|
||||||
event.visibility =
|
|
||||||
calendarEventIdsForWhichVisibilityIsMetadataMap.get(event.id) ??
|
|
||||||
TimelineCalendarEventVisibility.SHARE_EVERYTHING;
|
|
||||||
|
|
||||||
if (event.visibility === TimelineCalendarEventVisibility.METADATA) {
|
|
||||||
event.title = '';
|
|
||||||
event.description = '';
|
|
||||||
event.location = '';
|
|
||||||
event.conferenceSolution = '';
|
|
||||||
event.conferenceLink = { label: '', url: '' };
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
return {
|
return {
|
||||||
totalNumberOfCalendarEvents: totalNumberOfCalendarEvents[0].count,
|
totalNumberOfCalendarEvents: total,
|
||||||
timelineCalendarEvents,
|
timelineCalendarEvents,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
async getCalendarEventsFromCompanyId(
|
async getCalendarEventsFromCompanyId(
|
||||||
workspaceMemberId: string,
|
|
||||||
workspaceId: string,
|
|
||||||
companyId: string,
|
companyId: string,
|
||||||
page = 1,
|
page = 1,
|
||||||
pageSize: number = TIMELINE_CALENDAR_EVENTS_DEFAULT_PAGE_SIZE,
|
pageSize: number = TIMELINE_CALENDAR_EVENTS_DEFAULT_PAGE_SIZE,
|
||||||
): Promise<TimelineCalendarEventsWithTotal> {
|
): Promise<TimelineCalendarEventsWithTotal> {
|
||||||
const dataSourceSchema =
|
const personIds = await this.personRepository.find({
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
where: {
|
||||||
|
company: {
|
||||||
|
id: companyId,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
select: {
|
||||||
|
id: true,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
const personIds = await this.workspaceDataSourceService.executeRawQuery(
|
if (personIds.length <= 0) {
|
||||||
`
|
|
||||||
SELECT
|
|
||||||
p."id"
|
|
||||||
FROM
|
|
||||||
${dataSourceSchema}."person" p
|
|
||||||
WHERE
|
|
||||||
p."companyId" = $1
|
|
||||||
`,
|
|
||||||
[companyId],
|
|
||||||
workspaceId,
|
|
||||||
);
|
|
||||||
|
|
||||||
if (!personIds) {
|
|
||||||
return {
|
return {
|
||||||
totalNumberOfCalendarEvents: 0,
|
totalNumberOfCalendarEvents: 0,
|
||||||
timelineCalendarEvents: [],
|
timelineCalendarEvents: [],
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
const formattedPersonIds = personIds.map(
|
const formattedPersonIds = personIds.map(({ id }) => id);
|
||||||
(personId: { id: string }) => personId.id,
|
|
||||||
);
|
|
||||||
|
|
||||||
const messageThreads = await this.getCalendarEventsFromPersonIds(
|
const messageThreads = await this.getCalendarEventsFromPersonIds(
|
||||||
workspaceMemberId,
|
|
||||||
workspaceId,
|
|
||||||
formattedPersonIds,
|
formattedPersonIds,
|
||||||
page,
|
page,
|
||||||
pageSize,
|
pageSize,
|
||||||
|
|||||||
@ -10,6 +10,7 @@ import { TimelineMessagingModule } from 'src/engine/core-modules/messaging/timel
|
|||||||
import { TimelineCalendarEventModule } from 'src/engine/core-modules/calendar/timeline-calendar-event.module';
|
import { TimelineCalendarEventModule } from 'src/engine/core-modules/calendar/timeline-calendar-event.module';
|
||||||
import { BillingModule } from 'src/engine/core-modules/billing/billing.module';
|
import { BillingModule } from 'src/engine/core-modules/billing/billing.module';
|
||||||
import { HealthModule } from 'src/engine/core-modules/health/health.module';
|
import { HealthModule } from 'src/engine/core-modules/health/health.module';
|
||||||
|
import { TwentyORMModule } from 'src/engine/twenty-orm/twenty-orm.module';
|
||||||
|
|
||||||
import { AnalyticsModule } from './analytics/analytics.module';
|
import { AnalyticsModule } from './analytics/analytics.module';
|
||||||
import { FileModule } from './file/file.module';
|
import { FileModule } from './file/file.module';
|
||||||
@ -17,6 +18,9 @@ import { ClientConfigModule } from './client-config/client-config.module';
|
|||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
|
TwentyORMModule.register({
|
||||||
|
workspaceEntities: ['dist/src/**/*.workspace-entity{.ts,.js}'],
|
||||||
|
}),
|
||||||
HealthModule,
|
HealthModule,
|
||||||
AnalyticsModule,
|
AnalyticsModule,
|
||||||
AuthModule,
|
AuthModule,
|
||||||
|
|||||||
@ -10,7 +10,7 @@ import { DataSourceService } from 'src/engine/metadata-modules/data-source/data-
|
|||||||
import { User } from 'src/engine/core-modules/user/user.entity';
|
import { User } from 'src/engine/core-modules/user/user.entity';
|
||||||
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
||||||
import { ObjectRecordCreateEvent } from 'src/engine/integrations/event-emitter/types/object-record-create.event';
|
import { ObjectRecordCreateEvent } from 'src/engine/integrations/event-emitter/types/object-record-create.event';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
import { assert } from 'src/utils/assert';
|
import { assert } from 'src/utils/assert';
|
||||||
|
|
||||||
export class UserWorkspaceService extends TypeOrmQueryService<UserWorkspace> {
|
export class UserWorkspaceService extends TypeOrmQueryService<UserWorkspace> {
|
||||||
@ -59,7 +59,7 @@ export class UserWorkspaceService extends TypeOrmQueryService<UserWorkspace> {
|
|||||||
`Error while creating workspace member ${user.email} on workspace ${workspaceId}`,
|
`Error while creating workspace member ${user.email} on workspace ${workspaceId}`,
|
||||||
);
|
);
|
||||||
const payload =
|
const payload =
|
||||||
new ObjectRecordCreateEvent<WorkspaceMemberObjectMetadata>();
|
new ObjectRecordCreateEvent<WorkspaceMemberWorkspaceEntity>();
|
||||||
|
|
||||||
payload.workspaceId = workspaceId;
|
payload.workspaceId = workspaceId;
|
||||||
payload.properties = {
|
payload.properties = {
|
||||||
|
|||||||
@ -10,7 +10,7 @@ import { WorkspaceMember } from 'src/engine/core-modules/user/dtos/workspace-mem
|
|||||||
import { DataSourceService } from 'src/engine/metadata-modules/data-source/data-source.service';
|
import { DataSourceService } from 'src/engine/metadata-modules/data-source/data-source.service';
|
||||||
import { TypeORMService } from 'src/database/typeorm/typeorm.service';
|
import { TypeORMService } from 'src/database/typeorm/typeorm.service';
|
||||||
import { DataSourceEntity } from 'src/engine/metadata-modules/data-source/data-source.entity';
|
import { DataSourceEntity } from 'src/engine/metadata-modules/data-source/data-source.entity';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
import { ObjectRecordDeleteEvent } from 'src/engine/integrations/event-emitter/types/object-record-delete.event';
|
import { ObjectRecordDeleteEvent } from 'src/engine/integrations/event-emitter/types/object-record-delete.event';
|
||||||
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
||||||
import { WorkspaceService } from 'src/engine/core-modules/workspace/services/workspace.service';
|
import { WorkspaceService } from 'src/engine/core-modules/workspace/services/workspace.service';
|
||||||
@ -113,7 +113,7 @@ export class UserService extends TypeOrmQueryService<User> {
|
|||||||
`SELECT * FROM ${dataSourceMetadata.schema}."workspaceMember"`,
|
`SELECT * FROM ${dataSourceMetadata.schema}."workspaceMember"`,
|
||||||
);
|
);
|
||||||
const workspaceMember = workspaceMembers.filter(
|
const workspaceMember = workspaceMembers.filter(
|
||||||
(member: ObjectRecord<WorkspaceMemberObjectMetadata>) =>
|
(member: ObjectRecord<WorkspaceMemberWorkspaceEntity>) =>
|
||||||
member.userId === userId,
|
member.userId === userId,
|
||||||
)?.[0];
|
)?.[0];
|
||||||
|
|
||||||
@ -129,7 +129,7 @@ export class UserService extends TypeOrmQueryService<User> {
|
|||||||
`DELETE FROM ${dataSourceMetadata.schema}."workspaceMember" WHERE "userId" = '${userId}'`,
|
`DELETE FROM ${dataSourceMetadata.schema}."workspaceMember" WHERE "userId" = '${userId}'`,
|
||||||
);
|
);
|
||||||
const payload =
|
const payload =
|
||||||
new ObjectRecordDeleteEvent<WorkspaceMemberObjectMetadata>();
|
new ObjectRecordDeleteEvent<WorkspaceMemberWorkspaceEntity>();
|
||||||
|
|
||||||
payload.workspaceId = workspaceId;
|
payload.workspaceId = workspaceId;
|
||||||
payload.properties = {
|
payload.properties = {
|
||||||
|
|||||||
@ -3,7 +3,7 @@ import { OnEvent } from '@nestjs/event-emitter';
|
|||||||
|
|
||||||
import { MessageQueue } from 'src/engine/integrations/message-queue/message-queue.constants';
|
import { MessageQueue } from 'src/engine/integrations/message-queue/message-queue.constants';
|
||||||
import { MessageQueueService } from 'src/engine/integrations/message-queue/services/message-queue.service';
|
import { MessageQueueService } from 'src/engine/integrations/message-queue/services/message-queue.service';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
import { ObjectRecordDeleteEvent } from 'src/engine/integrations/event-emitter/types/object-record-delete.event';
|
import { ObjectRecordDeleteEvent } from 'src/engine/integrations/event-emitter/types/object-record-delete.event';
|
||||||
import {
|
import {
|
||||||
HandleWorkspaceMemberDeletedJob,
|
HandleWorkspaceMemberDeletedJob,
|
||||||
@ -19,7 +19,7 @@ export class WorkspaceWorkspaceMemberListener {
|
|||||||
|
|
||||||
@OnEvent('workspaceMember.deleted')
|
@OnEvent('workspaceMember.deleted')
|
||||||
async handleDeleteEvent(
|
async handleDeleteEvent(
|
||||||
payload: ObjectRecordDeleteEvent<WorkspaceMemberObjectMetadata>,
|
payload: ObjectRecordDeleteEvent<WorkspaceMemberWorkspaceEntity>,
|
||||||
) {
|
) {
|
||||||
const userId = payload.properties.before.userId;
|
const userId = payload.properties.before.userId;
|
||||||
|
|
||||||
|
|||||||
@ -26,7 +26,7 @@ export const fieldMetadataTypeToColumnType = <Type extends FieldMetadataType>(
|
|||||||
case FieldMetadataType.DATE_TIME:
|
case FieldMetadataType.DATE_TIME:
|
||||||
return 'timestamptz';
|
return 'timestamptz';
|
||||||
case FieldMetadataType.DATE:
|
case FieldMetadataType.DATE:
|
||||||
return 'date';
|
return 'datetime';
|
||||||
case FieldMetadataType.RATING:
|
case FieldMetadataType.RATING:
|
||||||
case FieldMetadataType.SELECT:
|
case FieldMetadataType.SELECT:
|
||||||
case FieldMetadataType.MULTI_SELECT:
|
case FieldMetadataType.MULTI_SELECT:
|
||||||
|
|||||||
@ -18,24 +18,24 @@ import { AttachmentRepository } from 'src/modules/attachment/repositories/attach
|
|||||||
import { CommentRepository } from 'src/modules/activity/repositories/comment.repository';
|
import { CommentRepository } from 'src/modules/activity/repositories/comment.repository';
|
||||||
|
|
||||||
export const metadataToRepositoryMapping = {
|
export const metadataToRepositoryMapping = {
|
||||||
AuditLogObjectMetadata: AuditLogRepository,
|
AuditLogWorkspaceEntity: AuditLogRepository,
|
||||||
BlocklistObjectMetadata: BlocklistRepository,
|
BlocklistWorkspaceEntity: BlocklistRepository,
|
||||||
CalendarChannelEventAssociationObjectMetadata:
|
CalendarChannelEventAssociationWorkspaceEntity:
|
||||||
CalendarChannelEventAssociationRepository,
|
CalendarChannelEventAssociationRepository,
|
||||||
CalendarChannelObjectMetadata: CalendarChannelRepository,
|
CalendarChannelWorkspaceEntity: CalendarChannelRepository,
|
||||||
CalendarEventParticipantObjectMetadata: CalendarEventParticipantRepository,
|
CalendarEventParticipantWorkspaceEntity: CalendarEventParticipantRepository,
|
||||||
CalendarEventObjectMetadata: CalendarEventRepository,
|
CalendarEventWorkspaceEntity: CalendarEventRepository,
|
||||||
CompanyObjectMetadata: CompanyRepository,
|
CompanyWorkspaceEntity: CompanyRepository,
|
||||||
ConnectedAccountObjectMetadata: ConnectedAccountRepository,
|
ConnectedAccountWorkspaceEntity: ConnectedAccountRepository,
|
||||||
MessageChannelMessageAssociationObjectMetadata:
|
MessageChannelMessageAssociationWorkspaceEntity:
|
||||||
MessageChannelMessageAssociationRepository,
|
MessageChannelMessageAssociationRepository,
|
||||||
MessageChannelObjectMetadata: MessageChannelRepository,
|
MessageChannelWorkspaceEntity: MessageChannelRepository,
|
||||||
MessageObjectMetadata: MessageRepository,
|
MessageWorkspaceEntity: MessageRepository,
|
||||||
MessageParticipantObjectMetadata: MessageParticipantRepository,
|
MessageParticipantWorkspaceEntity: MessageParticipantRepository,
|
||||||
MessageThreadObjectMetadata: MessageThreadRepository,
|
MessageThreadWorkspaceEntity: MessageThreadRepository,
|
||||||
PersonObjectMetadata: PersonRepository,
|
PersonWorkspaceEntity: PersonRepository,
|
||||||
TimelineActivityObjectMetadata: TimelineActivityRepository,
|
TimelineActivityWorkspaceEntity: TimelineActivityRepository,
|
||||||
WorkspaceMemberObjectMetadata: WorkspaceMemberRepository,
|
WorkspaceMemberWorkspaceEntity: WorkspaceMemberRepository,
|
||||||
AttachmentObjectMetadata: AttachmentRepository,
|
AttachmentWorkspaceEntity: AttachmentRepository,
|
||||||
CommentObjectMetadata: CommentRepository,
|
CommentWorkspaceEntity: CommentRepository,
|
||||||
};
|
};
|
||||||
|
|||||||
@ -3,11 +3,11 @@ import {
|
|||||||
RelationMetadataType,
|
RelationMetadataType,
|
||||||
RelationOnDeleteAction,
|
RelationOnDeleteAction,
|
||||||
} from 'src/engine/metadata-modules/relation-metadata/relation-metadata.entity';
|
} from 'src/engine/metadata-modules/relation-metadata/relation-metadata.entity';
|
||||||
import { ActivityTargetObjectMetadata } from 'src/modules/activity/standard-objects/activity-target.object-metadata';
|
import { ActivityTargetWorkspaceEntity } from 'src/modules/activity/standard-objects/activity-target.workspace-entity';
|
||||||
import { FavoriteObjectMetadata } from 'src/modules/favorite/standard-objects/favorite.object-metadata';
|
import { FavoriteWorkspaceEntity } from 'src/modules/favorite/standard-objects/favorite.workspace-entity';
|
||||||
import { AttachmentObjectMetadata } from 'src/modules/attachment/standard-objects/attachment.object-metadata';
|
import { AttachmentWorkspaceEntity } from 'src/modules/attachment/standard-objects/attachment.workspace-entity';
|
||||||
import { CUSTOM_OBJECT_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
import { CUSTOM_OBJECT_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
||||||
import { TimelineActivityObjectMetadata } from 'src/modules/timeline/standard-objects/timeline-activity.object-metadata';
|
import { TimelineActivityWorkspaceEntity } from 'src/modules/timeline/standard-objects/timeline-activity.workspace-entity';
|
||||||
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
||||||
import { WorkspaceIsNullable } from 'src/engine/twenty-orm/decorators/workspace-is-nullable.decorator';
|
import { WorkspaceIsNullable } from 'src/engine/twenty-orm/decorators/workspace-is-nullable.decorator';
|
||||||
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
||||||
@ -45,11 +45,11 @@ export class CustomWorkspaceEntity extends BaseWorkspaceEntity {
|
|||||||
description: (objectMetadata) =>
|
description: (objectMetadata) =>
|
||||||
`Activities tied to the ${objectMetadata.labelSingular}`,
|
`Activities tied to the ${objectMetadata.labelSingular}`,
|
||||||
icon: 'IconCheckbox',
|
icon: 'IconCheckbox',
|
||||||
inverseSideTarget: () => ActivityTargetObjectMetadata,
|
inverseSideTarget: () => ActivityTargetWorkspaceEntity,
|
||||||
onDelete: RelationOnDeleteAction.CASCADE,
|
onDelete: RelationOnDeleteAction.CASCADE,
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
activityTargets: ActivityTargetObjectMetadata[];
|
activityTargets: ActivityTargetWorkspaceEntity[];
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: CUSTOM_OBJECT_STANDARD_FIELD_IDS.favorites,
|
standardId: CUSTOM_OBJECT_STANDARD_FIELD_IDS.favorites,
|
||||||
@ -58,12 +58,12 @@ export class CustomWorkspaceEntity extends BaseWorkspaceEntity {
|
|||||||
description: (objectMetadata) =>
|
description: (objectMetadata) =>
|
||||||
`Favorites tied to the ${objectMetadata.labelSingular}`,
|
`Favorites tied to the ${objectMetadata.labelSingular}`,
|
||||||
icon: 'IconHeart',
|
icon: 'IconHeart',
|
||||||
inverseSideTarget: () => FavoriteObjectMetadata,
|
inverseSideTarget: () => FavoriteWorkspaceEntity,
|
||||||
onDelete: RelationOnDeleteAction.CASCADE,
|
onDelete: RelationOnDeleteAction.CASCADE,
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
@WorkspaceIsSystem()
|
@WorkspaceIsSystem()
|
||||||
favorites: FavoriteObjectMetadata[];
|
favorites: FavoriteWorkspaceEntity[];
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: CUSTOM_OBJECT_STANDARD_FIELD_IDS.attachments,
|
standardId: CUSTOM_OBJECT_STANDARD_FIELD_IDS.attachments,
|
||||||
@ -72,11 +72,11 @@ export class CustomWorkspaceEntity extends BaseWorkspaceEntity {
|
|||||||
description: (objectMetadata) =>
|
description: (objectMetadata) =>
|
||||||
`Attachments tied to the ${objectMetadata.labelSingular}`,
|
`Attachments tied to the ${objectMetadata.labelSingular}`,
|
||||||
icon: 'IconFileImport',
|
icon: 'IconFileImport',
|
||||||
inverseSideTarget: () => AttachmentObjectMetadata,
|
inverseSideTarget: () => AttachmentWorkspaceEntity,
|
||||||
onDelete: RelationOnDeleteAction.CASCADE,
|
onDelete: RelationOnDeleteAction.CASCADE,
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
attachments: AttachmentObjectMetadata[];
|
attachments: AttachmentWorkspaceEntity[];
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: CUSTOM_OBJECT_STANDARD_FIELD_IDS.timelineActivities,
|
standardId: CUSTOM_OBJECT_STANDARD_FIELD_IDS.timelineActivities,
|
||||||
@ -85,10 +85,10 @@ export class CustomWorkspaceEntity extends BaseWorkspaceEntity {
|
|||||||
description: (objectMetadata) =>
|
description: (objectMetadata) =>
|
||||||
`Timeline Activities tied to the ${objectMetadata.labelSingular}`,
|
`Timeline Activities tied to the ${objectMetadata.labelSingular}`,
|
||||||
icon: 'IconIconTimelineEvent',
|
icon: 'IconIconTimelineEvent',
|
||||||
inverseSideTarget: () => TimelineActivityObjectMetadata,
|
inverseSideTarget: () => TimelineActivityWorkspaceEntity,
|
||||||
onDelete: RelationOnDeleteAction.CASCADE,
|
onDelete: RelationOnDeleteAction.CASCADE,
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
@WorkspaceIsSystem()
|
@WorkspaceIsSystem()
|
||||||
timelineActivities: TimelineActivityObjectMetadata[];
|
timelineActivities: TimelineActivityWorkspaceEntity[];
|
||||||
}
|
}
|
||||||
|
|||||||
@ -9,7 +9,9 @@ export class WorkspaceEntityManager extends EntityManager {
|
|||||||
// find already created repository instance and return it if found
|
// find already created repository instance and return it if found
|
||||||
const repoFromMap = this.repositories.get(target);
|
const repoFromMap = this.repositories.get(target);
|
||||||
|
|
||||||
if (repoFromMap) return repoFromMap as WorkspaceRepository<Entity>;
|
if (repoFromMap) {
|
||||||
|
return repoFromMap as WorkspaceRepository<Entity>;
|
||||||
|
}
|
||||||
|
|
||||||
const newRepository = new WorkspaceRepository<Entity>(
|
const newRepository = new WorkspaceRepository<Entity>(
|
||||||
target,
|
target,
|
||||||
|
|||||||
@ -3,6 +3,7 @@ import { Injectable } from '@nestjs/common';
|
|||||||
import { ColumnType, EntitySchemaColumnOptions } from 'typeorm';
|
import { ColumnType, EntitySchemaColumnOptions } from 'typeorm';
|
||||||
|
|
||||||
import { WorkspaceFieldMetadataArgs } from 'src/engine/twenty-orm/interfaces/workspace-field-metadata-args.interface';
|
import { WorkspaceFieldMetadataArgs } from 'src/engine/twenty-orm/interfaces/workspace-field-metadata-args.interface';
|
||||||
|
import { WorkspaceRelationMetadataArgs } from 'src/engine/twenty-orm/interfaces/workspace-relation-metadata-args.interface';
|
||||||
|
|
||||||
import { fieldMetadataTypeToColumnType } from 'src/engine/metadata-modules/workspace-migration/utils/field-metadata-type-to-column-type.util';
|
import { fieldMetadataTypeToColumnType } from 'src/engine/metadata-modules/workspace-migration/utils/field-metadata-type-to-column-type.util';
|
||||||
import { isEnumFieldMetadataType } from 'src/engine/metadata-modules/field-metadata/utils/is-enum-field-metadata-type.util';
|
import { isEnumFieldMetadataType } from 'src/engine/metadata-modules/field-metadata/utils/is-enum-field-metadata-type.util';
|
||||||
@ -20,6 +21,7 @@ type EntitySchemaColumnMap = {
|
|||||||
export class EntitySchemaColumnFactory {
|
export class EntitySchemaColumnFactory {
|
||||||
create(
|
create(
|
||||||
fieldMetadataArgsCollection: WorkspaceFieldMetadataArgs[],
|
fieldMetadataArgsCollection: WorkspaceFieldMetadataArgs[],
|
||||||
|
relationMetadataArgsCollection: WorkspaceRelationMetadataArgs[],
|
||||||
): EntitySchemaColumnMap {
|
): EntitySchemaColumnMap {
|
||||||
let entitySchemaColumnMap: EntitySchemaColumnMap = {};
|
let entitySchemaColumnMap: EntitySchemaColumnMap = {};
|
||||||
|
|
||||||
@ -53,6 +55,16 @@ export class EntitySchemaColumnFactory {
|
|||||||
default: defaultValue,
|
default: defaultValue,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
for (const relationMetadataArgs of relationMetadataArgsCollection) {
|
||||||
|
if (relationMetadataArgs.joinColumn) {
|
||||||
|
entitySchemaColumnMap[relationMetadataArgs.joinColumn] = {
|
||||||
|
name: relationMetadataArgs.joinColumn,
|
||||||
|
type: 'uuid',
|
||||||
|
nullable: relationMetadataArgs.isNullable,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (isEnumFieldMetadataType(fieldMetadataArgs.type)) {
|
if (isEnumFieldMetadataType(fieldMetadataArgs.type)) {
|
||||||
const values = fieldMetadataArgs.options?.map((option) => option.value);
|
const values = fieldMetadataArgs.options?.map((option) => option.value);
|
||||||
|
|
||||||
|
|||||||
@ -15,11 +15,14 @@ type EntitySchemaRelationMap = {
|
|||||||
@Injectable()
|
@Injectable()
|
||||||
export class EntitySchemaRelationFactory {
|
export class EntitySchemaRelationFactory {
|
||||||
create(
|
create(
|
||||||
|
// eslint-disable-next-line @typescript-eslint/ban-types
|
||||||
|
target: Function,
|
||||||
relationMetadataArgsCollection: WorkspaceRelationMetadataArgs[],
|
relationMetadataArgsCollection: WorkspaceRelationMetadataArgs[],
|
||||||
): EntitySchemaRelationMap {
|
): EntitySchemaRelationMap {
|
||||||
const entitySchemaRelationMap: EntitySchemaRelationMap = {};
|
const entitySchemaRelationMap: EntitySchemaRelationMap = {};
|
||||||
|
|
||||||
for (const relationMetadataArgs of relationMetadataArgsCollection) {
|
for (const relationMetadataArgs of relationMetadataArgsCollection) {
|
||||||
|
const objectName = convertClassNameToObjectMetadataName(target.name);
|
||||||
const oppositeTarget = relationMetadataArgs.inverseSideTarget();
|
const oppositeTarget = relationMetadataArgs.inverseSideTarget();
|
||||||
const oppositeObjectName = convertClassNameToObjectMetadataName(
|
const oppositeObjectName = convertClassNameToObjectMetadataName(
|
||||||
oppositeTarget.name,
|
oppositeTarget.name,
|
||||||
@ -30,7 +33,7 @@ export class EntitySchemaRelationFactory {
|
|||||||
entitySchemaRelationMap[relationMetadataArgs.name] = {
|
entitySchemaRelationMap[relationMetadataArgs.name] = {
|
||||||
type: relationType,
|
type: relationType,
|
||||||
target: oppositeObjectName,
|
target: oppositeObjectName,
|
||||||
inverseSide: relationMetadataArgs.inverseSideFieldKey,
|
inverseSide: relationMetadataArgs.inverseSideFieldKey ?? objectName,
|
||||||
joinColumn: relationMetadataArgs.joinColumn
|
joinColumn: relationMetadataArgs.joinColumn
|
||||||
? {
|
? {
|
||||||
name: relationMetadataArgs.joinColumn,
|
name: relationMetadataArgs.joinColumn,
|
||||||
|
|||||||
@ -28,9 +28,11 @@ export class EntitySchemaFactory {
|
|||||||
|
|
||||||
const columns = this.entitySchemaColumnFactory.create(
|
const columns = this.entitySchemaColumnFactory.create(
|
||||||
fieldMetadataArgsCollection,
|
fieldMetadataArgsCollection,
|
||||||
|
relationMetadataArgsCollection,
|
||||||
);
|
);
|
||||||
|
|
||||||
const relations = this.entitySchemaRelationFactory.create(
|
const relations = this.entitySchemaRelationFactory.create(
|
||||||
|
target,
|
||||||
relationMetadataArgsCollection,
|
relationMetadataArgsCollection,
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|||||||
@ -3,7 +3,7 @@ import { FactoryProvider, ModuleMetadata, Type } from '@nestjs/common';
|
|||||||
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
||||||
|
|
||||||
export interface TwentyORMOptions {
|
export interface TwentyORMOptions {
|
||||||
workspaceEntities: Type<BaseWorkspaceEntity>[];
|
workspaceEntities: (Type<BaseWorkspaceEntity> | string)[];
|
||||||
}
|
}
|
||||||
|
|
||||||
export type TwentyORMModuleAsyncOptions = {
|
export type TwentyORMModuleAsyncOptions = {
|
||||||
|
|||||||
@ -21,6 +21,7 @@ import { ObjectLiteralStorage } from 'src/engine/twenty-orm/storage/object-liter
|
|||||||
import { compositeTypeDefintions } from 'src/engine/metadata-modules/field-metadata/composite-types';
|
import { compositeTypeDefintions } from 'src/engine/metadata-modules/field-metadata/composite-types';
|
||||||
import { computeCompositeColumnName } from 'src/engine/metadata-modules/field-metadata/utils/compute-column-name.util';
|
import { computeCompositeColumnName } from 'src/engine/metadata-modules/field-metadata/utils/compute-column-name.util';
|
||||||
import { isCompositeFieldMetadataType } from 'src/engine/metadata-modules/field-metadata/utils/is-composite-field-metadata-type.util';
|
import { isCompositeFieldMetadataType } from 'src/engine/metadata-modules/field-metadata/utils/is-composite-field-metadata-type.util';
|
||||||
|
import { isPlainObject } from 'src/utils/is-plain-object';
|
||||||
|
|
||||||
export class WorkspaceRepository<
|
export class WorkspaceRepository<
|
||||||
Entity extends ObjectLiteral,
|
Entity extends ObjectLiteral,
|
||||||
@ -492,7 +493,7 @@ export class WorkspaceRepository<
|
|||||||
const fieldMetadataArgs = compositeFieldMetadataArgsMap.get(key);
|
const fieldMetadataArgs = compositeFieldMetadataArgsMap.get(key);
|
||||||
|
|
||||||
if (!fieldMetadataArgs) {
|
if (!fieldMetadataArgs) {
|
||||||
if (typeof value === 'object') {
|
if (isPlainObject(value)) {
|
||||||
newData[key] = this.formatData(value);
|
newData[key] = this.formatData(value);
|
||||||
} else {
|
} else {
|
||||||
newData[key] = value;
|
newData[key] = value;
|
||||||
@ -524,25 +525,30 @@ export class WorkspaceRepository<
|
|||||||
return newData as T;
|
return newData as T;
|
||||||
}
|
}
|
||||||
|
|
||||||
private formatResult<T>(data: T): T {
|
private formatResult<T>(
|
||||||
|
data: T,
|
||||||
|
target = ObjectLiteralStorage.getObjectLiteral(this.target as any),
|
||||||
|
): T {
|
||||||
if (!data) {
|
if (!data) {
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Array.isArray(data)) {
|
if (Array.isArray(data)) {
|
||||||
return data.map((item) => this.formatResult(item)) as T;
|
return data.map((item) => this.formatResult(item, target)) as T;
|
||||||
}
|
}
|
||||||
|
|
||||||
const objectLiteral = ObjectLiteralStorage.getObjectLiteral(
|
if (!isPlainObject(data)) {
|
||||||
this.target as any,
|
return data;
|
||||||
);
|
}
|
||||||
|
|
||||||
if (!objectLiteral) {
|
if (!target) {
|
||||||
throw new Error('Object literal is missing');
|
throw new Error('Object literal is missing');
|
||||||
}
|
}
|
||||||
|
|
||||||
const fieldMetadataArgsCollection =
|
const fieldMetadataArgsCollection =
|
||||||
metadataArgsStorage.filterFields(objectLiteral);
|
metadataArgsStorage.filterFields(target);
|
||||||
|
const relationMetadataArgsCollection =
|
||||||
|
metadataArgsStorage.filterRelations(target);
|
||||||
const compositeFieldMetadataArgsCollection =
|
const compositeFieldMetadataArgsCollection =
|
||||||
fieldMetadataArgsCollection.filter((fieldMetadataArg) =>
|
fieldMetadataArgsCollection.filter((fieldMetadataArg) =>
|
||||||
isCompositeFieldMetadataType(fieldMetadataArg.type),
|
isCompositeFieldMetadataType(fieldMetadataArg.type),
|
||||||
@ -565,13 +571,20 @@ export class WorkspaceRepository<
|
|||||||
]);
|
]);
|
||||||
}),
|
}),
|
||||||
);
|
);
|
||||||
|
const relationMetadataArgsMap = new Map(
|
||||||
|
relationMetadataArgsCollection.map((relationMetadataArgs) => [
|
||||||
|
relationMetadataArgs.name,
|
||||||
|
relationMetadataArgs,
|
||||||
|
]),
|
||||||
|
);
|
||||||
const newData: object = {};
|
const newData: object = {};
|
||||||
|
|
||||||
for (const [key, value] of Object.entries(data)) {
|
for (const [key, value] of Object.entries(data)) {
|
||||||
const compositePropertyArgs = compositeFieldMetadataArgsMap.get(key);
|
const compositePropertyArgs = compositeFieldMetadataArgsMap.get(key);
|
||||||
|
const relationMetadataArgs = relationMetadataArgsMap.get(key);
|
||||||
|
|
||||||
if (!compositePropertyArgs) {
|
if (!compositePropertyArgs && !relationMetadataArgs) {
|
||||||
if (typeof value === 'object') {
|
if (isPlainObject(value)) {
|
||||||
newData[key] = this.formatResult(value);
|
newData[key] = this.formatResult(value);
|
||||||
} else {
|
} else {
|
||||||
newData[key] = value;
|
newData[key] = value;
|
||||||
@ -579,6 +592,18 @@ export class WorkspaceRepository<
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (relationMetadataArgs) {
|
||||||
|
newData[key] = this.formatResult(
|
||||||
|
value,
|
||||||
|
relationMetadataArgs.inverseSideTarget() as any,
|
||||||
|
);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!compositePropertyArgs) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
const { parentField, ...compositeProperty } = compositePropertyArgs;
|
const { parentField, ...compositeProperty } = compositePropertyArgs;
|
||||||
|
|
||||||
if (!newData[parentField]) {
|
if (!newData[parentField]) {
|
||||||
|
|||||||
@ -5,12 +5,16 @@ import {
|
|||||||
Module,
|
Module,
|
||||||
OnApplicationShutdown,
|
OnApplicationShutdown,
|
||||||
Provider,
|
Provider,
|
||||||
|
Type,
|
||||||
} from '@nestjs/common';
|
} from '@nestjs/common';
|
||||||
import {
|
import {
|
||||||
ConfigurableModuleClass,
|
ConfigurableModuleClass,
|
||||||
MODULE_OPTIONS_TOKEN,
|
MODULE_OPTIONS_TOKEN,
|
||||||
} from '@nestjs/common/cache/cache.module-definition';
|
} from '@nestjs/common/cache/cache.module-definition';
|
||||||
|
|
||||||
|
import { importClassesFromDirectories } from 'typeorm/util/DirectoryExportedClassesLoader';
|
||||||
|
import { Logger as TypeORMLogger } from 'typeorm/logger/Logger';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
TwentyORMModuleAsyncOptions,
|
TwentyORMModuleAsyncOptions,
|
||||||
TwentyORMOptions,
|
TwentyORMOptions,
|
||||||
@ -23,6 +27,9 @@ import { DataSourceModule } from 'src/engine/metadata-modules/data-source/data-s
|
|||||||
import { EntitySchemaFactory } from 'src/engine/twenty-orm/factories/entity-schema.factory';
|
import { EntitySchemaFactory } from 'src/engine/twenty-orm/factories/entity-schema.factory';
|
||||||
import { DataSourceStorage } from 'src/engine/twenty-orm/storage/data-source.storage';
|
import { DataSourceStorage } from 'src/engine/twenty-orm/storage/data-source.storage';
|
||||||
import { ScopedWorkspaceDatasourceFactory } from 'src/engine/twenty-orm/factories/scoped-workspace-datasource.factory';
|
import { ScopedWorkspaceDatasourceFactory } from 'src/engine/twenty-orm/factories/scoped-workspace-datasource.factory';
|
||||||
|
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
||||||
|
import { splitClassesAndStrings } from 'src/engine/twenty-orm/utils/split-classes-and-strings.util';
|
||||||
|
import { CustomWorkspaceEntity } from 'src/engine/twenty-orm/custom.workspace-entity';
|
||||||
|
|
||||||
@Global()
|
@Global()
|
||||||
@Module({
|
@Module({
|
||||||
@ -34,10 +41,12 @@ export class TwentyORMCoreModule
|
|||||||
extends ConfigurableModuleClass
|
extends ConfigurableModuleClass
|
||||||
implements OnApplicationShutdown
|
implements OnApplicationShutdown
|
||||||
{
|
{
|
||||||
private readonly logger = new Logger(TwentyORMCoreModule.name);
|
private static readonly logger = new Logger(TwentyORMCoreModule.name);
|
||||||
|
|
||||||
static register(options: TwentyORMOptions): DynamicModule {
|
static register(options: TwentyORMOptions): DynamicModule {
|
||||||
const dynamicModule = super.register(options);
|
const dynamicModule = super.register(options);
|
||||||
|
|
||||||
|
console.log('register', options);
|
||||||
const providers: Provider[] = [
|
const providers: Provider[] = [
|
||||||
{
|
{
|
||||||
provide: TWENTY_ORM_WORKSPACE_DATASOURCE,
|
provide: TWENTY_ORM_WORKSPACE_DATASOURCE,
|
||||||
@ -45,7 +54,11 @@ export class TwentyORMCoreModule
|
|||||||
entitySchemaFactory: EntitySchemaFactory,
|
entitySchemaFactory: EntitySchemaFactory,
|
||||||
scopedWorkspaceDatasourceFactory: ScopedWorkspaceDatasourceFactory,
|
scopedWorkspaceDatasourceFactory: ScopedWorkspaceDatasourceFactory,
|
||||||
) => {
|
) => {
|
||||||
const entities = options.workspaceEntities.map((entityClass) =>
|
const workspaceEntities = await this.loadEntities(
|
||||||
|
options.workspaceEntities,
|
||||||
|
);
|
||||||
|
|
||||||
|
const entities = workspaceEntities.map((entityClass) =>
|
||||||
entitySchemaFactory.create(entityClass),
|
entitySchemaFactory.create(entityClass),
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -80,7 +93,11 @@ export class TwentyORMCoreModule
|
|||||||
scopedWorkspaceDatasourceFactory: ScopedWorkspaceDatasourceFactory,
|
scopedWorkspaceDatasourceFactory: ScopedWorkspaceDatasourceFactory,
|
||||||
options: TwentyORMOptions,
|
options: TwentyORMOptions,
|
||||||
) => {
|
) => {
|
||||||
const entities = options.workspaceEntities.map((entityClass) =>
|
const workspaceEntities = await this.loadEntities(
|
||||||
|
options.workspaceEntities,
|
||||||
|
);
|
||||||
|
|
||||||
|
const entities = workspaceEntities.map((entityClass) =>
|
||||||
entitySchemaFactory.create(entityClass),
|
entitySchemaFactory.create(entityClass),
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -123,4 +140,29 @@ export class TwentyORMCoreModule
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static async loadEntities(
|
||||||
|
workspaceEntities: (Type<BaseWorkspaceEntity> | string)[],
|
||||||
|
): Promise<Type<BaseWorkspaceEntity>[]> {
|
||||||
|
const [entityClassesOrSchemas, entityDirectories] = splitClassesAndStrings(
|
||||||
|
workspaceEntities || [],
|
||||||
|
);
|
||||||
|
const importedEntities = await importClassesFromDirectories(
|
||||||
|
// Only `log` function is used under importClassesFromDirectories function
|
||||||
|
this.logger as unknown as TypeORMLogger,
|
||||||
|
entityDirectories,
|
||||||
|
);
|
||||||
|
const entities = [
|
||||||
|
...entityClassesOrSchemas,
|
||||||
|
...(importedEntities as Type<BaseWorkspaceEntity>[]),
|
||||||
|
];
|
||||||
|
|
||||||
|
return entities.filter(
|
||||||
|
(entity) =>
|
||||||
|
// Filter out CustomWorkspaceEntity as it's a partial entity handled separately
|
||||||
|
entity.name !== CustomWorkspaceEntity.name &&
|
||||||
|
// Filter out BaseWorkspaceEntity as it's a base entity and should not be included in the workspace entities
|
||||||
|
entity.name !== BaseWorkspaceEntity.name,
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -0,0 +1,8 @@
|
|||||||
|
export const splitClassesAndStrings = <T>(
|
||||||
|
classesAndStrings: (string | T)[],
|
||||||
|
): [T[], string[]] => {
|
||||||
|
return [
|
||||||
|
classesAndStrings.filter((cls): cls is T => typeof cls !== 'string'),
|
||||||
|
classesAndStrings.filter((str): str is string => typeof str === 'string'),
|
||||||
|
];
|
||||||
|
};
|
||||||
@ -7,7 +7,7 @@ import {
|
|||||||
FieldComparatorResult,
|
FieldComparatorResult,
|
||||||
} from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/comparator.interface';
|
} from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/comparator.interface';
|
||||||
import { ComputedPartialFieldMetadata } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-field-metadata.interface';
|
import { ComputedPartialFieldMetadata } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-field-metadata.interface';
|
||||||
import { ComputedPartialObjectMetadata } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-object-metadata.interface';
|
import { ComputedPartialWorkspaceEntity } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-object-metadata.interface';
|
||||||
|
|
||||||
import { ObjectMetadataEntity } from 'src/engine/metadata-modules/object-metadata/object-metadata.entity';
|
import { ObjectMetadataEntity } from 'src/engine/metadata-modules/object-metadata/object-metadata.entity';
|
||||||
import { transformMetadataForComparison } from 'src/engine/workspace-manager/workspace-sync-metadata/comparators/utils/transform-metadata-for-comparison.util';
|
import { transformMetadataForComparison } from 'src/engine/workspace-manager/workspace-sync-metadata/comparators/utils/transform-metadata-for-comparison.util';
|
||||||
@ -36,7 +36,7 @@ export class WorkspaceFieldComparator {
|
|||||||
|
|
||||||
public compare(
|
public compare(
|
||||||
originalObjectMetadata: ObjectMetadataEntity,
|
originalObjectMetadata: ObjectMetadataEntity,
|
||||||
standardObjectMetadata: ComputedPartialObjectMetadata,
|
standardObjectMetadata: ComputedPartialWorkspaceEntity,
|
||||||
): FieldComparatorResult[] {
|
): FieldComparatorResult[] {
|
||||||
const result: FieldComparatorResult[] = [];
|
const result: FieldComparatorResult[] = [];
|
||||||
const fieldPropertiesToUpdateMap: Record<
|
const fieldPropertiesToUpdateMap: Record<
|
||||||
|
|||||||
@ -7,7 +7,7 @@ import {
|
|||||||
ComparatorAction,
|
ComparatorAction,
|
||||||
ObjectComparatorResult,
|
ObjectComparatorResult,
|
||||||
} from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/comparator.interface';
|
} from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/comparator.interface';
|
||||||
import { ComputedPartialObjectMetadata } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-object-metadata.interface';
|
import { ComputedPartialWorkspaceEntity } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-object-metadata.interface';
|
||||||
|
|
||||||
import { transformMetadataForComparison } from 'src/engine/workspace-manager/workspace-sync-metadata/comparators/utils/transform-metadata-for-comparison.util';
|
import { transformMetadataForComparison } from 'src/engine/workspace-manager/workspace-sync-metadata/comparators/utils/transform-metadata-for-comparison.util';
|
||||||
import { ObjectMetadataEntity } from 'src/engine/metadata-modules/object-metadata/object-metadata.entity';
|
import { ObjectMetadataEntity } from 'src/engine/metadata-modules/object-metadata/object-metadata.entity';
|
||||||
@ -28,7 +28,7 @@ export class WorkspaceObjectComparator {
|
|||||||
|
|
||||||
public compare(
|
public compare(
|
||||||
originalObjectMetadata: ObjectMetadataEntity | undefined,
|
originalObjectMetadata: ObjectMetadataEntity | undefined,
|
||||||
standardObjectMetadata: ComputedPartialObjectMetadata,
|
standardObjectMetadata: ComputedPartialWorkspaceEntity,
|
||||||
): ObjectComparatorResult {
|
): ObjectComparatorResult {
|
||||||
// If the object doesn't exist in the original metadata, we need to create it
|
// If the object doesn't exist in the original metadata, we need to create it
|
||||||
if (!originalObjectMetadata) {
|
if (!originalObjectMetadata) {
|
||||||
@ -38,7 +38,8 @@ export class WorkspaceObjectComparator {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
const objectPropertiesToUpdate: Partial<ComputedPartialObjectMetadata> = {};
|
const objectPropertiesToUpdate: Partial<ComputedPartialWorkspaceEntity> =
|
||||||
|
{};
|
||||||
|
|
||||||
// Only compare properties that are not ignored
|
// Only compare properties that are not ignored
|
||||||
const partialOriginalObjectMetadata = transformMetadataForComparison(
|
const partialOriginalObjectMetadata = transformMetadataForComparison(
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
import { Injectable } from '@nestjs/common';
|
import { Injectable } from '@nestjs/common';
|
||||||
|
|
||||||
import { WorkspaceSyncContext } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/workspace-sync-context.interface';
|
import { WorkspaceSyncContext } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/workspace-sync-context.interface';
|
||||||
import { PartialObjectMetadata } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-object-metadata.interface';
|
import { PartialWorkspaceEntity } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-object-metadata.interface';
|
||||||
import { FeatureFlagMap } from 'src/engine/core-modules/feature-flag/interfaces/feature-flag-map.interface';
|
import { FeatureFlagMap } from 'src/engine/core-modules/feature-flag/interfaces/feature-flag-map.interface';
|
||||||
|
|
||||||
import { isGatedAndNotEnabled } from 'src/engine/workspace-manager/workspace-sync-metadata/utils/is-gate-and-not-enabled.util';
|
import { isGatedAndNotEnabled } from 'src/engine/workspace-manager/workspace-sync-metadata/utils/is-gate-and-not-enabled.util';
|
||||||
@ -18,19 +18,19 @@ export class StandardObjectFactory {
|
|||||||
standardObjectMetadataDefinitions: (typeof BaseWorkspaceEntity)[],
|
standardObjectMetadataDefinitions: (typeof BaseWorkspaceEntity)[],
|
||||||
context: WorkspaceSyncContext,
|
context: WorkspaceSyncContext,
|
||||||
workspaceFeatureFlagsMap: FeatureFlagMap,
|
workspaceFeatureFlagsMap: FeatureFlagMap,
|
||||||
): PartialObjectMetadata[] {
|
): PartialWorkspaceEntity[] {
|
||||||
return standardObjectMetadataDefinitions
|
return standardObjectMetadataDefinitions
|
||||||
.map((metadata) =>
|
.map((metadata) =>
|
||||||
this.createObjectMetadata(metadata, context, workspaceFeatureFlagsMap),
|
this.createObjectMetadata(metadata, context, workspaceFeatureFlagsMap),
|
||||||
)
|
)
|
||||||
.filter((metadata): metadata is PartialObjectMetadata => !!metadata);
|
.filter((metadata): metadata is PartialWorkspaceEntity => !!metadata);
|
||||||
}
|
}
|
||||||
|
|
||||||
private createObjectMetadata(
|
private createObjectMetadata(
|
||||||
target: typeof BaseWorkspaceEntity,
|
target: typeof BaseWorkspaceEntity,
|
||||||
context: WorkspaceSyncContext,
|
context: WorkspaceSyncContext,
|
||||||
workspaceFeatureFlagsMap: FeatureFlagMap,
|
workspaceFeatureFlagsMap: FeatureFlagMap,
|
||||||
): PartialObjectMetadata | undefined {
|
): PartialWorkspaceEntity | undefined {
|
||||||
const workspaceEntityMetadataArgs =
|
const workspaceEntityMetadataArgs =
|
||||||
metadataArgsStorage.filterEntities(target);
|
metadataArgsStorage.filterEntities(target);
|
||||||
|
|
||||||
|
|||||||
@ -2,7 +2,7 @@ import { FieldMetadataEntity } from 'src/engine/metadata-modules/field-metadata/
|
|||||||
import { RelationMetadataEntity } from 'src/engine/metadata-modules/relation-metadata/relation-metadata.entity';
|
import { RelationMetadataEntity } from 'src/engine/metadata-modules/relation-metadata/relation-metadata.entity';
|
||||||
|
|
||||||
import { ComputedPartialFieldMetadata } from './partial-field-metadata.interface';
|
import { ComputedPartialFieldMetadata } from './partial-field-metadata.interface';
|
||||||
import { ComputedPartialObjectMetadata } from './partial-object-metadata.interface';
|
import { ComputedPartialWorkspaceEntity } from './partial-object-metadata.interface';
|
||||||
|
|
||||||
export const enum ComparatorAction {
|
export const enum ComparatorAction {
|
||||||
SKIP = 'SKIP',
|
SKIP = 'SKIP',
|
||||||
@ -32,9 +32,9 @@ export interface ComparatorDeleteResult<T> {
|
|||||||
|
|
||||||
export type ObjectComparatorResult =
|
export type ObjectComparatorResult =
|
||||||
| ComparatorSkipResult
|
| ComparatorSkipResult
|
||||||
| ComparatorCreateResult<ComputedPartialObjectMetadata>
|
| ComparatorCreateResult<ComputedPartialWorkspaceEntity>
|
||||||
| ComparatorUpdateResult<
|
| ComparatorUpdateResult<
|
||||||
Partial<ComputedPartialObjectMetadata> & { id: string }
|
Partial<ComputedPartialWorkspaceEntity> & { id: string }
|
||||||
>;
|
>;
|
||||||
|
|
||||||
export type FieldComparatorResult =
|
export type FieldComparatorResult =
|
||||||
|
|||||||
@ -1,13 +1,13 @@
|
|||||||
import { PartialFieldMetadata } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-field-metadata.interface';
|
import { PartialFieldMetadata } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-field-metadata.interface';
|
||||||
import { PartialObjectMetadata } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-object-metadata.interface';
|
import { PartialWorkspaceEntity } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-object-metadata.interface';
|
||||||
|
|
||||||
import { ObjectMetadataEntity } from 'src/engine/metadata-modules/object-metadata/object-metadata.entity';
|
import { ObjectMetadataEntity } from 'src/engine/metadata-modules/object-metadata/object-metadata.entity';
|
||||||
import { FieldMetadataEntity } from 'src/engine/metadata-modules/field-metadata/field-metadata.entity';
|
import { FieldMetadataEntity } from 'src/engine/metadata-modules/field-metadata/field-metadata.entity';
|
||||||
|
|
||||||
export type MappedFieldMetadata = Record<string, PartialFieldMetadata>;
|
export type MappedFieldMetadata = Record<string, PartialFieldMetadata>;
|
||||||
|
|
||||||
export interface MappedObjectMetadata
|
export interface MappedWorkspaceEntity
|
||||||
extends Omit<PartialObjectMetadata, 'fields'> {
|
extends Omit<PartialWorkspaceEntity, 'fields'> {
|
||||||
fields: MappedFieldMetadata;
|
fields: MappedFieldMetadata;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -5,7 +5,7 @@ import {
|
|||||||
} from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-field-metadata.interface';
|
} from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-field-metadata.interface';
|
||||||
import { ObjectMetadataInterface } from 'src/engine/metadata-modules/field-metadata/interfaces/object-metadata.interface';
|
import { ObjectMetadataInterface } from 'src/engine/metadata-modules/field-metadata/interfaces/object-metadata.interface';
|
||||||
|
|
||||||
export type PartialObjectMetadata = Omit<
|
export type PartialWorkspaceEntity = Omit<
|
||||||
ObjectMetadataInterface,
|
ObjectMetadataInterface,
|
||||||
'id' | 'standardId' | 'fromRelations' | 'toRelations' | 'fields' | 'isActive'
|
'id' | 'standardId' | 'fromRelations' | 'toRelations' | 'fields' | 'isActive'
|
||||||
> & {
|
> & {
|
||||||
@ -16,8 +16,8 @@ export type PartialObjectMetadata = Omit<
|
|||||||
fields: (PartialFieldMetadata | PartialComputedFieldMetadata)[];
|
fields: (PartialFieldMetadata | PartialComputedFieldMetadata)[];
|
||||||
};
|
};
|
||||||
|
|
||||||
export type ComputedPartialObjectMetadata = Omit<
|
export type ComputedPartialWorkspaceEntity = Omit<
|
||||||
PartialObjectMetadata,
|
PartialWorkspaceEntity,
|
||||||
'standardId' | 'fields'
|
'standardId' | 'fields'
|
||||||
> & {
|
> & {
|
||||||
standardId: string | null;
|
standardId: string | null;
|
||||||
|
|||||||
@ -1,61 +1,61 @@
|
|||||||
import { ActivityTargetObjectMetadata } from 'src/modules/activity/standard-objects/activity-target.object-metadata';
|
import { ActivityTargetWorkspaceEntity } from 'src/modules/activity/standard-objects/activity-target.workspace-entity';
|
||||||
import { ActivityObjectMetadata } from 'src/modules/activity/standard-objects/activity.object-metadata';
|
import { ActivityWorkspaceEntity } from 'src/modules/activity/standard-objects/activity.workspace-entity';
|
||||||
import { ApiKeyObjectMetadata } from 'src/modules/api-key/standard-objects/api-key.object-metadata';
|
import { ApiKeyWorkspaceEntity } from 'src/modules/api-key/standard-objects/api-key.workspace-entity';
|
||||||
import { AttachmentObjectMetadata } from 'src/modules/attachment/standard-objects/attachment.object-metadata';
|
import { AttachmentWorkspaceEntity } from 'src/modules/attachment/standard-objects/attachment.workspace-entity';
|
||||||
import { BlocklistObjectMetadata } from 'src/modules/connected-account/standard-objects/blocklist.object-metadata';
|
import { BlocklistWorkspaceEntity } from 'src/modules/connected-account/standard-objects/blocklist.workspace-entity';
|
||||||
import { CalendarEventObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event.object-metadata';
|
import { CalendarEventWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event.workspace-entity';
|
||||||
import { CalendarChannelObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel.object-metadata';
|
import { CalendarChannelWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel.workspace-entity';
|
||||||
import { CalendarEventParticipantObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event-participant.object-metadata';
|
import { CalendarEventParticipantWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event-participant.workspace-entity';
|
||||||
import { CommentObjectMetadata } from 'src/modules/activity/standard-objects/comment.object-metadata';
|
import { CommentWorkspaceEntity } from 'src/modules/activity/standard-objects/comment.workspace-entity';
|
||||||
import { CompanyObjectMetadata } from 'src/modules/company/standard-objects/company.object-metadata';
|
import { CompanyWorkspaceEntity } from 'src/modules/company/standard-objects/company.workspace-entity';
|
||||||
import { ConnectedAccountObjectMetadata } from 'src/modules/connected-account/standard-objects/connected-account.object-metadata';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
import { FavoriteObjectMetadata } from 'src/modules/favorite/standard-objects/favorite.object-metadata';
|
import { FavoriteWorkspaceEntity } from 'src/modules/favorite/standard-objects/favorite.workspace-entity';
|
||||||
import { MessageChannelMessageAssociationObjectMetadata } from 'src/modules/messaging/standard-objects/message-channel-message-association.object-metadata';
|
import { MessageChannelMessageAssociationWorkspaceEntity } from 'src/modules/messaging/standard-objects/message-channel-message-association.workspace-entity';
|
||||||
import { MessageChannelObjectMetadata } from 'src/modules/messaging/standard-objects/message-channel.object-metadata';
|
import { MessageChannelWorkspaceEntity } from 'src/modules/messaging/standard-objects/message-channel.workspace-entity';
|
||||||
import { MessageParticipantObjectMetadata } from 'src/modules/messaging/standard-objects/message-participant.object-metadata';
|
import { MessageParticipantWorkspaceEntity } from 'src/modules/messaging/standard-objects/message-participant.workspace-entity';
|
||||||
import { MessageThreadObjectMetadata } from 'src/modules/messaging/standard-objects/message-thread.object-metadata';
|
import { MessageThreadWorkspaceEntity } from 'src/modules/messaging/standard-objects/message-thread.workspace-entity';
|
||||||
import { MessageObjectMetadata } from 'src/modules/messaging/standard-objects/message.object-metadata';
|
import { MessageWorkspaceEntity } from 'src/modules/messaging/standard-objects/message.workspace-entity';
|
||||||
import { OpportunityObjectMetadata } from 'src/modules/opportunity/standard-objects/opportunity.object-metadata';
|
import { OpportunityWorkspaceEntity } from 'src/modules/opportunity/standard-objects/opportunity.workspace-entity';
|
||||||
import { PersonObjectMetadata } from 'src/modules/person/standard-objects/person.object-metadata';
|
import { PersonWorkspaceEntity } from 'src/modules/person/standard-objects/person.workspace-entity';
|
||||||
import { ViewFieldObjectMetadata } from 'src/modules/view/standard-objects/view-field.object-metadata';
|
import { ViewFieldWorkspaceEntity } from 'src/modules/view/standard-objects/view-field.workspace-entity';
|
||||||
import { ViewFilterObjectMetadata } from 'src/modules/view/standard-objects/view-filter.object-metadata';
|
import { ViewFilterWorkspaceEntity } from 'src/modules/view/standard-objects/view-filter.workspace-entity';
|
||||||
import { ViewSortObjectMetadata } from 'src/modules/view/standard-objects/view-sort.object-metadata';
|
import { ViewSortWorkspaceEntity } from 'src/modules/view/standard-objects/view-sort.workspace-entity';
|
||||||
import { ViewObjectMetadata } from 'src/modules/view/standard-objects/view.object-metadata';
|
import { ViewWorkspaceEntity } from 'src/modules/view/standard-objects/view.workspace-entity';
|
||||||
import { WebhookObjectMetadata } from 'src/modules/webhook/standard-objects/webhook.object-metadata';
|
import { WebhookWorkspaceEntity } from 'src/modules/webhook/standard-objects/webhook.workspace-entity';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
import { CalendarChannelEventAssociationObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.object-metadata';
|
import { CalendarChannelEventAssociationWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.workspace-entity';
|
||||||
import { AuditLogObjectMetadata } from 'src/modules/timeline/standard-objects/audit-log.object-metadata';
|
import { AuditLogWorkspaceEntity } from 'src/modules/timeline/standard-objects/audit-log.workspace-entity';
|
||||||
import { TimelineActivityObjectMetadata } from 'src/modules/timeline/standard-objects/timeline-activity.object-metadata';
|
import { TimelineActivityWorkspaceEntity } from 'src/modules/timeline/standard-objects/timeline-activity.workspace-entity';
|
||||||
import { BehavioralEventObjectMetadata } from 'src/modules/timeline/standard-objects/behavioral-event.object-metadata';
|
import { BehavioralEventWorkspaceEntity } from 'src/modules/timeline/standard-objects/behavioral-event.workspace-entity';
|
||||||
|
|
||||||
export const standardObjectMetadataDefinitions = [
|
export const standardObjectMetadataDefinitions = [
|
||||||
ActivityTargetObjectMetadata,
|
ActivityTargetWorkspaceEntity,
|
||||||
ActivityObjectMetadata,
|
ActivityWorkspaceEntity,
|
||||||
ApiKeyObjectMetadata,
|
ApiKeyWorkspaceEntity,
|
||||||
AuditLogObjectMetadata,
|
AuditLogWorkspaceEntity,
|
||||||
AttachmentObjectMetadata,
|
AttachmentWorkspaceEntity,
|
||||||
BehavioralEventObjectMetadata,
|
BehavioralEventWorkspaceEntity,
|
||||||
BlocklistObjectMetadata,
|
BlocklistWorkspaceEntity,
|
||||||
CalendarEventObjectMetadata,
|
CalendarEventWorkspaceEntity,
|
||||||
CalendarChannelObjectMetadata,
|
CalendarChannelWorkspaceEntity,
|
||||||
CalendarChannelEventAssociationObjectMetadata,
|
CalendarChannelEventAssociationWorkspaceEntity,
|
||||||
CalendarEventParticipantObjectMetadata,
|
CalendarEventParticipantWorkspaceEntity,
|
||||||
CommentObjectMetadata,
|
CommentWorkspaceEntity,
|
||||||
CompanyObjectMetadata,
|
CompanyWorkspaceEntity,
|
||||||
ConnectedAccountObjectMetadata,
|
ConnectedAccountWorkspaceEntity,
|
||||||
FavoriteObjectMetadata,
|
FavoriteWorkspaceEntity,
|
||||||
OpportunityObjectMetadata,
|
OpportunityWorkspaceEntity,
|
||||||
PersonObjectMetadata,
|
PersonWorkspaceEntity,
|
||||||
TimelineActivityObjectMetadata,
|
TimelineActivityWorkspaceEntity,
|
||||||
ViewFieldObjectMetadata,
|
ViewFieldWorkspaceEntity,
|
||||||
ViewFilterObjectMetadata,
|
ViewFilterWorkspaceEntity,
|
||||||
ViewSortObjectMetadata,
|
ViewSortWorkspaceEntity,
|
||||||
ViewObjectMetadata,
|
ViewWorkspaceEntity,
|
||||||
WebhookObjectMetadata,
|
WebhookWorkspaceEntity,
|
||||||
WorkspaceMemberObjectMetadata,
|
WorkspaceMemberWorkspaceEntity,
|
||||||
MessageThreadObjectMetadata,
|
MessageThreadWorkspaceEntity,
|
||||||
MessageObjectMetadata,
|
MessageWorkspaceEntity,
|
||||||
MessageChannelObjectMetadata,
|
MessageChannelWorkspaceEntity,
|
||||||
MessageParticipantObjectMetadata,
|
MessageParticipantWorkspaceEntity,
|
||||||
MessageChannelMessageAssociationObjectMetadata,
|
MessageChannelMessageAssociationWorkspaceEntity,
|
||||||
];
|
];
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
import { ComputedPartialObjectMetadata } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-object-metadata.interface';
|
import { ComputedPartialWorkspaceEntity } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-object-metadata.interface';
|
||||||
import { ComputedPartialFieldMetadata } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-field-metadata.interface';
|
import { ComputedPartialFieldMetadata } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-field-metadata.interface';
|
||||||
|
|
||||||
import { ObjectMetadataEntity } from 'src/engine/metadata-modules/object-metadata/object-metadata.entity';
|
import { ObjectMetadataEntity } from 'src/engine/metadata-modules/object-metadata/object-metadata.entity';
|
||||||
@ -7,9 +7,9 @@ import { RelationMetadataEntity } from 'src/engine/metadata-modules/relation-met
|
|||||||
|
|
||||||
export class WorkspaceSyncStorage {
|
export class WorkspaceSyncStorage {
|
||||||
// Object metadata
|
// Object metadata
|
||||||
private readonly _objectMetadataCreateCollection: ComputedPartialObjectMetadata[] =
|
private readonly _objectMetadataCreateCollection: ComputedPartialWorkspaceEntity[] =
|
||||||
[];
|
[];
|
||||||
private readonly _objectMetadataUpdateCollection: (Partial<ComputedPartialObjectMetadata> & {
|
private readonly _objectMetadataUpdateCollection: (Partial<ComputedPartialWorkspaceEntity> & {
|
||||||
id: string;
|
id: string;
|
||||||
})[] = [];
|
})[] = [];
|
||||||
private readonly _objectMetadataDeleteCollection: ObjectMetadataEntity[] = [];
|
private readonly _objectMetadataDeleteCollection: ObjectMetadataEntity[] = [];
|
||||||
@ -68,12 +68,12 @@ export class WorkspaceSyncStorage {
|
|||||||
return this._relationMetadataDeleteCollection;
|
return this._relationMetadataDeleteCollection;
|
||||||
}
|
}
|
||||||
|
|
||||||
addCreateObjectMetadata(object: ComputedPartialObjectMetadata) {
|
addCreateObjectMetadata(object: ComputedPartialWorkspaceEntity) {
|
||||||
this._objectMetadataCreateCollection.push(object);
|
this._objectMetadataCreateCollection.push(object);
|
||||||
}
|
}
|
||||||
|
|
||||||
addUpdateObjectMetadata(
|
addUpdateObjectMetadata(
|
||||||
object: Partial<ComputedPartialObjectMetadata> & { id: string },
|
object: Partial<ComputedPartialWorkspaceEntity> & { id: string },
|
||||||
) {
|
) {
|
||||||
this._objectMetadataUpdateCollection.push(object);
|
this._objectMetadataUpdateCollection.push(object);
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,9 +1,19 @@
|
|||||||
|
import { ObjectLiteral } from 'typeorm';
|
||||||
|
|
||||||
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
||||||
|
|
||||||
export type ObjectRecord<T extends BaseWorkspaceEntity> = {
|
export type ObjectRecord<T extends ObjectLiteral> = {
|
||||||
[K in keyof T as T[K] extends BaseWorkspaceEntity
|
[K in keyof T as T[K] extends BaseWorkspaceEntity
|
||||||
? `${Extract<K, string>}Id`
|
? `${Extract<K, string>}Id`
|
||||||
: K]: T[K] extends BaseWorkspaceEntity ? string : T[K];
|
: K]: T[K] extends BaseWorkspaceEntity
|
||||||
|
? string
|
||||||
|
: T[K] extends BaseWorkspaceEntity[]
|
||||||
|
? string[]
|
||||||
|
: T[K];
|
||||||
} & {
|
} & {
|
||||||
[K in keyof T]: T[K] extends BaseWorkspaceEntity ? ObjectRecord<T[K]> : T[K];
|
[K in keyof T]: T[K] extends BaseWorkspaceEntity
|
||||||
|
? ObjectRecord<T[K]>
|
||||||
|
: T[K] extends BaseWorkspaceEntity[]
|
||||||
|
? ObjectRecord<T[K][number]>[]
|
||||||
|
: T[K];
|
||||||
};
|
};
|
||||||
|
|||||||
@ -1,6 +1,6 @@
|
|||||||
import {
|
import {
|
||||||
ComputedPartialObjectMetadata,
|
ComputedPartialWorkspaceEntity,
|
||||||
PartialObjectMetadata,
|
PartialWorkspaceEntity,
|
||||||
} from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-object-metadata.interface';
|
} from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-object-metadata.interface';
|
||||||
import { ComputedPartialFieldMetadata } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-field-metadata.interface';
|
import { ComputedPartialFieldMetadata } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/partial-field-metadata.interface';
|
||||||
|
|
||||||
@ -12,12 +12,12 @@ import {
|
|||||||
} from 'src/engine/workspace-manager/workspace-sync-metadata/utils/create-deterministic-uuid.util';
|
} from 'src/engine/workspace-manager/workspace-sync-metadata/utils/create-deterministic-uuid.util';
|
||||||
|
|
||||||
export const computeStandardObject = (
|
export const computeStandardObject = (
|
||||||
standardObjectMetadata: Omit<PartialObjectMetadata, 'standardId'> & {
|
standardObjectMetadata: Omit<PartialWorkspaceEntity, 'standardId'> & {
|
||||||
standardId: string | null;
|
standardId: string | null;
|
||||||
},
|
},
|
||||||
originalObjectMetadata: ObjectMetadataEntity,
|
originalObjectMetadata: ObjectMetadataEntity,
|
||||||
customObjectMetadataCollection: ObjectMetadataEntity[] = [],
|
customObjectMetadataCollection: ObjectMetadataEntity[] = [],
|
||||||
): ComputedPartialObjectMetadata => {
|
): ComputedPartialWorkspaceEntity => {
|
||||||
const fields: ComputedPartialFieldMetadata[] = [];
|
const fields: ComputedPartialFieldMetadata[] = [];
|
||||||
|
|
||||||
for (const partialFieldMetadata of standardObjectMetadata.fields) {
|
for (const partialFieldMetadata of standardObjectMetadata.fields) {
|
||||||
|
|||||||
@ -1,7 +1,8 @@
|
|||||||
import { camelCase } from 'src/utils/camel-case';
|
import { camelCase } from 'src/utils/camel-case';
|
||||||
|
|
||||||
|
const classSuffix = 'WorkspaceEntity';
|
||||||
|
|
||||||
export const convertClassNameToObjectMetadataName = (name: string): string => {
|
export const convertClassNameToObjectMetadataName = (name: string): string => {
|
||||||
const classSuffix = 'ObjectMetadata';
|
|
||||||
let objectName = camelCase(name);
|
let objectName = camelCase(name);
|
||||||
|
|
||||||
if (objectName.endsWith(classSuffix)) {
|
if (objectName.endsWith(classSuffix)) {
|
||||||
|
|||||||
@ -3,11 +3,11 @@ import { Relation } from 'src/engine/workspace-manager/workspace-sync-metadata/i
|
|||||||
import { ACTIVITY_TARGET_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
import { ACTIVITY_TARGET_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
||||||
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
||||||
import { CustomWorkspaceEntity } from 'src/engine/twenty-orm/custom.workspace-entity';
|
import { CustomWorkspaceEntity } from 'src/engine/twenty-orm/custom.workspace-entity';
|
||||||
import { ActivityObjectMetadata } from 'src/modules/activity/standard-objects/activity.object-metadata';
|
import { ActivityWorkspaceEntity } from 'src/modules/activity/standard-objects/activity.workspace-entity';
|
||||||
import { CompanyObjectMetadata } from 'src/modules/company/standard-objects/company.object-metadata';
|
import { CompanyWorkspaceEntity } from 'src/modules/company/standard-objects/company.workspace-entity';
|
||||||
import { OpportunityObjectMetadata } from 'src/modules/opportunity/standard-objects/opportunity.object-metadata';
|
import { OpportunityWorkspaceEntity } from 'src/modules/opportunity/standard-objects/opportunity.workspace-entity';
|
||||||
import { PersonObjectMetadata } from 'src/modules/person/standard-objects/person.object-metadata';
|
import { PersonWorkspaceEntity } from 'src/modules/person/standard-objects/person.workspace-entity';
|
||||||
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-object.decorator';
|
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-entity.decorator';
|
||||||
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
||||||
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
||||||
import { WorkspaceIsNullable } from 'src/engine/twenty-orm/decorators/workspace-is-nullable.decorator';
|
import { WorkspaceIsNullable } from 'src/engine/twenty-orm/decorators/workspace-is-nullable.decorator';
|
||||||
@ -26,7 +26,7 @@ import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity
|
|||||||
})
|
})
|
||||||
@WorkspaceIsSystem()
|
@WorkspaceIsSystem()
|
||||||
@WorkspaceIsNotAuditLogged()
|
@WorkspaceIsNotAuditLogged()
|
||||||
export class ActivityTargetObjectMetadata extends BaseWorkspaceEntity {
|
export class ActivityTargetWorkspaceEntity extends BaseWorkspaceEntity {
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: ACTIVITY_TARGET_STANDARD_FIELD_IDS.activity,
|
standardId: ACTIVITY_TARGET_STANDARD_FIELD_IDS.activity,
|
||||||
type: RelationMetadataType.MANY_TO_ONE,
|
type: RelationMetadataType.MANY_TO_ONE,
|
||||||
@ -34,11 +34,11 @@ export class ActivityTargetObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'ActivityTarget activity',
|
description: 'ActivityTarget activity',
|
||||||
icon: 'IconNotes',
|
icon: 'IconNotes',
|
||||||
joinColumn: 'activityId',
|
joinColumn: 'activityId',
|
||||||
inverseSideTarget: () => ActivityObjectMetadata,
|
inverseSideTarget: () => ActivityWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'activityTargets',
|
inverseSideFieldKey: 'activityTargets',
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
activity: Relation<ActivityObjectMetadata>;
|
activity: Relation<ActivityWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: ACTIVITY_TARGET_STANDARD_FIELD_IDS.person,
|
standardId: ACTIVITY_TARGET_STANDARD_FIELD_IDS.person,
|
||||||
@ -47,11 +47,11 @@ export class ActivityTargetObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'ActivityTarget person',
|
description: 'ActivityTarget person',
|
||||||
icon: 'IconUser',
|
icon: 'IconUser',
|
||||||
joinColumn: 'personId',
|
joinColumn: 'personId',
|
||||||
inverseSideTarget: () => PersonObjectMetadata,
|
inverseSideTarget: () => PersonWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'activityTargets',
|
inverseSideFieldKey: 'activityTargets',
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
person: Relation<PersonObjectMetadata>;
|
person: Relation<PersonWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: ACTIVITY_TARGET_STANDARD_FIELD_IDS.company,
|
standardId: ACTIVITY_TARGET_STANDARD_FIELD_IDS.company,
|
||||||
@ -60,11 +60,11 @@ export class ActivityTargetObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'ActivityTarget company',
|
description: 'ActivityTarget company',
|
||||||
icon: 'IconBuildingSkyscraper',
|
icon: 'IconBuildingSkyscraper',
|
||||||
joinColumn: 'companyId',
|
joinColumn: 'companyId',
|
||||||
inverseSideTarget: () => CompanyObjectMetadata,
|
inverseSideTarget: () => CompanyWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'activityTargets',
|
inverseSideFieldKey: 'activityTargets',
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
company: Relation<CompanyObjectMetadata>;
|
company: Relation<CompanyWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: ACTIVITY_TARGET_STANDARD_FIELD_IDS.opportunity,
|
standardId: ACTIVITY_TARGET_STANDARD_FIELD_IDS.opportunity,
|
||||||
@ -73,11 +73,11 @@ export class ActivityTargetObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'ActivityTarget opportunity',
|
description: 'ActivityTarget opportunity',
|
||||||
icon: 'IconTargetArrow',
|
icon: 'IconTargetArrow',
|
||||||
joinColumn: 'opportunityId',
|
joinColumn: 'opportunityId',
|
||||||
inverseSideTarget: () => OpportunityObjectMetadata,
|
inverseSideTarget: () => OpportunityWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'activityTargets',
|
inverseSideFieldKey: 'activityTargets',
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
opportunity: Relation<OpportunityObjectMetadata>;
|
opportunity: Relation<OpportunityWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceDynamicRelation({
|
@WorkspaceDynamicRelation({
|
||||||
type: RelationMetadataType.MANY_TO_ONE,
|
type: RelationMetadataType.MANY_TO_ONE,
|
||||||
@ -7,11 +7,11 @@ import {
|
|||||||
} from 'src/engine/metadata-modules/relation-metadata/relation-metadata.entity';
|
} from 'src/engine/metadata-modules/relation-metadata/relation-metadata.entity';
|
||||||
import { ACTIVITY_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
import { ACTIVITY_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
||||||
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
||||||
import { ActivityTargetObjectMetadata } from 'src/modules/activity/standard-objects/activity-target.object-metadata';
|
import { ActivityTargetWorkspaceEntity } from 'src/modules/activity/standard-objects/activity-target.workspace-entity';
|
||||||
import { AttachmentObjectMetadata } from 'src/modules/attachment/standard-objects/attachment.object-metadata';
|
import { AttachmentWorkspaceEntity } from 'src/modules/attachment/standard-objects/attachment.workspace-entity';
|
||||||
import { CommentObjectMetadata } from 'src/modules/activity/standard-objects/comment.object-metadata';
|
import { CommentWorkspaceEntity } from 'src/modules/activity/standard-objects/comment.workspace-entity';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-object.decorator';
|
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-entity.decorator';
|
||||||
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
||||||
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
||||||
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
||||||
@ -29,7 +29,7 @@ import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity
|
|||||||
})
|
})
|
||||||
@WorkspaceIsNotAuditLogged()
|
@WorkspaceIsNotAuditLogged()
|
||||||
@WorkspaceIsSystem()
|
@WorkspaceIsSystem()
|
||||||
export class ActivityObjectMetadata extends BaseWorkspaceEntity {
|
export class ActivityWorkspaceEntity extends BaseWorkspaceEntity {
|
||||||
@WorkspaceField({
|
@WorkspaceField({
|
||||||
standardId: ACTIVITY_STANDARD_FIELD_IDS.title,
|
standardId: ACTIVITY_STANDARD_FIELD_IDS.title,
|
||||||
type: FieldMetadataType.TEXT,
|
type: FieldMetadataType.TEXT,
|
||||||
@ -94,11 +94,11 @@ export class ActivityObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'Activity targets',
|
description: 'Activity targets',
|
||||||
icon: 'IconCheckbox',
|
icon: 'IconCheckbox',
|
||||||
type: RelationMetadataType.ONE_TO_MANY,
|
type: RelationMetadataType.ONE_TO_MANY,
|
||||||
inverseSideTarget: () => ActivityTargetObjectMetadata,
|
inverseSideTarget: () => ActivityTargetWorkspaceEntity,
|
||||||
onDelete: RelationOnDeleteAction.SET_NULL,
|
onDelete: RelationOnDeleteAction.SET_NULL,
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
activityTargets: Relation<ActivityTargetObjectMetadata[]>;
|
activityTargets: Relation<ActivityTargetWorkspaceEntity[]>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: ACTIVITY_STANDARD_FIELD_IDS.attachments,
|
standardId: ACTIVITY_STANDARD_FIELD_IDS.attachments,
|
||||||
@ -106,11 +106,11 @@ export class ActivityObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'Activity attachments',
|
description: 'Activity attachments',
|
||||||
icon: 'IconFileImport',
|
icon: 'IconFileImport',
|
||||||
type: RelationMetadataType.ONE_TO_MANY,
|
type: RelationMetadataType.ONE_TO_MANY,
|
||||||
inverseSideTarget: () => AttachmentObjectMetadata,
|
inverseSideTarget: () => AttachmentWorkspaceEntity,
|
||||||
onDelete: RelationOnDeleteAction.SET_NULL,
|
onDelete: RelationOnDeleteAction.SET_NULL,
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
attachments: Relation<AttachmentObjectMetadata[]>;
|
attachments: Relation<AttachmentWorkspaceEntity[]>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: ACTIVITY_STANDARD_FIELD_IDS.comments,
|
standardId: ACTIVITY_STANDARD_FIELD_IDS.comments,
|
||||||
@ -118,11 +118,11 @@ export class ActivityObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'Activity comments',
|
description: 'Activity comments',
|
||||||
icon: 'IconComment',
|
icon: 'IconComment',
|
||||||
type: RelationMetadataType.ONE_TO_MANY,
|
type: RelationMetadataType.ONE_TO_MANY,
|
||||||
inverseSideTarget: () => CommentObjectMetadata,
|
inverseSideTarget: () => CommentWorkspaceEntity,
|
||||||
onDelete: RelationOnDeleteAction.CASCADE,
|
onDelete: RelationOnDeleteAction.CASCADE,
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
comments: Relation<CommentObjectMetadata[]>;
|
comments: Relation<CommentWorkspaceEntity[]>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: ACTIVITY_STANDARD_FIELD_IDS.author,
|
standardId: ACTIVITY_STANDARD_FIELD_IDS.author,
|
||||||
@ -130,13 +130,13 @@ export class ActivityObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'Activity author',
|
description: 'Activity author',
|
||||||
icon: 'IconUserCircle',
|
icon: 'IconUserCircle',
|
||||||
type: RelationMetadataType.MANY_TO_ONE,
|
type: RelationMetadataType.MANY_TO_ONE,
|
||||||
inverseSideTarget: () => WorkspaceMemberObjectMetadata,
|
inverseSideTarget: () => WorkspaceMemberWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'authoredActivities',
|
inverseSideFieldKey: 'authoredActivities',
|
||||||
onDelete: RelationOnDeleteAction.SET_NULL,
|
onDelete: RelationOnDeleteAction.SET_NULL,
|
||||||
joinColumn: 'authorId',
|
joinColumn: 'authorId',
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
author: Relation<WorkspaceMemberObjectMetadata>;
|
author: Relation<WorkspaceMemberWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: ACTIVITY_STANDARD_FIELD_IDS.assignee,
|
standardId: ACTIVITY_STANDARD_FIELD_IDS.assignee,
|
||||||
@ -144,11 +144,11 @@ export class ActivityObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'Activity assignee',
|
description: 'Activity assignee',
|
||||||
icon: 'IconUserCircle',
|
icon: 'IconUserCircle',
|
||||||
type: RelationMetadataType.MANY_TO_ONE,
|
type: RelationMetadataType.MANY_TO_ONE,
|
||||||
inverseSideTarget: () => WorkspaceMemberObjectMetadata,
|
inverseSideTarget: () => WorkspaceMemberWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'assignedActivities',
|
inverseSideFieldKey: 'assignedActivities',
|
||||||
onDelete: RelationOnDeleteAction.SET_NULL,
|
onDelete: RelationOnDeleteAction.SET_NULL,
|
||||||
joinColumn: 'assigneeId',
|
joinColumn: 'assigneeId',
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
assignee: Relation<WorkspaceMemberObjectMetadata>;
|
assignee: Relation<WorkspaceMemberWorkspaceEntity>;
|
||||||
}
|
}
|
||||||
@ -3,9 +3,9 @@ import { Relation } from 'src/engine/workspace-manager/workspace-sync-metadata/i
|
|||||||
import { FieldMetadataType } from 'src/engine/metadata-modules/field-metadata/field-metadata.entity';
|
import { FieldMetadataType } from 'src/engine/metadata-modules/field-metadata/field-metadata.entity';
|
||||||
import { COMMENT_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
import { COMMENT_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
||||||
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
||||||
import { ActivityObjectMetadata } from 'src/modules/activity/standard-objects/activity.object-metadata';
|
import { ActivityWorkspaceEntity } from 'src/modules/activity/standard-objects/activity.workspace-entity';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-object.decorator';
|
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-entity.decorator';
|
||||||
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
||||||
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
||||||
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
||||||
@ -23,7 +23,7 @@ import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity
|
|||||||
})
|
})
|
||||||
@WorkspaceIsSystem()
|
@WorkspaceIsSystem()
|
||||||
@WorkspaceIsNotAuditLogged()
|
@WorkspaceIsNotAuditLogged()
|
||||||
export class CommentObjectMetadata extends BaseWorkspaceEntity {
|
export class CommentWorkspaceEntity extends BaseWorkspaceEntity {
|
||||||
@WorkspaceField({
|
@WorkspaceField({
|
||||||
standardId: COMMENT_STANDARD_FIELD_IDS.body,
|
standardId: COMMENT_STANDARD_FIELD_IDS.body,
|
||||||
type: FieldMetadataType.TEXT,
|
type: FieldMetadataType.TEXT,
|
||||||
@ -40,10 +40,10 @@ export class CommentObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'Comment author',
|
description: 'Comment author',
|
||||||
icon: 'IconCircleUser',
|
icon: 'IconCircleUser',
|
||||||
joinColumn: 'authorId',
|
joinColumn: 'authorId',
|
||||||
inverseSideTarget: () => WorkspaceMemberObjectMetadata,
|
inverseSideTarget: () => WorkspaceMemberWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'authoredComments',
|
inverseSideFieldKey: 'authoredComments',
|
||||||
})
|
})
|
||||||
author: Relation<WorkspaceMemberObjectMetadata>;
|
author: Relation<WorkspaceMemberWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: COMMENT_STANDARD_FIELD_IDS.activity,
|
standardId: COMMENT_STANDARD_FIELD_IDS.activity,
|
||||||
@ -52,8 +52,8 @@ export class CommentObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'Comment activity',
|
description: 'Comment activity',
|
||||||
icon: 'IconNotes',
|
icon: 'IconNotes',
|
||||||
joinColumn: 'activityId',
|
joinColumn: 'activityId',
|
||||||
inverseSideTarget: () => ActivityObjectMetadata,
|
inverseSideTarget: () => ActivityWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'comments',
|
inverseSideFieldKey: 'comments',
|
||||||
})
|
})
|
||||||
activity: Relation<ActivityObjectMetadata>;
|
activity: Relation<ActivityWorkspaceEntity>;
|
||||||
}
|
}
|
||||||
@ -4,7 +4,7 @@ import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field
|
|||||||
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
||||||
import { WorkspaceIsNullable } from 'src/engine/twenty-orm/decorators/workspace-is-nullable.decorator';
|
import { WorkspaceIsNullable } from 'src/engine/twenty-orm/decorators/workspace-is-nullable.decorator';
|
||||||
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
||||||
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-object.decorator';
|
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-entity.decorator';
|
||||||
import { API_KEY_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
import { API_KEY_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
||||||
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
||||||
|
|
||||||
@ -18,7 +18,7 @@ import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync
|
|||||||
})
|
})
|
||||||
@WorkspaceIsSystem()
|
@WorkspaceIsSystem()
|
||||||
@WorkspaceIsNotAuditLogged()
|
@WorkspaceIsNotAuditLogged()
|
||||||
export class ApiKeyObjectMetadata extends BaseWorkspaceEntity {
|
export class ApiKeyWorkspaceEntity extends BaseWorkspaceEntity {
|
||||||
@WorkspaceField({
|
@WorkspaceField({
|
||||||
standardId: API_KEY_STANDARD_FIELD_IDS.name,
|
standardId: API_KEY_STANDARD_FIELD_IDS.name,
|
||||||
type: FieldMetadataType.TEXT,
|
type: FieldMetadataType.TEXT,
|
||||||
@ -4,12 +4,12 @@ import { FieldMetadataType } from 'src/engine/metadata-modules/field-metadata/fi
|
|||||||
import { ATTACHMENT_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
import { ATTACHMENT_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
||||||
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
||||||
import { CustomWorkspaceEntity } from 'src/engine/twenty-orm/custom.workspace-entity';
|
import { CustomWorkspaceEntity } from 'src/engine/twenty-orm/custom.workspace-entity';
|
||||||
import { ActivityObjectMetadata } from 'src/modules/activity/standard-objects/activity.object-metadata';
|
import { ActivityWorkspaceEntity } from 'src/modules/activity/standard-objects/activity.workspace-entity';
|
||||||
import { CompanyObjectMetadata } from 'src/modules/company/standard-objects/company.object-metadata';
|
import { CompanyWorkspaceEntity } from 'src/modules/company/standard-objects/company.workspace-entity';
|
||||||
import { OpportunityObjectMetadata } from 'src/modules/opportunity/standard-objects/opportunity.object-metadata';
|
import { OpportunityWorkspaceEntity } from 'src/modules/opportunity/standard-objects/opportunity.workspace-entity';
|
||||||
import { PersonObjectMetadata } from 'src/modules/person/standard-objects/person.object-metadata';
|
import { PersonWorkspaceEntity } from 'src/modules/person/standard-objects/person.workspace-entity';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-object.decorator';
|
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-entity.decorator';
|
||||||
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
||||||
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
||||||
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
||||||
@ -29,7 +29,7 @@ import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity
|
|||||||
})
|
})
|
||||||
@WorkspaceIsSystem()
|
@WorkspaceIsSystem()
|
||||||
@WorkspaceIsNotAuditLogged()
|
@WorkspaceIsNotAuditLogged()
|
||||||
export class AttachmentObjectMetadata extends BaseWorkspaceEntity {
|
export class AttachmentWorkspaceEntity extends BaseWorkspaceEntity {
|
||||||
@WorkspaceField({
|
@WorkspaceField({
|
||||||
standardId: ATTACHMENT_STANDARD_FIELD_IDS.name,
|
standardId: ATTACHMENT_STANDARD_FIELD_IDS.name,
|
||||||
type: FieldMetadataType.TEXT,
|
type: FieldMetadataType.TEXT,
|
||||||
@ -64,10 +64,10 @@ export class AttachmentObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'Attachment author',
|
description: 'Attachment author',
|
||||||
icon: 'IconCircleUser',
|
icon: 'IconCircleUser',
|
||||||
joinColumn: 'authorId',
|
joinColumn: 'authorId',
|
||||||
inverseSideTarget: () => WorkspaceMemberObjectMetadata,
|
inverseSideTarget: () => WorkspaceMemberWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'authoredAttachments',
|
inverseSideFieldKey: 'authoredAttachments',
|
||||||
})
|
})
|
||||||
author: Relation<WorkspaceMemberObjectMetadata>;
|
author: Relation<WorkspaceMemberWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: ATTACHMENT_STANDARD_FIELD_IDS.activity,
|
standardId: ATTACHMENT_STANDARD_FIELD_IDS.activity,
|
||||||
@ -76,11 +76,11 @@ export class AttachmentObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'Attachment activity',
|
description: 'Attachment activity',
|
||||||
icon: 'IconNotes',
|
icon: 'IconNotes',
|
||||||
joinColumn: 'activityId',
|
joinColumn: 'activityId',
|
||||||
inverseSideTarget: () => ActivityObjectMetadata,
|
inverseSideTarget: () => ActivityWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'attachments',
|
inverseSideFieldKey: 'attachments',
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
activity: Relation<ActivityObjectMetadata>;
|
activity: Relation<ActivityWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: ATTACHMENT_STANDARD_FIELD_IDS.person,
|
standardId: ATTACHMENT_STANDARD_FIELD_IDS.person,
|
||||||
@ -89,11 +89,11 @@ export class AttachmentObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'Attachment person',
|
description: 'Attachment person',
|
||||||
icon: 'IconUser',
|
icon: 'IconUser',
|
||||||
joinColumn: 'personId',
|
joinColumn: 'personId',
|
||||||
inverseSideTarget: () => PersonObjectMetadata,
|
inverseSideTarget: () => PersonWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'attachments',
|
inverseSideFieldKey: 'attachments',
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
person: Relation<PersonObjectMetadata>;
|
person: Relation<PersonWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: ATTACHMENT_STANDARD_FIELD_IDS.company,
|
standardId: ATTACHMENT_STANDARD_FIELD_IDS.company,
|
||||||
@ -102,11 +102,11 @@ export class AttachmentObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'Attachment company',
|
description: 'Attachment company',
|
||||||
icon: 'IconBuildingSkyscraper',
|
icon: 'IconBuildingSkyscraper',
|
||||||
joinColumn: 'companyId',
|
joinColumn: 'companyId',
|
||||||
inverseSideTarget: () => CompanyObjectMetadata,
|
inverseSideTarget: () => CompanyWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'attachments',
|
inverseSideFieldKey: 'attachments',
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
company: Relation<CompanyObjectMetadata>;
|
company: Relation<CompanyWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: ATTACHMENT_STANDARD_FIELD_IDS.opportunity,
|
standardId: ATTACHMENT_STANDARD_FIELD_IDS.opportunity,
|
||||||
@ -115,11 +115,11 @@ export class AttachmentObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'Attachment opportunity',
|
description: 'Attachment opportunity',
|
||||||
icon: 'IconBuildingSkyscraper',
|
icon: 'IconBuildingSkyscraper',
|
||||||
joinColumn: 'opportunityId',
|
joinColumn: 'opportunityId',
|
||||||
inverseSideTarget: () => OpportunityObjectMetadata,
|
inverseSideTarget: () => OpportunityWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'attachments',
|
inverseSideFieldKey: 'attachments',
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
opportunity: Relation<OpportunityObjectMetadata>;
|
opportunity: Relation<OpportunityWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceDynamicRelation({
|
@WorkspaceDynamicRelation({
|
||||||
type: RelationMetadataType.MANY_TO_ONE,
|
type: RelationMetadataType.MANY_TO_ONE,
|
||||||
@ -14,7 +14,7 @@ import {
|
|||||||
UnmatchParticipantJobData,
|
UnmatchParticipantJobData,
|
||||||
UnmatchParticipantJob,
|
UnmatchParticipantJob,
|
||||||
} from 'src/modules/calendar-messaging-participant/jobs/unmatch-participant.job';
|
} from 'src/modules/calendar-messaging-participant/jobs/unmatch-participant.job';
|
||||||
import { PersonObjectMetadata } from 'src/modules/person/standard-objects/person.object-metadata';
|
import { PersonWorkspaceEntity } from 'src/modules/person/standard-objects/person.workspace-entity';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class ParticipantPersonListener {
|
export class ParticipantPersonListener {
|
||||||
@ -25,7 +25,7 @@ export class ParticipantPersonListener {
|
|||||||
|
|
||||||
@OnEvent('person.created')
|
@OnEvent('person.created')
|
||||||
async handleCreatedEvent(
|
async handleCreatedEvent(
|
||||||
payload: ObjectRecordCreateEvent<PersonObjectMetadata>,
|
payload: ObjectRecordCreateEvent<PersonWorkspaceEntity>,
|
||||||
) {
|
) {
|
||||||
if (payload.properties.after.email === null) {
|
if (payload.properties.after.email === null) {
|
||||||
return;
|
return;
|
||||||
@ -43,7 +43,7 @@ export class ParticipantPersonListener {
|
|||||||
|
|
||||||
@OnEvent('person.updated')
|
@OnEvent('person.updated')
|
||||||
async handleUpdatedEvent(
|
async handleUpdatedEvent(
|
||||||
payload: ObjectRecordUpdateEvent<PersonObjectMetadata>,
|
payload: ObjectRecordUpdateEvent<PersonWorkspaceEntity>,
|
||||||
) {
|
) {
|
||||||
if (
|
if (
|
||||||
objectRecordUpdateEventChangedProperties(
|
objectRecordUpdateEventChangedProperties(
|
||||||
|
|||||||
@ -14,7 +14,7 @@ import {
|
|||||||
UnmatchParticipantJobData,
|
UnmatchParticipantJobData,
|
||||||
UnmatchParticipantJob,
|
UnmatchParticipantJob,
|
||||||
} from 'src/modules/calendar-messaging-participant/jobs/unmatch-participant.job';
|
} from 'src/modules/calendar-messaging-participant/jobs/unmatch-participant.job';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class ParticipantWorkspaceMemberListener {
|
export class ParticipantWorkspaceMemberListener {
|
||||||
@ -25,7 +25,7 @@ export class ParticipantWorkspaceMemberListener {
|
|||||||
|
|
||||||
@OnEvent('workspaceMember.created')
|
@OnEvent('workspaceMember.created')
|
||||||
async handleCreatedEvent(
|
async handleCreatedEvent(
|
||||||
payload: ObjectRecordCreateEvent<WorkspaceMemberObjectMetadata>,
|
payload: ObjectRecordCreateEvent<WorkspaceMemberWorkspaceEntity>,
|
||||||
) {
|
) {
|
||||||
if (payload.properties.after.userEmail === null) {
|
if (payload.properties.after.userEmail === null) {
|
||||||
return;
|
return;
|
||||||
@ -43,7 +43,7 @@ export class ParticipantWorkspaceMemberListener {
|
|||||||
|
|
||||||
@OnEvent('workspaceMember.updated')
|
@OnEvent('workspaceMember.updated')
|
||||||
async handleUpdatedEvent(
|
async handleUpdatedEvent(
|
||||||
payload: ObjectRecordUpdateEvent<WorkspaceMemberObjectMetadata>,
|
payload: ObjectRecordUpdateEvent<WorkspaceMemberWorkspaceEntity>,
|
||||||
) {
|
) {
|
||||||
if (
|
if (
|
||||||
objectRecordUpdateEventChangedProperties(
|
objectRecordUpdateEventChangedProperties(
|
||||||
|
|||||||
@ -3,12 +3,12 @@ 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 { WorkspaceDataSourceModule } from 'src/engine/workspace-datasource/workspace-datasource.module';
|
import { WorkspaceDataSourceModule } from 'src/engine/workspace-datasource/workspace-datasource.module';
|
||||||
import { AddPersonIdAndWorkspaceMemberIdService } from 'src/modules/calendar-messaging-participant/services/add-person-id-and-workspace-member-id/add-person-id-and-workspace-member-id.service';
|
import { AddPersonIdAndWorkspaceMemberIdService } from 'src/modules/calendar-messaging-participant/services/add-person-id-and-workspace-member-id/add-person-id-and-workspace-member-id.service';
|
||||||
import { PersonObjectMetadata } from 'src/modules/person/standard-objects/person.object-metadata';
|
import { PersonWorkspaceEntity } from 'src/modules/person/standard-objects/person.workspace-entity';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
WorkspaceDataSourceModule,
|
WorkspaceDataSourceModule,
|
||||||
ObjectMetadataRepositoryModule.forFeature([PersonObjectMetadata]),
|
ObjectMetadataRepositoryModule.forFeature([PersonWorkspaceEntity]),
|
||||||
],
|
],
|
||||||
providers: [AddPersonIdAndWorkspaceMemberIdService],
|
providers: [AddPersonIdAndWorkspaceMemberIdService],
|
||||||
exports: [AddPersonIdAndWorkspaceMemberIdService],
|
exports: [AddPersonIdAndWorkspaceMemberIdService],
|
||||||
|
|||||||
@ -5,13 +5,13 @@ import { EntityManager } 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 { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
||||||
import { PersonRepository } from 'src/modules/person/repositories/person.repository';
|
import { PersonRepository } from 'src/modules/person/repositories/person.repository';
|
||||||
import { PersonObjectMetadata } from 'src/modules/person/standard-objects/person.object-metadata';
|
import { PersonWorkspaceEntity } from 'src/modules/person/standard-objects/person.workspace-entity';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class AddPersonIdAndWorkspaceMemberIdService {
|
export class AddPersonIdAndWorkspaceMemberIdService {
|
||||||
constructor(
|
constructor(
|
||||||
private readonly workspaceDataSourceService: WorkspaceDataSourceService,
|
private readonly workspaceDataSourceService: WorkspaceDataSourceService,
|
||||||
@InjectObjectMetadataRepository(PersonObjectMetadata)
|
@InjectObjectMetadataRepository(PersonWorkspaceEntity)
|
||||||
private readonly personRepository: PersonRepository,
|
private readonly personRepository: PersonRepository,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
|
|||||||
@ -3,14 +3,14 @@ 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 { GoogleCalendarSyncCommand } from 'src/modules/calendar/commands/google-calendar-sync.command';
|
import { GoogleCalendarSyncCommand } from 'src/modules/calendar/commands/google-calendar-sync.command';
|
||||||
import { WorkspaceGoogleCalendarSyncModule } from 'src/modules/calendar/services/workspace-google-calendar-sync/workspace-google-calendar-sync.module';
|
import { WorkspaceGoogleCalendarSyncModule } from 'src/modules/calendar/services/workspace-google-calendar-sync/workspace-google-calendar-sync.module';
|
||||||
import { CalendarChannelObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel.object-metadata';
|
import { CalendarChannelWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel.workspace-entity';
|
||||||
import { ConnectedAccountObjectMetadata } from 'src/modules/connected-account/standard-objects/connected-account.object-metadata';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
ObjectMetadataRepositoryModule.forFeature([
|
ObjectMetadataRepositoryModule.forFeature([
|
||||||
ConnectedAccountObjectMetadata,
|
ConnectedAccountWorkspaceEntity,
|
||||||
CalendarChannelObjectMetadata,
|
CalendarChannelWorkspaceEntity,
|
||||||
]),
|
]),
|
||||||
WorkspaceGoogleCalendarSyncModule,
|
WorkspaceGoogleCalendarSyncModule,
|
||||||
],
|
],
|
||||||
|
|||||||
@ -6,10 +6,10 @@ import { InjectObjectMetadataRepository } from 'src/engine/object-metadata-repos
|
|||||||
import { CalendarChannelEventAssociationRepository } from 'src/modules/calendar/repositories/calendar-channel-event-association.repository';
|
import { CalendarChannelEventAssociationRepository } from 'src/modules/calendar/repositories/calendar-channel-event-association.repository';
|
||||||
import { CalendarChannelRepository } from 'src/modules/calendar/repositories/calendar-channel.repository';
|
import { CalendarChannelRepository } from 'src/modules/calendar/repositories/calendar-channel.repository';
|
||||||
import { CalendarEventCleanerService } from 'src/modules/calendar/services/calendar-event-cleaner/calendar-event-cleaner.service';
|
import { CalendarEventCleanerService } from 'src/modules/calendar/services/calendar-event-cleaner/calendar-event-cleaner.service';
|
||||||
import { CalendarChannelEventAssociationObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.object-metadata';
|
import { CalendarChannelEventAssociationWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.workspace-entity';
|
||||||
import { CalendarChannelObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel.object-metadata';
|
import { CalendarChannelWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel.workspace-entity';
|
||||||
import { BlocklistRepository } from 'src/modules/connected-account/repositories/blocklist.repository';
|
import { BlocklistRepository } from 'src/modules/connected-account/repositories/blocklist.repository';
|
||||||
import { BlocklistObjectMetadata } from 'src/modules/connected-account/standard-objects/blocklist.object-metadata';
|
import { BlocklistWorkspaceEntity } from 'src/modules/connected-account/standard-objects/blocklist.workspace-entity';
|
||||||
|
|
||||||
export type BlocklistItemDeleteCalendarEventsJobData = {
|
export type BlocklistItemDeleteCalendarEventsJobData = {
|
||||||
workspaceId: string;
|
workspaceId: string;
|
||||||
@ -25,13 +25,13 @@ export class BlocklistItemDeleteCalendarEventsJob
|
|||||||
);
|
);
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
@InjectObjectMetadataRepository(CalendarChannelObjectMetadata)
|
@InjectObjectMetadataRepository(CalendarChannelWorkspaceEntity)
|
||||||
private readonly calendarChannelRepository: CalendarChannelRepository,
|
private readonly calendarChannelRepository: CalendarChannelRepository,
|
||||||
@InjectObjectMetadataRepository(
|
@InjectObjectMetadataRepository(
|
||||||
CalendarChannelEventAssociationObjectMetadata,
|
CalendarChannelEventAssociationWorkspaceEntity,
|
||||||
)
|
)
|
||||||
private readonly calendarChannelEventAssociationRepository: CalendarChannelEventAssociationRepository,
|
private readonly calendarChannelEventAssociationRepository: CalendarChannelEventAssociationRepository,
|
||||||
@InjectObjectMetadataRepository(BlocklistObjectMetadata)
|
@InjectObjectMetadataRepository(BlocklistWorkspaceEntity)
|
||||||
private readonly blocklistRepository: BlocklistRepository,
|
private readonly blocklistRepository: BlocklistRepository,
|
||||||
private readonly calendarEventCleanerService: CalendarEventCleanerService,
|
private readonly calendarEventCleanerService: CalendarEventCleanerService,
|
||||||
) {}
|
) {}
|
||||||
|
|||||||
@ -5,7 +5,7 @@ import { MessageQueueJob } from 'src/engine/integrations/message-queue/interface
|
|||||||
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 { GoogleCalendarSyncService } from 'src/modules/calendar/services/google-calendar-sync/google-calendar-sync.service';
|
import { GoogleCalendarSyncService } from 'src/modules/calendar/services/google-calendar-sync/google-calendar-sync.service';
|
||||||
import { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
import { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
||||||
import { ConnectedAccountObjectMetadata } from 'src/modules/connected-account/standard-objects/connected-account.object-metadata';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
|
|
||||||
export type BlocklistReimportCalendarEventsJobData = {
|
export type BlocklistReimportCalendarEventsJobData = {
|
||||||
workspaceId: string;
|
workspaceId: string;
|
||||||
@ -20,7 +20,7 @@ export class BlocklistReimportCalendarEventsJob
|
|||||||
private readonly logger = new Logger(BlocklistReimportCalendarEventsJob.name);
|
private readonly logger = new Logger(BlocklistReimportCalendarEventsJob.name);
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
@InjectObjectMetadataRepository(ConnectedAccountObjectMetadata)
|
@InjectObjectMetadataRepository(ConnectedAccountWorkspaceEntity)
|
||||||
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
||||||
private readonly googleCalendarSyncService: GoogleCalendarSyncService,
|
private readonly googleCalendarSyncService: GoogleCalendarSyncService,
|
||||||
) {}
|
) {}
|
||||||
|
|||||||
@ -5,8 +5,8 @@ import { MessageQueueJob } from 'src/engine/integrations/message-queue/interface
|
|||||||
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 { CalendarChannelRepository } from 'src/modules/calendar/repositories/calendar-channel.repository';
|
import { CalendarChannelRepository } from 'src/modules/calendar/repositories/calendar-channel.repository';
|
||||||
import { CalendarEventParticipantRepository } from 'src/modules/calendar/repositories/calendar-event-participant.repository';
|
import { CalendarEventParticipantRepository } from 'src/modules/calendar/repositories/calendar-event-participant.repository';
|
||||||
import { CalendarChannelObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel.object-metadata';
|
import { CalendarChannelWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel.workspace-entity';
|
||||||
import { CalendarEventParticipantObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event-participant.object-metadata';
|
import { CalendarEventParticipantWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event-participant.workspace-entity';
|
||||||
import { CreateCompanyAndContactService } from 'src/modules/connected-account/auto-companies-and-contacts-creation/services/create-company-and-contact.service';
|
import { CreateCompanyAndContactService } from 'src/modules/connected-account/auto-companies-and-contacts-creation/services/create-company-and-contact.service';
|
||||||
|
|
||||||
export type CalendarCreateCompanyAndContactAfterSyncJobData = {
|
export type CalendarCreateCompanyAndContactAfterSyncJobData = {
|
||||||
@ -23,9 +23,9 @@ export class CalendarCreateCompanyAndContactAfterSyncJob
|
|||||||
);
|
);
|
||||||
constructor(
|
constructor(
|
||||||
private readonly createCompanyAndContactService: CreateCompanyAndContactService,
|
private readonly createCompanyAndContactService: CreateCompanyAndContactService,
|
||||||
@InjectObjectMetadataRepository(CalendarChannelObjectMetadata)
|
@InjectObjectMetadataRepository(CalendarChannelWorkspaceEntity)
|
||||||
private readonly calendarChannelService: CalendarChannelRepository,
|
private readonly calendarChannelService: CalendarChannelRepository,
|
||||||
@InjectObjectMetadataRepository(CalendarEventParticipantObjectMetadata)
|
@InjectObjectMetadataRepository(CalendarEventParticipantWorkspaceEntity)
|
||||||
private readonly calendarEventParticipantRepository: CalendarEventParticipantRepository,
|
private readonly calendarEventParticipantRepository: CalendarEventParticipantRepository,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
|
|||||||
@ -8,22 +8,22 @@ import { DeleteConnectedAccountAssociatedCalendarDataJob } from 'src/modules/cal
|
|||||||
import { GoogleCalendarSyncJob } from 'src/modules/calendar/jobs/google-calendar-sync.job';
|
import { GoogleCalendarSyncJob } from 'src/modules/calendar/jobs/google-calendar-sync.job';
|
||||||
import { CalendarEventCleanerModule } from 'src/modules/calendar/services/calendar-event-cleaner/calendar-event-cleaner.module';
|
import { CalendarEventCleanerModule } from 'src/modules/calendar/services/calendar-event-cleaner/calendar-event-cleaner.module';
|
||||||
import { GoogleCalendarSyncModule } from 'src/modules/calendar/services/google-calendar-sync/google-calendar-sync.module';
|
import { GoogleCalendarSyncModule } from 'src/modules/calendar/services/google-calendar-sync/google-calendar-sync.module';
|
||||||
import { CalendarChannelEventAssociationObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.object-metadata';
|
import { CalendarChannelEventAssociationWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.workspace-entity';
|
||||||
import { CalendarChannelObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel.object-metadata';
|
import { CalendarChannelWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel.workspace-entity';
|
||||||
import { CalendarEventParticipantObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event-participant.object-metadata';
|
import { CalendarEventParticipantWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event-participant.workspace-entity';
|
||||||
import { AutoCompaniesAndContactsCreationModule } from 'src/modules/connected-account/auto-companies-and-contacts-creation/auto-companies-and-contacts-creation.module';
|
import { AutoCompaniesAndContactsCreationModule } from 'src/modules/connected-account/auto-companies-and-contacts-creation/auto-companies-and-contacts-creation.module';
|
||||||
import { GoogleAPIRefreshAccessTokenModule } from 'src/modules/connected-account/services/google-api-refresh-access-token/google-api-refresh-access-token.module';
|
import { GoogleAPIRefreshAccessTokenModule } from 'src/modules/connected-account/services/google-api-refresh-access-token/google-api-refresh-access-token.module';
|
||||||
import { BlocklistObjectMetadata } from 'src/modules/connected-account/standard-objects/blocklist.object-metadata';
|
import { BlocklistWorkspaceEntity } from 'src/modules/connected-account/standard-objects/blocklist.workspace-entity';
|
||||||
import { ConnectedAccountObjectMetadata } from 'src/modules/connected-account/standard-objects/connected-account.object-metadata';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
ObjectMetadataRepositoryModule.forFeature([
|
ObjectMetadataRepositoryModule.forFeature([
|
||||||
CalendarChannelObjectMetadata,
|
CalendarChannelWorkspaceEntity,
|
||||||
CalendarChannelEventAssociationObjectMetadata,
|
CalendarChannelEventAssociationWorkspaceEntity,
|
||||||
CalendarEventParticipantObjectMetadata,
|
CalendarEventParticipantWorkspaceEntity,
|
||||||
ConnectedAccountObjectMetadata,
|
ConnectedAccountWorkspaceEntity,
|
||||||
BlocklistObjectMetadata,
|
BlocklistWorkspaceEntity,
|
||||||
]),
|
]),
|
||||||
CalendarEventCleanerModule,
|
CalendarEventCleanerModule,
|
||||||
AutoCompaniesAndContactsCreationModule,
|
AutoCompaniesAndContactsCreationModule,
|
||||||
|
|||||||
@ -14,7 +14,7 @@ import {
|
|||||||
BlocklistReimportCalendarEventsJobData,
|
BlocklistReimportCalendarEventsJobData,
|
||||||
BlocklistReimportCalendarEventsJob,
|
BlocklistReimportCalendarEventsJob,
|
||||||
} from 'src/modules/calendar/jobs/blocklist-reimport-calendar-events.job';
|
} from 'src/modules/calendar/jobs/blocklist-reimport-calendar-events.job';
|
||||||
import { BlocklistObjectMetadata } from 'src/modules/connected-account/standard-objects/blocklist.object-metadata';
|
import { BlocklistWorkspaceEntity } from 'src/modules/connected-account/standard-objects/blocklist.workspace-entity';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class CalendarBlocklistListener {
|
export class CalendarBlocklistListener {
|
||||||
@ -25,7 +25,7 @@ export class CalendarBlocklistListener {
|
|||||||
|
|
||||||
@OnEvent('blocklist.created')
|
@OnEvent('blocklist.created')
|
||||||
async handleCreatedEvent(
|
async handleCreatedEvent(
|
||||||
payload: ObjectRecordCreateEvent<BlocklistObjectMetadata>,
|
payload: ObjectRecordCreateEvent<BlocklistWorkspaceEntity>,
|
||||||
) {
|
) {
|
||||||
await this.messageQueueService.add<BlocklistItemDeleteCalendarEventsJobData>(
|
await this.messageQueueService.add<BlocklistItemDeleteCalendarEventsJobData>(
|
||||||
BlocklistItemDeleteCalendarEventsJob.name,
|
BlocklistItemDeleteCalendarEventsJob.name,
|
||||||
@ -38,7 +38,7 @@ export class CalendarBlocklistListener {
|
|||||||
|
|
||||||
@OnEvent('blocklist.deleted')
|
@OnEvent('blocklist.deleted')
|
||||||
async handleDeletedEvent(
|
async handleDeletedEvent(
|
||||||
payload: ObjectRecordDeleteEvent<BlocklistObjectMetadata>,
|
payload: ObjectRecordDeleteEvent<BlocklistWorkspaceEntity>,
|
||||||
) {
|
) {
|
||||||
await this.messageQueueService.add<BlocklistReimportCalendarEventsJobData>(
|
await this.messageQueueService.add<BlocklistReimportCalendarEventsJobData>(
|
||||||
BlocklistReimportCalendarEventsJob.name,
|
BlocklistReimportCalendarEventsJob.name,
|
||||||
@ -52,7 +52,7 @@ export class CalendarBlocklistListener {
|
|||||||
|
|
||||||
@OnEvent('blocklist.updated')
|
@OnEvent('blocklist.updated')
|
||||||
async handleUpdatedEvent(
|
async handleUpdatedEvent(
|
||||||
payload: ObjectRecordUpdateEvent<BlocklistObjectMetadata>,
|
payload: ObjectRecordUpdateEvent<BlocklistWorkspaceEntity>,
|
||||||
) {
|
) {
|
||||||
await this.messageQueueService.add<BlocklistItemDeleteCalendarEventsJobData>(
|
await this.messageQueueService.add<BlocklistItemDeleteCalendarEventsJobData>(
|
||||||
BlocklistItemDeleteCalendarEventsJob.name,
|
BlocklistItemDeleteCalendarEventsJob.name,
|
||||||
|
|||||||
@ -9,7 +9,7 @@ import {
|
|||||||
CalendarCreateCompanyAndContactAfterSyncJobData,
|
CalendarCreateCompanyAndContactAfterSyncJobData,
|
||||||
CalendarCreateCompanyAndContactAfterSyncJob,
|
CalendarCreateCompanyAndContactAfterSyncJob,
|
||||||
} from 'src/modules/calendar/jobs/calendar-create-company-and-contact-after-sync.job';
|
} from 'src/modules/calendar/jobs/calendar-create-company-and-contact-after-sync.job';
|
||||||
import { MessageChannelObjectMetadata } from 'src/modules/messaging/standard-objects/message-channel.object-metadata';
|
import { MessageChannelWorkspaceEntity } from 'src/modules/messaging/standard-objects/message-channel.workspace-entity';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class CalendarChannelListener {
|
export class CalendarChannelListener {
|
||||||
@ -20,7 +20,7 @@ export class CalendarChannelListener {
|
|||||||
|
|
||||||
@OnEvent('calendarChannel.updated')
|
@OnEvent('calendarChannel.updated')
|
||||||
async handleUpdatedEvent(
|
async handleUpdatedEvent(
|
||||||
payload: ObjectRecordUpdateEvent<MessageChannelObjectMetadata>,
|
payload: ObjectRecordUpdateEvent<MessageChannelWorkspaceEntity>,
|
||||||
) {
|
) {
|
||||||
if (
|
if (
|
||||||
objectRecordChangedProperties(
|
objectRecordChangedProperties(
|
||||||
|
|||||||
@ -8,7 +8,7 @@ import { WorkspacePreQueryHook } from 'src/engine/api/graphql/workspace-query-ru
|
|||||||
import { FindManyResolverArgs } from 'src/engine/api/graphql/workspace-resolver-builder/interfaces/workspace-resolvers-builder.interface';
|
import { FindManyResolverArgs } from 'src/engine/api/graphql/workspace-resolver-builder/interfaces/workspace-resolvers-builder.interface';
|
||||||
|
|
||||||
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 { CalendarChannelEventAssociationObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.object-metadata';
|
import { CalendarChannelEventAssociationWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.workspace-entity';
|
||||||
import { CalendarChannelEventAssociationRepository } from 'src/modules/calendar/repositories/calendar-channel-event-association.repository';
|
import { CalendarChannelEventAssociationRepository } from 'src/modules/calendar/repositories/calendar-channel-event-association.repository';
|
||||||
import { CanAccessCalendarEventService } from 'src/modules/calendar/query-hooks/calendar-event/services/can-access-calendar-event.service';
|
import { CanAccessCalendarEventService } from 'src/modules/calendar/query-hooks/calendar-event/services/can-access-calendar-event.service';
|
||||||
|
|
||||||
@ -18,7 +18,7 @@ export class CalendarEventFindManyPreQueryHook
|
|||||||
{
|
{
|
||||||
constructor(
|
constructor(
|
||||||
@InjectObjectMetadataRepository(
|
@InjectObjectMetadataRepository(
|
||||||
CalendarChannelEventAssociationObjectMetadata,
|
CalendarChannelEventAssociationWorkspaceEntity,
|
||||||
)
|
)
|
||||||
private readonly calendarChannelEventAssociationRepository: CalendarChannelEventAssociationRepository,
|
private readonly calendarChannelEventAssociationRepository: CalendarChannelEventAssociationRepository,
|
||||||
private readonly canAccessCalendarEventService: CanAccessCalendarEventService,
|
private readonly canAccessCalendarEventService: CanAccessCalendarEventService,
|
||||||
|
|||||||
@ -10,13 +10,13 @@ import { FindOneResolverArgs } from 'src/engine/api/graphql/workspace-resolver-b
|
|||||||
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 { CanAccessCalendarEventService } from 'src/modules/calendar/query-hooks/calendar-event/services/can-access-calendar-event.service';
|
import { CanAccessCalendarEventService } from 'src/modules/calendar/query-hooks/calendar-event/services/can-access-calendar-event.service';
|
||||||
import { CalendarChannelEventAssociationRepository } from 'src/modules/calendar/repositories/calendar-channel-event-association.repository';
|
import { CalendarChannelEventAssociationRepository } from 'src/modules/calendar/repositories/calendar-channel-event-association.repository';
|
||||||
import { CalendarChannelEventAssociationObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.object-metadata';
|
import { CalendarChannelEventAssociationWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.workspace-entity';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class CalendarEventFindOnePreQueryHook implements WorkspacePreQueryHook {
|
export class CalendarEventFindOnePreQueryHook implements WorkspacePreQueryHook {
|
||||||
constructor(
|
constructor(
|
||||||
@InjectObjectMetadataRepository(
|
@InjectObjectMetadataRepository(
|
||||||
CalendarChannelEventAssociationObjectMetadata,
|
CalendarChannelEventAssociationWorkspaceEntity,
|
||||||
)
|
)
|
||||||
private readonly calendarChannelEventAssociationRepository: CalendarChannelEventAssociationRepository,
|
private readonly calendarChannelEventAssociationRepository: CalendarChannelEventAssociationRepository,
|
||||||
private readonly canAccessCalendarEventService: CanAccessCalendarEventService,
|
private readonly canAccessCalendarEventService: CanAccessCalendarEventService,
|
||||||
|
|||||||
@ -5,31 +5,31 @@ import groupBy from 'lodash.groupby';
|
|||||||
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 { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
||||||
import { CalendarChannelRepository } from 'src/modules/calendar/repositories/calendar-channel.repository';
|
import { CalendarChannelRepository } from 'src/modules/calendar/repositories/calendar-channel.repository';
|
||||||
import { CalendarChannelEventAssociationObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.object-metadata';
|
import { CalendarChannelEventAssociationWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.workspace-entity';
|
||||||
import {
|
import {
|
||||||
CalendarChannelObjectMetadata,
|
CalendarChannelWorkspaceEntity,
|
||||||
CalendarChannelVisibility,
|
CalendarChannelVisibility,
|
||||||
} from 'src/modules/calendar/standard-objects/calendar-channel.object-metadata';
|
} from 'src/modules/calendar/standard-objects/calendar-channel.workspace-entity';
|
||||||
import { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
import { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
||||||
import { ConnectedAccountObjectMetadata } from 'src/modules/connected-account/standard-objects/connected-account.object-metadata';
|
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 { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class CanAccessCalendarEventService {
|
export class CanAccessCalendarEventService {
|
||||||
constructor(
|
constructor(
|
||||||
@InjectObjectMetadataRepository(CalendarChannelObjectMetadata)
|
@InjectObjectMetadataRepository(CalendarChannelWorkspaceEntity)
|
||||||
private readonly calendarChannelRepository: CalendarChannelRepository,
|
private readonly calendarChannelRepository: CalendarChannelRepository,
|
||||||
@InjectObjectMetadataRepository(ConnectedAccountObjectMetadata)
|
@InjectObjectMetadataRepository(ConnectedAccountWorkspaceEntity)
|
||||||
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
||||||
@InjectObjectMetadataRepository(WorkspaceMemberObjectMetadata)
|
@InjectObjectMetadataRepository(WorkspaceMemberWorkspaceEntity)
|
||||||
private readonly workspaceMemberService: WorkspaceMemberRepository,
|
private readonly workspaceMemberService: WorkspaceMemberRepository,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
public async canAccessCalendarEvent(
|
public async canAccessCalendarEvent(
|
||||||
userId: string,
|
userId: string,
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
calendarChannelCalendarEventAssociations: ObjectRecord<CalendarChannelEventAssociationObjectMetadata>[],
|
calendarChannelCalendarEventAssociations: ObjectRecord<CalendarChannelEventAssociationWorkspaceEntity>[],
|
||||||
) {
|
) {
|
||||||
const calendarChannels = await this.calendarChannelRepository.getByIds(
|
const calendarChannels = await this.calendarChannelRepository.getByIds(
|
||||||
calendarChannelCalendarEventAssociations.map(
|
calendarChannelCalendarEventAssociations.map(
|
||||||
|
|||||||
@ -1,10 +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 { ObjectMetadataRepositoryModule } from 'src/engine/object-metadata-repository/object-metadata-repository.module';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
import { ConnectedAccountObjectMetadata } from 'src/modules/connected-account/standard-objects/connected-account.object-metadata';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
import { CalendarChannelEventAssociationObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.object-metadata';
|
import { CalendarChannelEventAssociationWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.workspace-entity';
|
||||||
import { CalendarChannelObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel.object-metadata';
|
import { CalendarChannelWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel.workspace-entity';
|
||||||
import { CalendarEventFindManyPreQueryHook } from 'src/modules/calendar/query-hooks/calendar-event/calendar-event-find-many.pre-query.hook';
|
import { CalendarEventFindManyPreQueryHook } from 'src/modules/calendar/query-hooks/calendar-event/calendar-event-find-many.pre-query.hook';
|
||||||
import { CalendarEventFindOnePreQueryHook } from 'src/modules/calendar/query-hooks/calendar-event/calendar-event-find-one.pre-query-hook';
|
import { CalendarEventFindOnePreQueryHook } from 'src/modules/calendar/query-hooks/calendar-event/calendar-event-find-one.pre-query-hook';
|
||||||
import { CanAccessCalendarEventService } from 'src/modules/calendar/query-hooks/calendar-event/services/can-access-calendar-event.service';
|
import { CanAccessCalendarEventService } from 'src/modules/calendar/query-hooks/calendar-event/services/can-access-calendar-event.service';
|
||||||
@ -12,10 +12,10 @@ import { CanAccessCalendarEventService } from 'src/modules/calendar/query-hooks/
|
|||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
ObjectMetadataRepositoryModule.forFeature([
|
ObjectMetadataRepositoryModule.forFeature([
|
||||||
CalendarChannelEventAssociationObjectMetadata,
|
CalendarChannelEventAssociationWorkspaceEntity,
|
||||||
CalendarChannelObjectMetadata,
|
CalendarChannelWorkspaceEntity,
|
||||||
ConnectedAccountObjectMetadata,
|
ConnectedAccountWorkspaceEntity,
|
||||||
WorkspaceMemberObjectMetadata,
|
WorkspaceMemberWorkspaceEntity,
|
||||||
]),
|
]),
|
||||||
],
|
],
|
||||||
providers: [
|
providers: [
|
||||||
|
|||||||
@ -4,7 +4,7 @@ import { EntityManager } from 'typeorm';
|
|||||||
|
|
||||||
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
||||||
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
||||||
import { CalendarChannelEventAssociationObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.object-metadata';
|
import { CalendarChannelEventAssociationWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.workspace-entity';
|
||||||
import { getFlattenedValuesAndValuesStringForBatchRawQuery } from 'src/modules/calendar/utils/get-flattened-values-and-values-string-for-batch-raw-query.util';
|
import { getFlattenedValuesAndValuesStringForBatchRawQuery } from 'src/modules/calendar/utils/get-flattened-values-and-values-string-for-batch-raw-query.util';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
@ -18,7 +18,7 @@ export class CalendarChannelEventAssociationRepository {
|
|||||||
calendarChannelId: string,
|
calendarChannelId: string,
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<CalendarChannelEventAssociationObjectMetadata>[]> {
|
): Promise<ObjectRecord<CalendarChannelEventAssociationWorkspaceEntity>[]> {
|
||||||
if (eventExternalIds.length === 0) {
|
if (eventExternalIds.length === 0) {
|
||||||
return [];
|
return [];
|
||||||
}
|
}
|
||||||
@ -56,7 +56,7 @@ export class CalendarChannelEventAssociationRepository {
|
|||||||
calendarChannelIds: string[],
|
calendarChannelIds: string[],
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<CalendarChannelEventAssociationObjectMetadata>[]> {
|
): Promise<ObjectRecord<CalendarChannelEventAssociationWorkspaceEntity>[]> {
|
||||||
if (calendarChannelIds.length === 0) {
|
if (calendarChannelIds.length === 0) {
|
||||||
return [];
|
return [];
|
||||||
}
|
}
|
||||||
@ -117,7 +117,7 @@ export class CalendarChannelEventAssociationRepository {
|
|||||||
calendarEventIds: string[],
|
calendarEventIds: string[],
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<CalendarChannelEventAssociationObjectMetadata>[]> {
|
): Promise<ObjectRecord<CalendarChannelEventAssociationWorkspaceEntity>[]> {
|
||||||
if (calendarEventIds.length === 0) {
|
if (calendarEventIds.length === 0) {
|
||||||
return [];
|
return [];
|
||||||
}
|
}
|
||||||
@ -136,7 +136,7 @@ export class CalendarChannelEventAssociationRepository {
|
|||||||
|
|
||||||
public async saveCalendarChannelEventAssociations(
|
public async saveCalendarChannelEventAssociations(
|
||||||
calendarChannelEventAssociations: Omit<
|
calendarChannelEventAssociations: Omit<
|
||||||
ObjectRecord<CalendarChannelEventAssociationObjectMetadata>,
|
ObjectRecord<CalendarChannelEventAssociationWorkspaceEntity>,
|
||||||
'id' | 'createdAt' | 'updatedAt' | 'calendarChannel' | 'calendarEvent'
|
'id' | 'createdAt' | 'updatedAt' | 'calendarChannel' | 'calendarEvent'
|
||||||
>[],
|
>[],
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
|
|||||||
@ -3,7 +3,7 @@ import { Injectable } from '@nestjs/common';
|
|||||||
import { EntityManager } from 'typeorm';
|
import { EntityManager } from 'typeorm';
|
||||||
|
|
||||||
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
||||||
import { CalendarChannelObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel.object-metadata';
|
import { CalendarChannelWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel.workspace-entity';
|
||||||
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
@ -15,7 +15,7 @@ export class CalendarChannelRepository {
|
|||||||
public async getAll(
|
public async getAll(
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<CalendarChannelObjectMetadata>[]> {
|
): Promise<ObjectRecord<CalendarChannelWorkspaceEntity>[]> {
|
||||||
const dataSourceSchema =
|
const dataSourceSchema =
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
||||||
|
|
||||||
@ -29,7 +29,7 @@ export class CalendarChannelRepository {
|
|||||||
|
|
||||||
public async create(
|
public async create(
|
||||||
calendarChannel: Pick<
|
calendarChannel: Pick<
|
||||||
ObjectRecord<CalendarChannelObjectMetadata>,
|
ObjectRecord<CalendarChannelWorkspaceEntity>,
|
||||||
'id' | 'connectedAccountId' | 'handle' | 'visibility'
|
'id' | 'connectedAccountId' | 'handle' | 'visibility'
|
||||||
>,
|
>,
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
@ -55,7 +55,7 @@ export class CalendarChannelRepository {
|
|||||||
connectedAccountId: string,
|
connectedAccountId: string,
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<CalendarChannelObjectMetadata>[]> {
|
): Promise<ObjectRecord<CalendarChannelWorkspaceEntity>[]> {
|
||||||
const dataSourceSchema =
|
const dataSourceSchema =
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
||||||
|
|
||||||
@ -70,7 +70,7 @@ export class CalendarChannelRepository {
|
|||||||
public async getFirstByConnectedAccountId(
|
public async getFirstByConnectedAccountId(
|
||||||
connectedAccountId: string,
|
connectedAccountId: string,
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
): Promise<ObjectRecord<CalendarChannelObjectMetadata> | undefined> {
|
): Promise<ObjectRecord<CalendarChannelWorkspaceEntity> | undefined> {
|
||||||
const calendarChannels = await this.getByConnectedAccountId(
|
const calendarChannels = await this.getByConnectedAccountId(
|
||||||
connectedAccountId,
|
connectedAccountId,
|
||||||
workspaceId,
|
workspaceId,
|
||||||
@ -83,7 +83,7 @@ export class CalendarChannelRepository {
|
|||||||
ids: string[],
|
ids: string[],
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<CalendarChannelObjectMetadata>[]> {
|
): Promise<ObjectRecord<CalendarChannelWorkspaceEntity>[]> {
|
||||||
const dataSourceSchema =
|
const dataSourceSchema =
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
||||||
|
|
||||||
@ -99,7 +99,7 @@ export class CalendarChannelRepository {
|
|||||||
workspaceMemberId: string,
|
workspaceMemberId: string,
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<CalendarChannelObjectMetadata>[]> {
|
): Promise<ObjectRecord<CalendarChannelWorkspaceEntity>[]> {
|
||||||
const dataSourceSchema =
|
const dataSourceSchema =
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
||||||
|
|
||||||
|
|||||||
@ -5,7 +5,7 @@ import differenceWith from 'lodash.differencewith';
|
|||||||
|
|
||||||
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
||||||
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
||||||
import { CalendarEventParticipantObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event-participant.object-metadata';
|
import { CalendarEventParticipantWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event-participant.workspace-entity';
|
||||||
import { getFlattenedValuesAndValuesStringForBatchRawQuery } from 'src/modules/calendar/utils/get-flattened-values-and-values-string-for-batch-raw-query.util';
|
import { getFlattenedValuesAndValuesStringForBatchRawQuery } from 'src/modules/calendar/utils/get-flattened-values-and-values-string-for-batch-raw-query.util';
|
||||||
import {
|
import {
|
||||||
CalendarEventParticipant,
|
CalendarEventParticipant,
|
||||||
@ -22,7 +22,7 @@ export class CalendarEventParticipantRepository {
|
|||||||
handles: string[],
|
handles: string[],
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<CalendarEventParticipantObjectMetadata>[]> {
|
): Promise<ObjectRecord<CalendarEventParticipantWorkspaceEntity>[]> {
|
||||||
const dataSourceSchema =
|
const dataSourceSchema =
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
||||||
|
|
||||||
@ -104,7 +104,7 @@ export class CalendarEventParticipantRepository {
|
|||||||
calendarEventParticipantIds: string[],
|
calendarEventParticipantIds: string[],
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<CalendarEventParticipantObjectMetadata>[]> {
|
): Promise<ObjectRecord<CalendarEventParticipantWorkspaceEntity>[]> {
|
||||||
if (calendarEventParticipantIds.length === 0) {
|
if (calendarEventParticipantIds.length === 0) {
|
||||||
return [];
|
return [];
|
||||||
}
|
}
|
||||||
@ -124,7 +124,7 @@ export class CalendarEventParticipantRepository {
|
|||||||
calendarEventIds: string[],
|
calendarEventIds: string[],
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<CalendarEventParticipantObjectMetadata>[]> {
|
): Promise<ObjectRecord<CalendarEventParticipantWorkspaceEntity>[]> {
|
||||||
if (calendarEventIds.length === 0) {
|
if (calendarEventIds.length === 0) {
|
||||||
return [];
|
return [];
|
||||||
}
|
}
|
||||||
|
|||||||
@ -4,10 +4,10 @@ import { EntityManager } from 'typeorm';
|
|||||||
|
|
||||||
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
||||||
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
||||||
import { CalendarEventObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event.object-metadata';
|
import { CalendarEventWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event.workspace-entity';
|
||||||
import { getFlattenedValuesAndValuesStringForBatchRawQuery } from 'src/modules/calendar/utils/get-flattened-values-and-values-string-for-batch-raw-query.util';
|
import { getFlattenedValuesAndValuesStringForBatchRawQuery } from 'src/modules/calendar/utils/get-flattened-values-and-values-string-for-batch-raw-query.util';
|
||||||
import { CalendarEvent } from 'src/modules/calendar/types/calendar-event';
|
import { CalendarEvent } from 'src/modules/calendar/types/calendar-event';
|
||||||
import { CalendarEventParticipantObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event-participant.object-metadata';
|
import { CalendarEventParticipantWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event-participant.workspace-entity';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class CalendarEventRepository {
|
export class CalendarEventRepository {
|
||||||
@ -19,7 +19,7 @@ export class CalendarEventRepository {
|
|||||||
calendarEventIds: string[],
|
calendarEventIds: string[],
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<CalendarEventObjectMetadata>[]> {
|
): Promise<ObjectRecord<CalendarEventWorkspaceEntity>[]> {
|
||||||
if (calendarEventIds.length === 0) {
|
if (calendarEventIds.length === 0) {
|
||||||
return [];
|
return [];
|
||||||
}
|
}
|
||||||
@ -39,7 +39,7 @@ export class CalendarEventRepository {
|
|||||||
iCalUIDs: string[],
|
iCalUIDs: string[],
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<CalendarEventObjectMetadata>[]> {
|
): Promise<ObjectRecord<CalendarEventWorkspaceEntity>[]> {
|
||||||
if (iCalUIDs.length === 0) {
|
if (iCalUIDs.length === 0) {
|
||||||
return [];
|
return [];
|
||||||
}
|
}
|
||||||
@ -80,7 +80,7 @@ export class CalendarEventRepository {
|
|||||||
offset: number,
|
offset: number,
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<CalendarEventParticipantObjectMetadata>[]> {
|
): Promise<ObjectRecord<CalendarEventParticipantWorkspaceEntity>[]> {
|
||||||
const dataSourceSchema =
|
const dataSourceSchema =
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
||||||
|
|
||||||
|
|||||||
@ -2,11 +2,11 @@ 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 { CalendarEventCleanerService } from 'src/modules/calendar/services/calendar-event-cleaner/calendar-event-cleaner.service';
|
import { CalendarEventCleanerService } from 'src/modules/calendar/services/calendar-event-cleaner/calendar-event-cleaner.service';
|
||||||
import { CalendarEventObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event.object-metadata';
|
import { CalendarEventWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event.workspace-entity';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
ObjectMetadataRepositoryModule.forFeature([CalendarEventObjectMetadata]),
|
ObjectMetadataRepositoryModule.forFeature([CalendarEventWorkspaceEntity]),
|
||||||
],
|
],
|
||||||
providers: [CalendarEventCleanerService],
|
providers: [CalendarEventCleanerService],
|
||||||
exports: [CalendarEventCleanerService],
|
exports: [CalendarEventCleanerService],
|
||||||
|
|||||||
@ -2,13 +2,13 @@ import { Injectable } from '@nestjs/common';
|
|||||||
|
|
||||||
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 { CalendarEventRepository } from 'src/modules/calendar/repositories/calendar-event.repository';
|
import { CalendarEventRepository } from 'src/modules/calendar/repositories/calendar-event.repository';
|
||||||
import { CalendarEventObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event.object-metadata';
|
import { CalendarEventWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event.workspace-entity';
|
||||||
import { deleteUsingPagination } from 'src/modules/messaging/services/thread-cleaner/utils/delete-using-pagination.util';
|
import { deleteUsingPagination } from 'src/modules/messaging/services/thread-cleaner/utils/delete-using-pagination.util';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class CalendarEventCleanerService {
|
export class CalendarEventCleanerService {
|
||||||
constructor(
|
constructor(
|
||||||
@InjectObjectMetadataRepository(CalendarEventObjectMetadata)
|
@InjectObjectMetadataRepository(CalendarEventWorkspaceEntity)
|
||||||
private readonly calendarEventRepository: CalendarEventRepository,
|
private readonly calendarEventRepository: CalendarEventRepository,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
|
|||||||
@ -4,12 +4,12 @@ import { ObjectMetadataRepositoryModule } from 'src/engine/object-metadata-repos
|
|||||||
import { WorkspaceDataSourceModule } from 'src/engine/workspace-datasource/workspace-datasource.module';
|
import { WorkspaceDataSourceModule } from 'src/engine/workspace-datasource/workspace-datasource.module';
|
||||||
import { AddPersonIdAndWorkspaceMemberIdModule } from 'src/modules/calendar-messaging-participant/services/add-person-id-and-workspace-member-id/add-person-id-and-workspace-member-id.module';
|
import { AddPersonIdAndWorkspaceMemberIdModule } from 'src/modules/calendar-messaging-participant/services/add-person-id-and-workspace-member-id/add-person-id-and-workspace-member-id.module';
|
||||||
import { CalendarEventParticipantService } from 'src/modules/calendar/services/calendar-event-participant/calendar-event-participant.service';
|
import { CalendarEventParticipantService } from 'src/modules/calendar/services/calendar-event-participant/calendar-event-participant.service';
|
||||||
import { PersonObjectMetadata } from 'src/modules/person/standard-objects/person.object-metadata';
|
import { PersonWorkspaceEntity } from 'src/modules/person/standard-objects/person.workspace-entity';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
WorkspaceDataSourceModule,
|
WorkspaceDataSourceModule,
|
||||||
ObjectMetadataRepositoryModule.forFeature([PersonObjectMetadata]),
|
ObjectMetadataRepositoryModule.forFeature([PersonWorkspaceEntity]),
|
||||||
AddPersonIdAndWorkspaceMemberIdModule,
|
AddPersonIdAndWorkspaceMemberIdModule,
|
||||||
],
|
],
|
||||||
providers: [CalendarEventParticipantService],
|
providers: [CalendarEventParticipantService],
|
||||||
|
|||||||
@ -4,12 +4,12 @@ import { EntityManager } 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 { PersonRepository } from 'src/modules/person/repositories/person.repository';
|
import { PersonRepository } from 'src/modules/person/repositories/person.repository';
|
||||||
import { PersonObjectMetadata } from 'src/modules/person/standard-objects/person.object-metadata';
|
import { PersonWorkspaceEntity } from 'src/modules/person/standard-objects/person.workspace-entity';
|
||||||
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
||||||
import { getFlattenedValuesAndValuesStringForBatchRawQuery } from 'src/modules/calendar/utils/get-flattened-values-and-values-string-for-batch-raw-query.util';
|
import { getFlattenedValuesAndValuesStringForBatchRawQuery } from 'src/modules/calendar/utils/get-flattened-values-and-values-string-for-batch-raw-query.util';
|
||||||
import { CalendarEventParticipant } from 'src/modules/calendar/types/calendar-event';
|
import { CalendarEventParticipant } from 'src/modules/calendar/types/calendar-event';
|
||||||
import { CalendarEventParticipantRepository } from 'src/modules/calendar/repositories/calendar-event-participant.repository';
|
import { CalendarEventParticipantRepository } from 'src/modules/calendar/repositories/calendar-event-participant.repository';
|
||||||
import { CalendarEventParticipantObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event-participant.object-metadata';
|
import { CalendarEventParticipantWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event-participant.workspace-entity';
|
||||||
import { AddPersonIdAndWorkspaceMemberIdService } from 'src/modules/calendar-messaging-participant/services/add-person-id-and-workspace-member-id/add-person-id-and-workspace-member-id.service';
|
import { AddPersonIdAndWorkspaceMemberIdService } from 'src/modules/calendar-messaging-participant/services/add-person-id-and-workspace-member-id/add-person-id-and-workspace-member-id.service';
|
||||||
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
||||||
|
|
||||||
@ -17,15 +17,15 @@ import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metada
|
|||||||
export class CalendarEventParticipantService {
|
export class CalendarEventParticipantService {
|
||||||
constructor(
|
constructor(
|
||||||
private readonly workspaceDataSourceService: WorkspaceDataSourceService,
|
private readonly workspaceDataSourceService: WorkspaceDataSourceService,
|
||||||
@InjectObjectMetadataRepository(CalendarEventParticipantObjectMetadata)
|
@InjectObjectMetadataRepository(CalendarEventParticipantWorkspaceEntity)
|
||||||
private readonly calendarEventParticipantRepository: CalendarEventParticipantRepository,
|
private readonly calendarEventParticipantRepository: CalendarEventParticipantRepository,
|
||||||
@InjectObjectMetadataRepository(PersonObjectMetadata)
|
@InjectObjectMetadataRepository(PersonWorkspaceEntity)
|
||||||
private readonly personRepository: PersonRepository,
|
private readonly personRepository: PersonRepository,
|
||||||
private readonly addPersonIdAndWorkspaceMemberIdService: AddPersonIdAndWorkspaceMemberIdService,
|
private readonly addPersonIdAndWorkspaceMemberIdService: AddPersonIdAndWorkspaceMemberIdService,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
public async updateCalendarEventParticipantsAfterPeopleCreation(
|
public async updateCalendarEventParticipantsAfterPeopleCreation(
|
||||||
createdPeople: ObjectRecord<PersonObjectMetadata>[],
|
createdPeople: ObjectRecord<PersonWorkspaceEntity>[],
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<void> {
|
): Promise<void> {
|
||||||
|
|||||||
@ -8,27 +8,27 @@ import { CalendarEventCleanerModule } from 'src/modules/calendar/services/calend
|
|||||||
import { CalendarEventParticipantModule } from 'src/modules/calendar/services/calendar-event-participant/calendar-event-participant.module';
|
import { CalendarEventParticipantModule } from 'src/modules/calendar/services/calendar-event-participant/calendar-event-participant.module';
|
||||||
import { GoogleCalendarSyncService } from 'src/modules/calendar/services/google-calendar-sync/google-calendar-sync.service';
|
import { GoogleCalendarSyncService } from 'src/modules/calendar/services/google-calendar-sync/google-calendar-sync.service';
|
||||||
import { CalendarProvidersModule } from 'src/modules/calendar/services/providers/calendar-providers.module';
|
import { CalendarProvidersModule } from 'src/modules/calendar/services/providers/calendar-providers.module';
|
||||||
import { CalendarChannelEventAssociationObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.object-metadata';
|
import { CalendarChannelEventAssociationWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.workspace-entity';
|
||||||
import { CalendarChannelObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel.object-metadata';
|
import { CalendarChannelWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel.workspace-entity';
|
||||||
import { CalendarEventParticipantObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event-participant.object-metadata';
|
import { CalendarEventParticipantWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event-participant.workspace-entity';
|
||||||
import { CalendarEventObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event.object-metadata';
|
import { CalendarEventWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event.workspace-entity';
|
||||||
import { BlocklistObjectMetadata } from 'src/modules/connected-account/standard-objects/blocklist.object-metadata';
|
import { BlocklistWorkspaceEntity } from 'src/modules/connected-account/standard-objects/blocklist.workspace-entity';
|
||||||
import { ConnectedAccountObjectMetadata } from 'src/modules/connected-account/standard-objects/connected-account.object-metadata';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
import { PersonObjectMetadata } from 'src/modules/person/standard-objects/person.object-metadata';
|
import { PersonWorkspaceEntity } from 'src/modules/person/standard-objects/person.workspace-entity';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
CalendarProvidersModule,
|
CalendarProvidersModule,
|
||||||
ObjectMetadataRepositoryModule.forFeature([
|
ObjectMetadataRepositoryModule.forFeature([
|
||||||
ConnectedAccountObjectMetadata,
|
ConnectedAccountWorkspaceEntity,
|
||||||
CalendarEventObjectMetadata,
|
CalendarEventWorkspaceEntity,
|
||||||
CalendarChannelObjectMetadata,
|
CalendarChannelWorkspaceEntity,
|
||||||
CalendarChannelEventAssociationObjectMetadata,
|
CalendarChannelEventAssociationWorkspaceEntity,
|
||||||
CalendarEventParticipantObjectMetadata,
|
CalendarEventParticipantWorkspaceEntity,
|
||||||
BlocklistObjectMetadata,
|
BlocklistWorkspaceEntity,
|
||||||
PersonObjectMetadata,
|
PersonWorkspaceEntity,
|
||||||
WorkspaceMemberObjectMetadata,
|
WorkspaceMemberWorkspaceEntity,
|
||||||
]),
|
]),
|
||||||
CalendarEventParticipantModule,
|
CalendarEventParticipantModule,
|
||||||
TypeOrmModule.forFeature([FeatureFlagEntity], 'core'),
|
TypeOrmModule.forFeature([FeatureFlagEntity], 'core'),
|
||||||
|
|||||||
@ -17,13 +17,13 @@ import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/work
|
|||||||
import { CalendarEventRepository } from 'src/modules/calendar/repositories/calendar-event.repository';
|
import { CalendarEventRepository } from 'src/modules/calendar/repositories/calendar-event.repository';
|
||||||
import { formatGoogleCalendarEvent } from 'src/modules/calendar/utils/format-google-calendar-event.util';
|
import { formatGoogleCalendarEvent } from 'src/modules/calendar/utils/format-google-calendar-event.util';
|
||||||
import { CalendarEventParticipantRepository } from 'src/modules/calendar/repositories/calendar-event-participant.repository';
|
import { CalendarEventParticipantRepository } from 'src/modules/calendar/repositories/calendar-event-participant.repository';
|
||||||
import { ConnectedAccountObjectMetadata } from 'src/modules/connected-account/standard-objects/connected-account.object-metadata';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
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 { CalendarEventObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event.object-metadata';
|
import { CalendarEventWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event.workspace-entity';
|
||||||
import { CalendarChannelObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel.object-metadata';
|
import { CalendarChannelWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel.workspace-entity';
|
||||||
import { CalendarChannelEventAssociationObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.object-metadata';
|
import { CalendarChannelEventAssociationWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.workspace-entity';
|
||||||
import { CalendarEventParticipantObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event-participant.object-metadata';
|
import { CalendarEventParticipantWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event-participant.workspace-entity';
|
||||||
import { BlocklistObjectMetadata } from 'src/modules/connected-account/standard-objects/blocklist.object-metadata';
|
import { BlocklistWorkspaceEntity } from 'src/modules/connected-account/standard-objects/blocklist.workspace-entity';
|
||||||
import { CalendarEventCleanerService } from 'src/modules/calendar/services/calendar-event-cleaner/calendar-event-cleaner.service';
|
import { CalendarEventCleanerService } from 'src/modules/calendar/services/calendar-event-cleaner/calendar-event-cleaner.service';
|
||||||
import { CalendarEventParticipantService } from 'src/modules/calendar/services/calendar-event-participant/calendar-event-participant.service';
|
import { CalendarEventParticipantService } from 'src/modules/calendar/services/calendar-event-participant/calendar-event-participant.service';
|
||||||
import { CalendarEventWithParticipants } from 'src/modules/calendar/types/calendar-event';
|
import { CalendarEventWithParticipants } from 'src/modules/calendar/types/calendar-event';
|
||||||
@ -42,19 +42,19 @@ export class GoogleCalendarSyncService {
|
|||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
private readonly googleCalendarClientProvider: GoogleCalendarClientProvider,
|
private readonly googleCalendarClientProvider: GoogleCalendarClientProvider,
|
||||||
@InjectObjectMetadataRepository(ConnectedAccountObjectMetadata)
|
@InjectObjectMetadataRepository(ConnectedAccountWorkspaceEntity)
|
||||||
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
||||||
@InjectObjectMetadataRepository(CalendarEventObjectMetadata)
|
@InjectObjectMetadataRepository(CalendarEventWorkspaceEntity)
|
||||||
private readonly calendarEventRepository: CalendarEventRepository,
|
private readonly calendarEventRepository: CalendarEventRepository,
|
||||||
@InjectObjectMetadataRepository(CalendarChannelObjectMetadata)
|
@InjectObjectMetadataRepository(CalendarChannelWorkspaceEntity)
|
||||||
private readonly calendarChannelRepository: CalendarChannelRepository,
|
private readonly calendarChannelRepository: CalendarChannelRepository,
|
||||||
@InjectObjectMetadataRepository(
|
@InjectObjectMetadataRepository(
|
||||||
CalendarChannelEventAssociationObjectMetadata,
|
CalendarChannelEventAssociationWorkspaceEntity,
|
||||||
)
|
)
|
||||||
private readonly calendarChannelEventAssociationRepository: CalendarChannelEventAssociationRepository,
|
private readonly calendarChannelEventAssociationRepository: CalendarChannelEventAssociationRepository,
|
||||||
@InjectObjectMetadataRepository(CalendarEventParticipantObjectMetadata)
|
@InjectObjectMetadataRepository(CalendarEventParticipantWorkspaceEntity)
|
||||||
private readonly calendarEventParticipantsRepository: CalendarEventParticipantRepository,
|
private readonly calendarEventParticipantsRepository: CalendarEventParticipantRepository,
|
||||||
@InjectObjectMetadataRepository(BlocklistObjectMetadata)
|
@InjectObjectMetadataRepository(BlocklistWorkspaceEntity)
|
||||||
private readonly blocklistRepository: BlocklistRepository,
|
private readonly blocklistRepository: BlocklistRepository,
|
||||||
@InjectRepository(FeatureFlagEntity, 'core')
|
@InjectRepository(FeatureFlagEntity, 'core')
|
||||||
private readonly featureFlagRepository: Repository<FeatureFlagEntity>,
|
private readonly featureFlagRepository: Repository<FeatureFlagEntity>,
|
||||||
@ -364,8 +364,8 @@ export class GoogleCalendarSyncService {
|
|||||||
eventExternalId: string;
|
eventExternalId: string;
|
||||||
calendarChannelId: string;
|
calendarChannelId: string;
|
||||||
}[],
|
}[],
|
||||||
connectedAccount: ConnectedAccountObjectMetadata,
|
connectedAccount: ConnectedAccountWorkspaceEntity,
|
||||||
calendarChannel: CalendarChannelObjectMetadata,
|
calendarChannel: CalendarChannelWorkspaceEntity,
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
): Promise<void> {
|
): Promise<void> {
|
||||||
const dataSourceMetadata =
|
const dataSourceMetadata =
|
||||||
|
|||||||
@ -2,11 +2,11 @@ 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 { WorkspaceGoogleCalendarSyncService } from 'src/modules/calendar/services/workspace-google-calendar-sync/workspace-google-calendar-sync.service';
|
import { WorkspaceGoogleCalendarSyncService } from 'src/modules/calendar/services/workspace-google-calendar-sync/workspace-google-calendar-sync.service';
|
||||||
import { CalendarChannelObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel.object-metadata';
|
import { CalendarChannelWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel.workspace-entity';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
ObjectMetadataRepositoryModule.forFeature([CalendarChannelObjectMetadata]),
|
ObjectMetadataRepositoryModule.forFeature([CalendarChannelWorkspaceEntity]),
|
||||||
],
|
],
|
||||||
providers: [WorkspaceGoogleCalendarSyncService],
|
providers: [WorkspaceGoogleCalendarSyncService],
|
||||||
exports: [WorkspaceGoogleCalendarSyncService],
|
exports: [WorkspaceGoogleCalendarSyncService],
|
||||||
|
|||||||
@ -9,12 +9,12 @@ import {
|
|||||||
GoogleCalendarSyncJob,
|
GoogleCalendarSyncJob,
|
||||||
} from 'src/modules/calendar/jobs/google-calendar-sync.job';
|
} from 'src/modules/calendar/jobs/google-calendar-sync.job';
|
||||||
import { CalendarChannelRepository } from 'src/modules/calendar/repositories/calendar-channel.repository';
|
import { CalendarChannelRepository } from 'src/modules/calendar/repositories/calendar-channel.repository';
|
||||||
import { CalendarChannelObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel.object-metadata';
|
import { CalendarChannelWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel.workspace-entity';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class WorkspaceGoogleCalendarSyncService {
|
export class WorkspaceGoogleCalendarSyncService {
|
||||||
constructor(
|
constructor(
|
||||||
@InjectObjectMetadataRepository(CalendarChannelObjectMetadata)
|
@InjectObjectMetadataRepository(CalendarChannelWorkspaceEntity)
|
||||||
private readonly calendarChannelRepository: CalendarChannelRepository,
|
private readonly calendarChannelRepository: CalendarChannelRepository,
|
||||||
@InjectMessageQueue(MessageQueue.calendarQueue)
|
@InjectMessageQueue(MessageQueue.calendarQueue)
|
||||||
private readonly messageQueueService: MessageQueueService,
|
private readonly messageQueueService: MessageQueueService,
|
||||||
|
|||||||
@ -3,15 +3,15 @@ import { Relation } from 'src/engine/workspace-manager/workspace-sync-metadata/i
|
|||||||
import { FieldMetadataType } from 'src/engine/metadata-modules/field-metadata/field-metadata.entity';
|
import { FieldMetadataType } from 'src/engine/metadata-modules/field-metadata/field-metadata.entity';
|
||||||
import { CALENDAR_CHANNEL_EVENT_ASSOCIATION_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
import { CALENDAR_CHANNEL_EVENT_ASSOCIATION_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
||||||
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
||||||
import { CalendarEventObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event.object-metadata';
|
import { CalendarEventWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event.workspace-entity';
|
||||||
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-object.decorator';
|
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-entity.decorator';
|
||||||
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
||||||
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
||||||
import { WorkspaceGate } from 'src/engine/twenty-orm/decorators/workspace-gate.decorator';
|
|
||||||
import { WorkspaceRelation } from 'src/engine/twenty-orm/decorators/workspace-relation.decorator';
|
import { WorkspaceRelation } from 'src/engine/twenty-orm/decorators/workspace-relation.decorator';
|
||||||
import { RelationMetadataType } from 'src/engine/metadata-modules/relation-metadata/relation-metadata.entity';
|
import { RelationMetadataType } from 'src/engine/metadata-modules/relation-metadata/relation-metadata.entity';
|
||||||
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
||||||
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
||||||
|
import { CalendarChannelWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel.workspace-entity';
|
||||||
|
|
||||||
@WorkspaceEntity({
|
@WorkspaceEntity({
|
||||||
standardId: STANDARD_OBJECT_IDS.calendarChannelEventAssociation,
|
standardId: STANDARD_OBJECT_IDS.calendarChannelEventAssociation,
|
||||||
@ -23,7 +23,7 @@ import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity
|
|||||||
})
|
})
|
||||||
@WorkspaceIsSystem()
|
@WorkspaceIsSystem()
|
||||||
@WorkspaceIsNotAuditLogged()
|
@WorkspaceIsNotAuditLogged()
|
||||||
export class CalendarChannelEventAssociationObjectMetadata extends BaseWorkspaceEntity {
|
export class CalendarChannelEventAssociationWorkspaceEntity extends BaseWorkspaceEntity {
|
||||||
@WorkspaceField({
|
@WorkspaceField({
|
||||||
standardId:
|
standardId:
|
||||||
CALENDAR_CHANNEL_EVENT_ASSOCIATION_STANDARD_FIELD_IDS.eventExternalId,
|
CALENDAR_CHANNEL_EVENT_ASSOCIATION_STANDARD_FIELD_IDS.eventExternalId,
|
||||||
@ -42,10 +42,10 @@ export class CalendarChannelEventAssociationObjectMetadata extends BaseWorkspace
|
|||||||
description: 'Channel ID',
|
description: 'Channel ID',
|
||||||
icon: 'IconCalendar',
|
icon: 'IconCalendar',
|
||||||
joinColumn: 'calendarChannelId',
|
joinColumn: 'calendarChannelId',
|
||||||
inverseSideTarget: () => CalendarEventObjectMetadata,
|
inverseSideTarget: () => CalendarChannelWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'calendarChannelEventAssociations',
|
inverseSideFieldKey: 'calendarChannelEventAssociations',
|
||||||
})
|
})
|
||||||
calendarChannel: Relation<CalendarEventObjectMetadata>;
|
calendarChannel: Relation<CalendarChannelWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId:
|
standardId:
|
||||||
@ -55,8 +55,8 @@ export class CalendarChannelEventAssociationObjectMetadata extends BaseWorkspace
|
|||||||
description: 'Event ID',
|
description: 'Event ID',
|
||||||
icon: 'IconCalendar',
|
icon: 'IconCalendar',
|
||||||
joinColumn: 'calendarEventId',
|
joinColumn: 'calendarEventId',
|
||||||
inverseSideTarget: () => CalendarEventObjectMetadata,
|
inverseSideTarget: () => CalendarEventWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'calendarChannelEventAssociations',
|
inverseSideFieldKey: 'calendarChannelEventAssociations',
|
||||||
})
|
})
|
||||||
calendarEvent: Relation<CalendarEventObjectMetadata>;
|
calendarEvent: Relation<CalendarEventWorkspaceEntity>;
|
||||||
}
|
}
|
||||||
@ -7,10 +7,10 @@ import {
|
|||||||
import { FieldMetadataType } from 'src/engine/metadata-modules/field-metadata/field-metadata.entity';
|
import { FieldMetadataType } from 'src/engine/metadata-modules/field-metadata/field-metadata.entity';
|
||||||
import { CALENDAR_CHANNEL_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
import { CALENDAR_CHANNEL_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
||||||
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
||||||
import { ConnectedAccountObjectMetadata } from 'src/modules/connected-account/standard-objects/connected-account.object-metadata';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
import { CalendarChannelEventAssociationObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.object-metadata';
|
import { CalendarChannelEventAssociationWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.workspace-entity';
|
||||||
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
||||||
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-object.decorator';
|
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-entity.decorator';
|
||||||
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
||||||
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
||||||
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
||||||
@ -31,7 +31,7 @@ export enum CalendarChannelVisibility {
|
|||||||
})
|
})
|
||||||
@WorkspaceIsSystem()
|
@WorkspaceIsSystem()
|
||||||
@WorkspaceIsNotAuditLogged()
|
@WorkspaceIsNotAuditLogged()
|
||||||
export class CalendarChannelObjectMetadata extends BaseWorkspaceEntity {
|
export class CalendarChannelWorkspaceEntity extends BaseWorkspaceEntity {
|
||||||
@WorkspaceField({
|
@WorkspaceField({
|
||||||
standardId: CALENDAR_CHANNEL_STANDARD_FIELD_IDS.handle,
|
standardId: CALENDAR_CHANNEL_STANDARD_FIELD_IDS.handle,
|
||||||
type: FieldMetadataType.TEXT,
|
type: FieldMetadataType.TEXT,
|
||||||
@ -103,10 +103,10 @@ export class CalendarChannelObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'Connected Account',
|
description: 'Connected Account',
|
||||||
icon: 'IconUserCircle',
|
icon: 'IconUserCircle',
|
||||||
joinColumn: 'connectedAccountId',
|
joinColumn: 'connectedAccountId',
|
||||||
inverseSideTarget: () => ConnectedAccountObjectMetadata,
|
inverseSideTarget: () => ConnectedAccountWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'calendarChannels',
|
inverseSideFieldKey: 'calendarChannels',
|
||||||
})
|
})
|
||||||
connectedAccount: Relation<ConnectedAccountObjectMetadata>;
|
connectedAccount: Relation<ConnectedAccountWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId:
|
standardId:
|
||||||
@ -115,10 +115,10 @@ export class CalendarChannelObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
label: 'Calendar Channel Event Associations',
|
label: 'Calendar Channel Event Associations',
|
||||||
description: 'Calendar Channel Event Associations',
|
description: 'Calendar Channel Event Associations',
|
||||||
icon: 'IconCalendar',
|
icon: 'IconCalendar',
|
||||||
inverseSideTarget: () => CalendarChannelEventAssociationObjectMetadata,
|
inverseSideTarget: () => CalendarChannelEventAssociationWorkspaceEntity,
|
||||||
onDelete: RelationOnDeleteAction.CASCADE,
|
onDelete: RelationOnDeleteAction.CASCADE,
|
||||||
})
|
})
|
||||||
calendarChannelEventAssociations: Relation<
|
calendarChannelEventAssociations: Relation<
|
||||||
CalendarChannelEventAssociationObjectMetadata[]
|
CalendarChannelEventAssociationWorkspaceEntity[]
|
||||||
>;
|
>;
|
||||||
}
|
}
|
||||||
@ -3,11 +3,11 @@ import { Relation } from 'src/engine/workspace-manager/workspace-sync-metadata/i
|
|||||||
import { FieldMetadataType } from 'src/engine/metadata-modules/field-metadata/field-metadata.entity';
|
import { FieldMetadataType } from 'src/engine/metadata-modules/field-metadata/field-metadata.entity';
|
||||||
import { CALENDAR_EVENT_PARTICIPANT_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
import { CALENDAR_EVENT_PARTICIPANT_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
||||||
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
||||||
import { CalendarEventObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event.object-metadata';
|
import { CalendarEventWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event.workspace-entity';
|
||||||
import { PersonObjectMetadata } from 'src/modules/person/standard-objects/person.object-metadata';
|
import { PersonWorkspaceEntity } from 'src/modules/person/standard-objects/person.workspace-entity';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
||||||
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-object.decorator';
|
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-entity.decorator';
|
||||||
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
||||||
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
||||||
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
||||||
@ -32,7 +32,7 @@ export enum CalendarEventParticipantResponseStatus {
|
|||||||
})
|
})
|
||||||
@WorkspaceIsSystem()
|
@WorkspaceIsSystem()
|
||||||
@WorkspaceIsNotAuditLogged()
|
@WorkspaceIsNotAuditLogged()
|
||||||
export class CalendarEventParticipantObjectMetadata extends BaseWorkspaceEntity {
|
export class CalendarEventParticipantWorkspaceEntity extends BaseWorkspaceEntity {
|
||||||
@WorkspaceField({
|
@WorkspaceField({
|
||||||
standardId: CALENDAR_EVENT_PARTICIPANT_STANDARD_FIELD_IDS.handle,
|
standardId: CALENDAR_EVENT_PARTICIPANT_STANDARD_FIELD_IDS.handle,
|
||||||
type: FieldMetadataType.TEXT,
|
type: FieldMetadataType.TEXT,
|
||||||
@ -104,10 +104,10 @@ export class CalendarEventParticipantObjectMetadata extends BaseWorkspaceEntity
|
|||||||
description: 'Event ID',
|
description: 'Event ID',
|
||||||
icon: 'IconCalendar',
|
icon: 'IconCalendar',
|
||||||
joinColumn: 'calendarEventId',
|
joinColumn: 'calendarEventId',
|
||||||
inverseSideTarget: () => CalendarEventObjectMetadata,
|
inverseSideTarget: () => CalendarEventWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'calendarEventParticipants',
|
inverseSideFieldKey: 'calendarEventParticipants',
|
||||||
})
|
})
|
||||||
calendarEvent: Relation<CalendarEventObjectMetadata>;
|
calendarEvent: Relation<CalendarEventWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: CALENDAR_EVENT_PARTICIPANT_STANDARD_FIELD_IDS.person,
|
standardId: CALENDAR_EVENT_PARTICIPANT_STANDARD_FIELD_IDS.person,
|
||||||
@ -116,11 +116,11 @@ export class CalendarEventParticipantObjectMetadata extends BaseWorkspaceEntity
|
|||||||
description: 'Person',
|
description: 'Person',
|
||||||
icon: 'IconUser',
|
icon: 'IconUser',
|
||||||
joinColumn: 'personId',
|
joinColumn: 'personId',
|
||||||
inverseSideTarget: () => PersonObjectMetadata,
|
inverseSideTarget: () => PersonWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'calendarEventParticipants',
|
inverseSideFieldKey: 'calendarEventParticipants',
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
person: Relation<PersonObjectMetadata>;
|
person: Relation<PersonWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: CALENDAR_EVENT_PARTICIPANT_STANDARD_FIELD_IDS.workspaceMember,
|
standardId: CALENDAR_EVENT_PARTICIPANT_STANDARD_FIELD_IDS.workspaceMember,
|
||||||
@ -129,9 +129,9 @@ export class CalendarEventParticipantObjectMetadata extends BaseWorkspaceEntity
|
|||||||
description: 'Workspace Member',
|
description: 'Workspace Member',
|
||||||
icon: 'IconUser',
|
icon: 'IconUser',
|
||||||
joinColumn: 'workspaceMemberId',
|
joinColumn: 'workspaceMemberId',
|
||||||
inverseSideTarget: () => WorkspaceMemberObjectMetadata,
|
inverseSideTarget: () => WorkspaceMemberWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'calendarEventParticipants',
|
inverseSideFieldKey: 'calendarEventParticipants',
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
workspaceMember: Relation<WorkspaceMemberObjectMetadata>;
|
workspaceMember: Relation<WorkspaceMemberWorkspaceEntity>;
|
||||||
}
|
}
|
||||||
@ -5,13 +5,13 @@ import {
|
|||||||
RelationMetadataType,
|
RelationMetadataType,
|
||||||
RelationOnDeleteAction,
|
RelationOnDeleteAction,
|
||||||
} from 'src/engine/metadata-modules/relation-metadata/relation-metadata.entity';
|
} from 'src/engine/metadata-modules/relation-metadata/relation-metadata.entity';
|
||||||
import { CalendarChannelEventAssociationObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.object-metadata';
|
import { CalendarChannelEventAssociationWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel-event-association.workspace-entity';
|
||||||
import { CalendarEventParticipantObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event-participant.object-metadata';
|
import { CalendarEventParticipantWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event-participant.workspace-entity';
|
||||||
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
||||||
import { CALENDAR_EVENT_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
import { CALENDAR_EVENT_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
||||||
import { LinkMetadata } from 'src/engine/metadata-modules/field-metadata/composite-types/link.composite-type';
|
import { LinkMetadata } from 'src/engine/metadata-modules/field-metadata/composite-types/link.composite-type';
|
||||||
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
||||||
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-object.decorator';
|
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-entity.decorator';
|
||||||
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
||||||
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
||||||
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
||||||
@ -28,7 +28,7 @@ import { WorkspaceRelation } from 'src/engine/twenty-orm/decorators/workspace-re
|
|||||||
})
|
})
|
||||||
@WorkspaceIsSystem()
|
@WorkspaceIsSystem()
|
||||||
@WorkspaceIsNotAuditLogged()
|
@WorkspaceIsNotAuditLogged()
|
||||||
export class CalendarEventObjectMetadata extends BaseWorkspaceEntity {
|
export class CalendarEventWorkspaceEntity extends BaseWorkspaceEntity {
|
||||||
@WorkspaceField({
|
@WorkspaceField({
|
||||||
standardId: CALENDAR_EVENT_STANDARD_FIELD_IDS.title,
|
standardId: CALENDAR_EVENT_STANDARD_FIELD_IDS.title,
|
||||||
type: FieldMetadataType.TEXT,
|
type: FieldMetadataType.TEXT,
|
||||||
@ -158,11 +158,11 @@ export class CalendarEventObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
label: 'Calendar Channel Event Associations',
|
label: 'Calendar Channel Event Associations',
|
||||||
description: 'Calendar Channel Event Associations',
|
description: 'Calendar Channel Event Associations',
|
||||||
icon: 'IconCalendar',
|
icon: 'IconCalendar',
|
||||||
inverseSideTarget: () => CalendarChannelEventAssociationObjectMetadata,
|
inverseSideTarget: () => CalendarChannelEventAssociationWorkspaceEntity,
|
||||||
onDelete: RelationOnDeleteAction.CASCADE,
|
onDelete: RelationOnDeleteAction.CASCADE,
|
||||||
})
|
})
|
||||||
calendarChannelEventAssociations: Relation<
|
calendarChannelEventAssociations: Relation<
|
||||||
CalendarChannelEventAssociationObjectMetadata[]
|
CalendarChannelEventAssociationWorkspaceEntity[]
|
||||||
>;
|
>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
@ -171,8 +171,10 @@ export class CalendarEventObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
label: 'Event Participants',
|
label: 'Event Participants',
|
||||||
description: 'Event Participants',
|
description: 'Event Participants',
|
||||||
icon: 'IconUserCircle',
|
icon: 'IconUserCircle',
|
||||||
inverseSideTarget: () => CalendarEventParticipantObjectMetadata,
|
inverseSideTarget: () => CalendarEventParticipantWorkspaceEntity,
|
||||||
onDelete: RelationOnDeleteAction.CASCADE,
|
onDelete: RelationOnDeleteAction.CASCADE,
|
||||||
})
|
})
|
||||||
calendarEventParticipants: Relation<CalendarEventParticipantObjectMetadata[]>;
|
calendarEventParticipants: Relation<
|
||||||
|
CalendarEventParticipantWorkspaceEntity[]
|
||||||
|
>;
|
||||||
}
|
}
|
||||||
@ -1,9 +1,9 @@
|
|||||||
import { CalendarEventParticipantObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event-participant.object-metadata';
|
import { CalendarEventParticipantWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event-participant.workspace-entity';
|
||||||
import { CalendarEventObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event.object-metadata';
|
import { CalendarEventWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event.workspace-entity';
|
||||||
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
||||||
|
|
||||||
export type CalendarEvent = Omit<
|
export type CalendarEvent = Omit<
|
||||||
ObjectRecord<CalendarEventObjectMetadata>,
|
ObjectRecord<CalendarEventWorkspaceEntity>,
|
||||||
| 'createdAt'
|
| 'createdAt'
|
||||||
| 'updatedAt'
|
| 'updatedAt'
|
||||||
| 'calendarChannelEventAssociations'
|
| 'calendarChannelEventAssociations'
|
||||||
@ -15,7 +15,7 @@ export type CalendarEvent = Omit<
|
|||||||
};
|
};
|
||||||
|
|
||||||
export type CalendarEventParticipant = Omit<
|
export type CalendarEventParticipant = Omit<
|
||||||
ObjectRecord<CalendarEventParticipantObjectMetadata>,
|
ObjectRecord<CalendarEventParticipantWorkspaceEntity>,
|
||||||
| 'id'
|
| 'id'
|
||||||
| 'createdAt'
|
| 'createdAt'
|
||||||
| 'updatedAt'
|
| 'updatedAt'
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
import { calendar_v3 as calendarV3 } from 'googleapis';
|
import { calendar_v3 as calendarV3 } from 'googleapis';
|
||||||
import { v4 } from 'uuid';
|
import { v4 } from 'uuid';
|
||||||
|
|
||||||
import { CalendarEventParticipantResponseStatus } from 'src/modules/calendar/standard-objects/calendar-event-participant.object-metadata';
|
import { CalendarEventParticipantResponseStatus } from 'src/modules/calendar/standard-objects/calendar-event-participant.workspace-entity';
|
||||||
import { CalendarEventWithParticipants } from 'src/modules/calendar/types/calendar-event';
|
import { CalendarEventWithParticipants } from 'src/modules/calendar/types/calendar-event';
|
||||||
|
|
||||||
export const formatGoogleCalendarEvent = (
|
export const formatGoogleCalendarEvent = (
|
||||||
|
|||||||
@ -9,15 +9,15 @@ import {
|
|||||||
} from 'src/engine/metadata-modules/relation-metadata/relation-metadata.entity';
|
} from 'src/engine/metadata-modules/relation-metadata/relation-metadata.entity';
|
||||||
import { COMPANY_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
import { COMPANY_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
||||||
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
||||||
import { ActivityTargetObjectMetadata } from 'src/modules/activity/standard-objects/activity-target.object-metadata';
|
import { ActivityTargetWorkspaceEntity } from 'src/modules/activity/standard-objects/activity-target.workspace-entity';
|
||||||
import { AttachmentObjectMetadata } from 'src/modules/attachment/standard-objects/attachment.object-metadata';
|
import { AttachmentWorkspaceEntity } from 'src/modules/attachment/standard-objects/attachment.workspace-entity';
|
||||||
import { FavoriteObjectMetadata } from 'src/modules/favorite/standard-objects/favorite.object-metadata';
|
import { FavoriteWorkspaceEntity } from 'src/modules/favorite/standard-objects/favorite.workspace-entity';
|
||||||
import { OpportunityObjectMetadata } from 'src/modules/opportunity/standard-objects/opportunity.object-metadata';
|
import { OpportunityWorkspaceEntity } from 'src/modules/opportunity/standard-objects/opportunity.workspace-entity';
|
||||||
import { PersonObjectMetadata } from 'src/modules/person/standard-objects/person.object-metadata';
|
import { PersonWorkspaceEntity } from 'src/modules/person/standard-objects/person.workspace-entity';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
import { TimelineActivityObjectMetadata } from 'src/modules/timeline/standard-objects/timeline-activity.object-metadata';
|
import { TimelineActivityWorkspaceEntity } from 'src/modules/timeline/standard-objects/timeline-activity.workspace-entity';
|
||||||
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
||||||
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-object.decorator';
|
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-entity.decorator';
|
||||||
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
||||||
import { WorkspaceIsNullable } from 'src/engine/twenty-orm/decorators/workspace-is-nullable.decorator';
|
import { WorkspaceIsNullable } from 'src/engine/twenty-orm/decorators/workspace-is-nullable.decorator';
|
||||||
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
||||||
@ -31,7 +31,7 @@ import { WorkspaceRelation } from 'src/engine/twenty-orm/decorators/workspace-re
|
|||||||
description: 'A company',
|
description: 'A company',
|
||||||
icon: 'IconBuildingSkyscraper',
|
icon: 'IconBuildingSkyscraper',
|
||||||
})
|
})
|
||||||
export class CompanyObjectMetadata extends BaseWorkspaceEntity {
|
export class CompanyWorkspaceEntity extends BaseWorkspaceEntity {
|
||||||
@WorkspaceField({
|
@WorkspaceField({
|
||||||
standardId: COMPANY_STANDARD_FIELD_IDS.name,
|
standardId: COMPANY_STANDARD_FIELD_IDS.name,
|
||||||
type: FieldMetadataType.TEXT,
|
type: FieldMetadataType.TEXT,
|
||||||
@ -130,11 +130,11 @@ export class CompanyObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
label: 'People',
|
label: 'People',
|
||||||
description: 'People linked to the company.',
|
description: 'People linked to the company.',
|
||||||
icon: 'IconUsers',
|
icon: 'IconUsers',
|
||||||
inverseSideTarget: () => PersonObjectMetadata,
|
inverseSideTarget: () => PersonWorkspaceEntity,
|
||||||
onDelete: RelationOnDeleteAction.SET_NULL,
|
onDelete: RelationOnDeleteAction.SET_NULL,
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
people: Relation<PersonObjectMetadata[]>;
|
people: Relation<PersonWorkspaceEntity[]>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: COMPANY_STANDARD_FIELD_IDS.accountOwner,
|
standardId: COMPANY_STANDARD_FIELD_IDS.accountOwner,
|
||||||
@ -144,12 +144,12 @@ export class CompanyObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
'Your team member responsible for managing the company account',
|
'Your team member responsible for managing the company account',
|
||||||
icon: 'IconUserCircle',
|
icon: 'IconUserCircle',
|
||||||
joinColumn: 'accountOwnerId',
|
joinColumn: 'accountOwnerId',
|
||||||
inverseSideTarget: () => WorkspaceMemberObjectMetadata,
|
inverseSideTarget: () => WorkspaceMemberWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'accountOwnerForCompanies',
|
inverseSideFieldKey: 'accountOwnerForCompanies',
|
||||||
onDelete: RelationOnDeleteAction.SET_NULL,
|
onDelete: RelationOnDeleteAction.SET_NULL,
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
accountOwner: Relation<WorkspaceMemberObjectMetadata>;
|
accountOwner: Relation<WorkspaceMemberWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: COMPANY_STANDARD_FIELD_IDS.activityTargets,
|
standardId: COMPANY_STANDARD_FIELD_IDS.activityTargets,
|
||||||
@ -157,11 +157,11 @@ export class CompanyObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
label: 'Activities',
|
label: 'Activities',
|
||||||
description: 'Activities tied to the company',
|
description: 'Activities tied to the company',
|
||||||
icon: 'IconCheckbox',
|
icon: 'IconCheckbox',
|
||||||
inverseSideTarget: () => ActivityTargetObjectMetadata,
|
inverseSideTarget: () => ActivityTargetWorkspaceEntity,
|
||||||
onDelete: RelationOnDeleteAction.CASCADE,
|
onDelete: RelationOnDeleteAction.CASCADE,
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
activityTargets: Relation<ActivityTargetObjectMetadata[]>;
|
activityTargets: Relation<ActivityTargetWorkspaceEntity[]>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: COMPANY_STANDARD_FIELD_IDS.opportunities,
|
standardId: COMPANY_STANDARD_FIELD_IDS.opportunities,
|
||||||
@ -169,11 +169,11 @@ export class CompanyObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
label: 'Opportunities',
|
label: 'Opportunities',
|
||||||
description: 'Opportunities linked to the company.',
|
description: 'Opportunities linked to the company.',
|
||||||
icon: 'IconTargetArrow',
|
icon: 'IconTargetArrow',
|
||||||
inverseSideTarget: () => OpportunityObjectMetadata,
|
inverseSideTarget: () => OpportunityWorkspaceEntity,
|
||||||
onDelete: RelationOnDeleteAction.SET_NULL,
|
onDelete: RelationOnDeleteAction.SET_NULL,
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
opportunities: Relation<OpportunityObjectMetadata[]>;
|
opportunities: Relation<OpportunityWorkspaceEntity[]>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: COMPANY_STANDARD_FIELD_IDS.favorites,
|
standardId: COMPANY_STANDARD_FIELD_IDS.favorites,
|
||||||
@ -181,12 +181,12 @@ export class CompanyObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
label: 'Favorites',
|
label: 'Favorites',
|
||||||
description: 'Favorites linked to the company',
|
description: 'Favorites linked to the company',
|
||||||
icon: 'IconHeart',
|
icon: 'IconHeart',
|
||||||
inverseSideTarget: () => FavoriteObjectMetadata,
|
inverseSideTarget: () => FavoriteWorkspaceEntity,
|
||||||
onDelete: RelationOnDeleteAction.CASCADE,
|
onDelete: RelationOnDeleteAction.CASCADE,
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
@WorkspaceIsSystem()
|
@WorkspaceIsSystem()
|
||||||
favorites: Relation<FavoriteObjectMetadata[]>;
|
favorites: Relation<FavoriteWorkspaceEntity[]>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: COMPANY_STANDARD_FIELD_IDS.attachments,
|
standardId: COMPANY_STANDARD_FIELD_IDS.attachments,
|
||||||
@ -194,11 +194,11 @@ export class CompanyObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
label: 'Attachments',
|
label: 'Attachments',
|
||||||
description: 'Attachments linked to the company',
|
description: 'Attachments linked to the company',
|
||||||
icon: 'IconFileImport',
|
icon: 'IconFileImport',
|
||||||
inverseSideTarget: () => AttachmentObjectMetadata,
|
inverseSideTarget: () => AttachmentWorkspaceEntity,
|
||||||
onDelete: RelationOnDeleteAction.CASCADE,
|
onDelete: RelationOnDeleteAction.CASCADE,
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
attachments: Relation<AttachmentObjectMetadata[]>;
|
attachments: Relation<AttachmentWorkspaceEntity[]>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: COMPANY_STANDARD_FIELD_IDS.timelineActivities,
|
standardId: COMPANY_STANDARD_FIELD_IDS.timelineActivities,
|
||||||
@ -206,10 +206,10 @@ export class CompanyObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
label: 'Timeline Activities',
|
label: 'Timeline Activities',
|
||||||
description: 'Timeline Activities linked to the company',
|
description: 'Timeline Activities linked to the company',
|
||||||
icon: 'IconIconTimelineEvent',
|
icon: 'IconIconTimelineEvent',
|
||||||
inverseSideTarget: () => TimelineActivityObjectMetadata,
|
inverseSideTarget: () => TimelineActivityWorkspaceEntity,
|
||||||
onDelete: RelationOnDeleteAction.CASCADE,
|
onDelete: RelationOnDeleteAction.CASCADE,
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
@WorkspaceIsSystem()
|
@WorkspaceIsSystem()
|
||||||
timelineActivities: Relation<TimelineActivityObjectMetadata[]>;
|
timelineActivities: Relation<TimelineActivityWorkspaceEntity[]>;
|
||||||
}
|
}
|
||||||
@ -5,11 +5,11 @@ import { CreateCompanyAndContactService } from 'src/modules/connected-account/au
|
|||||||
import { CreateCompanyModule } from 'src/modules/connected-account/auto-companies-and-contacts-creation/create-company/create-company.module';
|
import { CreateCompanyModule } from 'src/modules/connected-account/auto-companies-and-contacts-creation/create-company/create-company.module';
|
||||||
import { CreateContactModule } from 'src/modules/connected-account/auto-companies-and-contacts-creation/create-contact/create-contact.module';
|
import { CreateContactModule } from 'src/modules/connected-account/auto-companies-and-contacts-creation/create-contact/create-contact.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 { PersonObjectMetadata } from 'src/modules/person/standard-objects/person.object-metadata';
|
import { PersonWorkspaceEntity } from 'src/modules/person/standard-objects/person.workspace-entity';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
import { MessageParticipantModule } from 'src/modules/messaging/services/message-participant/message-participant.module';
|
import { MessageParticipantModule } from 'src/modules/messaging/services/message-participant/message-participant.module';
|
||||||
import { WorkspaceDataSourceModule } from 'src/engine/workspace-datasource/workspace-datasource.module';
|
import { WorkspaceDataSourceModule } from 'src/engine/workspace-datasource/workspace-datasource.module';
|
||||||
import { CalendarEventParticipantObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-event-participant.object-metadata';
|
import { CalendarEventParticipantWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-event-participant.workspace-entity';
|
||||||
import { CalendarEventParticipantModule } from 'src/modules/calendar/services/calendar-event-participant/calendar-event-participant.module';
|
import { CalendarEventParticipantModule } from 'src/modules/calendar/services/calendar-event-participant/calendar-event-participant.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';
|
||||||
|
|
||||||
@ -18,9 +18,9 @@ import { FeatureFlagEntity } from 'src/engine/core-modules/feature-flag/feature-
|
|||||||
CreateContactModule,
|
CreateContactModule,
|
||||||
CreateCompanyModule,
|
CreateCompanyModule,
|
||||||
ObjectMetadataRepositoryModule.forFeature([
|
ObjectMetadataRepositoryModule.forFeature([
|
||||||
PersonObjectMetadata,
|
PersonWorkspaceEntity,
|
||||||
WorkspaceMemberObjectMetadata,
|
WorkspaceMemberWorkspaceEntity,
|
||||||
CalendarEventParticipantObjectMetadata,
|
CalendarEventParticipantWorkspaceEntity,
|
||||||
]),
|
]),
|
||||||
MessageParticipantModule,
|
MessageParticipantModule,
|
||||||
WorkspaceDataSourceModule,
|
WorkspaceDataSourceModule,
|
||||||
|
|||||||
@ -1,11 +1,13 @@
|
|||||||
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 { CompanyObjectMetadata } from 'src/modules/company/standard-objects/company.object-metadata';
|
import { CompanyWorkspaceEntity } from 'src/modules/company/standard-objects/company.workspace-entity';
|
||||||
import { CreateCompanyService } from 'src/modules/connected-account/auto-companies-and-contacts-creation/create-company/create-company.service';
|
import { CreateCompanyService } from 'src/modules/connected-account/auto-companies-and-contacts-creation/create-company/create-company.service';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [ObjectMetadataRepositoryModule.forFeature([CompanyObjectMetadata])],
|
imports: [
|
||||||
|
ObjectMetadataRepositoryModule.forFeature([CompanyWorkspaceEntity]),
|
||||||
|
],
|
||||||
providers: [CreateCompanyService],
|
providers: [CreateCompanyService],
|
||||||
exports: [CreateCompanyService],
|
exports: [CreateCompanyService],
|
||||||
})
|
})
|
||||||
|
|||||||
@ -7,13 +7,13 @@ import axios, { AxiosInstance } from 'axios';
|
|||||||
import { CompanyRepository } from 'src/modules/company/repositories/company.repository';
|
import { CompanyRepository } from 'src/modules/company/repositories/company.repository';
|
||||||
import { getCompanyNameFromDomainName } from 'src/modules/calendar-messaging-participant/utils/get-company-name-from-domain-name.util';
|
import { getCompanyNameFromDomainName } from 'src/modules/calendar-messaging-participant/utils/get-company-name-from-domain-name.util';
|
||||||
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 { CompanyObjectMetadata } from 'src/modules/company/standard-objects/company.object-metadata';
|
import { CompanyWorkspaceEntity } from 'src/modules/company/standard-objects/company.workspace-entity';
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class CreateCompanyService {
|
export class CreateCompanyService {
|
||||||
private readonly httpService: AxiosInstance;
|
private readonly httpService: AxiosInstance;
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
@InjectObjectMetadataRepository(CompanyObjectMetadata)
|
@InjectObjectMetadataRepository(CompanyWorkspaceEntity)
|
||||||
private readonly companyRepository: CompanyRepository,
|
private readonly companyRepository: CompanyRepository,
|
||||||
) {
|
) {
|
||||||
this.httpService = axios.create({
|
this.httpService = axios.create({
|
||||||
|
|||||||
@ -2,10 +2,10 @@ 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 { CreateContactService } from 'src/modules/connected-account/auto-companies-and-contacts-creation/create-contact/create-contact.service';
|
import { CreateContactService } from 'src/modules/connected-account/auto-companies-and-contacts-creation/create-contact/create-contact.service';
|
||||||
import { PersonObjectMetadata } from 'src/modules/person/standard-objects/person.object-metadata';
|
import { PersonWorkspaceEntity } from 'src/modules/person/standard-objects/person.workspace-entity';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [ObjectMetadataRepositoryModule.forFeature([PersonObjectMetadata])],
|
imports: [ObjectMetadataRepositoryModule.forFeature([PersonWorkspaceEntity])],
|
||||||
providers: [CreateContactService],
|
providers: [CreateContactService],
|
||||||
exports: [CreateContactService],
|
exports: [CreateContactService],
|
||||||
})
|
})
|
||||||
|
|||||||
@ -6,7 +6,7 @@ import { v4 } from 'uuid';
|
|||||||
import { PersonRepository } from 'src/modules/person/repositories/person.repository';
|
import { PersonRepository } from 'src/modules/person/repositories/person.repository';
|
||||||
import { getFirstNameAndLastNameFromHandleAndDisplayName } from 'src/modules/calendar-messaging-participant/utils/get-first-name-and-last-name-from-handle-and-display-name.util';
|
import { getFirstNameAndLastNameFromHandleAndDisplayName } from 'src/modules/calendar-messaging-participant/utils/get-first-name-and-last-name-from-handle-and-display-name.util';
|
||||||
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 { PersonObjectMetadata } from 'src/modules/person/standard-objects/person.object-metadata';
|
import { PersonWorkspaceEntity } from 'src/modules/person/standard-objects/person.workspace-entity';
|
||||||
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
||||||
|
|
||||||
type ContactToCreate = {
|
type ContactToCreate = {
|
||||||
@ -26,7 +26,7 @@ type FormattedContactToCreate = {
|
|||||||
@Injectable()
|
@Injectable()
|
||||||
export class CreateContactService {
|
export class CreateContactService {
|
||||||
constructor(
|
constructor(
|
||||||
@InjectObjectMetadataRepository(PersonObjectMetadata)
|
@InjectObjectMetadataRepository(PersonWorkspaceEntity)
|
||||||
private readonly personRepository: PersonRepository,
|
private readonly personRepository: PersonRepository,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
@ -55,7 +55,7 @@ export class CreateContactService {
|
|||||||
contactsToCreate: ContactToCreate[],
|
contactsToCreate: ContactToCreate[],
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<PersonObjectMetadata>[]> {
|
): Promise<ObjectRecord<PersonWorkspaceEntity>[]> {
|
||||||
if (contactsToCreate.length === 0) return [];
|
if (contactsToCreate.length === 0) return [];
|
||||||
|
|
||||||
const formattedContacts = this.formatContacts(contactsToCreate);
|
const formattedContacts = this.formatContacts(contactsToCreate);
|
||||||
|
|||||||
@ -11,8 +11,8 @@ import { PersonRepository } from 'src/modules/person/repositories/person.reposit
|
|||||||
import { WorkspaceMemberRepository } from 'src/modules/workspace-member/repositories/workspace-member.repository';
|
import { WorkspaceMemberRepository } from 'src/modules/workspace-member/repositories/workspace-member.repository';
|
||||||
import { isWorkEmail } from 'src/utils/is-work-email';
|
import { isWorkEmail } from 'src/utils/is-work-email';
|
||||||
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 { PersonObjectMetadata } from 'src/modules/person/standard-objects/person.object-metadata';
|
import { PersonWorkspaceEntity } from 'src/modules/person/standard-objects/person.workspace-entity';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
import { getUniqueContactsAndHandles } from 'src/modules/connected-account/auto-companies-and-contacts-creation/utils/get-unique-contacts-and-handles.util';
|
import { getUniqueContactsAndHandles } from 'src/modules/connected-account/auto-companies-and-contacts-creation/utils/get-unique-contacts-and-handles.util';
|
||||||
import { Contacts } from 'src/modules/connected-account/auto-companies-and-contacts-creation/types/contact.type';
|
import { Contacts } from 'src/modules/connected-account/auto-companies-and-contacts-creation/types/contact.type';
|
||||||
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
||||||
@ -27,9 +27,9 @@ export class CreateCompanyAndContactService {
|
|||||||
constructor(
|
constructor(
|
||||||
private readonly createContactService: CreateContactService,
|
private readonly createContactService: CreateContactService,
|
||||||
private readonly createCompaniesService: CreateCompanyService,
|
private readonly createCompaniesService: CreateCompanyService,
|
||||||
@InjectObjectMetadataRepository(PersonObjectMetadata)
|
@InjectObjectMetadataRepository(PersonWorkspaceEntity)
|
||||||
private readonly personRepository: PersonRepository,
|
private readonly personRepository: PersonRepository,
|
||||||
@InjectObjectMetadataRepository(WorkspaceMemberObjectMetadata)
|
@InjectObjectMetadataRepository(WorkspaceMemberWorkspaceEntity)
|
||||||
private readonly workspaceMemberRepository: WorkspaceMemberRepository,
|
private readonly workspaceMemberRepository: WorkspaceMemberRepository,
|
||||||
private readonly workspaceDataSourceService: WorkspaceDataSourceService,
|
private readonly workspaceDataSourceService: WorkspaceDataSourceService,
|
||||||
private readonly messageParticipantService: MessageParticipantService,
|
private readonly messageParticipantService: MessageParticipantService,
|
||||||
@ -43,7 +43,7 @@ export class CreateCompanyAndContactService {
|
|||||||
contactsToCreate: Contacts,
|
contactsToCreate: Contacts,
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<PersonObjectMetadata>[]> {
|
): Promise<ObjectRecord<PersonWorkspaceEntity>[]> {
|
||||||
if (!contactsToCreate || contactsToCreate.length === 0) {
|
if (!contactsToCreate || contactsToCreate.length === 0) {
|
||||||
return [];
|
return [];
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,12 +1,12 @@
|
|||||||
import { getDomainNameFromHandle } from 'src/modules/calendar-messaging-participant/utils/get-domain-name-from-handle.util';
|
import { getDomainNameFromHandle } from 'src/modules/calendar-messaging-participant/utils/get-domain-name-from-handle.util';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
||||||
import { Contacts } from 'src/modules/connected-account/auto-companies-and-contacts-creation/types/contact.type';
|
import { Contacts } from 'src/modules/connected-account/auto-companies-and-contacts-creation/types/contact.type';
|
||||||
|
|
||||||
export function filterOutContactsFromCompanyOrWorkspace(
|
export function filterOutContactsFromCompanyOrWorkspace(
|
||||||
contacts: Contacts,
|
contacts: Contacts,
|
||||||
selfHandle: string,
|
selfHandle: string,
|
||||||
workspaceMembers: ObjectRecord<WorkspaceMemberObjectMetadata>[],
|
workspaceMembers: ObjectRecord<WorkspaceMemberWorkspaceEntity>[],
|
||||||
): Contacts {
|
): Contacts {
|
||||||
const selfDomainName = getDomainNameFromHandle(selfHandle);
|
const selfDomainName = getDomainNameFromHandle(selfHandle);
|
||||||
|
|
||||||
|
|||||||
@ -4,7 +4,7 @@ import { EntityManager } from 'typeorm';
|
|||||||
|
|
||||||
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
||||||
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
||||||
import { BlocklistObjectMetadata } from 'src/modules/connected-account/standard-objects/blocklist.object-metadata';
|
import { BlocklistWorkspaceEntity } from 'src/modules/connected-account/standard-objects/blocklist.workspace-entity';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class BlocklistRepository {
|
export class BlocklistRepository {
|
||||||
@ -16,7 +16,7 @@ export class BlocklistRepository {
|
|||||||
id: string,
|
id: string,
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<BlocklistObjectMetadata> | null> {
|
): Promise<ObjectRecord<BlocklistWorkspaceEntity> | null> {
|
||||||
const dataSourceSchema =
|
const dataSourceSchema =
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
||||||
|
|
||||||
@ -39,7 +39,7 @@ export class BlocklistRepository {
|
|||||||
workspaceMemberId: string,
|
workspaceMemberId: string,
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<BlocklistObjectMetadata>[]> {
|
): Promise<ObjectRecord<BlocklistWorkspaceEntity>[]> {
|
||||||
const dataSourceSchema =
|
const dataSourceSchema =
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
||||||
|
|
||||||
@ -56,7 +56,7 @@ export class BlocklistRepository {
|
|||||||
handle: string,
|
handle: string,
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<BlocklistObjectMetadata>[]> {
|
): Promise<ObjectRecord<BlocklistWorkspaceEntity>[]> {
|
||||||
const dataSourceSchema =
|
const dataSourceSchema =
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
||||||
|
|
||||||
|
|||||||
@ -3,7 +3,7 @@ import { Injectable, NotFoundException } from '@nestjs/common';
|
|||||||
import { EntityManager } from 'typeorm';
|
import { EntityManager } from 'typeorm';
|
||||||
|
|
||||||
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
import { WorkspaceDataSourceService } from 'src/engine/workspace-datasource/workspace-datasource.service';
|
||||||
import { ConnectedAccountObjectMetadata } from 'src/modules/connected-account/standard-objects/connected-account.object-metadata';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
import { ObjectRecord } from 'src/engine/workspace-manager/workspace-sync-metadata/types/object-record';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
@ -15,7 +15,7 @@ export class ConnectedAccountRepository {
|
|||||||
public async getAll(
|
public async getAll(
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<ConnectedAccountObjectMetadata>[]> {
|
): Promise<ObjectRecord<ConnectedAccountWorkspaceEntity>[]> {
|
||||||
const dataSourceSchema =
|
const dataSourceSchema =
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
||||||
|
|
||||||
@ -31,7 +31,7 @@ export class ConnectedAccountRepository {
|
|||||||
connectedAccountIds: string[],
|
connectedAccountIds: string[],
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<ConnectedAccountObjectMetadata>[]> {
|
): Promise<ObjectRecord<ConnectedAccountWorkspaceEntity>[]> {
|
||||||
const dataSourceSchema =
|
const dataSourceSchema =
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
||||||
|
|
||||||
@ -47,7 +47,7 @@ export class ConnectedAccountRepository {
|
|||||||
workspaceMemberId: string,
|
workspaceMemberId: string,
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<ConnectedAccountObjectMetadata>[] | undefined> {
|
): Promise<ObjectRecord<ConnectedAccountWorkspaceEntity>[] | undefined> {
|
||||||
const dataSourceSchema =
|
const dataSourceSchema =
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
||||||
|
|
||||||
@ -67,7 +67,7 @@ export class ConnectedAccountRepository {
|
|||||||
workspaceMemberId: string,
|
workspaceMemberId: string,
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<ConnectedAccountObjectMetadata>[] | undefined> {
|
): Promise<ObjectRecord<ConnectedAccountWorkspaceEntity>[] | undefined> {
|
||||||
const dataSourceSchema =
|
const dataSourceSchema =
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
||||||
|
|
||||||
@ -84,7 +84,7 @@ export class ConnectedAccountRepository {
|
|||||||
|
|
||||||
public async create(
|
public async create(
|
||||||
connectedAccount: Pick<
|
connectedAccount: Pick<
|
||||||
ObjectRecord<ConnectedAccountObjectMetadata>,
|
ObjectRecord<ConnectedAccountWorkspaceEntity>,
|
||||||
| 'id'
|
| 'id'
|
||||||
| 'handle'
|
| 'handle'
|
||||||
| 'provider'
|
| 'provider'
|
||||||
@ -94,7 +94,7 @@ export class ConnectedAccountRepository {
|
|||||||
>,
|
>,
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<ConnectedAccountObjectMetadata>> {
|
): Promise<ObjectRecord<ConnectedAccountWorkspaceEntity>> {
|
||||||
const dataSourceSchema =
|
const dataSourceSchema =
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
||||||
|
|
||||||
@ -135,7 +135,7 @@ export class ConnectedAccountRepository {
|
|||||||
connectedAccountId: string,
|
connectedAccountId: string,
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<ConnectedAccountObjectMetadata> | undefined> {
|
): Promise<ObjectRecord<ConnectedAccountWorkspaceEntity> | undefined> {
|
||||||
const dataSourceSchema =
|
const dataSourceSchema =
|
||||||
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
this.workspaceDataSourceService.getSchemaName(workspaceId);
|
||||||
|
|
||||||
@ -154,7 +154,7 @@ export class ConnectedAccountRepository {
|
|||||||
connectedAccountId: string,
|
connectedAccountId: string,
|
||||||
workspaceId: string,
|
workspaceId: string,
|
||||||
transactionManager?: EntityManager,
|
transactionManager?: EntityManager,
|
||||||
): Promise<ObjectRecord<ConnectedAccountObjectMetadata>> {
|
): Promise<ObjectRecord<ConnectedAccountWorkspaceEntity>> {
|
||||||
const connectedAccount = await this.getById(
|
const connectedAccount = await this.getById(
|
||||||
connectedAccountId,
|
connectedAccountId,
|
||||||
workspaceId,
|
workspaceId,
|
||||||
|
|||||||
@ -2,14 +2,14 @@ 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 { BlocklistValidationService } from 'src/modules/connected-account/services/blocklist/blocklist-validation.service';
|
import { BlocklistValidationService } from 'src/modules/connected-account/services/blocklist/blocklist-validation.service';
|
||||||
import { BlocklistObjectMetadata } from 'src/modules/connected-account/standard-objects/blocklist.object-metadata';
|
import { BlocklistWorkspaceEntity } from 'src/modules/connected-account/standard-objects/blocklist.workspace-entity';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
ObjectMetadataRepositoryModule.forFeature([
|
ObjectMetadataRepositoryModule.forFeature([
|
||||||
BlocklistObjectMetadata,
|
BlocklistWorkspaceEntity,
|
||||||
WorkspaceMemberObjectMetadata,
|
WorkspaceMemberWorkspaceEntity,
|
||||||
]),
|
]),
|
||||||
],
|
],
|
||||||
providers: [BlocklistValidationService],
|
providers: [BlocklistValidationService],
|
||||||
|
|||||||
@ -10,12 +10,12 @@ import {
|
|||||||
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 { isDomain } from 'src/engine/utils/is-domain';
|
import { isDomain } from 'src/engine/utils/is-domain';
|
||||||
import { BlocklistRepository } from 'src/modules/connected-account/repositories/blocklist.repository';
|
import { BlocklistRepository } from 'src/modules/connected-account/repositories/blocklist.repository';
|
||||||
import { BlocklistObjectMetadata } from 'src/modules/connected-account/standard-objects/blocklist.object-metadata';
|
import { BlocklistWorkspaceEntity } from 'src/modules/connected-account/standard-objects/blocklist.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 { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
|
|
||||||
export type BlocklistItem = Omit<
|
export type BlocklistItem = Omit<
|
||||||
BlocklistObjectMetadata,
|
BlocklistWorkspaceEntity,
|
||||||
'createdAt' | 'updatedAt' | 'workspaceMember'
|
'createdAt' | 'updatedAt' | 'workspaceMember'
|
||||||
> & {
|
> & {
|
||||||
createdAt: string;
|
createdAt: string;
|
||||||
@ -26,9 +26,9 @@ export type BlocklistItem = Omit<
|
|||||||
@Injectable()
|
@Injectable()
|
||||||
export class BlocklistValidationService {
|
export class BlocklistValidationService {
|
||||||
constructor(
|
constructor(
|
||||||
@InjectObjectMetadataRepository(BlocklistObjectMetadata)
|
@InjectObjectMetadataRepository(BlocklistWorkspaceEntity)
|
||||||
private readonly blocklistRepository: BlocklistRepository,
|
private readonly blocklistRepository: BlocklistRepository,
|
||||||
@InjectObjectMetadataRepository(WorkspaceMemberObjectMetadata)
|
@InjectObjectMetadataRepository(WorkspaceMemberWorkspaceEntity)
|
||||||
private readonly workspaceMemberRepository: WorkspaceMemberRepository,
|
private readonly workspaceMemberRepository: WorkspaceMemberRepository,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
|
|||||||
@ -2,11 +2,13 @@ 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 { GoogleAPIRefreshAccessTokenService } from 'src/modules/connected-account/services/google-api-refresh-access-token/google-api-refresh-access-token.service';
|
import { GoogleAPIRefreshAccessTokenService } from 'src/modules/connected-account/services/google-api-refresh-access-token/google-api-refresh-access-token.service';
|
||||||
import { ConnectedAccountObjectMetadata } from 'src/modules/connected-account/standard-objects/connected-account.object-metadata';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
ObjectMetadataRepositoryModule.forFeature([ConnectedAccountObjectMetadata]),
|
ObjectMetadataRepositoryModule.forFeature([
|
||||||
|
ConnectedAccountWorkspaceEntity,
|
||||||
|
]),
|
||||||
],
|
],
|
||||||
providers: [GoogleAPIRefreshAccessTokenService],
|
providers: [GoogleAPIRefreshAccessTokenService],
|
||||||
exports: [GoogleAPIRefreshAccessTokenService],
|
exports: [GoogleAPIRefreshAccessTokenService],
|
||||||
|
|||||||
@ -5,13 +5,13 @@ import axios from 'axios';
|
|||||||
import { EnvironmentService } from 'src/engine/integrations/environment/environment.service';
|
import { EnvironmentService } from 'src/engine/integrations/environment/environment.service';
|
||||||
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 { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
import { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
||||||
import { ConnectedAccountObjectMetadata } from 'src/modules/connected-account/standard-objects/connected-account.object-metadata';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class GoogleAPIRefreshAccessTokenService {
|
export class GoogleAPIRefreshAccessTokenService {
|
||||||
constructor(
|
constructor(
|
||||||
private readonly environmentService: EnvironmentService,
|
private readonly environmentService: EnvironmentService,
|
||||||
@InjectObjectMetadataRepository(ConnectedAccountObjectMetadata)
|
@InjectObjectMetadataRepository(ConnectedAccountWorkspaceEntity)
|
||||||
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
|
|||||||
@ -3,9 +3,9 @@ import { Relation } from 'src/engine/workspace-manager/workspace-sync-metadata/i
|
|||||||
import { FieldMetadataType } from 'src/engine/metadata-modules/field-metadata/field-metadata.entity';
|
import { FieldMetadataType } from 'src/engine/metadata-modules/field-metadata/field-metadata.entity';
|
||||||
import { BLOCKLIST_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
import { BLOCKLIST_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
||||||
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
||||||
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-object.decorator';
|
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-entity.decorator';
|
||||||
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
||||||
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
||||||
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
||||||
@ -22,7 +22,7 @@ import { RelationMetadataType } from 'src/engine/metadata-modules/relation-metad
|
|||||||
})
|
})
|
||||||
@WorkspaceIsSystem()
|
@WorkspaceIsSystem()
|
||||||
@WorkspaceIsNotAuditLogged()
|
@WorkspaceIsNotAuditLogged()
|
||||||
export class BlocklistObjectMetadata extends BaseWorkspaceEntity {
|
export class BlocklistWorkspaceEntity extends BaseWorkspaceEntity {
|
||||||
@WorkspaceField({
|
@WorkspaceField({
|
||||||
standardId: BLOCKLIST_STANDARD_FIELD_IDS.handle,
|
standardId: BLOCKLIST_STANDARD_FIELD_IDS.handle,
|
||||||
type: FieldMetadataType.TEXT,
|
type: FieldMetadataType.TEXT,
|
||||||
@ -39,8 +39,8 @@ export class BlocklistObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'WorkspaceMember',
|
description: 'WorkspaceMember',
|
||||||
icon: 'IconCircleUser',
|
icon: 'IconCircleUser',
|
||||||
joinColumn: 'workspaceMemberId',
|
joinColumn: 'workspaceMemberId',
|
||||||
inverseSideTarget: () => WorkspaceMemberObjectMetadata,
|
inverseSideTarget: () => WorkspaceMemberWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'blocklist',
|
inverseSideFieldKey: 'blocklist',
|
||||||
})
|
})
|
||||||
workspaceMember: Relation<WorkspaceMemberObjectMetadata>;
|
workspaceMember: Relation<WorkspaceMemberWorkspaceEntity>;
|
||||||
}
|
}
|
||||||
@ -7,11 +7,11 @@ import {
|
|||||||
} from 'src/engine/metadata-modules/relation-metadata/relation-metadata.entity';
|
} from 'src/engine/metadata-modules/relation-metadata/relation-metadata.entity';
|
||||||
import { CONNECTED_ACCOUNT_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
import { CONNECTED_ACCOUNT_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
||||||
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
||||||
import { CalendarChannelObjectMetadata } from 'src/modules/calendar/standard-objects/calendar-channel.object-metadata';
|
import { CalendarChannelWorkspaceEntity } from 'src/modules/calendar/standard-objects/calendar-channel.workspace-entity';
|
||||||
import { MessageChannelObjectMetadata } from 'src/modules/messaging/standard-objects/message-channel.object-metadata';
|
import { MessageChannelWorkspaceEntity } from 'src/modules/messaging/standard-objects/message-channel.workspace-entity';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
||||||
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-object.decorator';
|
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-entity.decorator';
|
||||||
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
||||||
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
||||||
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
||||||
@ -32,7 +32,7 @@ export enum ConnectedAccountProvider {
|
|||||||
})
|
})
|
||||||
@WorkspaceIsSystem()
|
@WorkspaceIsSystem()
|
||||||
@WorkspaceIsNotAuditLogged()
|
@WorkspaceIsNotAuditLogged()
|
||||||
export class ConnectedAccountObjectMetadata extends BaseWorkspaceEntity {
|
export class ConnectedAccountWorkspaceEntity extends BaseWorkspaceEntity {
|
||||||
@WorkspaceField({
|
@WorkspaceField({
|
||||||
standardId: CONNECTED_ACCOUNT_STANDARD_FIELD_IDS.handle,
|
standardId: CONNECTED_ACCOUNT_STANDARD_FIELD_IDS.handle,
|
||||||
type: FieldMetadataType.TEXT,
|
type: FieldMetadataType.TEXT,
|
||||||
@ -95,10 +95,10 @@ export class ConnectedAccountObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'Account Owner',
|
description: 'Account Owner',
|
||||||
icon: 'IconUserCircle',
|
icon: 'IconUserCircle',
|
||||||
joinColumn: 'accountOwnerId',
|
joinColumn: 'accountOwnerId',
|
||||||
inverseSideTarget: () => WorkspaceMemberObjectMetadata,
|
inverseSideTarget: () => WorkspaceMemberWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'connectedAccounts',
|
inverseSideFieldKey: 'connectedAccounts',
|
||||||
})
|
})
|
||||||
accountOwner: Relation<WorkspaceMemberObjectMetadata>;
|
accountOwner: Relation<WorkspaceMemberWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: CONNECTED_ACCOUNT_STANDARD_FIELD_IDS.messageChannels,
|
standardId: CONNECTED_ACCOUNT_STANDARD_FIELD_IDS.messageChannels,
|
||||||
@ -106,10 +106,10 @@ export class ConnectedAccountObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
label: 'Message Channels',
|
label: 'Message Channels',
|
||||||
description: 'Message Channels',
|
description: 'Message Channels',
|
||||||
icon: 'IconMessage',
|
icon: 'IconMessage',
|
||||||
inverseSideTarget: () => MessageChannelObjectMetadata,
|
inverseSideTarget: () => MessageChannelWorkspaceEntity,
|
||||||
onDelete: RelationOnDeleteAction.CASCADE,
|
onDelete: RelationOnDeleteAction.CASCADE,
|
||||||
})
|
})
|
||||||
messageChannels: Relation<MessageChannelObjectMetadata[]>;
|
messageChannels: Relation<MessageChannelWorkspaceEntity[]>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: CONNECTED_ACCOUNT_STANDARD_FIELD_IDS.calendarChannels,
|
standardId: CONNECTED_ACCOUNT_STANDARD_FIELD_IDS.calendarChannels,
|
||||||
@ -117,8 +117,8 @@ export class ConnectedAccountObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
label: 'Calendar Channels',
|
label: 'Calendar Channels',
|
||||||
description: 'Calendar Channels',
|
description: 'Calendar Channels',
|
||||||
icon: 'IconCalendar',
|
icon: 'IconCalendar',
|
||||||
inverseSideTarget: () => CalendarChannelObjectMetadata,
|
inverseSideTarget: () => CalendarChannelWorkspaceEntity,
|
||||||
onDelete: RelationOnDeleteAction.CASCADE,
|
onDelete: RelationOnDeleteAction.CASCADE,
|
||||||
})
|
})
|
||||||
calendarChannels: Relation<CalendarChannelObjectMetadata[]>;
|
calendarChannels: Relation<CalendarChannelWorkspaceEntity[]>;
|
||||||
}
|
}
|
||||||
@ -4,12 +4,12 @@ import { FieldMetadataType } from 'src/engine/metadata-modules/field-metadata/fi
|
|||||||
import { FAVORITE_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
import { FAVORITE_STANDARD_FIELD_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-field-ids';
|
||||||
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
import { STANDARD_OBJECT_IDS } from 'src/engine/workspace-manager/workspace-sync-metadata/constants/standard-object-ids';
|
||||||
import { CustomWorkspaceEntity } from 'src/engine/twenty-orm/custom.workspace-entity';
|
import { CustomWorkspaceEntity } from 'src/engine/twenty-orm/custom.workspace-entity';
|
||||||
import { CompanyObjectMetadata } from 'src/modules/company/standard-objects/company.object-metadata';
|
import { CompanyWorkspaceEntity } from 'src/modules/company/standard-objects/company.workspace-entity';
|
||||||
import { OpportunityObjectMetadata } from 'src/modules/opportunity/standard-objects/opportunity.object-metadata';
|
import { OpportunityWorkspaceEntity } from 'src/modules/opportunity/standard-objects/opportunity.workspace-entity';
|
||||||
import { PersonObjectMetadata } from 'src/modules/person/standard-objects/person.object-metadata';
|
import { PersonWorkspaceEntity } from 'src/modules/person/standard-objects/person.workspace-entity';
|
||||||
import { WorkspaceMemberObjectMetadata } from 'src/modules/workspace-member/standard-objects/workspace-member.object-metadata';
|
import { WorkspaceMemberWorkspaceEntity } from 'src/modules/workspace-member/standard-objects/workspace-member.workspace-entity';
|
||||||
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
import { BaseWorkspaceEntity } from 'src/engine/twenty-orm/base.workspace-entity';
|
||||||
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-object.decorator';
|
import { WorkspaceEntity } from 'src/engine/twenty-orm/decorators/workspace-entity.decorator';
|
||||||
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
import { WorkspaceIsNotAuditLogged } from 'src/engine/twenty-orm/decorators/workspace-is-not-audit-logged.decorator';
|
||||||
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
import { WorkspaceIsSystem } from 'src/engine/twenty-orm/decorators/workspace-is-system.decorator';
|
||||||
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
import { WorkspaceField } from 'src/engine/twenty-orm/decorators/workspace-field.decorator';
|
||||||
@ -28,7 +28,7 @@ import { WorkspaceDynamicRelation } from 'src/engine/twenty-orm/decorators/works
|
|||||||
})
|
})
|
||||||
@WorkspaceIsNotAuditLogged()
|
@WorkspaceIsNotAuditLogged()
|
||||||
@WorkspaceIsSystem()
|
@WorkspaceIsSystem()
|
||||||
export class FavoriteObjectMetadata extends BaseWorkspaceEntity {
|
export class FavoriteWorkspaceEntity extends BaseWorkspaceEntity {
|
||||||
@WorkspaceField({
|
@WorkspaceField({
|
||||||
standardId: FAVORITE_STANDARD_FIELD_IDS.position,
|
standardId: FAVORITE_STANDARD_FIELD_IDS.position,
|
||||||
type: FieldMetadataType.NUMBER,
|
type: FieldMetadataType.NUMBER,
|
||||||
@ -48,9 +48,9 @@ export class FavoriteObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
icon: 'IconCircleUser',
|
icon: 'IconCircleUser',
|
||||||
joinColumn: 'workspaceMemberId',
|
joinColumn: 'workspaceMemberId',
|
||||||
inverseSideFieldKey: 'favorites',
|
inverseSideFieldKey: 'favorites',
|
||||||
inverseSideTarget: () => WorkspaceMemberObjectMetadata,
|
inverseSideTarget: () => WorkspaceMemberWorkspaceEntity,
|
||||||
})
|
})
|
||||||
workspaceMember: Relation<WorkspaceMemberObjectMetadata>;
|
workspaceMember: Relation<WorkspaceMemberWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: FAVORITE_STANDARD_FIELD_IDS.person,
|
standardId: FAVORITE_STANDARD_FIELD_IDS.person,
|
||||||
@ -59,11 +59,11 @@ export class FavoriteObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'Favorite person',
|
description: 'Favorite person',
|
||||||
icon: 'IconUser',
|
icon: 'IconUser',
|
||||||
joinColumn: 'personId',
|
joinColumn: 'personId',
|
||||||
inverseSideTarget: () => PersonObjectMetadata,
|
inverseSideTarget: () => PersonWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'favorites',
|
inverseSideFieldKey: 'favorites',
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
person: Relation<PersonObjectMetadata>;
|
person: Relation<PersonWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: FAVORITE_STANDARD_FIELD_IDS.company,
|
standardId: FAVORITE_STANDARD_FIELD_IDS.company,
|
||||||
@ -72,11 +72,11 @@ export class FavoriteObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'Favorite company',
|
description: 'Favorite company',
|
||||||
icon: 'IconBuildingSkyscraper',
|
icon: 'IconBuildingSkyscraper',
|
||||||
joinColumn: 'companyId',
|
joinColumn: 'companyId',
|
||||||
inverseSideTarget: () => CompanyObjectMetadata,
|
inverseSideTarget: () => CompanyWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'favorites',
|
inverseSideFieldKey: 'favorites',
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
company: Relation<CompanyObjectMetadata>;
|
company: Relation<CompanyWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceRelation({
|
@WorkspaceRelation({
|
||||||
standardId: FAVORITE_STANDARD_FIELD_IDS.opportunity,
|
standardId: FAVORITE_STANDARD_FIELD_IDS.opportunity,
|
||||||
@ -85,11 +85,11 @@ export class FavoriteObjectMetadata extends BaseWorkspaceEntity {
|
|||||||
description: 'Favorite opportunity',
|
description: 'Favorite opportunity',
|
||||||
icon: 'IconTargetArrow',
|
icon: 'IconTargetArrow',
|
||||||
joinColumn: 'opportunityId',
|
joinColumn: 'opportunityId',
|
||||||
inverseSideTarget: () => OpportunityObjectMetadata,
|
inverseSideTarget: () => OpportunityWorkspaceEntity,
|
||||||
inverseSideFieldKey: 'favorites',
|
inverseSideFieldKey: 'favorites',
|
||||||
})
|
})
|
||||||
@WorkspaceIsNullable()
|
@WorkspaceIsNullable()
|
||||||
opportunity: Relation<OpportunityObjectMetadata>;
|
opportunity: Relation<OpportunityWorkspaceEntity>;
|
||||||
|
|
||||||
@WorkspaceDynamicRelation({
|
@WorkspaceDynamicRelation({
|
||||||
type: RelationMetadataType.MANY_TO_ONE,
|
type: RelationMetadataType.MANY_TO_ONE,
|
||||||
@ -1,12 +1,14 @@
|
|||||||
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 { ConnectedAccountObjectMetadata } from 'src/modules/connected-account/standard-objects/connected-account.object-metadata';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
import { GmailFetchMessagesFromCacheCronCommand } from 'src/modules/messaging/crons/commands/gmail-fetch-messages-from-cache.cron.command';
|
import { GmailFetchMessagesFromCacheCronCommand } from 'src/modules/messaging/crons/commands/gmail-fetch-messages-from-cache.cron.command';
|
||||||
import { GmailPartialSyncCronCommand } from 'src/modules/messaging/crons/commands/gmail-partial-sync.cron.command';
|
import { GmailPartialSyncCronCommand } from 'src/modules/messaging/crons/commands/gmail-partial-sync.cron.command';
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
ObjectMetadataRepositoryModule.forFeature([ConnectedAccountObjectMetadata]),
|
ObjectMetadataRepositoryModule.forFeature([
|
||||||
|
ConnectedAccountWorkspaceEntity,
|
||||||
|
]),
|
||||||
],
|
],
|
||||||
providers: [
|
providers: [
|
||||||
GmailPartialSyncCronCommand,
|
GmailPartialSyncCronCommand,
|
||||||
|
|||||||
@ -9,7 +9,7 @@ import { Workspace } from 'src/engine/core-modules/workspace/workspace.entity';
|
|||||||
import { DataSourceEntity } from 'src/engine/metadata-modules/data-source/data-source.entity';
|
import { DataSourceEntity } from 'src/engine/metadata-modules/data-source/data-source.entity';
|
||||||
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 { MessageChannelRepository } from 'src/modules/messaging/repositories/message-channel.repository';
|
import { MessageChannelRepository } from 'src/modules/messaging/repositories/message-channel.repository';
|
||||||
import { MessageChannelObjectMetadata } from 'src/modules/messaging/standard-objects/message-channel.object-metadata';
|
import { MessageChannelWorkspaceEntity } from 'src/modules/messaging/standard-objects/message-channel.workspace-entity';
|
||||||
import { GmailFetchMessageContentFromCacheService } from 'src/modules/messaging/services/gmail-fetch-message-content-from-cache/gmail-fetch-message-content-from-cache.service';
|
import { GmailFetchMessageContentFromCacheService } from 'src/modules/messaging/services/gmail-fetch-message-content-from-cache/gmail-fetch-message-content-from-cache.service';
|
||||||
import { EnvironmentService } from 'src/engine/integrations/environment/environment.service';
|
import { EnvironmentService } from 'src/engine/integrations/environment/environment.service';
|
||||||
|
|
||||||
@ -22,7 +22,7 @@ export class GmailFetchMessagesFromCacheCronJob
|
|||||||
private readonly workspaceRepository: Repository<Workspace>,
|
private readonly workspaceRepository: Repository<Workspace>,
|
||||||
@InjectRepository(DataSourceEntity, 'metadata')
|
@InjectRepository(DataSourceEntity, 'metadata')
|
||||||
private readonly dataSourceRepository: Repository<DataSourceEntity>,
|
private readonly dataSourceRepository: Repository<DataSourceEntity>,
|
||||||
@InjectObjectMetadataRepository(MessageChannelObjectMetadata)
|
@InjectObjectMetadataRepository(MessageChannelWorkspaceEntity)
|
||||||
private readonly messageChannelRepository: MessageChannelRepository,
|
private readonly messageChannelRepository: MessageChannelRepository,
|
||||||
private readonly gmailFetchMessageContentFromCacheService: GmailFetchMessageContentFromCacheService,
|
private readonly gmailFetchMessageContentFromCacheService: GmailFetchMessageContentFromCacheService,
|
||||||
private readonly environmentService: EnvironmentService,
|
private readonly environmentService: EnvironmentService,
|
||||||
|
|||||||
@ -15,7 +15,7 @@ import { MessageQueue } from 'src/engine/integrations/message-queue/message-queu
|
|||||||
import { MessageQueueService } from 'src/engine/integrations/message-queue/services/message-queue.service';
|
import { MessageQueueService } from 'src/engine/integrations/message-queue/services/message-queue.service';
|
||||||
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 { MessageChannelRepository } from 'src/modules/messaging/repositories/message-channel.repository';
|
import { MessageChannelRepository } from 'src/modules/messaging/repositories/message-channel.repository';
|
||||||
import { MessageChannelObjectMetadata } from 'src/modules/messaging/standard-objects/message-channel.object-metadata';
|
import { MessageChannelWorkspaceEntity } from 'src/modules/messaging/standard-objects/message-channel.workspace-entity';
|
||||||
import { EnvironmentService } from 'src/engine/integrations/environment/environment.service';
|
import { EnvironmentService } from 'src/engine/integrations/environment/environment.service';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
@ -29,7 +29,7 @@ export class GmailPartialSyncCronJob implements MessageQueueJob<undefined> {
|
|||||||
private readonly dataSourceRepository: Repository<DataSourceEntity>,
|
private readonly dataSourceRepository: Repository<DataSourceEntity>,
|
||||||
@Inject(MessageQueue.messagingQueue)
|
@Inject(MessageQueue.messagingQueue)
|
||||||
private readonly messageQueueService: MessageQueueService,
|
private readonly messageQueueService: MessageQueueService,
|
||||||
@InjectObjectMetadataRepository(MessageChannelObjectMetadata)
|
@InjectObjectMetadataRepository(MessageChannelWorkspaceEntity)
|
||||||
private readonly messageChannelRepository: MessageChannelRepository,
|
private readonly messageChannelRepository: MessageChannelRepository,
|
||||||
private readonly environmentService: EnvironmentService,
|
private readonly environmentService: EnvironmentService,
|
||||||
) {}
|
) {}
|
||||||
|
|||||||
@ -8,13 +8,13 @@ import { ObjectMetadataRepositoryModule } from 'src/engine/object-metadata-repos
|
|||||||
import { GmailFetchMessagesFromCacheCronJob } from 'src/modules/messaging/crons/jobs/gmail-fetch-messages-from-cache.cron.job';
|
import { GmailFetchMessagesFromCacheCronJob } from 'src/modules/messaging/crons/jobs/gmail-fetch-messages-from-cache.cron.job';
|
||||||
import { GmailPartialSyncCronJob } from 'src/modules/messaging/crons/jobs/gmail-partial-sync.cron.job';
|
import { GmailPartialSyncCronJob } from 'src/modules/messaging/crons/jobs/gmail-partial-sync.cron.job';
|
||||||
import { GmailFetchMessageContentFromCacheModule } from 'src/modules/messaging/services/gmail-fetch-message-content-from-cache/gmail-fetch-message-content-from-cache.module';
|
import { GmailFetchMessageContentFromCacheModule } from 'src/modules/messaging/services/gmail-fetch-message-content-from-cache/gmail-fetch-message-content-from-cache.module';
|
||||||
import { MessageChannelObjectMetadata } from 'src/modules/messaging/standard-objects/message-channel.object-metadata';
|
import { MessageChannelWorkspaceEntity } from 'src/modules/messaging/standard-objects/message-channel.workspace-entity';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
TypeOrmModule.forFeature([Workspace, FeatureFlagEntity], 'core'),
|
TypeOrmModule.forFeature([Workspace, FeatureFlagEntity], 'core'),
|
||||||
TypeOrmModule.forFeature([DataSourceEntity], 'metadata'),
|
TypeOrmModule.forFeature([DataSourceEntity], 'metadata'),
|
||||||
ObjectMetadataRepositoryModule.forFeature([MessageChannelObjectMetadata]),
|
ObjectMetadataRepositoryModule.forFeature([MessageChannelWorkspaceEntity]),
|
||||||
GmailFetchMessageContentFromCacheModule,
|
GmailFetchMessageContentFromCacheModule,
|
||||||
],
|
],
|
||||||
providers: [
|
providers: [
|
||||||
|
|||||||
@ -4,12 +4,12 @@ import { MessageQueueJob } from 'src/engine/integrations/message-queue/interface
|
|||||||
|
|
||||||
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 { BlocklistRepository } from 'src/modules/connected-account/repositories/blocklist.repository';
|
import { BlocklistRepository } from 'src/modules/connected-account/repositories/blocklist.repository';
|
||||||
import { BlocklistObjectMetadata } from 'src/modules/connected-account/standard-objects/blocklist.object-metadata';
|
import { BlocklistWorkspaceEntity } from 'src/modules/connected-account/standard-objects/blocklist.workspace-entity';
|
||||||
import { MessageChannelMessageAssociationRepository } from 'src/modules/messaging/repositories/message-channel-message-association.repository';
|
import { MessageChannelMessageAssociationRepository } from 'src/modules/messaging/repositories/message-channel-message-association.repository';
|
||||||
import { MessageChannelRepository } from 'src/modules/messaging/repositories/message-channel.repository';
|
import { MessageChannelRepository } from 'src/modules/messaging/repositories/message-channel.repository';
|
||||||
import { ThreadCleanerService } from 'src/modules/messaging/services/thread-cleaner/thread-cleaner.service';
|
import { ThreadCleanerService } from 'src/modules/messaging/services/thread-cleaner/thread-cleaner.service';
|
||||||
import { MessageChannelMessageAssociationObjectMetadata } from 'src/modules/messaging/standard-objects/message-channel-message-association.object-metadata';
|
import { MessageChannelMessageAssociationWorkspaceEntity } from 'src/modules/messaging/standard-objects/message-channel-message-association.workspace-entity';
|
||||||
import { MessageChannelObjectMetadata } from 'src/modules/messaging/standard-objects/message-channel.object-metadata';
|
import { MessageChannelWorkspaceEntity } from 'src/modules/messaging/standard-objects/message-channel.workspace-entity';
|
||||||
|
|
||||||
export type BlocklistItemDeleteMessagesJobData = {
|
export type BlocklistItemDeleteMessagesJobData = {
|
||||||
workspaceId: string;
|
workspaceId: string;
|
||||||
@ -23,13 +23,13 @@ export class BlocklistItemDeleteMessagesJob
|
|||||||
private readonly logger = new Logger(BlocklistItemDeleteMessagesJob.name);
|
private readonly logger = new Logger(BlocklistItemDeleteMessagesJob.name);
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
@InjectObjectMetadataRepository(MessageChannelObjectMetadata)
|
@InjectObjectMetadataRepository(MessageChannelWorkspaceEntity)
|
||||||
private readonly messageChannelRepository: MessageChannelRepository,
|
private readonly messageChannelRepository: MessageChannelRepository,
|
||||||
@InjectObjectMetadataRepository(
|
@InjectObjectMetadataRepository(
|
||||||
MessageChannelMessageAssociationObjectMetadata,
|
MessageChannelMessageAssociationWorkspaceEntity,
|
||||||
)
|
)
|
||||||
private readonly messageChannelMessageAssociationRepository: MessageChannelMessageAssociationRepository,
|
private readonly messageChannelMessageAssociationRepository: MessageChannelMessageAssociationRepository,
|
||||||
@InjectObjectMetadataRepository(BlocklistObjectMetadata)
|
@InjectObjectMetadataRepository(BlocklistWorkspaceEntity)
|
||||||
private readonly blocklistRepository: BlocklistRepository,
|
private readonly blocklistRepository: BlocklistRepository,
|
||||||
private readonly threadCleanerService: ThreadCleanerService,
|
private readonly threadCleanerService: ThreadCleanerService,
|
||||||
) {}
|
) {}
|
||||||
|
|||||||
@ -4,7 +4,7 @@ import { MessageQueueJob } from 'src/engine/integrations/message-queue/interface
|
|||||||
|
|
||||||
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 { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
import { ConnectedAccountRepository } from 'src/modules/connected-account/repositories/connected-account.repository';
|
||||||
import { ConnectedAccountObjectMetadata } from 'src/modules/connected-account/standard-objects/connected-account.object-metadata';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
import { GmailFullSyncService } from 'src/modules/messaging/services/gmail-full-sync/gmail-full-sync.service';
|
import { GmailFullSyncService } from 'src/modules/messaging/services/gmail-full-sync/gmail-full-sync.service';
|
||||||
|
|
||||||
export type BlocklistReimportMessagesJobData = {
|
export type BlocklistReimportMessagesJobData = {
|
||||||
@ -20,7 +20,7 @@ export class BlocklistReimportMessagesJob
|
|||||||
private readonly logger = new Logger(BlocklistReimportMessagesJob.name);
|
private readonly logger = new Logger(BlocklistReimportMessagesJob.name);
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
@InjectObjectMetadataRepository(ConnectedAccountObjectMetadata)
|
@InjectObjectMetadataRepository(ConnectedAccountWorkspaceEntity)
|
||||||
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
private readonly connectedAccountRepository: ConnectedAccountRepository,
|
||||||
private readonly gmailFullSyncService: GmailFullSyncService,
|
private readonly gmailFullSyncService: GmailFullSyncService,
|
||||||
) {}
|
) {}
|
||||||
|
|||||||
@ -6,8 +6,8 @@ import { InjectObjectMetadataRepository } from 'src/engine/object-metadata-repos
|
|||||||
import { CreateCompanyAndContactService } from 'src/modules/connected-account/auto-companies-and-contacts-creation/services/create-company-and-contact.service';
|
import { CreateCompanyAndContactService } from 'src/modules/connected-account/auto-companies-and-contacts-creation/services/create-company-and-contact.service';
|
||||||
import { MessageChannelRepository } from 'src/modules/messaging/repositories/message-channel.repository';
|
import { MessageChannelRepository } from 'src/modules/messaging/repositories/message-channel.repository';
|
||||||
import { MessageParticipantRepository } from 'src/modules/messaging/repositories/message-participant.repository';
|
import { MessageParticipantRepository } from 'src/modules/messaging/repositories/message-participant.repository';
|
||||||
import { MessageChannelObjectMetadata } from 'src/modules/messaging/standard-objects/message-channel.object-metadata';
|
import { MessageChannelWorkspaceEntity } from 'src/modules/messaging/standard-objects/message-channel.workspace-entity';
|
||||||
import { MessageParticipantObjectMetadata } from 'src/modules/messaging/standard-objects/message-participant.object-metadata';
|
import { MessageParticipantWorkspaceEntity } from 'src/modules/messaging/standard-objects/message-participant.workspace-entity';
|
||||||
|
|
||||||
export type MessagingCreateCompanyAndContactAfterSyncJobData = {
|
export type MessagingCreateCompanyAndContactAfterSyncJobData = {
|
||||||
workspaceId: string;
|
workspaceId: string;
|
||||||
@ -23,9 +23,9 @@ export class MessagingCreateCompanyAndContactAfterSyncJob
|
|||||||
);
|
);
|
||||||
constructor(
|
constructor(
|
||||||
private readonly createCompanyAndContactService: CreateCompanyAndContactService,
|
private readonly createCompanyAndContactService: CreateCompanyAndContactService,
|
||||||
@InjectObjectMetadataRepository(MessageChannelObjectMetadata)
|
@InjectObjectMetadataRepository(MessageChannelWorkspaceEntity)
|
||||||
private readonly messageChannelService: MessageChannelRepository,
|
private readonly messageChannelService: MessageChannelRepository,
|
||||||
@InjectObjectMetadataRepository(MessageParticipantObjectMetadata)
|
@InjectObjectMetadataRepository(MessageParticipantWorkspaceEntity)
|
||||||
private readonly messageParticipantRepository: MessageParticipantRepository,
|
private readonly messageParticipantRepository: MessageParticipantRepository,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
|
|||||||
@ -3,8 +3,8 @@ 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 { AutoCompaniesAndContactsCreationModule } from 'src/modules/connected-account/auto-companies-and-contacts-creation/auto-companies-and-contacts-creation.module';
|
import { AutoCompaniesAndContactsCreationModule } from 'src/modules/connected-account/auto-companies-and-contacts-creation/auto-companies-and-contacts-creation.module';
|
||||||
import { GoogleAPIRefreshAccessTokenModule } from 'src/modules/connected-account/services/google-api-refresh-access-token/google-api-refresh-access-token.module';
|
import { GoogleAPIRefreshAccessTokenModule } from 'src/modules/connected-account/services/google-api-refresh-access-token/google-api-refresh-access-token.module';
|
||||||
import { BlocklistObjectMetadata } from 'src/modules/connected-account/standard-objects/blocklist.object-metadata';
|
import { BlocklistWorkspaceEntity } from 'src/modules/connected-account/standard-objects/blocklist.workspace-entity';
|
||||||
import { ConnectedAccountObjectMetadata } from 'src/modules/connected-account/standard-objects/connected-account.object-metadata';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
import { BlocklistItemDeleteMessagesJob } from 'src/modules/messaging/jobs/blocklist-item-delete-messages.job';
|
import { BlocklistItemDeleteMessagesJob } from 'src/modules/messaging/jobs/blocklist-item-delete-messages.job';
|
||||||
import { BlocklistReimportMessagesJob } from 'src/modules/messaging/jobs/blocklist-reimport-messages.job';
|
import { BlocklistReimportMessagesJob } from 'src/modules/messaging/jobs/blocklist-reimport-messages.job';
|
||||||
import { DeleteConnectedAccountAssociatedMessagingDataJob } from 'src/modules/messaging/jobs/delete-connected-account-associated-messaging-data.job';
|
import { DeleteConnectedAccountAssociatedMessagingDataJob } from 'src/modules/messaging/jobs/delete-connected-account-associated-messaging-data.job';
|
||||||
@ -14,18 +14,18 @@ import { MessagingCreateCompanyAndContactAfterSyncJob } from 'src/modules/messag
|
|||||||
import { GmailFullSyncModule } from 'src/modules/messaging/services/gmail-full-sync/gmail-full-sync.module';
|
import { GmailFullSyncModule } from 'src/modules/messaging/services/gmail-full-sync/gmail-full-sync.module';
|
||||||
import { GmailPartialSyncModule } from 'src/modules/messaging/services/gmail-partial-sync/gmail-partial-sync.module';
|
import { GmailPartialSyncModule } from 'src/modules/messaging/services/gmail-partial-sync/gmail-partial-sync.module';
|
||||||
import { ThreadCleanerModule } from 'src/modules/messaging/services/thread-cleaner/thread-cleaner.module';
|
import { ThreadCleanerModule } from 'src/modules/messaging/services/thread-cleaner/thread-cleaner.module';
|
||||||
import { MessageChannelMessageAssociationObjectMetadata } from 'src/modules/messaging/standard-objects/message-channel-message-association.object-metadata';
|
import { MessageChannelMessageAssociationWorkspaceEntity } from 'src/modules/messaging/standard-objects/message-channel-message-association.workspace-entity';
|
||||||
import { MessageChannelObjectMetadata } from 'src/modules/messaging/standard-objects/message-channel.object-metadata';
|
import { MessageChannelWorkspaceEntity } from 'src/modules/messaging/standard-objects/message-channel.workspace-entity';
|
||||||
import { MessageParticipantObjectMetadata } from 'src/modules/messaging/standard-objects/message-participant.object-metadata';
|
import { MessageParticipantWorkspaceEntity } from 'src/modules/messaging/standard-objects/message-participant.workspace-entity';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
ObjectMetadataRepositoryModule.forFeature([
|
ObjectMetadataRepositoryModule.forFeature([
|
||||||
ConnectedAccountObjectMetadata,
|
ConnectedAccountWorkspaceEntity,
|
||||||
MessageChannelObjectMetadata,
|
MessageChannelWorkspaceEntity,
|
||||||
MessageParticipantObjectMetadata,
|
MessageParticipantWorkspaceEntity,
|
||||||
MessageChannelMessageAssociationObjectMetadata,
|
MessageChannelMessageAssociationWorkspaceEntity,
|
||||||
BlocklistObjectMetadata,
|
BlocklistWorkspaceEntity,
|
||||||
]),
|
]),
|
||||||
GmailFullSyncModule,
|
GmailFullSyncModule,
|
||||||
GmailPartialSyncModule,
|
GmailPartialSyncModule,
|
||||||
|
|||||||
@ -5,7 +5,7 @@ import { ObjectRecordCreateEvent } from 'src/engine/integrations/event-emitter/t
|
|||||||
import { ObjectRecordDeleteEvent } from 'src/engine/integrations/event-emitter/types/object-record-delete.event';
|
import { ObjectRecordDeleteEvent } from 'src/engine/integrations/event-emitter/types/object-record-delete.event';
|
||||||
import { MessageQueue } from 'src/engine/integrations/message-queue/message-queue.constants';
|
import { MessageQueue } from 'src/engine/integrations/message-queue/message-queue.constants';
|
||||||
import { MessageQueueService } from 'src/engine/integrations/message-queue/services/message-queue.service';
|
import { MessageQueueService } from 'src/engine/integrations/message-queue/services/message-queue.service';
|
||||||
import { BlocklistObjectMetadata } from 'src/modules/connected-account/standard-objects/blocklist.object-metadata';
|
import { BlocklistWorkspaceEntity } from 'src/modules/connected-account/standard-objects/blocklist.workspace-entity';
|
||||||
import {
|
import {
|
||||||
BlocklistReimportMessagesJob,
|
BlocklistReimportMessagesJob,
|
||||||
BlocklistReimportMessagesJobData,
|
BlocklistReimportMessagesJobData,
|
||||||
@ -25,7 +25,7 @@ export class MessagingBlocklistListener {
|
|||||||
|
|
||||||
@OnEvent('blocklist.created')
|
@OnEvent('blocklist.created')
|
||||||
async handleCreatedEvent(
|
async handleCreatedEvent(
|
||||||
payload: ObjectRecordCreateEvent<BlocklistObjectMetadata>,
|
payload: ObjectRecordCreateEvent<BlocklistWorkspaceEntity>,
|
||||||
) {
|
) {
|
||||||
await this.messageQueueService.add<BlocklistItemDeleteMessagesJobData>(
|
await this.messageQueueService.add<BlocklistItemDeleteMessagesJobData>(
|
||||||
BlocklistItemDeleteMessagesJob.name,
|
BlocklistItemDeleteMessagesJob.name,
|
||||||
@ -38,7 +38,7 @@ export class MessagingBlocklistListener {
|
|||||||
|
|
||||||
@OnEvent('blocklist.deleted')
|
@OnEvent('blocklist.deleted')
|
||||||
async handleDeletedEvent(
|
async handleDeletedEvent(
|
||||||
payload: ObjectRecordDeleteEvent<BlocklistObjectMetadata>,
|
payload: ObjectRecordDeleteEvent<BlocklistWorkspaceEntity>,
|
||||||
) {
|
) {
|
||||||
await this.messageQueueService.add<BlocklistReimportMessagesJobData>(
|
await this.messageQueueService.add<BlocklistReimportMessagesJobData>(
|
||||||
BlocklistReimportMessagesJob.name,
|
BlocklistReimportMessagesJob.name,
|
||||||
@ -52,7 +52,7 @@ export class MessagingBlocklistListener {
|
|||||||
|
|
||||||
@OnEvent('blocklist.updated')
|
@OnEvent('blocklist.updated')
|
||||||
async handleUpdatedEvent(
|
async handleUpdatedEvent(
|
||||||
payload: ObjectRecordUpdateEvent<BlocklistObjectMetadata>,
|
payload: ObjectRecordUpdateEvent<BlocklistWorkspaceEntity>,
|
||||||
) {
|
) {
|
||||||
await this.messageQueueService.add<BlocklistItemDeleteMessagesJobData>(
|
await this.messageQueueService.add<BlocklistItemDeleteMessagesJobData>(
|
||||||
BlocklistItemDeleteMessagesJob.name,
|
BlocklistItemDeleteMessagesJob.name,
|
||||||
|
|||||||
@ -15,7 +15,7 @@ import {
|
|||||||
DeleteConnectedAccountAssociatedMessagingDataJobData,
|
DeleteConnectedAccountAssociatedMessagingDataJobData,
|
||||||
DeleteConnectedAccountAssociatedMessagingDataJob,
|
DeleteConnectedAccountAssociatedMessagingDataJob,
|
||||||
} from 'src/modules/messaging/jobs/delete-connected-account-associated-messaging-data.job';
|
} from 'src/modules/messaging/jobs/delete-connected-account-associated-messaging-data.job';
|
||||||
import { ConnectedAccountObjectMetadata } from 'src/modules/connected-account/standard-objects/connected-account.object-metadata';
|
import { ConnectedAccountWorkspaceEntity } from 'src/modules/connected-account/standard-objects/connected-account.workspace-entity';
|
||||||
import { FeatureFlagEntity } from 'src/engine/core-modules/feature-flag/feature-flag.entity';
|
import { FeatureFlagEntity } from 'src/engine/core-modules/feature-flag/feature-flag.entity';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
@ -31,7 +31,7 @@ export class MessagingConnectedAccountListener {
|
|||||||
|
|
||||||
@OnEvent('connectedAccount.deleted')
|
@OnEvent('connectedAccount.deleted')
|
||||||
async handleDeletedEvent(
|
async handleDeletedEvent(
|
||||||
payload: ObjectRecordDeleteEvent<ConnectedAccountObjectMetadata>,
|
payload: ObjectRecordDeleteEvent<ConnectedAccountWorkspaceEntity>,
|
||||||
) {
|
) {
|
||||||
await this.messageQueueService.add<DeleteConnectedAccountAssociatedMessagingDataJobData>(
|
await this.messageQueueService.add<DeleteConnectedAccountAssociatedMessagingDataJobData>(
|
||||||
DeleteConnectedAccountAssociatedMessagingDataJob.name,
|
DeleteConnectedAccountAssociatedMessagingDataJob.name,
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user