Fix mutations with custom objects (#8688)
This commit is contained in:
@ -14,6 +14,7 @@ import { ProcessNestedRelationsHelper } from 'src/engine/api/graphql/graphql-que
|
|||||||
import { assertIsValidUuid } from 'src/engine/api/graphql/workspace-query-runner/utils/assert-is-valid-uuid.util';
|
import { assertIsValidUuid } from 'src/engine/api/graphql/workspace-query-runner/utils/assert-is-valid-uuid.util';
|
||||||
import { assertMutationNotOnRemoteObject } from 'src/engine/metadata-modules/object-metadata/utils/assert-mutation-not-on-remote-object.util';
|
import { assertMutationNotOnRemoteObject } from 'src/engine/metadata-modules/object-metadata/utils/assert-mutation-not-on-remote-object.util';
|
||||||
import { formatResult } from 'src/engine/twenty-orm/utils/format-result.util';
|
import { formatResult } from 'src/engine/twenty-orm/utils/format-result.util';
|
||||||
|
import { computeTableName } from 'src/engine/utils/compute-table-name.util';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class GraphqlQueryDeleteManyResolverService extends GraphqlQueryBaseResolverService<
|
export class GraphqlQueryDeleteManyResolverService extends GraphqlQueryBaseResolverService<
|
||||||
@ -30,9 +31,14 @@ export class GraphqlQueryDeleteManyResolverService extends GraphqlQueryBaseResol
|
|||||||
objectMetadataItemWithFieldMaps.nameSingular,
|
objectMetadataItemWithFieldMaps.nameSingular,
|
||||||
);
|
);
|
||||||
|
|
||||||
|
const tableName = computeTableName(
|
||||||
|
objectMetadataItemWithFieldMaps.nameSingular,
|
||||||
|
objectMetadataItemWithFieldMaps.isCustom,
|
||||||
|
);
|
||||||
|
|
||||||
executionArgs.graphqlQueryParser.applyFilterToBuilder(
|
executionArgs.graphqlQueryParser.applyFilterToBuilder(
|
||||||
queryBuilder,
|
queryBuilder,
|
||||||
objectMetadataItemWithFieldMaps.nameSingular,
|
tableName,
|
||||||
executionArgs.args.filter,
|
executionArgs.args.filter,
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|||||||
@ -12,6 +12,7 @@ import { QUERY_MAX_RECORDS } from 'src/engine/api/graphql/graphql-query-runner/c
|
|||||||
import { ObjectRecordsToGraphqlConnectionHelper } from 'src/engine/api/graphql/graphql-query-runner/helpers/object-records-to-graphql-connection.helper';
|
import { ObjectRecordsToGraphqlConnectionHelper } from 'src/engine/api/graphql/graphql-query-runner/helpers/object-records-to-graphql-connection.helper';
|
||||||
import { ProcessNestedRelationsHelper } from 'src/engine/api/graphql/graphql-query-runner/helpers/process-nested-relations.helper';
|
import { ProcessNestedRelationsHelper } from 'src/engine/api/graphql/graphql-query-runner/helpers/process-nested-relations.helper';
|
||||||
import { formatResult } from 'src/engine/twenty-orm/utils/format-result.util';
|
import { formatResult } from 'src/engine/twenty-orm/utils/format-result.util';
|
||||||
|
import { computeTableName } from 'src/engine/utils/compute-table-name.util';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class GraphqlQueryDestroyManyResolverService extends GraphqlQueryBaseResolverService<
|
export class GraphqlQueryDestroyManyResolverService extends GraphqlQueryBaseResolverService<
|
||||||
@ -28,9 +29,14 @@ export class GraphqlQueryDestroyManyResolverService extends GraphqlQueryBaseReso
|
|||||||
objectMetadataItemWithFieldMaps.nameSingular,
|
objectMetadataItemWithFieldMaps.nameSingular,
|
||||||
);
|
);
|
||||||
|
|
||||||
|
const tableName = computeTableName(
|
||||||
|
objectMetadataItemWithFieldMaps.nameSingular,
|
||||||
|
objectMetadataItemWithFieldMaps.isCustom,
|
||||||
|
);
|
||||||
|
|
||||||
executionArgs.graphqlQueryParser.applyFilterToBuilder(
|
executionArgs.graphqlQueryParser.applyFilterToBuilder(
|
||||||
queryBuilder,
|
queryBuilder,
|
||||||
objectMetadataItemWithFieldMaps.nameSingular,
|
tableName,
|
||||||
executionArgs.args.filter,
|
executionArgs.args.filter,
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|||||||
@ -14,6 +14,7 @@ import { ProcessNestedRelationsHelper } from 'src/engine/api/graphql/graphql-que
|
|||||||
import { assertIsValidUuid } from 'src/engine/api/graphql/workspace-query-runner/utils/assert-is-valid-uuid.util';
|
import { assertIsValidUuid } from 'src/engine/api/graphql/workspace-query-runner/utils/assert-is-valid-uuid.util';
|
||||||
import { assertMutationNotOnRemoteObject } from 'src/engine/metadata-modules/object-metadata/utils/assert-mutation-not-on-remote-object.util';
|
import { assertMutationNotOnRemoteObject } from 'src/engine/metadata-modules/object-metadata/utils/assert-mutation-not-on-remote-object.util';
|
||||||
import { formatResult } from 'src/engine/twenty-orm/utils/format-result.util';
|
import { formatResult } from 'src/engine/twenty-orm/utils/format-result.util';
|
||||||
|
import { computeTableName } from 'src/engine/utils/compute-table-name.util';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class GraphqlQueryRestoreManyResolverService extends GraphqlQueryBaseResolverService<
|
export class GraphqlQueryRestoreManyResolverService extends GraphqlQueryBaseResolverService<
|
||||||
@ -30,9 +31,14 @@ export class GraphqlQueryRestoreManyResolverService extends GraphqlQueryBaseReso
|
|||||||
objectMetadataItemWithFieldMaps.nameSingular,
|
objectMetadataItemWithFieldMaps.nameSingular,
|
||||||
);
|
);
|
||||||
|
|
||||||
|
const tableName = computeTableName(
|
||||||
|
objectMetadataItemWithFieldMaps.nameSingular,
|
||||||
|
objectMetadataItemWithFieldMaps.isCustom,
|
||||||
|
);
|
||||||
|
|
||||||
executionArgs.graphqlQueryParser.applyFilterToBuilder(
|
executionArgs.graphqlQueryParser.applyFilterToBuilder(
|
||||||
queryBuilder,
|
queryBuilder,
|
||||||
objectMetadataItemWithFieldMaps.nameSingular,
|
tableName,
|
||||||
executionArgs.args.filter,
|
executionArgs.args.filter,
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|||||||
@ -15,6 +15,7 @@ import { assertIsValidUuid } from 'src/engine/api/graphql/workspace-query-runner
|
|||||||
import { assertMutationNotOnRemoteObject } from 'src/engine/metadata-modules/object-metadata/utils/assert-mutation-not-on-remote-object.util';
|
import { assertMutationNotOnRemoteObject } from 'src/engine/metadata-modules/object-metadata/utils/assert-mutation-not-on-remote-object.util';
|
||||||
import { formatData } from 'src/engine/twenty-orm/utils/format-data.util';
|
import { formatData } from 'src/engine/twenty-orm/utils/format-data.util';
|
||||||
import { formatResult } from 'src/engine/twenty-orm/utils/format-result.util';
|
import { formatResult } from 'src/engine/twenty-orm/utils/format-result.util';
|
||||||
|
import { computeTableName } from 'src/engine/utils/compute-table-name.util';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class GraphqlQueryUpdateManyResolverService extends GraphqlQueryBaseResolverService<
|
export class GraphqlQueryUpdateManyResolverService extends GraphqlQueryBaseResolverService<
|
||||||
@ -31,14 +32,14 @@ export class GraphqlQueryUpdateManyResolverService extends GraphqlQueryBaseResol
|
|||||||
objectMetadataItemWithFieldMaps.nameSingular,
|
objectMetadataItemWithFieldMaps.nameSingular,
|
||||||
);
|
);
|
||||||
|
|
||||||
|
const existingRecordsBuilder = queryBuilder.clone();
|
||||||
|
|
||||||
executionArgs.graphqlQueryParser.applyFilterToBuilder(
|
executionArgs.graphqlQueryParser.applyFilterToBuilder(
|
||||||
queryBuilder,
|
existingRecordsBuilder,
|
||||||
objectMetadataItemWithFieldMaps.nameSingular,
|
objectMetadataItemWithFieldMaps.nameSingular,
|
||||||
executionArgs.args.filter,
|
executionArgs.args.filter,
|
||||||
);
|
);
|
||||||
|
|
||||||
const existingRecordsBuilder = queryBuilder.clone();
|
|
||||||
|
|
||||||
const existingRecords = await existingRecordsBuilder.getMany();
|
const existingRecords = await existingRecordsBuilder.getMany();
|
||||||
|
|
||||||
const formattedExistingRecords = formatResult<ObjectRecord[]>(
|
const formattedExistingRecords = formatResult<ObjectRecord[]>(
|
||||||
@ -47,6 +48,17 @@ export class GraphqlQueryUpdateManyResolverService extends GraphqlQueryBaseResol
|
|||||||
objectMetadataMaps,
|
objectMetadataMaps,
|
||||||
);
|
);
|
||||||
|
|
||||||
|
const tableName = computeTableName(
|
||||||
|
objectMetadataItemWithFieldMaps.nameSingular,
|
||||||
|
objectMetadataItemWithFieldMaps.isCustom,
|
||||||
|
);
|
||||||
|
|
||||||
|
executionArgs.graphqlQueryParser.applyFilterToBuilder(
|
||||||
|
queryBuilder,
|
||||||
|
tableName,
|
||||||
|
executionArgs.args.filter,
|
||||||
|
);
|
||||||
|
|
||||||
const data = formatData(
|
const data = formatData(
|
||||||
executionArgs.args.data,
|
executionArgs.args.data,
|
||||||
objectMetadataItemWithFieldMaps,
|
objectMetadataItemWithFieldMaps,
|
||||||
|
|||||||
Reference in New Issue
Block a user