123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194 |
- import { Document } from 'arangojs/documents';
- import { DocumentCollection } from 'arangojs/collection';
- import { AqlLiteral, GeneratedAqlQuery } from 'arangojs/aql';
- import { Database } from 'arangojs';
- /**
- * A `CountFn` function returns the number of documents in a single collection matching search `terms` given.
- *
- * `count()` provides the standard implementation.
- */
- export declare type CountFn<T extends Searchable, S extends Searchable = T> = (terms?: Terms<Document<DeepNonNullable<S>>>, inject?: Inject) => Promise<number>;
- /**
- * Recursively renders all of a complex object's properties required, non-null, and non-undefined.
- *
- * Note: this type recurses through objects only, not arrays.
- */
- export declare type DeepNonNullable<T> = NonNullable<T> extends object ? {
- [P in keyof T]-?: DeepNonNullable<T[P]>;
- } : T;
- /** Query sort direction. */
- export declare type Direction = 'ASC' | 'DESC';
- /**
- * Simple search filter type in which any number of conditions can be specified for a presumed parameter.
- *
- * Multiple operators can be used in combination.
- * By default they will be combined into an `AND` filter.
- * Specify `mode: "OR"` to switch to an `OR` filter.
- *
- * Note: `LIKE`, `NOT LIKE`, and regular expression operators are only available if `T` extends `string`.
- */
- export declare type Filter<T> = {
- mode?: 'AND' | 'OR';
- eq?: T | null;
- gt?: T;
- gte?: T;
- in?: T[];
- like?: T & string;
- lt?: T;
- lte?: T;
- neq?: T | null;
- nin?: T[];
- nlike?: T & string;
- nreg?: T & string;
- reg?: T & string;
- };
- /**
- * A `FindFn` function returns the first document in a single collection matching search `terms` given.
- * A `sort` can be specified to control the result.
- *
- * `find()` provides the standard implementation.
- */
- export declare type FindFn<T extends Searchable, S extends Searchable = T> = (terms?: Terms<Document<DeepNonNullable<S>>>, sort?: Sort<Document<T>>[] | Sort<Document<T>>, inject?: Inject) => Promise<Document<T> | undefined>;
- /**
- * An `Inject` object allows modifying a search query with user-defined AQL literal expressions.
- * This can be useful for complex requirements, such as joining data or setting additional variables with `LET`.
- *
- * All injected strings are implicitly converted to AQL literals in the query, so should be manually escaped as needed.
- *
- * Note that while `CountFn` and `FindFn` do not use all the same parameters as `SearchFn`, all injections are still
- * supported so a single injection provider can be used for all query types.
- */
- export declare type Inject = {
- /** Injected before FILTER statements. */
- beforeFilter?: string;
- /** Injected after FILTER statements, before SORT statements. */
- beforeSort?: string;
- /** Injected after SORT statements, before LIMIT statement. */
- beforeLimit?: string;
- /** Injected after all other statements. */
- after?: string;
- };
- /**
- * Query limit.
- * Always a tuple, but the second value can be omitted.
- */
- export declare type Limit = [number, number?];
- /**
- * Searchable data type.
- * Essentially, any object is valid.
- */
- export declare type Searchable = Record<string, unknown>;
- /**
- * Formulate search terms based on a complex data type.
- * Nested object types are preserved, while scalar properties are converted to `Filter` representations.
- */
- export declare type Terms<T> = {
- [P in keyof T]?: NonNullable<NonNullable<T[P]> extends object ? Terms<T[P]> : Filter<T[P]>>;
- };
- /**
- * A `SearchFn` function matches documents in a single collection and returns a `SearchResult` based on the given
- * `terms`, `limit`, and `sort`.
- *
- * A fourth `inject` argument can be given to add user-defined sections to the query, allowing complex requirements
- * to be added around the core query pattern.
- */
- export declare type SearchFn<T extends Searchable, S extends Searchable = T> = (terms?: Terms<Document<DeepNonNullable<S>>>, limit?: Limit, sort?: Sort<Document<S>>[] | Sort<Document<S>>, inject?: Inject) => Promise<SearchResult<T>>;
- /**
- * A `SimpleSearchFn` function matches documents in a single collection and returns a `SearchResult` based on the given
- * `terms`, `limit`, and `sort`.
- *
- * This type can be implemented by user code as an alternative to `SearchFn` to prevent further injections.
- */
- export declare type SimpleSearchFn<T extends Searchable, S extends Searchable = T> = (terms?: Terms<Document<DeepNonNullable<S>>>, limit?: Limit, sort?: Sort<Document<S>>[] | Sort<Document<S>>) => Promise<SearchResult<T>>;
- /**
- * Search results are a tuple of three values:
- * 1. The **total** number of matching documents in the searched collection, ignoring limit
- * 2. The documents matched within the searched collection, respecting limit
- * 3. The AQL query object for the latter (for debugging purposes)
- */
- export declare type SearchResult<T extends Searchable> = [number, Document<T>[], GeneratedAqlQuery];
- /**
- * Query sort order as a tuple of key and direction.
- *
- * The sort key can be specified as an AQL literal, in which case it will be used exactly as given.
- * This can be useful in conjunction with query injections.
- */
- export declare type Sort<T> = [AqlLiteral | keyof T, Direction];
- /** Format scalar or scalar array data for use in AQL. */
- export declare const formatData: <T>(data: T | T[]) => string;
- /** Format scalar data for use in AQL. */
- export declare const formatValue: <T>(data: T) => string;
- /** Map of search operator properties to AQL equivalents. */
- export declare const operatorMap: Record<keyof Omit<Filter<unknown>, 'mode'>, string>;
- /** Search operators. */
- export declare const operators: string[];
- /**
- * Parse a search limit to a string AQL limit.
- *
- * Note: `LIMIT` is not prepended.
- */
- export declare const parseLimit: (l: Limit) => string | number;
- /**
- * Parse a search filter to a string of AQL filters.
- *
- * Note: `FILTER` is not prepended.
- */
- export declare const parseFilter: <T>(param: string, search: Filter<T>) => string;
- /**
- * Parse query sort(s) to an array of string AQL sorts.
- *
- * Note: `SORT` is not prepended.
- */
- export declare const parseSort: <T>(s: Sort<T> | Sort<T>[], parent: string) => string[];
- /**
- * Parse search terms to a flat array of search filters.
- * The `parent` argument refers to the current document, and is prefixed to each filter.
- */
- export declare const parseTerms: <T>(s: Terms<T>, parent: string) => string[];
- /**
- * Build and execute a count query that matches documents in a single collection.
- * Returns the total number of matches.
- *
- * This example resembles the generated AQL query:
- *
- * ```aql
- * FOR {i} IN {c} {FILTER ...} COLLECT WITH COUNT INTO {n} RETURN {n}
- * ```
- */
- export declare const count: <T extends Searchable, S extends Searchable = T>(db: Database, c: DocumentCollection<T>, i?: string, n?: string) => CountFn<T, S>;
- /**
- * Build and execute a find query that returns the first matching document in a single collection.
- *
- * This example resembles the generated AQL query:
- *
- * ```aql
- * FOR {i} IN {collection} {FILTER ...} {SORT ...} LIMIT 1 RETURN {i}
- * ```
- */
- export declare const find: <T extends Searchable, S extends Searchable = T>(db: Database, c: DocumentCollection<T>, i?: string) => FindFn<T, S>;
- /**
- * Build and execute a search query across a single collection.
- * Returns a `SearchResult` tuple containing the total number of matches (ignoring limit), all matching documents
- * (respecting limit), and the AQL query.
- *
- * This example resembles the generated AQL query:
- *
- * ```aql
- * FOR {i} IN {collection} {FILTER ...} {SORT ...} {LIMIT ...} RETURN {i}
- * ```
- */
- export declare const search: <T extends Searchable, S extends Searchable = T>(db: Database, c: DocumentCollection<T>, i?: string, n?: string) => SearchFn<T, S>;
- declare const _default: {
- count: <T extends Searchable, S extends Searchable = T>(db: Database, c: DocumentCollection<T>, i?: string, n?: string) => CountFn<T, S>;
- find: <T_1 extends Searchable, S_1 extends Searchable = T_1>(db: Database, c: DocumentCollection<T_1>, i?: string) => FindFn<T_1, S_1>;
- formatData: <T_2>(data: T_2 | T_2[]) => string;
- formatValue: <T_3>(data: T_3) => string;
- operatorMap: Record<"eq" | "gt" | "gte" | "in" | "like" | "lt" | "lte" | "neq" | "nin" | "nlike" | "nreg" | "reg", string>;
- operators: string[];
- parseFilter: <T_4>(param: string, search: Filter<T_4>) => string;
- parseLimit: (l: Limit) => string | number;
- parseSort: <T_5>(s: Sort<T_5> | Sort<T_5>[], parent: string) => string[];
- parseTerms: <T_6>(s: Terms<T_6>, parent: string) => string[];
- search: <T_7 extends Searchable, S_2 extends Searchable = T_7>(db: Database, c: DocumentCollection<T_7>, i?: string, n?: string) => SearchFn<T_7, S_2>;
- };
- export default _default;
|