Your IP : 216.73.217.13


Current Path : /home/deltalab/PMS/sms-connector/node_modules/graphql-compose-mongoose/lib/resolvers/
Upload File :
Current File : //home/deltalab/PMS/sms-connector/node_modules/graphql-compose-mongoose/lib/resolvers/updateMany.js

"use strict";
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
    return new (P || (P = Promise))(function (resolve, reject) {
        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
        function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
        step((generator = generator.apply(thisArg, _arguments || [])).next());
    });
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.updateMany = void 0;
const helpers_1 = require("./helpers");
const toMongoDottedObject_1 = require("../utils/toMongoDottedObject");
const beforeQueryHelper_1 = require("./helpers/beforeQueryHelper");
const errorCatcher_1 = require("./helpers/errorCatcher");
function updateMany(model, tc, opts) {
    if (!model || !model.modelName || !model.schema) {
        throw new Error('First arg for Resolver updateMany() should be instance of Mongoose Model.');
    }
    if (!tc || tc.constructor.name !== 'ObjectTypeComposer') {
        throw new Error('Second arg for Resolver updateMany() should be instance of ObjectTypeComposer.');
    }
    const outputTypeName = `UpdateMany${tc.getTypeName()}${(opts === null || opts === void 0 ? void 0 : opts.suffix) || ''}Payload`;
    const outputType = tc.schemaComposer.getOrCreateOTC(outputTypeName, (t) => {
        t.addFields({
            numAffected: {
                type: 'Int',
                description: 'Affected documents number',
            },
        });
    });
    const aliases = helpers_1.prepareNestedAliases(model.schema);
    const resolver = tc.schemaComposer.createResolver({
        name: 'updateMany',
        kind: 'mutation',
        description: 'Update many documents without returning them: ' +
            'Use Query.update mongoose method. ' +
            'Do not apply mongoose defaults, setters, hooks and validation. ',
        type: outputType,
        args: Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({}, helpers_1.recordHelperArgs(tc, Object.assign({ prefix: 'UpdateMany', suffix: `${(opts === null || opts === void 0 ? void 0 : opts.suffix) || ''}Input`, removeFields: ['id', '_id'], isRequired: true, allFieldsNullable: true }, opts === null || opts === void 0 ? void 0 : opts.record))), helpers_1.filterHelperArgs(tc, model, Object.assign({ prefix: 'FilterUpdateMany', suffix: `${(opts === null || opts === void 0 ? void 0 : opts.suffix) || ''}Input` }, opts === null || opts === void 0 ? void 0 : opts.filter))), helpers_1.sortHelperArgs(tc, model, Object.assign({ sortTypeName: `SortUpdateMany${tc.getTypeName()}${(opts === null || opts === void 0 ? void 0 : opts.suffix) || ''}Input` }, opts === null || opts === void 0 ? void 0 : opts.sort))), helpers_1.skipHelperArgs()), helpers_1.limitHelperArgs(Object.assign({}, opts === null || opts === void 0 ? void 0 : opts.limit))),
        resolve: ((resolveParams) => __awaiter(this, void 0, void 0, function* () {
            var _a;
            const recordData = (_a = resolveParams === null || resolveParams === void 0 ? void 0 : resolveParams.args) === null || _a === void 0 ? void 0 : _a.record;
            if (!(typeof recordData === 'object') || Object.keys(recordData).length === 0) {
                return Promise.reject(new Error(`${tc.getTypeName()}.updateMany resolver requires at least one value in args.record`));
            }
            resolveParams.query = model.find();
            resolveParams.model = model;
            helpers_1.filterHelper(resolveParams, aliases);
            helpers_1.skipHelper(resolveParams);
            helpers_1.sortHelper(resolveParams);
            helpers_1.limitHelper(resolveParams);
            resolveParams.query = resolveParams.query.setOptions({ multi: true });
            if (resolveParams.query.updateMany) {
                resolveParams.query.updateMany({
                    $set: toMongoDottedObject_1.toMongoDottedObject(recordData, aliases),
                });
            }
            else {
                resolveParams.query.update({
                    $set: toMongoDottedObject_1.toMongoDottedObject(recordData, aliases),
                });
            }
            const res = yield beforeQueryHelper_1.beforeQueryHelper(resolveParams);
            if (res.modifiedCount || res.acknowledged) {
                return {
                    numAffected: res.modifiedCount,
                };
            }
            else if (res.ok) {
                return {
                    numAffected: res.n || res.nModified,
                };
            }
            throw new Error(JSON.stringify(res));
        })),
    });
    if (!(opts === null || opts === void 0 ? void 0 : opts.disableErrorField)) {
        errorCatcher_1.addErrorCatcherField(resolver);
    }
    return resolver;
}
exports.updateMany = updateMany;
//# sourceMappingURL=updateMany.js.map