"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.ValidateCollectionOperation = void 0; const error_1 = require("../error"); const command_1 = require("./command"); /** @internal */ class ValidateCollectionOperation extends command_1.CommandOperation { constructor(admin, collectionName, options) { // Decorate command with extra options const command = { validate: collectionName }; const keys = Object.keys(options); for (let i = 0; i < keys.length; i++) { if (Object.prototype.hasOwnProperty.call(options, keys[i]) && keys[i] !== 'session') { command[keys[i]] = options[keys[i]]; } } super(admin.s.db, options); this.options = options; this.command = command; this.collectionName = collectionName; } execute(server, session, callback) { const collectionName = this.collectionName; super.executeCommand(server, session, this.command, (err, doc) => { if (err != null) return callback(err); // TODO(NODE-3483): Replace these with MongoUnexpectedServerResponseError if (doc.ok === 0) return callback(new error_1.MongoRuntimeError('Error with validate command')); if (doc.result != null && typeof doc.result !== 'string') return callback(new error_1.MongoRuntimeError('Error with validation data')); if (doc.result != null && doc.result.match(/exception|corrupt/) != null) return callback(new error_1.MongoRuntimeError(`Invalid collection ${collectionName}`)); if (doc.valid != null && !doc.valid) return callback(new error_1.MongoRuntimeError(`Invalid collection ${collectionName}`)); return callback(undefined, doc); }); } } exports.ValidateCollectionOperation = ValidateCollectionOperation; //# sourceMappingURL=validate_collection.js.map