UNPKG

@forestadmin/datasource-toolkit

Version:
121 lines 16.2 kB
"use strict"; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); const schema_1 = __importDefault(require("./schema")); const factory_1 = __importDefault(require("../interfaces/query/condition-tree/factory")); const factory_2 = __importDefault(require("../interfaces/query/filter/factory")); const unpaginated_1 = __importDefault(require("../interfaces/query/filter/unpaginated")); const projection_1 = __importDefault(require("../interfaces/query/projection")); class CollectionUtils { static getFieldSchema(collection, path) { const { fields } = collection.schema; const index = path.indexOf(':'); if (index === -1) { schema_1.default.throwIfMissingField(collection.schema, path, collection.name); return fields[path]; } const associationName = path.substring(0, index); const schema = schema_1.default.getRelation(collection.schema, associationName, collection.name); if (schema.type !== 'ManyToOne' && schema.type !== 'OneToOne') { throw new Error(`Unexpected field type '${schema.type}': '${collection.name}.${associationName}'`); } return CollectionUtils.getFieldSchema(collection.dataSource.getCollection(schema.foreignCollection), path.substring(index + 1)); } static getInverseRelation(collection, relationName) { const relation = schema_1.default.getRelation(collection.schema, relationName, collection.name); const foreignCollection = collection.dataSource.getCollection(relation.foreignCollection); const inverse = Object.entries(foreignCollection.schema.fields).find(([, field]) => { const isManyToManyInverse = field.type === 'ManyToMany' && relation.type === 'ManyToMany' && field.originKey === relation.foreignKey && field.throughCollection === relation.throughCollection && field.foreignKey === relation.originKey; const isManyToOneInverse = field.type === 'ManyToOne' && (relation.type === 'OneToMany' || relation.type === 'OneToOne') && field.foreignKey === relation.originKey; const isOtherInverse = (field.type === 'OneToMany' || field.type === 'OneToOne') && relation.type === 'ManyToOne' && field.originKey === relation.foreignKey; return ((isManyToManyInverse || isManyToOneInverse || isOtherInverse) && field.foreignCollection === collection.name); }); return inverse ? inverse[0] : null; } static getThroughOrigin(collection, relationName) { const relation = schema_1.default.getRelation(collection.schema, relationName, collection.name); if (relation.type !== 'ManyToMany') throw new Error('Relation must be many to many'); const throughCollection = collection.dataSource.getCollection(relation.throughCollection); const originRelation = Object.entries(throughCollection.schema.fields).find(([, field]) => { return (field.type === 'ManyToOne' && field.foreignCollection === collection.name && field.foreignKey === relation.originKey && field.foreignKeyTarget === relation.originKeyTarget); }); return originRelation ? originRelation[0] : null; } static getThroughTarget(collection, relationName) { const relation = schema_1.default.getRelation(collection.schema, relationName, collection.name); if (relation.type !== 'ManyToMany') throw new Error('Relation must be many to many'); const throughCollection = collection.dataSource.getCollection(relation.throughCollection); const foreignRelation = Object.entries(throughCollection.schema.fields).find(([, field]) => { return (field.type === 'ManyToOne' && field.foreignCollection === relation.foreignCollection && field.foreignKey === relation.foreignKey && field.foreignKeyTarget === relation.foreignKeyTarget); }); return foreignRelation ? foreignRelation[0] : null; } static async listRelation(collection, id, relationName, caller, foreignFilter, projection) { const relation = schema_1.default.getToManyRelation(collection.schema, relationName); // Optimization for many to many when there is not search/segment. if (relation.type === 'ManyToMany' && foreignFilter.isNestable) { const foreignRelation = CollectionUtils.getThroughTarget(collection, relationName); if (foreignRelation) { const through = collection.dataSource.getCollection(relation.throughCollection); const records = await through.list(caller, await factory_2.default.makeThroughFilter(collection, id, relationName, caller, foreignFilter), projection.nest(foreignRelation)); // Exclude null records, which may happen in case of a broken relation. // This happens on databases that don't support enforced foreign keys (e.g. Mongo) return records.map(r => r[foreignRelation]).filter(Boolean); } } // Otherwise fetch the target table (this works with both relation types) return collection.dataSource .getCollection(relation.foreignCollection) .list(caller, await factory_2.default.makeForeignFilter(collection, id, relationName, caller, foreignFilter), projection); } static async aggregateRelation(collection, id, relationName, caller, foreignFilter, aggregation, limit) { const relation = schema_1.default.getToManyRelation(collection.schema, relationName); // Optimization for many to many when there is not search/segment (saves one query) if (relation.type === 'ManyToMany' && foreignFilter.isNestable) { const foreignRelation = CollectionUtils.getThroughTarget(collection, relationName); if (foreignRelation) { const through = collection.dataSource.getCollection(relation.throughCollection); const records = await through.aggregate(caller, await factory_2.default.makeThroughFilter(collection, id, relationName, caller, foreignFilter), aggregation.nest(foreignRelation), limit); // unnest aggregation result return records.map(({ value, group }) => ({ value, group: Object.entries(group) .map(([key, v]) => [key.substring(key.indexOf(':') + 1), v]) .reduce((memo, [key, v]) => ({ ...memo, [key]: v }), {}), })); } } // Otherwise fetch the target table (this works with both relation types) return collection.dataSource .getCollection(relation.foreignCollection) .aggregate(caller, await factory_2.default.makeForeignFilter(collection, id, relationName, caller, foreignFilter), aggregation, limit); } static async getValue(collection, caller, id, field) { const index = schema_1.default.getPrimaryKeys(collection.schema).indexOf(field); if (index !== -1) return id[index]; const [record] = await collection.list(caller, new unpaginated_1.default({ conditionTree: factory_1.default.matchIds(collection.schema, [id]) }), new projection_1.default(field)); return record[field]; } } exports.default = CollectionUtils; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collection.js","sourceRoot":"","sources":["../../../src/utils/collection.ts"],"names":[],"mappings":"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"}