bulk_write.ts
1.81 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
import type {
AnyBulkWriteOperation,
BulkOperationBase,
BulkWriteOptions,
BulkWriteResult
} from '../bulk/common';
import type { Collection } from '../collection';
import type { Server } from '../sdam/server';
import type { ClientSession } from '../sessions';
import type { Callback } from '../utils';
import { AbstractOperation, Aspect, defineAspects } from './operation';
/** @internal */
export class BulkWriteOperation extends AbstractOperation<BulkWriteResult> {
override options: BulkWriteOptions;
collection: Collection;
operations: AnyBulkWriteOperation[];
constructor(
collection: Collection,
operations: AnyBulkWriteOperation[],
options: BulkWriteOptions
) {
super(options);
this.options = options;
this.collection = collection;
this.operations = operations;
}
override execute(
server: Server,
session: ClientSession | undefined,
callback: Callback<BulkWriteResult>
): void {
const coll = this.collection;
const operations = this.operations;
const options = { ...this.options, ...this.bsonOptions, readPreference: this.readPreference };
// Create the bulk operation
const bulk: BulkOperationBase =
options.ordered === false
? coll.initializeUnorderedBulkOp(options)
: coll.initializeOrderedBulkOp(options);
// for each op go through and add to the bulk
try {
for (let i = 0; i < operations.length; i++) {
bulk.raw(operations[i]);
}
} catch (err) {
return callback(err);
}
// Execute the bulk
bulk.execute({ ...options, session }, (err, r) => {
// We have connection level error
if (!r && err) {
return callback(err);
}
// Return the results
callback(undefined, r);
});
}
}
defineAspects(BulkWriteOperation, [Aspect.WRITE_OPERATION]);