started mongo stuff, but it's a PITA. fuck mongo
This commit is contained in:
parent
4cd36ea3fc
commit
0f1bc5dff3
937 changed files with 205043 additions and 0 deletions
72
parts/3/phonebookBackend/node_modules/mongodb/lib/operations/operation.js
generated
vendored
Normal file
72
parts/3/phonebookBackend/node_modules/mongodb/lib/operations/operation.js
generated
vendored
Normal file
|
|
@ -0,0 +1,72 @@
|
|||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.AbstractOperation = exports.Aspect = void 0;
|
||||
exports.defineAspects = defineAspects;
|
||||
const bson_1 = require("../bson");
|
||||
const read_preference_1 = require("../read_preference");
|
||||
exports.Aspect = {
|
||||
READ_OPERATION: Symbol('READ_OPERATION'),
|
||||
WRITE_OPERATION: Symbol('WRITE_OPERATION'),
|
||||
RETRYABLE: Symbol('RETRYABLE'),
|
||||
EXPLAINABLE: Symbol('EXPLAINABLE'),
|
||||
SKIP_COLLATION: Symbol('SKIP_COLLATION'),
|
||||
CURSOR_CREATING: Symbol('CURSOR_CREATING'),
|
||||
MUST_SELECT_SAME_SERVER: Symbol('MUST_SELECT_SAME_SERVER'),
|
||||
COMMAND_BATCHING: Symbol('COMMAND_BATCHING')
|
||||
};
|
||||
/**
|
||||
* This class acts as a parent class for any operation and is responsible for setting this.options,
|
||||
* as well as setting and getting a session.
|
||||
* Additionally, this class implements `hasAspect`, which determines whether an operation has
|
||||
* a specific aspect.
|
||||
* @internal
|
||||
*/
|
||||
class AbstractOperation {
|
||||
constructor(options = {}) {
|
||||
this.readPreference = this.hasAspect(exports.Aspect.WRITE_OPERATION)
|
||||
? read_preference_1.ReadPreference.primary
|
||||
: (read_preference_1.ReadPreference.fromOptions(options) ?? read_preference_1.ReadPreference.primary);
|
||||
// Pull the BSON serialize options from the already-resolved options
|
||||
this.bsonOptions = (0, bson_1.resolveBSONOptions)(options);
|
||||
this._session = options.session != null ? options.session : undefined;
|
||||
this.options = options;
|
||||
this.bypassPinningCheck = !!options.bypassPinningCheck;
|
||||
this.trySecondaryWrite = false;
|
||||
}
|
||||
hasAspect(aspect) {
|
||||
const ctor = this.constructor;
|
||||
if (ctor.aspects == null) {
|
||||
return false;
|
||||
}
|
||||
return ctor.aspects.has(aspect);
|
||||
}
|
||||
// Make sure the session is not writable from outside this class.
|
||||
get session() {
|
||||
return this._session;
|
||||
}
|
||||
clearSession() {
|
||||
this._session = undefined;
|
||||
}
|
||||
resetBatch() {
|
||||
return true;
|
||||
}
|
||||
get canRetryRead() {
|
||||
return this.hasAspect(exports.Aspect.RETRYABLE) && this.hasAspect(exports.Aspect.READ_OPERATION);
|
||||
}
|
||||
get canRetryWrite() {
|
||||
return this.hasAspect(exports.Aspect.RETRYABLE) && this.hasAspect(exports.Aspect.WRITE_OPERATION);
|
||||
}
|
||||
}
|
||||
exports.AbstractOperation = AbstractOperation;
|
||||
function defineAspects(operation, aspects) {
|
||||
if (!Array.isArray(aspects) && !(aspects instanceof Set)) {
|
||||
aspects = [aspects];
|
||||
}
|
||||
aspects = new Set(aspects);
|
||||
Object.defineProperty(operation, 'aspects', {
|
||||
value: aspects,
|
||||
writable: false
|
||||
});
|
||||
return aspects;
|
||||
}
|
||||
//# sourceMappingURL=operation.js.map
|
||||
Loading…
Add table
Add a link
Reference in a new issue