mongo works
This commit is contained in:
parent
ae6ccd559f
commit
125107da50
937 changed files with 205033 additions and 2 deletions
173
parts/3/followAlong/node_modules/mongodb/src/explain.ts
generated
vendored
Normal file
173
parts/3/followAlong/node_modules/mongodb/src/explain.ts
generated
vendored
Normal file
|
|
@ -0,0 +1,173 @@
|
|||
import { type Document } from './bson';
|
||||
import { AbstractCursor } from './cursor/abstract_cursor';
|
||||
import { MongoAPIError } from './error';
|
||||
|
||||
/** @public */
|
||||
export const ExplainVerbosity = Object.freeze({
|
||||
queryPlanner: 'queryPlanner',
|
||||
queryPlannerExtended: 'queryPlannerExtended',
|
||||
executionStats: 'executionStats',
|
||||
allPlansExecution: 'allPlansExecution'
|
||||
} as const);
|
||||
|
||||
/** @public */
|
||||
export type ExplainVerbosity = string;
|
||||
|
||||
/**
|
||||
* For backwards compatibility, true is interpreted as "allPlansExecution"
|
||||
* and false as "queryPlanner".
|
||||
* @public
|
||||
*/
|
||||
export type ExplainVerbosityLike = ExplainVerbosity | boolean;
|
||||
|
||||
/** @public */
|
||||
export interface ExplainCommandOptions {
|
||||
/** The explain verbosity for the command. */
|
||||
verbosity: ExplainVerbosity;
|
||||
/** The maxTimeMS setting for the command. */
|
||||
maxTimeMS?: number;
|
||||
}
|
||||
|
||||
/**
|
||||
* @public
|
||||
*
|
||||
* When set, this configures an explain command. Valid values are boolean (for legacy compatibility,
|
||||
* see {@link ExplainVerbosityLike}), a string containing the explain verbosity, or an object containing the verbosity and
|
||||
* an optional maxTimeMS.
|
||||
*
|
||||
* Examples of valid usage:
|
||||
*
|
||||
* ```typescript
|
||||
* collection.find({ name: 'john doe' }, { explain: true });
|
||||
* collection.find({ name: 'john doe' }, { explain: false });
|
||||
* collection.find({ name: 'john doe' }, { explain: 'queryPlanner' });
|
||||
* collection.find({ name: 'john doe' }, { explain: { verbosity: 'queryPlanner' } });
|
||||
* ```
|
||||
*
|
||||
* maxTimeMS can be configured to limit the amount of time the server
|
||||
* spends executing an explain by providing an object:
|
||||
*
|
||||
* ```typescript
|
||||
* // limits the `explain` command to no more than 2 seconds
|
||||
* collection.find({ name: 'john doe' }, {
|
||||
* explain: {
|
||||
* verbosity: 'queryPlanner',
|
||||
* maxTimeMS: 2000
|
||||
* }
|
||||
* });
|
||||
* ```
|
||||
*/
|
||||
export interface ExplainOptions {
|
||||
/** Specifies the verbosity mode for the explain output. */
|
||||
explain?: ExplainVerbosityLike | ExplainCommandOptions;
|
||||
}
|
||||
|
||||
/** @internal */
|
||||
export class Explain {
|
||||
readonly verbosity: ExplainVerbosity;
|
||||
readonly maxTimeMS?: number;
|
||||
|
||||
private constructor(verbosity: ExplainVerbosityLike, maxTimeMS?: number) {
|
||||
if (typeof verbosity === 'boolean') {
|
||||
this.verbosity = verbosity
|
||||
? ExplainVerbosity.allPlansExecution
|
||||
: ExplainVerbosity.queryPlanner;
|
||||
} else {
|
||||
this.verbosity = verbosity;
|
||||
}
|
||||
|
||||
this.maxTimeMS = maxTimeMS;
|
||||
}
|
||||
|
||||
static fromOptions({ explain }: ExplainOptions = {}): Explain | undefined {
|
||||
if (explain == null) return;
|
||||
|
||||
if (typeof explain === 'boolean' || typeof explain === 'string') {
|
||||
return new Explain(explain);
|
||||
}
|
||||
|
||||
const { verbosity, maxTimeMS } = explain;
|
||||
return new Explain(verbosity, maxTimeMS);
|
||||
}
|
||||
}
|
||||
|
||||
export function validateExplainTimeoutOptions(options: Document, explain?: Explain) {
|
||||
const { maxTimeMS, timeoutMS } = options;
|
||||
if (timeoutMS != null && (maxTimeMS != null || explain?.maxTimeMS != null)) {
|
||||
throw new MongoAPIError('Cannot use maxTimeMS with timeoutMS for explain commands.');
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Applies an explain to a given command.
|
||||
* @internal
|
||||
*
|
||||
* @param command - the command on which to apply the explain
|
||||
* @param options - the options containing the explain verbosity
|
||||
*/
|
||||
export function decorateWithExplain(
|
||||
command: Document,
|
||||
explain: Explain
|
||||
): {
|
||||
explain: Document;
|
||||
verbosity: ExplainVerbosity;
|
||||
maxTimeMS?: number;
|
||||
} {
|
||||
type ExplainCommand = ReturnType<typeof decorateWithExplain>;
|
||||
const { verbosity, maxTimeMS } = explain;
|
||||
const baseCommand: ExplainCommand = { explain: command, verbosity };
|
||||
|
||||
if (typeof maxTimeMS === 'number') {
|
||||
baseCommand.maxTimeMS = maxTimeMS;
|
||||
}
|
||||
|
||||
return baseCommand;
|
||||
}
|
||||
|
||||
/**
|
||||
* @public
|
||||
*
|
||||
* A base class for any cursors that have `explain()` methods.
|
||||
*/
|
||||
export abstract class ExplainableCursor<TSchema> extends AbstractCursor<TSchema> {
|
||||
/** Execute the explain for the cursor */
|
||||
abstract explain(): Promise<Document>;
|
||||
abstract explain(verbosity: ExplainVerbosityLike | ExplainCommandOptions): Promise<Document>;
|
||||
abstract explain(options: { timeoutMS?: number }): Promise<Document>;
|
||||
abstract explain(
|
||||
verbosity: ExplainVerbosityLike | ExplainCommandOptions,
|
||||
options: { timeoutMS?: number }
|
||||
): Promise<Document>;
|
||||
abstract explain(
|
||||
verbosity?: ExplainVerbosityLike | ExplainCommandOptions | { timeoutMS?: number },
|
||||
options?: { timeoutMS?: number }
|
||||
): Promise<Document>;
|
||||
|
||||
protected resolveExplainTimeoutOptions(
|
||||
verbosity?: ExplainVerbosityLike | ExplainCommandOptions | { timeoutMS?: number },
|
||||
options?: { timeoutMS?: number }
|
||||
): { timeout?: { timeoutMS?: number }; explain?: ExplainVerbosityLike | ExplainCommandOptions } {
|
||||
let explain: ExplainVerbosityLike | ExplainCommandOptions | undefined;
|
||||
let timeout: { timeoutMS?: number } | undefined;
|
||||
|
||||
if (verbosity == null && options == null) {
|
||||
explain = undefined;
|
||||
timeout = undefined;
|
||||
} else if (verbosity != null && options == null) {
|
||||
explain =
|
||||
typeof verbosity !== 'object'
|
||||
? verbosity
|
||||
: 'verbosity' in verbosity
|
||||
? verbosity
|
||||
: undefined;
|
||||
|
||||
timeout = typeof verbosity === 'object' && 'timeoutMS' in verbosity ? verbosity : undefined;
|
||||
} else {
|
||||
// @ts-expect-error TS isn't smart enough to determine that if both options are provided, the first is explain options
|
||||
explain = verbosity;
|
||||
timeout = options;
|
||||
}
|
||||
|
||||
return { timeout, explain };
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue