12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- "use strict";
- Object.defineProperty(exports, "__esModule", { value: true });
- exports.DistinctOperation = void 0;
- const error_1 = require("../error");
- const utils_1 = require("../utils");
- const command_1 = require("./command");
- const operation_1 = require("./operation");
- /**
- * Return a list of distinct values for the given key across a collection.
- * @internal
- */
- class DistinctOperation extends command_1.CommandOperation {
- /**
- * Construct a Distinct operation.
- *
- * @param collection - Collection instance.
- * @param key - Field of the document to find distinct values for.
- * @param query - The query for filtering the set of documents to which we apply the distinct filter.
- * @param options - Optional settings. See Collection.prototype.distinct for a list of options.
- */
- constructor(collection, key, query, options) {
- super(collection, options);
- this.options = options !== null && options !== void 0 ? options : {};
- this.collection = collection;
- this.key = key;
- this.query = query;
- }
- execute(server, session, callback) {
- const coll = this.collection;
- const key = this.key;
- const query = this.query;
- const options = this.options;
- // Distinct command
- const cmd = {
- distinct: coll.collectionName,
- key: key,
- query: query
- };
- // Add maxTimeMS if defined
- if (typeof options.maxTimeMS === 'number') {
- cmd.maxTimeMS = options.maxTimeMS;
- }
- // Do we have a readConcern specified
- (0, utils_1.decorateWithReadConcern)(cmd, coll, options);
- // Have we specified collation
- try {
- (0, utils_1.decorateWithCollation)(cmd, coll, options);
- }
- catch (err) {
- return callback(err);
- }
- if (this.explain && (0, utils_1.maxWireVersion)(server) < 4) {
- callback(new error_1.MongoCompatibilityError(`Server ${server.name} does not support explain on distinct`));
- return;
- }
- super.executeCommand(server, session, cmd, (err, result) => {
- if (err) {
- callback(err);
- return;
- }
- callback(undefined, this.explain ? result : result.values);
- });
- }
- }
- exports.DistinctOperation = DistinctOperation;
- (0, operation_1.defineAspects)(DistinctOperation, [operation_1.Aspect.READ_OPERATION, operation_1.Aspect.RETRYABLE, operation_1.Aspect.EXPLAINABLE]);
- //# sourceMappingURL=distinct.js.map
|